react-magma-dom 4.9.2-next.0 → 4.9.2-next.2
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/Modal/Modal.d.ts +5 -0
- package/dist/components/Table/Table.d.ts +26 -0
- package/dist/components/Table/TablePagination.d.ts +5 -0
- package/dist/components/Table/TableRow.d.ts +1 -1
- package/dist/components/Transition/Transition.d.ts +5 -0
- package/dist/esm/index.js +782 -545
- package/dist/esm/index.js.map +1 -1
- package/dist/i18n/interface.d.ts +6 -0
- package/dist/properties.json +147 -32
- package/dist/react-magma-dom.cjs.development.js +782 -545
- package/dist/react-magma-dom.cjs.development.js.map +1 -1
- package/dist/react-magma-dom.cjs.production.min.js +1 -1
- package/dist/react-magma-dom.cjs.production.min.js.map +1 -1
- package/dist/theme/components/drawerTransition.d.ts +2 -0
- package/package.json +3 -3
package/dist/esm/index.js
CHANGED
|
@@ -1110,323 +1110,6 @@ var curriedTransparentize = /*#__PURE__*/curry
|
|
|
1110
1110
|
/* ::<number | string, string, string> */
|
|
1111
1111
|
(transparentize);
|
|
1112
1112
|
|
|
1113
|
-
var defaultI18n = {
|
|
1114
|
-
locale: null,
|
|
1115
|
-
dateFormat: 'MM/dd/yyyy',
|
|
1116
|
-
timeFormat: '12',
|
|
1117
|
-
example: 'i18n defaults must be set in packages/react-magma-dom/src/i18n/default.ts',
|
|
1118
|
-
months: {
|
|
1119
|
-
"long": {
|
|
1120
|
-
january: 'January',
|
|
1121
|
-
february: 'February',
|
|
1122
|
-
march: 'March',
|
|
1123
|
-
april: 'April',
|
|
1124
|
-
may: 'May',
|
|
1125
|
-
june: 'June',
|
|
1126
|
-
july: 'July',
|
|
1127
|
-
august: 'August',
|
|
1128
|
-
september: 'September',
|
|
1129
|
-
october: 'October',
|
|
1130
|
-
november: 'November',
|
|
1131
|
-
december: 'December'
|
|
1132
|
-
},
|
|
1133
|
-
"short": {
|
|
1134
|
-
january: 'Jan',
|
|
1135
|
-
february: 'Feb',
|
|
1136
|
-
march: 'Mar',
|
|
1137
|
-
april: 'Apr',
|
|
1138
|
-
may: 'May',
|
|
1139
|
-
june: 'Jun',
|
|
1140
|
-
july: 'Jul',
|
|
1141
|
-
august: 'Aug',
|
|
1142
|
-
september: 'Sep',
|
|
1143
|
-
october: 'Oct',
|
|
1144
|
-
november: 'Nov',
|
|
1145
|
-
december: 'Dec'
|
|
1146
|
-
}
|
|
1147
|
-
},
|
|
1148
|
-
days: {
|
|
1149
|
-
"long": {
|
|
1150
|
-
monday: 'Monday',
|
|
1151
|
-
tuesday: 'Tuesday',
|
|
1152
|
-
wednesday: 'Wednesday',
|
|
1153
|
-
thursday: 'Thursday',
|
|
1154
|
-
friday: 'Friday',
|
|
1155
|
-
saturday: 'Saturday',
|
|
1156
|
-
sunday: 'Sunday'
|
|
1157
|
-
},
|
|
1158
|
-
"short": {
|
|
1159
|
-
monday: 'Mon',
|
|
1160
|
-
tuesday: 'Tues',
|
|
1161
|
-
wednesday: 'Wed',
|
|
1162
|
-
thursday: 'Thur',
|
|
1163
|
-
friday: 'Fri',
|
|
1164
|
-
saturday: 'Sat',
|
|
1165
|
-
sunday: 'Sun'
|
|
1166
|
-
},
|
|
1167
|
-
min: {
|
|
1168
|
-
monday: 'M',
|
|
1169
|
-
tuesday: 'T',
|
|
1170
|
-
wednesday: 'W',
|
|
1171
|
-
thursday: 'T',
|
|
1172
|
-
friday: 'F',
|
|
1173
|
-
saturday: 'S',
|
|
1174
|
-
sunday: 'S'
|
|
1175
|
-
}
|
|
1176
|
-
},
|
|
1177
|
-
emptyItemsListText: 'No Options',
|
|
1178
|
-
alert: {
|
|
1179
|
-
dismissAriaLabel: 'Close this message'
|
|
1180
|
-
},
|
|
1181
|
-
breadcrumb: {
|
|
1182
|
-
navAriaLabel: 'Breadcrumb'
|
|
1183
|
-
},
|
|
1184
|
-
characterCounter: {
|
|
1185
|
-
characterAllowed: 'character allowed',
|
|
1186
|
-
charactersAllowed: 'characters allowed',
|
|
1187
|
-
characterLeft: 'character left',
|
|
1188
|
-
charactersLeft: 'characters left',
|
|
1189
|
-
characterOver: 'character over limit',
|
|
1190
|
-
charactersOver: 'characters over limit'
|
|
1191
|
-
},
|
|
1192
|
-
charts: {
|
|
1193
|
-
line: {
|
|
1194
|
-
chartTabLabel: 'Chart',
|
|
1195
|
-
dataLegendsLabel: 'Select one or more of the categories below to filter out the ones you don’t want to see.',
|
|
1196
|
-
dataTabLabel: 'Data',
|
|
1197
|
-
keyboardInstructions: 'In the chart below, use your up and down arrows to move between each line. Use your left and right arrows to move between points on a line.',
|
|
1198
|
-
keyboardInstructionsHeader: 'Keyboard Instructions',
|
|
1199
|
-
keyboardInstructionsTooltip: 'Keyboard Instructions',
|
|
1200
|
-
legendButtonAriaLabel: 'Toggle data for {name}'
|
|
1201
|
-
}
|
|
1202
|
-
},
|
|
1203
|
-
combobox: {
|
|
1204
|
-
clearIndicatorAriaLabel: 'reset selection for {labelText}. {selectedItem} is selected',
|
|
1205
|
-
createLabel: 'Create "{inputValue}"',
|
|
1206
|
-
multi: {
|
|
1207
|
-
clearIndicatorAriaLabel: 'reset selection for {labelText}. {selectedItem} are selected'
|
|
1208
|
-
},
|
|
1209
|
-
loading: 'Loading...'
|
|
1210
|
-
},
|
|
1211
|
-
datePicker: {
|
|
1212
|
-
startOfWeek: 'sunday',
|
|
1213
|
-
calendarIconAriaLabel: 'Toggle Calendar Widget',
|
|
1214
|
-
calendarOpenAnnounce: 'Calendar Widget is now open.',
|
|
1215
|
-
calendarCloseAriaLabel: 'Close Calendar Widget',
|
|
1216
|
-
previousMonthAriaLabel: 'Previous Month',
|
|
1217
|
-
nextMonthAriaLabel: 'Next Month',
|
|
1218
|
-
disabledDayAriaLabel: 'Not Available. ',
|
|
1219
|
-
selectedDayAriaLabel: '(Selected)',
|
|
1220
|
-
todayAriaLabel: '(Today)',
|
|
1221
|
-
helpModal: {
|
|
1222
|
-
header: 'Keyboard Shortcuts',
|
|
1223
|
-
helpButtonAriaLabel: 'Calendar Widget Help',
|
|
1224
|
-
enter: {
|
|
1225
|
-
ariaLabel: 'Enter key',
|
|
1226
|
-
explanation: 'Select the date in focus.'
|
|
1227
|
-
},
|
|
1228
|
-
rightAndLeftArrowKeys: {
|
|
1229
|
-
ariaLabel: 'Right and left arrow keys',
|
|
1230
|
-
explanation: 'Move backward (left) and forward (right) by one day.'
|
|
1231
|
-
},
|
|
1232
|
-
upAndDownArrowKeys: {
|
|
1233
|
-
ariaLabel: 'up and down arrow keys',
|
|
1234
|
-
explanation: 'Move backward (up) and forward (down) by one week.'
|
|
1235
|
-
},
|
|
1236
|
-
pageUpAndPageDownKeys: {
|
|
1237
|
-
ariaLabel: 'page up and page down keys',
|
|
1238
|
-
displayValue: 'PGUP/PGDN',
|
|
1239
|
-
explanation: 'Switch months.'
|
|
1240
|
-
},
|
|
1241
|
-
homeAndEndKeys: {
|
|
1242
|
-
ariaLabel: 'Home and end keys',
|
|
1243
|
-
displayValue: 'HOME/END',
|
|
1244
|
-
explanation: 'Go to the first or last day of a week.'
|
|
1245
|
-
},
|
|
1246
|
-
escape: {
|
|
1247
|
-
ariaLabel: 'Escape key',
|
|
1248
|
-
displayValue: 'ESC',
|
|
1249
|
-
explanation: 'Return to the date input field.'
|
|
1250
|
-
}
|
|
1251
|
-
}
|
|
1252
|
-
},
|
|
1253
|
-
dropdown: {
|
|
1254
|
-
menuItemSelectedAriaLabel: '(selected)',
|
|
1255
|
-
toggleMenuAriaLabel: 'Toggle menu'
|
|
1256
|
-
},
|
|
1257
|
-
dropzone: {
|
|
1258
|
-
browseFiles: 'Browse Files',
|
|
1259
|
-
dragMessage: 'Drag and drop or browse files to upload.',
|
|
1260
|
-
errors: {
|
|
1261
|
-
'too-many-errors': {
|
|
1262
|
-
message: 'Files must not have any errors.'
|
|
1263
|
-
},
|
|
1264
|
-
'too-many-files': {
|
|
1265
|
-
message: 'You must upload a maximum of'
|
|
1266
|
-
},
|
|
1267
|
-
'too-few-files': {
|
|
1268
|
-
message: 'You must upload a minimum of'
|
|
1269
|
-
},
|
|
1270
|
-
'file-invalid-type': {
|
|
1271
|
-
header: 'Invalid File Type',
|
|
1272
|
-
message: 'Upload only the allowed file types'
|
|
1273
|
-
},
|
|
1274
|
-
'file-too-large': {
|
|
1275
|
-
header: 'File exceeds size limit',
|
|
1276
|
-
message: 'Upload only files with a maximum size of'
|
|
1277
|
-
},
|
|
1278
|
-
'file-too-small': {
|
|
1279
|
-
header: 'File size is below the limit',
|
|
1280
|
-
message: 'Upload only files with a minimum size of'
|
|
1281
|
-
},
|
|
1282
|
-
required: {
|
|
1283
|
-
message: 'You must upload at least one file.'
|
|
1284
|
-
}
|
|
1285
|
-
},
|
|
1286
|
-
files: 'files',
|
|
1287
|
-
bytes: 'Bytes',
|
|
1288
|
-
deleteFile: 'Delete file',
|
|
1289
|
-
removeFile: 'Remove file'
|
|
1290
|
-
},
|
|
1291
|
-
header: {
|
|
1292
|
-
navigationButtonLabel: 'Open navigation menu',
|
|
1293
|
-
search: {
|
|
1294
|
-
input: {
|
|
1295
|
-
ariaLabel: 'Search',
|
|
1296
|
-
placeholder: 'Search'
|
|
1297
|
-
},
|
|
1298
|
-
iconAriaLabel: 'Search'
|
|
1299
|
-
}
|
|
1300
|
-
},
|
|
1301
|
-
indeterminateCheckbox: {
|
|
1302
|
-
isCheckedAnnounce: 'All subitems are checked for {labelText} checkbox',
|
|
1303
|
-
isIndeterminateAnnounce: 'Some, but not all, subitems are checked for {labelText} checkbox',
|
|
1304
|
-
isUncheckedAnnounce: 'No subitems are checked for {labelText} checkbox'
|
|
1305
|
-
},
|
|
1306
|
-
input: {
|
|
1307
|
-
isClearableAriaLabel: 'Clear Input'
|
|
1308
|
-
},
|
|
1309
|
-
loadingIndicator: {
|
|
1310
|
-
progressBar: {
|
|
1311
|
-
messages: {
|
|
1312
|
-
first: 'Please be patient as this could take up to a minute to load.',
|
|
1313
|
-
second: 'Thank you for your patience. Still loading...',
|
|
1314
|
-
third: 'Thank you for waiting. We’re almost there!'
|
|
1315
|
-
}
|
|
1316
|
-
},
|
|
1317
|
-
spinner: {
|
|
1318
|
-
messages: {
|
|
1319
|
-
first: 'Loading...',
|
|
1320
|
-
second: 'Thank you for your patience. Still loading...',
|
|
1321
|
-
third: 'Sorry for the delay. This is taking longer than expected.'
|
|
1322
|
-
}
|
|
1323
|
-
}
|
|
1324
|
-
},
|
|
1325
|
-
modal: {
|
|
1326
|
-
closeAriaLabel: 'Close dialog'
|
|
1327
|
-
},
|
|
1328
|
-
multiSelect: {
|
|
1329
|
-
placeholder: 'Select...',
|
|
1330
|
-
selectedItemButtonAriaLabel: 'reset item {selectedItem}'
|
|
1331
|
-
},
|
|
1332
|
-
multiCombobox: {
|
|
1333
|
-
selectedItemButtonAriaLabel: 'reset item {selectedItem}'
|
|
1334
|
-
},
|
|
1335
|
-
pagination: {
|
|
1336
|
-
nextButtonLabel: 'Next Page',
|
|
1337
|
-
previousButtonLabel: 'Previous Page',
|
|
1338
|
-
pageButtonLabel: 'Go to Page'
|
|
1339
|
-
},
|
|
1340
|
-
password: {
|
|
1341
|
-
shown: {
|
|
1342
|
-
ariaLabel: 'Show password. Note: this will visually expose your password on the screen',
|
|
1343
|
-
buttonText: 'Show',
|
|
1344
|
-
announce: 'Password is now visible'
|
|
1345
|
-
},
|
|
1346
|
-
hidden: {
|
|
1347
|
-
ariaLabel: 'Hide password',
|
|
1348
|
-
buttonText: 'Hide',
|
|
1349
|
-
announce: 'Password is now hidden'
|
|
1350
|
-
}
|
|
1351
|
-
},
|
|
1352
|
-
search: {
|
|
1353
|
-
input: {
|
|
1354
|
-
ariaLabel: 'Search',
|
|
1355
|
-
placeholder: 'Search'
|
|
1356
|
-
},
|
|
1357
|
-
iconAriaLabel: 'Search'
|
|
1358
|
-
},
|
|
1359
|
-
select: {
|
|
1360
|
-
placeholder: 'Select...',
|
|
1361
|
-
clearIndicatorAriaLabel: 'reset selection for {labelText}. {selectedItem} is selected',
|
|
1362
|
-
multi: {
|
|
1363
|
-
clearIndicatorAriaLabel: 'reset selection for {labelText}. {selectedItem} are selected'
|
|
1364
|
-
}
|
|
1365
|
-
},
|
|
1366
|
-
simplePagination: {
|
|
1367
|
-
ofLabel: 'of',
|
|
1368
|
-
pageLabel: 'page',
|
|
1369
|
-
pagesLabel: 'pages',
|
|
1370
|
-
pageNumberLabel: 'Page number',
|
|
1371
|
-
selectedLabel: 'selected'
|
|
1372
|
-
},
|
|
1373
|
-
skipLink: {
|
|
1374
|
-
buttonText: 'Skip Navigation'
|
|
1375
|
-
},
|
|
1376
|
-
spinner: {
|
|
1377
|
-
ariaLabel: 'Loading'
|
|
1378
|
-
},
|
|
1379
|
-
stepper: {
|
|
1380
|
-
completionLabel: 'All steps completed',
|
|
1381
|
-
stepLabel: 'Step',
|
|
1382
|
-
stepOfLabel: 'of'
|
|
1383
|
-
},
|
|
1384
|
-
table: {
|
|
1385
|
-
pagination: {
|
|
1386
|
-
ofLabel: 'of',
|
|
1387
|
-
nextAriaLabel: 'Next page',
|
|
1388
|
-
previousAriaLabel: 'Previous page',
|
|
1389
|
-
rowsPerPageLabel: 'Rows per page'
|
|
1390
|
-
},
|
|
1391
|
-
selectable: {
|
|
1392
|
-
sortButtonAriaLabel: 'Sort rows',
|
|
1393
|
-
selectAllRowsAriaLabel: 'Select all rows',
|
|
1394
|
-
selectRowAriaLabel: 'Select row',
|
|
1395
|
-
deselectAllRowsAriaLabel: 'Deselect all rows',
|
|
1396
|
-
deselectRowAriaLabel: 'Deselect row'
|
|
1397
|
-
}
|
|
1398
|
-
},
|
|
1399
|
-
tabs: {
|
|
1400
|
-
horizontalTabsInstructions: 'use the right and left arrow keys to activate other tabs',
|
|
1401
|
-
verticalTabsInstructions: 'use the down and up arrow keys to activate other tabs',
|
|
1402
|
-
nextButtonLabel: 'Scroll tabs forward',
|
|
1403
|
-
previousButtonLabel: 'Scroll tabs back'
|
|
1404
|
-
},
|
|
1405
|
-
tag: {
|
|
1406
|
-
deleteAriaLabel: 'Delete {labelText} tag'
|
|
1407
|
-
},
|
|
1408
|
-
timePicker: {
|
|
1409
|
-
hoursAriaLabel: 'Hour',
|
|
1410
|
-
minutesAriaLabel: 'Minute',
|
|
1411
|
-
amButtonAriaLabel: 'AM selected. To change to PM press the p or enter button.',
|
|
1412
|
-
pmButtonAriaLabel: 'PM selected. To change to AM press the a or enter button.',
|
|
1413
|
-
amSelectedAnnounce: 'AM is now selected',
|
|
1414
|
-
pmSelectedAnnounce: 'PM is now selected'
|
|
1415
|
-
},
|
|
1416
|
-
wizard: {
|
|
1417
|
-
actions: {
|
|
1418
|
-
next: 'next',
|
|
1419
|
-
previous: 'previous',
|
|
1420
|
-
cancel: 'cancel',
|
|
1421
|
-
submit: 'submit'
|
|
1422
|
-
},
|
|
1423
|
-
optional: 'optional',
|
|
1424
|
-
navigationLabel: 'Navigation for the wizard'
|
|
1425
|
-
}
|
|
1426
|
-
};
|
|
1427
|
-
|
|
1428
|
-
var I18nContext = /*#__PURE__*/createContext(defaultI18n);
|
|
1429
|
-
|
|
1430
1113
|
var InverseContext = /*#__PURE__*/createContext({
|
|
1431
1114
|
isInverse: false
|
|
1432
1115
|
});
|
|
@@ -2999,105 +2682,428 @@ function buildActiveBackground(props) {
|
|
|
2999
2682
|
if (props.variant !== 'solid') {
|
|
3000
2683
|
return curriedTransparentize(0.5, props.theme.colors.neutral900);
|
|
3001
2684
|
}
|
|
3002
|
-
return props.theme.colors.danger700;
|
|
3003
|
-
}
|
|
3004
|
-
if (props.variant !== 'solid') {
|
|
3005
|
-
return props.theme.colors.danger200;
|
|
2685
|
+
return props.theme.colors.danger700;
|
|
2686
|
+
}
|
|
2687
|
+
if (props.variant !== 'solid') {
|
|
2688
|
+
return props.theme.colors.danger200;
|
|
2689
|
+
}
|
|
2690
|
+
}
|
|
2691
|
+
if (props.color === 'success') {
|
|
2692
|
+
if (props.variant === 'link') {
|
|
2693
|
+
if (props.isInverse) {
|
|
2694
|
+
return curriedTransparentize(0.5, props.theme.colors.neutral900);
|
|
2695
|
+
}
|
|
2696
|
+
return props.theme.colors.success200;
|
|
2697
|
+
}
|
|
2698
|
+
return props.theme.colors.success700;
|
|
2699
|
+
}
|
|
2700
|
+
if (props.color === 'secondary') {
|
|
2701
|
+
if (props.variant === 'link' && props.isInverse || props.isInverse) {
|
|
2702
|
+
return curriedTransparentize(0.5, props.theme.colors.neutral900);
|
|
2703
|
+
}
|
|
2704
|
+
}
|
|
2705
|
+
if (props.color === 'subtle') {
|
|
2706
|
+
if (props.isInverse) {
|
|
2707
|
+
return curriedTransparentize(0.5, props.theme.colors.neutral900);
|
|
2708
|
+
}
|
|
2709
|
+
return curriedTransparentize(0.9, props.theme.colors.neutral900);
|
|
2710
|
+
}
|
|
2711
|
+
if (props.variant === 'solid' && props.isInverse) {
|
|
2712
|
+
return props.theme.colors.tertiary700;
|
|
2713
|
+
}
|
|
2714
|
+
if (props.variant === 'link') {
|
|
2715
|
+
if (props.isInverse) {
|
|
2716
|
+
return curriedTransparentize(0.5, props.theme.colors.neutral900);
|
|
2717
|
+
}
|
|
2718
|
+
return props.theme.colors.primary200;
|
|
2719
|
+
}
|
|
2720
|
+
switch (props.color) {
|
|
2721
|
+
case 'secondary':
|
|
2722
|
+
return props.theme.colors.primary200;
|
|
2723
|
+
case 'danger':
|
|
2724
|
+
return props.theme.colors.danger700;
|
|
2725
|
+
default:
|
|
2726
|
+
return props.theme.colors.primary700;
|
|
2727
|
+
}
|
|
2728
|
+
}
|
|
2729
|
+
function buildActiveColor(props) {
|
|
2730
|
+
props = buildPropsWithDefaultButtonStyles(props);
|
|
2731
|
+
if (props.color === 'danger') {
|
|
2732
|
+
if (props.variant !== 'solid') {
|
|
2733
|
+
if (props.isInverse) {
|
|
2734
|
+
return props.theme.colors.danger200;
|
|
2735
|
+
}
|
|
2736
|
+
return props.theme.colors.danger700;
|
|
2737
|
+
}
|
|
2738
|
+
}
|
|
2739
|
+
if (props.color === 'success' && props.variant === 'link') {
|
|
2740
|
+
if (props.isInverse) {
|
|
2741
|
+
return props.theme.colors.success300;
|
|
2742
|
+
}
|
|
2743
|
+
return props.theme.colors.success700;
|
|
2744
|
+
}
|
|
2745
|
+
if (props.color === 'secondary' && props.variant === 'solid') {
|
|
2746
|
+
if (props.isInverse) {
|
|
2747
|
+
return props.theme.colors.tertiary500;
|
|
2748
|
+
}
|
|
2749
|
+
return props.theme.colors.primary600;
|
|
2750
|
+
}
|
|
2751
|
+
if (props.color === 'subtle') {
|
|
2752
|
+
if (props.isInverse) {
|
|
2753
|
+
return props.theme.colors.neutral100;
|
|
2754
|
+
}
|
|
2755
|
+
return props.theme.colors.neutral700;
|
|
2756
|
+
}
|
|
2757
|
+
if (props.variant !== 'solid' && !props.isInverse || props.variant === 'solid' && props.isInverse) {
|
|
2758
|
+
switch (props.color) {
|
|
2759
|
+
case 'danger':
|
|
2760
|
+
return props.theme.colors.neutral100;
|
|
2761
|
+
case 'success':
|
|
2762
|
+
return props.theme.colors.neutral100;
|
|
2763
|
+
default:
|
|
2764
|
+
return props.theme.colors.primary600;
|
|
2765
|
+
}
|
|
2766
|
+
}
|
|
2767
|
+
if (props.variant !== 'solid' && props.isInverse) {
|
|
2768
|
+
switch (props.color) {
|
|
2769
|
+
case 'primary':
|
|
2770
|
+
return props.theme.colors.tertiary500;
|
|
2771
|
+
case 'secondary':
|
|
2772
|
+
return props.theme.colors.tertiary500;
|
|
2773
|
+
case 'marketing':
|
|
2774
|
+
return props.theme.colors.tertiary500;
|
|
2775
|
+
default:
|
|
2776
|
+
return props.theme.colors.neutral100;
|
|
2777
|
+
}
|
|
2778
|
+
}
|
|
2779
|
+
if (props.color === 'marketing' && !props.isInverse) {
|
|
2780
|
+
return props.theme.colors.primary600;
|
|
2781
|
+
}
|
|
2782
|
+
return props.theme.colors.neutral100;
|
|
2783
|
+
}
|
|
2784
|
+
|
|
2785
|
+
var defaultI18n = {
|
|
2786
|
+
locale: null,
|
|
2787
|
+
dateFormat: 'MM/dd/yyyy',
|
|
2788
|
+
timeFormat: '12',
|
|
2789
|
+
example: 'i18n defaults must be set in packages/react-magma-dom/src/i18n/default.ts',
|
|
2790
|
+
months: {
|
|
2791
|
+
"long": {
|
|
2792
|
+
january: 'January',
|
|
2793
|
+
february: 'February',
|
|
2794
|
+
march: 'March',
|
|
2795
|
+
april: 'April',
|
|
2796
|
+
may: 'May',
|
|
2797
|
+
june: 'June',
|
|
2798
|
+
july: 'July',
|
|
2799
|
+
august: 'August',
|
|
2800
|
+
september: 'September',
|
|
2801
|
+
october: 'October',
|
|
2802
|
+
november: 'November',
|
|
2803
|
+
december: 'December'
|
|
2804
|
+
},
|
|
2805
|
+
"short": {
|
|
2806
|
+
january: 'Jan',
|
|
2807
|
+
february: 'Feb',
|
|
2808
|
+
march: 'Mar',
|
|
2809
|
+
april: 'Apr',
|
|
2810
|
+
may: 'May',
|
|
2811
|
+
june: 'Jun',
|
|
2812
|
+
july: 'Jul',
|
|
2813
|
+
august: 'Aug',
|
|
2814
|
+
september: 'Sep',
|
|
2815
|
+
october: 'Oct',
|
|
2816
|
+
november: 'Nov',
|
|
2817
|
+
december: 'Dec'
|
|
2818
|
+
}
|
|
2819
|
+
},
|
|
2820
|
+
days: {
|
|
2821
|
+
"long": {
|
|
2822
|
+
monday: 'Monday',
|
|
2823
|
+
tuesday: 'Tuesday',
|
|
2824
|
+
wednesday: 'Wednesday',
|
|
2825
|
+
thursday: 'Thursday',
|
|
2826
|
+
friday: 'Friday',
|
|
2827
|
+
saturday: 'Saturday',
|
|
2828
|
+
sunday: 'Sunday'
|
|
2829
|
+
},
|
|
2830
|
+
"short": {
|
|
2831
|
+
monday: 'Mon',
|
|
2832
|
+
tuesday: 'Tues',
|
|
2833
|
+
wednesday: 'Wed',
|
|
2834
|
+
thursday: 'Thur',
|
|
2835
|
+
friday: 'Fri',
|
|
2836
|
+
saturday: 'Sat',
|
|
2837
|
+
sunday: 'Sun'
|
|
2838
|
+
},
|
|
2839
|
+
min: {
|
|
2840
|
+
monday: 'M',
|
|
2841
|
+
tuesday: 'T',
|
|
2842
|
+
wednesday: 'W',
|
|
2843
|
+
thursday: 'T',
|
|
2844
|
+
friday: 'F',
|
|
2845
|
+
saturday: 'S',
|
|
2846
|
+
sunday: 'S'
|
|
2847
|
+
}
|
|
2848
|
+
},
|
|
2849
|
+
emptyItemsListText: 'No Options',
|
|
2850
|
+
alert: {
|
|
2851
|
+
dismissAriaLabel: 'Close this message'
|
|
2852
|
+
},
|
|
2853
|
+
breadcrumb: {
|
|
2854
|
+
navAriaLabel: 'Breadcrumb'
|
|
2855
|
+
},
|
|
2856
|
+
characterCounter: {
|
|
2857
|
+
characterAllowed: 'character allowed',
|
|
2858
|
+
charactersAllowed: 'characters allowed',
|
|
2859
|
+
characterLeft: 'character left',
|
|
2860
|
+
charactersLeft: 'characters left',
|
|
2861
|
+
characterOver: 'character over limit',
|
|
2862
|
+
charactersOver: 'characters over limit'
|
|
2863
|
+
},
|
|
2864
|
+
charts: {
|
|
2865
|
+
line: {
|
|
2866
|
+
chartTabLabel: 'Chart',
|
|
2867
|
+
dataLegendsLabel: 'Select one or more of the categories below to filter out the ones you don’t want to see.',
|
|
2868
|
+
dataTabLabel: 'Data',
|
|
2869
|
+
keyboardInstructions: 'In the chart below, use your up and down arrows to move between each line. Use your left and right arrows to move between points on a line.',
|
|
2870
|
+
keyboardInstructionsHeader: 'Keyboard Instructions',
|
|
2871
|
+
keyboardInstructionsTooltip: 'Keyboard Instructions',
|
|
2872
|
+
legendButtonAriaLabel: 'Toggle data for {name}'
|
|
2873
|
+
}
|
|
2874
|
+
},
|
|
2875
|
+
combobox: {
|
|
2876
|
+
clearIndicatorAriaLabel: 'reset selection for {labelText}. {selectedItem} is selected',
|
|
2877
|
+
createLabel: 'Create "{inputValue}"',
|
|
2878
|
+
multi: {
|
|
2879
|
+
clearIndicatorAriaLabel: 'reset selection for {labelText}. {selectedItem} are selected'
|
|
2880
|
+
},
|
|
2881
|
+
loading: 'Loading...'
|
|
2882
|
+
},
|
|
2883
|
+
datePicker: {
|
|
2884
|
+
startOfWeek: 'sunday',
|
|
2885
|
+
calendarIconAriaLabel: 'Toggle Calendar Widget',
|
|
2886
|
+
calendarOpenAnnounce: 'Calendar Widget is now open.',
|
|
2887
|
+
calendarCloseAriaLabel: 'Close Calendar Widget',
|
|
2888
|
+
previousMonthAriaLabel: 'Previous Month',
|
|
2889
|
+
nextMonthAriaLabel: 'Next Month',
|
|
2890
|
+
disabledDayAriaLabel: 'Not Available. ',
|
|
2891
|
+
selectedDayAriaLabel: '(Selected)',
|
|
2892
|
+
todayAriaLabel: '(Today)',
|
|
2893
|
+
helpModal: {
|
|
2894
|
+
header: 'Keyboard Shortcuts',
|
|
2895
|
+
helpButtonAriaLabel: 'Calendar Widget Help',
|
|
2896
|
+
enter: {
|
|
2897
|
+
ariaLabel: 'Enter key',
|
|
2898
|
+
explanation: 'Select the date in focus.'
|
|
2899
|
+
},
|
|
2900
|
+
rightAndLeftArrowKeys: {
|
|
2901
|
+
ariaLabel: 'Right and left arrow keys',
|
|
2902
|
+
explanation: 'Move backward (left) and forward (right) by one day.'
|
|
2903
|
+
},
|
|
2904
|
+
upAndDownArrowKeys: {
|
|
2905
|
+
ariaLabel: 'up and down arrow keys',
|
|
2906
|
+
explanation: 'Move backward (up) and forward (down) by one week.'
|
|
2907
|
+
},
|
|
2908
|
+
pageUpAndPageDownKeys: {
|
|
2909
|
+
ariaLabel: 'page up and page down keys',
|
|
2910
|
+
displayValue: 'PGUP/PGDN',
|
|
2911
|
+
explanation: 'Switch months.'
|
|
2912
|
+
},
|
|
2913
|
+
homeAndEndKeys: {
|
|
2914
|
+
ariaLabel: 'Home and end keys',
|
|
2915
|
+
displayValue: 'HOME/END',
|
|
2916
|
+
explanation: 'Go to the first or last day of a week.'
|
|
2917
|
+
},
|
|
2918
|
+
escape: {
|
|
2919
|
+
ariaLabel: 'Escape key',
|
|
2920
|
+
displayValue: 'ESC',
|
|
2921
|
+
explanation: 'Return to the date input field.'
|
|
2922
|
+
}
|
|
2923
|
+
}
|
|
2924
|
+
},
|
|
2925
|
+
dropdown: {
|
|
2926
|
+
menuItemSelectedAriaLabel: '(selected)',
|
|
2927
|
+
toggleMenuAriaLabel: 'Toggle menu'
|
|
2928
|
+
},
|
|
2929
|
+
dropzone: {
|
|
2930
|
+
browseFiles: 'Browse Files',
|
|
2931
|
+
dragMessage: 'Drag and drop or browse files to upload.',
|
|
2932
|
+
errors: {
|
|
2933
|
+
'too-many-errors': {
|
|
2934
|
+
message: 'Files must not have any errors.'
|
|
2935
|
+
},
|
|
2936
|
+
'too-many-files': {
|
|
2937
|
+
message: 'You must upload a maximum of'
|
|
2938
|
+
},
|
|
2939
|
+
'too-few-files': {
|
|
2940
|
+
message: 'You must upload a minimum of'
|
|
2941
|
+
},
|
|
2942
|
+
'file-invalid-type': {
|
|
2943
|
+
header: 'Invalid File Type',
|
|
2944
|
+
message: 'Upload only the allowed file types'
|
|
2945
|
+
},
|
|
2946
|
+
'file-too-large': {
|
|
2947
|
+
header: 'File exceeds size limit',
|
|
2948
|
+
message: 'Upload only files with a maximum size of'
|
|
2949
|
+
},
|
|
2950
|
+
'file-too-small': {
|
|
2951
|
+
header: 'File size is below the limit',
|
|
2952
|
+
message: 'Upload only files with a minimum size of'
|
|
2953
|
+
},
|
|
2954
|
+
required: {
|
|
2955
|
+
message: 'You must upload at least one file.'
|
|
2956
|
+
}
|
|
2957
|
+
},
|
|
2958
|
+
files: 'files',
|
|
2959
|
+
bytes: 'Bytes',
|
|
2960
|
+
deleteFile: 'Delete file',
|
|
2961
|
+
removeFile: 'Remove file'
|
|
2962
|
+
},
|
|
2963
|
+
header: {
|
|
2964
|
+
navigationButtonLabel: 'Open navigation menu',
|
|
2965
|
+
search: {
|
|
2966
|
+
input: {
|
|
2967
|
+
ariaLabel: 'Search',
|
|
2968
|
+
placeholder: 'Search'
|
|
2969
|
+
},
|
|
2970
|
+
iconAriaLabel: 'Search'
|
|
3006
2971
|
}
|
|
3007
|
-
}
|
|
3008
|
-
|
|
3009
|
-
|
|
3010
|
-
|
|
3011
|
-
|
|
2972
|
+
},
|
|
2973
|
+
indeterminateCheckbox: {
|
|
2974
|
+
isCheckedAnnounce: 'All subitems are checked for {labelText} checkbox',
|
|
2975
|
+
isIndeterminateAnnounce: 'Some, but not all, subitems are checked for {labelText} checkbox',
|
|
2976
|
+
isUncheckedAnnounce: 'No subitems are checked for {labelText} checkbox'
|
|
2977
|
+
},
|
|
2978
|
+
input: {
|
|
2979
|
+
isClearableAriaLabel: 'Clear Input'
|
|
2980
|
+
},
|
|
2981
|
+
loadingIndicator: {
|
|
2982
|
+
progressBar: {
|
|
2983
|
+
messages: {
|
|
2984
|
+
first: 'Please be patient as this could take up to a minute to load.',
|
|
2985
|
+
second: 'Thank you for your patience. Still loading...',
|
|
2986
|
+
third: 'Thank you for waiting. We’re almost there!'
|
|
3012
2987
|
}
|
|
3013
|
-
|
|
3014
|
-
|
|
3015
|
-
|
|
3016
|
-
|
|
3017
|
-
|
|
3018
|
-
|
|
3019
|
-
return curriedTransparentize(0.5, props.theme.colors.neutral900);
|
|
3020
|
-
}
|
|
3021
|
-
}
|
|
3022
|
-
if (props.color === 'subtle') {
|
|
3023
|
-
if (props.isInverse) {
|
|
3024
|
-
return curriedTransparentize(0.5, props.theme.colors.neutral900);
|
|
3025
|
-
}
|
|
3026
|
-
return curriedTransparentize(0.9, props.theme.colors.neutral900);
|
|
3027
|
-
}
|
|
3028
|
-
if (props.variant === 'solid' && props.isInverse) {
|
|
3029
|
-
return props.theme.colors.tertiary700;
|
|
3030
|
-
}
|
|
3031
|
-
if (props.variant === 'link') {
|
|
3032
|
-
if (props.isInverse) {
|
|
3033
|
-
return curriedTransparentize(0.5, props.theme.colors.neutral900);
|
|
3034
|
-
}
|
|
3035
|
-
return props.theme.colors.primary200;
|
|
3036
|
-
}
|
|
3037
|
-
switch (props.color) {
|
|
3038
|
-
case 'secondary':
|
|
3039
|
-
return props.theme.colors.primary200;
|
|
3040
|
-
case 'danger':
|
|
3041
|
-
return props.theme.colors.danger700;
|
|
3042
|
-
default:
|
|
3043
|
-
return props.theme.colors.primary700;
|
|
3044
|
-
}
|
|
3045
|
-
}
|
|
3046
|
-
function buildActiveColor(props) {
|
|
3047
|
-
props = buildPropsWithDefaultButtonStyles(props);
|
|
3048
|
-
if (props.color === 'danger') {
|
|
3049
|
-
if (props.variant !== 'solid') {
|
|
3050
|
-
if (props.isInverse) {
|
|
3051
|
-
return props.theme.colors.danger200;
|
|
2988
|
+
},
|
|
2989
|
+
spinner: {
|
|
2990
|
+
messages: {
|
|
2991
|
+
first: 'Loading...',
|
|
2992
|
+
second: 'Thank you for your patience. Still loading...',
|
|
2993
|
+
third: 'Sorry for the delay. This is taking longer than expected.'
|
|
3052
2994
|
}
|
|
3053
|
-
return props.theme.colors.danger700;
|
|
3054
|
-
}
|
|
3055
|
-
}
|
|
3056
|
-
if (props.color === 'success' && props.variant === 'link') {
|
|
3057
|
-
if (props.isInverse) {
|
|
3058
|
-
return props.theme.colors.success300;
|
|
3059
|
-
}
|
|
3060
|
-
return props.theme.colors.success700;
|
|
3061
|
-
}
|
|
3062
|
-
if (props.color === 'secondary' && props.variant === 'solid') {
|
|
3063
|
-
if (props.isInverse) {
|
|
3064
|
-
return props.theme.colors.tertiary500;
|
|
3065
2995
|
}
|
|
3066
|
-
|
|
3067
|
-
|
|
3068
|
-
|
|
3069
|
-
|
|
3070
|
-
|
|
2996
|
+
},
|
|
2997
|
+
modal: {
|
|
2998
|
+
closeAriaLabel: 'Close dialog'
|
|
2999
|
+
},
|
|
3000
|
+
multiSelect: {
|
|
3001
|
+
placeholder: 'Select...',
|
|
3002
|
+
selectedItemButtonAriaLabel: 'reset item {selectedItem}'
|
|
3003
|
+
},
|
|
3004
|
+
multiCombobox: {
|
|
3005
|
+
selectedItemButtonAriaLabel: 'reset item {selectedItem}'
|
|
3006
|
+
},
|
|
3007
|
+
pagination: {
|
|
3008
|
+
nextButtonLabel: 'Next Page',
|
|
3009
|
+
previousButtonLabel: 'Previous Page',
|
|
3010
|
+
pageButtonLabel: 'Go to Page'
|
|
3011
|
+
},
|
|
3012
|
+
password: {
|
|
3013
|
+
shown: {
|
|
3014
|
+
ariaLabel: 'Show password. Note: this will visually expose your password on the screen',
|
|
3015
|
+
buttonText: 'Show',
|
|
3016
|
+
announce: 'Password is now visible'
|
|
3017
|
+
},
|
|
3018
|
+
hidden: {
|
|
3019
|
+
ariaLabel: 'Hide password',
|
|
3020
|
+
buttonText: 'Hide',
|
|
3021
|
+
announce: 'Password is now hidden'
|
|
3071
3022
|
}
|
|
3072
|
-
|
|
3073
|
-
|
|
3074
|
-
|
|
3075
|
-
|
|
3076
|
-
|
|
3077
|
-
|
|
3078
|
-
|
|
3079
|
-
|
|
3080
|
-
|
|
3081
|
-
|
|
3023
|
+
},
|
|
3024
|
+
search: {
|
|
3025
|
+
input: {
|
|
3026
|
+
ariaLabel: 'Search',
|
|
3027
|
+
placeholder: 'Search'
|
|
3028
|
+
},
|
|
3029
|
+
iconAriaLabel: 'Search'
|
|
3030
|
+
},
|
|
3031
|
+
select: {
|
|
3032
|
+
placeholder: 'Select...',
|
|
3033
|
+
clearIndicatorAriaLabel: 'reset selection for {labelText}. {selectedItem} is selected',
|
|
3034
|
+
multi: {
|
|
3035
|
+
clearIndicatorAriaLabel: 'reset selection for {labelText}. {selectedItem} are selected'
|
|
3082
3036
|
}
|
|
3083
|
-
}
|
|
3084
|
-
|
|
3085
|
-
|
|
3086
|
-
|
|
3087
|
-
|
|
3088
|
-
|
|
3089
|
-
|
|
3090
|
-
|
|
3091
|
-
|
|
3092
|
-
|
|
3093
|
-
|
|
3037
|
+
},
|
|
3038
|
+
simplePagination: {
|
|
3039
|
+
ofLabel: 'of',
|
|
3040
|
+
pageLabel: 'page',
|
|
3041
|
+
pagesLabel: 'pages',
|
|
3042
|
+
pageNumberLabel: 'Page number',
|
|
3043
|
+
selectedLabel: 'selected'
|
|
3044
|
+
},
|
|
3045
|
+
skipLink: {
|
|
3046
|
+
buttonText: 'Skip Navigation'
|
|
3047
|
+
},
|
|
3048
|
+
spinner: {
|
|
3049
|
+
ariaLabel: 'Loading'
|
|
3050
|
+
},
|
|
3051
|
+
stepper: {
|
|
3052
|
+
completionLabel: 'All steps completed',
|
|
3053
|
+
stepLabel: 'Step',
|
|
3054
|
+
stepOfLabel: 'of'
|
|
3055
|
+
},
|
|
3056
|
+
table: {
|
|
3057
|
+
pagination: {
|
|
3058
|
+
ofLabel: 'of',
|
|
3059
|
+
nextAriaLabel: 'Next page',
|
|
3060
|
+
previousAriaLabel: 'Previous page',
|
|
3061
|
+
rowsPerPageLabel: 'Rows per page'
|
|
3062
|
+
},
|
|
3063
|
+
selectable: {
|
|
3064
|
+
sortButtonAriaLabel: 'Sort rows',
|
|
3065
|
+
selectAllRowsAriaLabel: 'Select all rows',
|
|
3066
|
+
selectRowAriaLabel: 'Select row',
|
|
3067
|
+
deselectAllRowsAriaLabel: 'Deselect all rows',
|
|
3068
|
+
deselectRowAriaLabel: 'Deselect row'
|
|
3094
3069
|
}
|
|
3070
|
+
},
|
|
3071
|
+
tabs: {
|
|
3072
|
+
horizontalTabsInstructions: 'use the right and left arrow keys to activate other tabs',
|
|
3073
|
+
verticalTabsInstructions: 'use the down and up arrow keys to activate other tabs',
|
|
3074
|
+
nextButtonLabel: 'Scroll tabs forward',
|
|
3075
|
+
previousButtonLabel: 'Scroll tabs back'
|
|
3076
|
+
},
|
|
3077
|
+
tag: {
|
|
3078
|
+
deleteAriaLabel: 'Delete {labelText} tag'
|
|
3079
|
+
},
|
|
3080
|
+
timePicker: {
|
|
3081
|
+
hoursAriaLabel: 'Hour',
|
|
3082
|
+
minutesAriaLabel: 'Minute',
|
|
3083
|
+
amButtonAriaLabel: 'AM selected. To change to PM press the p or enter button.',
|
|
3084
|
+
pmButtonAriaLabel: 'PM selected. To change to AM press the a or enter button.',
|
|
3085
|
+
amSelectedAnnounce: 'AM is now selected',
|
|
3086
|
+
pmSelectedAnnounce: 'PM is now selected'
|
|
3087
|
+
},
|
|
3088
|
+
wizard: {
|
|
3089
|
+
actions: {
|
|
3090
|
+
next: 'next',
|
|
3091
|
+
previous: 'previous',
|
|
3092
|
+
cancel: 'cancel',
|
|
3093
|
+
submit: 'submit'
|
|
3094
|
+
},
|
|
3095
|
+
optional: 'optional',
|
|
3096
|
+
navigationLabel: 'Navigation for the wizard'
|
|
3097
|
+
},
|
|
3098
|
+
alertVariants: {
|
|
3099
|
+
info: 'info icon',
|
|
3100
|
+
success: 'success icon',
|
|
3101
|
+
warning: 'warning icon',
|
|
3102
|
+
danger: 'danger icon'
|
|
3095
3103
|
}
|
|
3096
|
-
|
|
3097
|
-
|
|
3098
|
-
|
|
3099
|
-
return props.theme.colors.neutral100;
|
|
3100
|
-
}
|
|
3104
|
+
};
|
|
3105
|
+
|
|
3106
|
+
var I18nContext = /*#__PURE__*/createContext(defaultI18n);
|
|
3101
3107
|
|
|
3102
3108
|
var _excluded$1 = ["aria-label", "color", "noRole", "size", "testId"];
|
|
3103
3109
|
var StyledSpinner = /*#__PURE__*/_styled("span", {
|
|
@@ -3618,20 +3624,20 @@ var StyledAlert = /*#__PURE__*/_styled("div", {
|
|
|
3618
3624
|
}, ";}&:focus{outline:2px solid ", function (props) {
|
|
3619
3625
|
return props.isInverse ? props.theme.colors.focusInverse : props.theme.colors.focus;
|
|
3620
3626
|
}, ";}", function (props) {
|
|
3621
|
-
return props.isToast && /*#__PURE__*/css("animation:", props.isExiting ? "slideout " + transitionDuration + "ms" : "slidein " + transitionDuration + "ms", ";min-width:375px;margin:0 auto;@media (max-width: ", props.theme.breakpoints.small, "px){min-width:0;width:100%;};label:StyledAlert;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AA8JQ","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport isPropValid from '@emotion/is-prop-valid';\r\nimport { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport { InfoIcon, CheckCircleIcon, WarningIcon, ErrorIcon, CloseIcon, } from 'react-magma-icons';\r\nimport { I18nContext } from '../../i18n';\r\nimport { InverseContext, useIsInverse } from '../../inverse';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { useGenerateId } from '../../utils';\r\nimport { ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { ProgressRing } from '../ProgressRing';\r\nexport const VARIANT_ICON = {\r\n    info: InfoIcon,\r\n    success: CheckCircleIcon,\r\n    warning: WarningIcon,\r\n    danger: ErrorIcon,\r\n};\r\nexport var AlertVariant;\r\n(function (AlertVariant) {\r\n    AlertVariant[\"info\"] = \"info\";\r\n    AlertVariant[\"success\"] = \"success\";\r\n    AlertVariant[\"warning\"] = \"warning\";\r\n    AlertVariant[\"danger\"] = \"danger\";\r\n})(AlertVariant || (AlertVariant = {}));\r\nexport const transitionDuration = 500;\r\nexport function buildAlertBackground(props) {\r\n    if (props.isInverse) {\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return props.theme.colors.success700;\r\n            case 'warning':\r\n                return props.theme.colors.warning700;\r\n            case 'danger':\r\n                return props.theme.colors.danger700;\r\n            default:\r\n                return props.theme.colors.info700;\r\n        }\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success100;\r\n        case 'warning':\r\n            return props.theme.colors.warning100;\r\n        case 'danger':\r\n            return props.theme.colors.danger100;\r\n        default:\r\n            return props.theme.colors.info100;\r\n    }\r\n}\r\nexport function buildAlertBorder(props) {\r\n    if (props.isInverse) {\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return props.theme.colors.success300;\r\n            case 'warning':\r\n                return props.theme.colors.warning300;\r\n            case 'danger':\r\n                return props.theme.colors.danger200;\r\n            default:\r\n                return props.theme.colors.info300;\r\n        }\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success500;\r\n        case 'warning':\r\n            return props.theme.colors.warning500;\r\n        case 'danger':\r\n            return props.theme.colors.danger500;\r\n        default:\r\n            return props.theme.colors.info500;\r\n    }\r\n}\r\nexport function buildAlertColor(props) {\r\n    if (props.isInverse) {\r\n        return props.theme.colors.neutral100;\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success500;\r\n        case 'warning':\r\n            return props.theme.colors.warning500;\r\n        case 'danger':\r\n            return props.theme.colors.danger500;\r\n        default:\r\n            return props.theme.colors.info500;\r\n    }\r\n}\r\nexport function buildLinkColor(props) {\r\n    if (props.isInverse) {\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return props.theme.colors.success200;\r\n            case 'warning':\r\n                return props.theme.colors.warning200;\r\n            case 'danger':\r\n                return props.theme.colors.danger200;\r\n            default:\r\n                return props.theme.colors.info200;\r\n        }\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success700;\r\n        case 'warning':\r\n            return props.theme.colors.warning700;\r\n        case 'danger':\r\n            return props.theme.colors.danger700;\r\n        default:\r\n            return props.theme.colors.info700;\r\n    }\r\n}\r\nexport function buildLinkHoverColor(props) {\r\n    if (props.isInverse) {\r\n        return props.theme.colors.neutral100;\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success;\r\n        case 'warning':\r\n            return props.theme.colors.warning;\r\n        case 'danger':\r\n            return props.theme.colors.danger;\r\n        default:\r\n            return props.theme.colors.info;\r\n    }\r\n}\r\nconst StyledAlert = styled.div `\n  align-items: stretch;\n  animation: ${props => props.isExiting\r\n    ? `fadeout ${transitionDuration}ms`\r\n    : `fadein ${transitionDuration}ms`};\n  display: flex;\n  flex-direction: column;\n  font-size: ${props => props.theme.typeScale.size03.fontSize};\n  font-family: ${props => props.theme.bodyFont};\n  line-height: ${props => props.theme.typeScale.size03.lineHeight};\n  margin-bottom: ${props => props.theme.spaceScale.spacing06};\n  max-width: 100%;\n  padding: 0;\n  position: relative;\n\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    font-size: ${props => props.theme.typeScale.size02.fontSize};\n    letter-spacing: ${props => props.theme.typeScale.size02.letterSpacing};\n    line-height: ${props => props.theme.typeScale.size02.lineHeight};\n  }\n\n  &:focus {\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n  }\n\n  ${props => props.isToast &&\r\n    css `\n      animation: ${props.isExiting\r\n        ? `slideout ${transitionDuration}ms`\r\n        : `slidein ${transitionDuration}ms`};\n      min-width: 375px;\n      margin: 0 auto;\n\n      @media (max-width: ${props.theme.breakpoints.small}px) {\n        min-width: 0;\n        width: 100%;\n      }\n    `}\n\n  @keyframes fadein {\n    from {\n      opacity: 0;\n    }\n    to {\n      opacity: 1;\n    }\n  }\n\n  @keyframes fadeout {\n    from {\n      opacity: 1;\n    }\n    to {\n      opacity: 0;\n    }\n  }\n\n  @keyframes slidein {\n    from {\n      left: -500px;\n    }\n    to {\n      left: 0;\n    }\n  }\n\n  @keyframes slideout {\n    from {\n      left: 0;\n    }\n    to {\n      left: -500px;\n    }\n  }\n\n  a {\n    color: ${props => buildLinkColor(props)};\n    font-weight: 400;\n    text-decoration: underline;\n    &:not([disabled]) {\n      &:focus,\n      &:hover {\n        color: ${props => buildLinkHoverColor(props)};\n      }\n    }\n  }\n`;\r\nconst StyledAlertInner = styled.div `\n  background: ${buildAlertBackground};\n  border: 1px solid ${buildAlertBorder};\n  border-radius: ${props => props.theme.borderRadius};\n  color: ${buildAlertColor};\n  display: flex;\n  position: relative;\n\n  ${props => props.isToast &&\r\n    css `\n      box-shadow: ${props.isInverse\r\n        ? `0 2px 8px 0 ${transparentize(0.3, props.theme.colors.neutral900)}`\r\n        : `0 2px 8px 0 ${transparentize(0.6, props.theme.colors.neutral900)}`};\n      padding-right: 0;\n      height: ${props.theme.spaceScale.spacing11};\n    `}\n`;\r\nconst AlertContents = styled.div `\n  align-items: ${props => (props.additionalContent ? 'center' : '')};\n  align-self: center;\n  flex-grow: 1;\n  font-family: ${props => props.theme.bodyFont};\n  padding: ${props => props.theme.spaceScale.spacing04} 0;\n  display: ${props => (props.additionalContent ? 'flex' : '')};\n  margin-right: ${props => props.additionalContent && !props.isDismissible\r\n    ? props.theme.spaceScale.spacing03\r\n    : ''};\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    padding-left: 0;\n  }\n`;\r\nexport const AdditionalContentWrapper = styled.div `\n  flex: 1 0 auto;\n  justify-content: flex-end;\n  display: flex;\n  margin-left: ${props => props.theme.spaceScale.spacing05};\n`;\r\nconst IconWrapperStyles = css `\n  align-items: center;\n  display: flex;\n  flex-shrink: 0;\n  margin-right: 1px;\n`;\r\nconst IconWrapper = styled.span `\n  ${IconWrapperStyles}\n  padding: 0 ${props => props.theme.spaceScale.spacing03} 0 ${props => props.theme.spaceScale.spacing04};\n\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    padding: 0 ${props => props.theme.spaceScale.spacing03};\n    svg {\n      width: 20px;\n    }\n  }\n`;\r\nconst ProgressRingWrapper = styled.div `\n  margin-top: 6px;\n  position: absolute;\n  top: auto;\n  right: ${props => props.theme.spaceScale.spacing02};\n`;\r\nconst DismissibleIconWrapper = styled.span `\n  ${IconWrapperStyles}\n  margin-left: ${props => props.additionalContent ? props.theme.spaceScale.spacing03 : ''};\n`;\r\nconst whitelistProps = ['icon', 'isInverse', 'theme', 'variant'];\r\nconst shouldForwardProp = prop => {\r\n    return isPropValid(prop) || whitelistProps.includes(prop);\r\n};\r\nconst DismissButton = styled(IconButton, { shouldForwardProp }) `\n  align-self: stretch;\n  border-radius: 0 ${props => props.theme.borderRadius}\n    ${props => props.theme.borderRadius} 0;\n  color: inherit;\n  height: auto;\n  margin: ${props => (props.isToast ? '4px' : '0 -1px 0 0')};\n  padding: ${props => props.isToast\r\n    ? `0 ${props.theme.spaceScale.spacing04}`\r\n    : `0 ${props.theme.spaceScale.spacing03}`};\n  width: auto;\n  &:not(:disabled):hover {\n    background: none;\n    color: inherit;\n  }\n  &:focus:not(:disabled) {\n    background: none;\n    color: inherit;\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n    outline-offset: 0 !important;\n  }\n  &:not(:disabled):active {\n    background: none;\n    color: inherit;\n  }\n`;\r\nconst AlertSpan = styled.span `\n  white-space: pre-line;\n`;\r\nfunction renderIcon(variant = 'info', isToast, theme) {\r\n    const Icon = VARIANT_ICON[variant];\r\n    return (React.createElement(IconWrapper, { isToast: isToast, theme: theme },\r\n        React.createElement(Icon, { size: theme.iconSizes.medium })));\r\n}\r\nexport const AlertBase = React.forwardRef((props, ref) => {\r\n    const { additionalContent, children, closeAriaLabel, forceDismiss, hasTimerRing, id: defaultId, isDismissed, isDismissible, isExiting: externalIsExiting, isPaused, isToast, onDismiss, testId, toastDuration, variant, ...other } = props;\r\n    const id = useGenerateId(defaultId);\r\n    const [isExiting, setIsExiting] = React.useState(false);\r\n    const isInverse = useIsInverse(props.isInverse);\r\n    React.useEffect(() => {\r\n        if (isExiting) {\r\n            setTimeout(() => {\r\n                setIsExiting(false);\r\n                onDismiss && typeof onDismiss === 'function' && onDismiss();\r\n            }, transitionDuration - 300);\r\n        }\r\n    }, [isExiting]);\r\n    React.useEffect(() => {\r\n        if (isDismissed) {\r\n            handleDismiss();\r\n        }\r\n    }, [isDismissed]);\r\n    function handleDismiss() {\r\n        setIsExiting(true);\r\n    }\r\n    const theme = React.useContext(ThemeContext);\r\n    const i18n = React.useContext(I18nContext);\r\n    function progressRingColor() {\r\n        if (isInverse) {\r\n            return theme.colors.neutral100;\r\n        }\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return theme.colors.success500;\r\n            case 'warning':\r\n                return theme.colors.warning500;\r\n            case 'danger':\r\n                return theme.colors.danger500;\r\n            default:\r\n                return theme.colors.info500;\r\n        }\r\n    }\r\n    return (React.createElement(StyledAlert, Object.assign({}, other, { \"data-testid\": testId, id: id, tabIndex: -1, isInverse: isInverse, isExiting: isExiting, isToast: isToast, ref: ref, theme: theme, variant: variant }),\r\n        React.createElement(InverseContext.Provider, { value: { isInverse } },\r\n            React.createElement(StyledAlertInner, { isInverse: isInverse, isToast: isToast, theme: theme, variant: variant },\r\n                renderIcon(variant, isToast, theme),\r\n                React.createElement(AlertContents, { additionalContent: additionalContent, isDismissible: isDismissible, theme: theme },\r\n                    React.createElement(AlertSpan, null, children),\r\n                    additionalContent && (React.createElement(AdditionalContentWrapper, { theme: theme }, additionalContent))),\r\n                isDismissible && (React.createElement(DismissibleIconWrapper, { isInverse: isInverse, variant: variant, theme: theme },\r\n                    hasTimerRing && isToast && (React.createElement(ProgressRingWrapper, { theme: theme },\r\n                        React.createElement(ProgressRing, { color: progressRingColor(), isActive: !isPaused, duration: toastDuration }))),\r\n                    React.createElement(DismissButton, Object.assign({ alertVariant: variant }, (isToast\r\n                        ? { title: closeAriaLabel || i18n.alert.dismissAriaLabel }\r\n                        : {\r\n                            'aria-label': closeAriaLabel || i18n.alert.dismissAriaLabel,\r\n                        }), { icon: React.createElement(CloseIcon, { size: hasTimerRing\r\n                                ? theme.iconSizes.xSmall\r\n                                : theme.iconSizes.small }), isInverse: isInverse, isToast: isToast, onClick: forceDismiss || handleDismiss, theme: theme, variant: ButtonVariant.link }))))))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */"));
|
|
3627
|
+
return props.isToast && /*#__PURE__*/css("animation:", props.isExiting ? "slideout " + transitionDuration + "ms" : "slidein " + transitionDuration + "ms", ";min-width:375px;margin:0 auto;@media (max-width: ", props.theme.breakpoints.small, "px){min-width:0;width:100%;};label:StyledAlert;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AA8JQ","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport isPropValid from '@emotion/is-prop-valid';\r\nimport { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport { InfoIcon, CheckCircleIcon, WarningIcon, ErrorIcon, CloseIcon, } from 'react-magma-icons';\r\nimport { I18nContext } from '../..';\r\nimport { InverseContext, useIsInverse } from '../../inverse';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { useGenerateId } from '../../utils';\r\nimport { ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { ProgressRing } from '../ProgressRing';\r\nexport const VARIANT_ICON = {\r\n    info: InfoIcon,\r\n    success: CheckCircleIcon,\r\n    warning: WarningIcon,\r\n    danger: ErrorIcon,\r\n};\r\nexport var AlertVariant;\r\n(function (AlertVariant) {\r\n    AlertVariant[\"info\"] = \"info\";\r\n    AlertVariant[\"success\"] = \"success\";\r\n    AlertVariant[\"warning\"] = \"warning\";\r\n    AlertVariant[\"danger\"] = \"danger\";\r\n})(AlertVariant || (AlertVariant = {}));\r\nexport const transitionDuration = 500;\r\nexport function buildAlertBackground(props) {\r\n    if (props.isInverse) {\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return props.theme.colors.success700;\r\n            case 'warning':\r\n                return props.theme.colors.warning700;\r\n            case 'danger':\r\n                return props.theme.colors.danger700;\r\n            default:\r\n                return props.theme.colors.info700;\r\n        }\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success100;\r\n        case 'warning':\r\n            return props.theme.colors.warning100;\r\n        case 'danger':\r\n            return props.theme.colors.danger100;\r\n        default:\r\n            return props.theme.colors.info100;\r\n    }\r\n}\r\nexport function buildAlertBorder(props) {\r\n    if (props.isInverse) {\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return props.theme.colors.success300;\r\n            case 'warning':\r\n                return props.theme.colors.warning300;\r\n            case 'danger':\r\n                return props.theme.colors.danger200;\r\n            default:\r\n                return props.theme.colors.info300;\r\n        }\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success500;\r\n        case 'warning':\r\n            return props.theme.colors.warning500;\r\n        case 'danger':\r\n            return props.theme.colors.danger500;\r\n        default:\r\n            return props.theme.colors.info500;\r\n    }\r\n}\r\nexport function buildAlertColor(props) {\r\n    if (props.isInverse) {\r\n        return props.theme.colors.neutral100;\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success500;\r\n        case 'warning':\r\n            return props.theme.colors.warning500;\r\n        case 'danger':\r\n            return props.theme.colors.danger500;\r\n        default:\r\n            return props.theme.colors.info500;\r\n    }\r\n}\r\nexport function buildLinkColor(props) {\r\n    if (props.isInverse) {\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return props.theme.colors.success200;\r\n            case 'warning':\r\n                return props.theme.colors.warning200;\r\n            case 'danger':\r\n                return props.theme.colors.danger200;\r\n            default:\r\n                return props.theme.colors.info200;\r\n        }\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success700;\r\n        case 'warning':\r\n            return props.theme.colors.warning700;\r\n        case 'danger':\r\n            return props.theme.colors.danger700;\r\n        default:\r\n            return props.theme.colors.info700;\r\n    }\r\n}\r\nexport function buildLinkHoverColor(props) {\r\n    if (props.isInverse) {\r\n        return props.theme.colors.neutral100;\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success;\r\n        case 'warning':\r\n            return props.theme.colors.warning;\r\n        case 'danger':\r\n            return props.theme.colors.danger;\r\n        default:\r\n            return props.theme.colors.info;\r\n    }\r\n}\r\nconst StyledAlert = styled.div `\n  align-items: stretch;\n  animation: ${props => props.isExiting\r\n    ? `fadeout ${transitionDuration}ms`\r\n    : `fadein ${transitionDuration}ms`};\n  display: flex;\n  flex-direction: column;\n  font-size: ${props => props.theme.typeScale.size03.fontSize};\n  font-family: ${props => props.theme.bodyFont};\n  line-height: ${props => props.theme.typeScale.size03.lineHeight};\n  margin-bottom: ${props => props.theme.spaceScale.spacing06};\n  max-width: 100%;\n  padding: 0;\n  position: relative;\n\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    font-size: ${props => props.theme.typeScale.size02.fontSize};\n    letter-spacing: ${props => props.theme.typeScale.size02.letterSpacing};\n    line-height: ${props => props.theme.typeScale.size02.lineHeight};\n  }\n\n  &:focus {\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n  }\n\n  ${props => props.isToast &&\r\n    css `\n      animation: ${props.isExiting\r\n        ? `slideout ${transitionDuration}ms`\r\n        : `slidein ${transitionDuration}ms`};\n      min-width: 375px;\n      margin: 0 auto;\n\n      @media (max-width: ${props.theme.breakpoints.small}px) {\n        min-width: 0;\n        width: 100%;\n      }\n    `}\n\n  @keyframes fadein {\n    from {\n      opacity: 0;\n    }\n    to {\n      opacity: 1;\n    }\n  }\n\n  @keyframes fadeout {\n    from {\n      opacity: 1;\n    }\n    to {\n      opacity: 0;\n    }\n  }\n\n  @keyframes slidein {\n    from {\n      left: -500px;\n    }\n    to {\n      left: 0;\n    }\n  }\n\n  @keyframes slideout {\n    from {\n      left: 0;\n    }\n    to {\n      left: -500px;\n    }\n  }\n\n  a {\n    color: ${props => buildLinkColor(props)};\n    font-weight: 400;\n    text-decoration: underline;\n    &:not([disabled]) {\n      &:focus,\n      &:hover {\n        color: ${props => buildLinkHoverColor(props)};\n      }\n    }\n  }\n`;\r\nconst StyledAlertInner = styled.div `\n  background: ${buildAlertBackground};\n  border: 1px solid ${buildAlertBorder};\n  border-radius: ${props => props.theme.borderRadius};\n  color: ${buildAlertColor};\n  display: flex;\n  position: relative;\n\n  ${props => props.isToast &&\r\n    css `\n      box-shadow: ${props.isInverse\r\n        ? `0 2px 8px 0 ${transparentize(0.3, props.theme.colors.neutral900)}`\r\n        : `0 2px 8px 0 ${transparentize(0.6, props.theme.colors.neutral900)}`};\n      padding-right: 0;\n      height: ${props.theme.spaceScale.spacing11};\n    `}\n`;\r\nconst AlertContents = styled.div `\n  align-items: ${props => (props.additionalContent ? 'center' : '')};\n  align-self: center;\n  flex-grow: 1;\n  font-family: ${props => props.theme.bodyFont};\n  padding: ${props => props.theme.spaceScale.spacing04} 0;\n  display: ${props => (props.additionalContent ? 'flex' : '')};\n  margin-right: ${props => props.additionalContent && !props.isDismissible\r\n    ? props.theme.spaceScale.spacing03\r\n    : ''};\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    padding-left: 0;\n  }\n`;\r\nexport const AdditionalContentWrapper = styled.div `\n  flex: 1 0 auto;\n  justify-content: flex-end;\n  display: flex;\n  margin-left: ${props => props.theme.spaceScale.spacing05};\n`;\r\nconst IconWrapperStyles = css `\n  align-items: center;\n  display: flex;\n  flex-shrink: 0;\n  margin-right: 1px;\n`;\r\nconst IconWrapper = styled.span `\n  ${IconWrapperStyles}\n  padding: 0 ${props => props.theme.spaceScale.spacing03} 0 ${props => props.theme.spaceScale.spacing04};\n\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    padding: 0 ${props => props.theme.spaceScale.spacing03};\n    svg {\n      width: 20px;\n    }\n  }\n`;\r\nconst ProgressRingWrapper = styled.div `\n  margin-top: 6px;\n  position: absolute;\n  top: auto;\n  right: ${props => props.theme.spaceScale.spacing02};\n`;\r\nconst DismissibleIconWrapper = styled.span `\n  ${IconWrapperStyles}\n  margin-left: ${props => props.additionalContent ? props.theme.spaceScale.spacing03 : ''};\n`;\r\nconst whitelistProps = ['icon', 'isInverse', 'theme', 'variant'];\r\nconst shouldForwardProp = prop => {\r\n    return isPropValid(prop) || whitelistProps.includes(prop);\r\n};\r\nconst DismissButton = styled(IconButton, { shouldForwardProp }) `\n  align-self: stretch;\n  border-radius: 0 ${props => props.theme.borderRadius}\n    ${props => props.theme.borderRadius} 0;\n  color: inherit;\n  height: auto;\n  margin: ${props => (props.isToast ? '4px' : '0 -1px 0 0')};\n  padding: ${props => props.isToast\r\n    ? `0 ${props.theme.spaceScale.spacing04}`\r\n    : `0 ${props.theme.spaceScale.spacing03}`};\n  width: auto;\n  &:not(:disabled):hover {\n    background: none;\n    color: inherit;\n  }\n  &:focus:not(:disabled) {\n    background: none;\n    color: inherit;\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n    outline-offset: 0 !important;\n  }\n  &:not(:disabled):active {\n    background: none;\n    color: inherit;\n  }\n`;\r\nconst AlertSpan = styled.span `\n  white-space: pre-line;\n`;\r\nfunction getAriaLabelIcon(variant, i18n) {\r\n    switch (variant) {\r\n        case 'success':\r\n            return i18n.alertVariants.success;\r\n        case 'warning':\r\n            return i18n.alertVariants.warning;\r\n        case 'danger':\r\n            return i18n.alertVariants.danger;\r\n        default:\r\n            return i18n.alertVariants.info;\r\n    }\r\n}\r\nfunction renderIcon(variant = 'info', isToast, theme, i18n) {\r\n    const Icon = VARIANT_ICON[variant];\r\n    return (React.createElement(IconWrapper, { \"aria-label\": getAriaLabelIcon(variant, i18n), role: \"img\", isToast: isToast, theme: theme },\r\n        React.createElement(Icon, { size: theme.iconSizes.medium })));\r\n}\r\nexport const AlertBase = React.forwardRef((props, ref) => {\r\n    const { additionalContent, children, closeAriaLabel, forceDismiss, hasTimerRing, id: defaultId, isDismissed, isDismissible, isExiting: externalIsExiting, isPaused, isToast, onDismiss, testId, toastDuration, variant, ...other } = props;\r\n    const id = useGenerateId(defaultId);\r\n    const [isExiting, setIsExiting] = React.useState(false);\r\n    const isInverse = useIsInverse(props.isInverse);\r\n    React.useEffect(() => {\r\n        if (isExiting) {\r\n            setTimeout(() => {\r\n                setIsExiting(false);\r\n                onDismiss && typeof onDismiss === 'function' && onDismiss();\r\n            }, transitionDuration - 300);\r\n        }\r\n    }, [isExiting]);\r\n    React.useEffect(() => {\r\n        if (isDismissed) {\r\n            handleDismiss();\r\n        }\r\n    }, [isDismissed]);\r\n    function handleDismiss() {\r\n        setIsExiting(true);\r\n    }\r\n    const theme = React.useContext(ThemeContext);\r\n    const i18n = React.useContext(I18nContext);\r\n    function progressRingColor() {\r\n        if (isInverse) {\r\n            return theme.colors.neutral100;\r\n        }\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return theme.colors.success500;\r\n            case 'warning':\r\n                return theme.colors.warning500;\r\n            case 'danger':\r\n                return theme.colors.danger500;\r\n            default:\r\n                return theme.colors.info500;\r\n        }\r\n    }\r\n    return (React.createElement(StyledAlert, Object.assign({}, other, { \"data-testid\": testId, id: id, tabIndex: -1, isInverse: isInverse, isExiting: isExiting, isToast: isToast, ref: ref, theme: theme, variant: variant }),\r\n        React.createElement(InverseContext.Provider, { value: { isInverse } },\r\n            React.createElement(StyledAlertInner, { isInverse: isInverse, isToast: isToast, theme: theme, variant: variant },\r\n                renderIcon(variant, isToast, theme, i18n),\r\n                React.createElement(AlertContents, { additionalContent: additionalContent, isDismissible: isDismissible, theme: theme },\r\n                    React.createElement(AlertSpan, null, children),\r\n                    additionalContent && (React.createElement(AdditionalContentWrapper, { theme: theme }, additionalContent))),\r\n                isDismissible && (React.createElement(DismissibleIconWrapper, { isInverse: isInverse, variant: variant, theme: theme },\r\n                    hasTimerRing && isToast && (React.createElement(ProgressRingWrapper, { theme: theme },\r\n                        React.createElement(ProgressRing, { color: progressRingColor(), isActive: !isPaused, duration: toastDuration }))),\r\n                    React.createElement(DismissButton, Object.assign({ alertVariant: variant }, (isToast\r\n                        ? { title: closeAriaLabel || i18n.alert.dismissAriaLabel }\r\n                        : {\r\n                            'aria-label': closeAriaLabel || i18n.alert.dismissAriaLabel,\r\n                        }), { icon: React.createElement(CloseIcon, { size: hasTimerRing\r\n                                ? theme.iconSizes.xSmall\r\n                                : theme.iconSizes.small }), isInverse: isInverse, isToast: isToast, onClick: forceDismiss || handleDismiss, theme: theme, variant: ButtonVariant.link }))))))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */"));
|
|
3622
3628
|
}, "@keyframes fadein{from{opacity:0;}to{opacity:1;}}@keyframes fadeout{from{opacity:1;}to{opacity:0;}}@keyframes slidein{from{left:-500px;}to{left:0;}}@keyframes slideout{from{left:0;}to{left:-500px;}}a{color:", function (props) {
|
|
3623
3629
|
return buildLinkColor(props);
|
|
3624
3630
|
}, ";font-weight:400;text-decoration:underline;&:not([disabled]){&:focus,&:hover{color:", function (props) {
|
|
3625
3631
|
return buildLinkHoverColor(props);
|
|
3626
|
-
}, ";}}}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAiI+B","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport isPropValid from '@emotion/is-prop-valid';\r\nimport { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport { InfoIcon, CheckCircleIcon, WarningIcon, ErrorIcon, CloseIcon, } from 'react-magma-icons';\r\nimport { I18nContext } from '../../i18n';\r\nimport { InverseContext, useIsInverse } from '../../inverse';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { useGenerateId } from '../../utils';\r\nimport { ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { ProgressRing } from '../ProgressRing';\r\nexport const VARIANT_ICON = {\r\n    info: InfoIcon,\r\n    success: CheckCircleIcon,\r\n    warning: WarningIcon,\r\n    danger: ErrorIcon,\r\n};\r\nexport var AlertVariant;\r\n(function (AlertVariant) {\r\n    AlertVariant[\"info\"] = \"info\";\r\n    AlertVariant[\"success\"] = \"success\";\r\n    AlertVariant[\"warning\"] = \"warning\";\r\n    AlertVariant[\"danger\"] = \"danger\";\r\n})(AlertVariant || (AlertVariant = {}));\r\nexport const transitionDuration = 500;\r\nexport function buildAlertBackground(props) {\r\n    if (props.isInverse) {\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return props.theme.colors.success700;\r\n            case 'warning':\r\n                return props.theme.colors.warning700;\r\n            case 'danger':\r\n                return props.theme.colors.danger700;\r\n            default:\r\n                return props.theme.colors.info700;\r\n        }\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success100;\r\n        case 'warning':\r\n            return props.theme.colors.warning100;\r\n        case 'danger':\r\n            return props.theme.colors.danger100;\r\n        default:\r\n            return props.theme.colors.info100;\r\n    }\r\n}\r\nexport function buildAlertBorder(props) {\r\n    if (props.isInverse) {\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return props.theme.colors.success300;\r\n            case 'warning':\r\n                return props.theme.colors.warning300;\r\n            case 'danger':\r\n                return props.theme.colors.danger200;\r\n            default:\r\n                return props.theme.colors.info300;\r\n        }\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success500;\r\n        case 'warning':\r\n            return props.theme.colors.warning500;\r\n        case 'danger':\r\n            return props.theme.colors.danger500;\r\n        default:\r\n            return props.theme.colors.info500;\r\n    }\r\n}\r\nexport function buildAlertColor(props) {\r\n    if (props.isInverse) {\r\n        return props.theme.colors.neutral100;\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success500;\r\n        case 'warning':\r\n            return props.theme.colors.warning500;\r\n        case 'danger':\r\n            return props.theme.colors.danger500;\r\n        default:\r\n            return props.theme.colors.info500;\r\n    }\r\n}\r\nexport function buildLinkColor(props) {\r\n    if (props.isInverse) {\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return props.theme.colors.success200;\r\n            case 'warning':\r\n                return props.theme.colors.warning200;\r\n            case 'danger':\r\n                return props.theme.colors.danger200;\r\n            default:\r\n                return props.theme.colors.info200;\r\n        }\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success700;\r\n        case 'warning':\r\n            return props.theme.colors.warning700;\r\n        case 'danger':\r\n            return props.theme.colors.danger700;\r\n        default:\r\n            return props.theme.colors.info700;\r\n    }\r\n}\r\nexport function buildLinkHoverColor(props) {\r\n    if (props.isInverse) {\r\n        return props.theme.colors.neutral100;\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success;\r\n        case 'warning':\r\n            return props.theme.colors.warning;\r\n        case 'danger':\r\n            return props.theme.colors.danger;\r\n        default:\r\n            return props.theme.colors.info;\r\n    }\r\n}\r\nconst StyledAlert = styled.div `\n  align-items: stretch;\n  animation: ${props => props.isExiting\r\n    ? `fadeout ${transitionDuration}ms`\r\n    : `fadein ${transitionDuration}ms`};\n  display: flex;\n  flex-direction: column;\n  font-size: ${props => props.theme.typeScale.size03.fontSize};\n  font-family: ${props => props.theme.bodyFont};\n  line-height: ${props => props.theme.typeScale.size03.lineHeight};\n  margin-bottom: ${props => props.theme.spaceScale.spacing06};\n  max-width: 100%;\n  padding: 0;\n  position: relative;\n\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    font-size: ${props => props.theme.typeScale.size02.fontSize};\n    letter-spacing: ${props => props.theme.typeScale.size02.letterSpacing};\n    line-height: ${props => props.theme.typeScale.size02.lineHeight};\n  }\n\n  &:focus {\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n  }\n\n  ${props => props.isToast &&\r\n    css `\n      animation: ${props.isExiting\r\n        ? `slideout ${transitionDuration}ms`\r\n        : `slidein ${transitionDuration}ms`};\n      min-width: 375px;\n      margin: 0 auto;\n\n      @media (max-width: ${props.theme.breakpoints.small}px) {\n        min-width: 0;\n        width: 100%;\n      }\n    `}\n\n  @keyframes fadein {\n    from {\n      opacity: 0;\n    }\n    to {\n      opacity: 1;\n    }\n  }\n\n  @keyframes fadeout {\n    from {\n      opacity: 1;\n    }\n    to {\n      opacity: 0;\n    }\n  }\n\n  @keyframes slidein {\n    from {\n      left: -500px;\n    }\n    to {\n      left: 0;\n    }\n  }\n\n  @keyframes slideout {\n    from {\n      left: 0;\n    }\n    to {\n      left: -500px;\n    }\n  }\n\n  a {\n    color: ${props => buildLinkColor(props)};\n    font-weight: 400;\n    text-decoration: underline;\n    &:not([disabled]) {\n      &:focus,\n      &:hover {\n        color: ${props => buildLinkHoverColor(props)};\n      }\n    }\n  }\n`;\r\nconst StyledAlertInner = styled.div `\n  background: ${buildAlertBackground};\n  border: 1px solid ${buildAlertBorder};\n  border-radius: ${props => props.theme.borderRadius};\n  color: ${buildAlertColor};\n  display: flex;\n  position: relative;\n\n  ${props => props.isToast &&\r\n    css `\n      box-shadow: ${props.isInverse\r\n        ? `0 2px 8px 0 ${transparentize(0.3, props.theme.colors.neutral900)}`\r\n        : `0 2px 8px 0 ${transparentize(0.6, props.theme.colors.neutral900)}`};\n      padding-right: 0;\n      height: ${props.theme.spaceScale.spacing11};\n    `}\n`;\r\nconst AlertContents = styled.div `\n  align-items: ${props => (props.additionalContent ? 'center' : '')};\n  align-self: center;\n  flex-grow: 1;\n  font-family: ${props => props.theme.bodyFont};\n  padding: ${props => props.theme.spaceScale.spacing04} 0;\n  display: ${props => (props.additionalContent ? 'flex' : '')};\n  margin-right: ${props => props.additionalContent && !props.isDismissible\r\n    ? props.theme.spaceScale.spacing03\r\n    : ''};\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    padding-left: 0;\n  }\n`;\r\nexport const AdditionalContentWrapper = styled.div `\n  flex: 1 0 auto;\n  justify-content: flex-end;\n  display: flex;\n  margin-left: ${props => props.theme.spaceScale.spacing05};\n`;\r\nconst IconWrapperStyles = css `\n  align-items: center;\n  display: flex;\n  flex-shrink: 0;\n  margin-right: 1px;\n`;\r\nconst IconWrapper = styled.span `\n  ${IconWrapperStyles}\n  padding: 0 ${props => props.theme.spaceScale.spacing03} 0 ${props => props.theme.spaceScale.spacing04};\n\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    padding: 0 ${props => props.theme.spaceScale.spacing03};\n    svg {\n      width: 20px;\n    }\n  }\n`;\r\nconst ProgressRingWrapper = styled.div `\n  margin-top: 6px;\n  position: absolute;\n  top: auto;\n  right: ${props => props.theme.spaceScale.spacing02};\n`;\r\nconst DismissibleIconWrapper = styled.span `\n  ${IconWrapperStyles}\n  margin-left: ${props => props.additionalContent ? props.theme.spaceScale.spacing03 : ''};\n`;\r\nconst whitelistProps = ['icon', 'isInverse', 'theme', 'variant'];\r\nconst shouldForwardProp = prop => {\r\n    return isPropValid(prop) || whitelistProps.includes(prop);\r\n};\r\nconst DismissButton = styled(IconButton, { shouldForwardProp }) `\n  align-self: stretch;\n  border-radius: 0 ${props => props.theme.borderRadius}\n    ${props => props.theme.borderRadius} 0;\n  color: inherit;\n  height: auto;\n  margin: ${props => (props.isToast ? '4px' : '0 -1px 0 0')};\n  padding: ${props => props.isToast\r\n    ? `0 ${props.theme.spaceScale.spacing04}`\r\n    : `0 ${props.theme.spaceScale.spacing03}`};\n  width: auto;\n  &:not(:disabled):hover {\n    background: none;\n    color: inherit;\n  }\n  &:focus:not(:disabled) {\n    background: none;\n    color: inherit;\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n    outline-offset: 0 !important;\n  }\n  &:not(:disabled):active {\n    background: none;\n    color: inherit;\n  }\n`;\r\nconst AlertSpan = styled.span `\n  white-space: pre-line;\n`;\r\nfunction renderIcon(variant = 'info', isToast, theme) {\r\n    const Icon = VARIANT_ICON[variant];\r\n    return (React.createElement(IconWrapper, { isToast: isToast, theme: theme },\r\n        React.createElement(Icon, { size: theme.iconSizes.medium })));\r\n}\r\nexport const AlertBase = React.forwardRef((props, ref) => {\r\n    const { additionalContent, children, closeAriaLabel, forceDismiss, hasTimerRing, id: defaultId, isDismissed, isDismissible, isExiting: externalIsExiting, isPaused, isToast, onDismiss, testId, toastDuration, variant, ...other } = props;\r\n    const id = useGenerateId(defaultId);\r\n    const [isExiting, setIsExiting] = React.useState(false);\r\n    const isInverse = useIsInverse(props.isInverse);\r\n    React.useEffect(() => {\r\n        if (isExiting) {\r\n            setTimeout(() => {\r\n                setIsExiting(false);\r\n                onDismiss && typeof onDismiss === 'function' && onDismiss();\r\n            }, transitionDuration - 300);\r\n        }\r\n    }, [isExiting]);\r\n    React.useEffect(() => {\r\n        if (isDismissed) {\r\n            handleDismiss();\r\n        }\r\n    }, [isDismissed]);\r\n    function handleDismiss() {\r\n        setIsExiting(true);\r\n    }\r\n    const theme = React.useContext(ThemeContext);\r\n    const i18n = React.useContext(I18nContext);\r\n    function progressRingColor() {\r\n        if (isInverse) {\r\n            return theme.colors.neutral100;\r\n        }\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return theme.colors.success500;\r\n            case 'warning':\r\n                return theme.colors.warning500;\r\n            case 'danger':\r\n                return theme.colors.danger500;\r\n            default:\r\n                return theme.colors.info500;\r\n        }\r\n    }\r\n    return (React.createElement(StyledAlert, Object.assign({}, other, { \"data-testid\": testId, id: id, tabIndex: -1, isInverse: isInverse, isExiting: isExiting, isToast: isToast, ref: ref, theme: theme, variant: variant }),\r\n        React.createElement(InverseContext.Provider, { value: { isInverse } },\r\n            React.createElement(StyledAlertInner, { isInverse: isInverse, isToast: isToast, theme: theme, variant: variant },\r\n                renderIcon(variant, isToast, theme),\r\n                React.createElement(AlertContents, { additionalContent: additionalContent, isDismissible: isDismissible, theme: theme },\r\n                    React.createElement(AlertSpan, null, children),\r\n                    additionalContent && (React.createElement(AdditionalContentWrapper, { theme: theme }, additionalContent))),\r\n                isDismissible && (React.createElement(DismissibleIconWrapper, { isInverse: isInverse, variant: variant, theme: theme },\r\n                    hasTimerRing && isToast && (React.createElement(ProgressRingWrapper, { theme: theme },\r\n                        React.createElement(ProgressRing, { color: progressRingColor(), isActive: !isPaused, duration: toastDuration }))),\r\n                    React.createElement(DismissButton, Object.assign({ alertVariant: variant }, (isToast\r\n                        ? { title: closeAriaLabel || i18n.alert.dismissAriaLabel }\r\n                        : {\r\n                            'aria-label': closeAriaLabel || i18n.alert.dismissAriaLabel,\r\n                        }), { icon: React.createElement(CloseIcon, { size: hasTimerRing\r\n                                ? theme.iconSizes.xSmall\r\n                                : theme.iconSizes.small }), isInverse: isInverse, isToast: isToast, onClick: forceDismiss || handleDismiss, theme: theme, variant: ButtonVariant.link }))))))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */"));
|
|
3632
|
+
}, ";}}}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAiI+B","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport isPropValid from '@emotion/is-prop-valid';\r\nimport { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport { InfoIcon, CheckCircleIcon, WarningIcon, ErrorIcon, CloseIcon, } from 'react-magma-icons';\r\nimport { I18nContext } from '../..';\r\nimport { InverseContext, useIsInverse } from '../../inverse';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { useGenerateId } from '../../utils';\r\nimport { ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { ProgressRing } from '../ProgressRing';\r\nexport const VARIANT_ICON = {\r\n    info: InfoIcon,\r\n    success: CheckCircleIcon,\r\n    warning: WarningIcon,\r\n    danger: ErrorIcon,\r\n};\r\nexport var AlertVariant;\r\n(function (AlertVariant) {\r\n    AlertVariant[\"info\"] = \"info\";\r\n    AlertVariant[\"success\"] = \"success\";\r\n    AlertVariant[\"warning\"] = \"warning\";\r\n    AlertVariant[\"danger\"] = \"danger\";\r\n})(AlertVariant || (AlertVariant = {}));\r\nexport const transitionDuration = 500;\r\nexport function buildAlertBackground(props) {\r\n    if (props.isInverse) {\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return props.theme.colors.success700;\r\n            case 'warning':\r\n                return props.theme.colors.warning700;\r\n            case 'danger':\r\n                return props.theme.colors.danger700;\r\n            default:\r\n                return props.theme.colors.info700;\r\n        }\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success100;\r\n        case 'warning':\r\n            return props.theme.colors.warning100;\r\n        case 'danger':\r\n            return props.theme.colors.danger100;\r\n        default:\r\n            return props.theme.colors.info100;\r\n    }\r\n}\r\nexport function buildAlertBorder(props) {\r\n    if (props.isInverse) {\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return props.theme.colors.success300;\r\n            case 'warning':\r\n                return props.theme.colors.warning300;\r\n            case 'danger':\r\n                return props.theme.colors.danger200;\r\n            default:\r\n                return props.theme.colors.info300;\r\n        }\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success500;\r\n        case 'warning':\r\n            return props.theme.colors.warning500;\r\n        case 'danger':\r\n            return props.theme.colors.danger500;\r\n        default:\r\n            return props.theme.colors.info500;\r\n    }\r\n}\r\nexport function buildAlertColor(props) {\r\n    if (props.isInverse) {\r\n        return props.theme.colors.neutral100;\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success500;\r\n        case 'warning':\r\n            return props.theme.colors.warning500;\r\n        case 'danger':\r\n            return props.theme.colors.danger500;\r\n        default:\r\n            return props.theme.colors.info500;\r\n    }\r\n}\r\nexport function buildLinkColor(props) {\r\n    if (props.isInverse) {\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return props.theme.colors.success200;\r\n            case 'warning':\r\n                return props.theme.colors.warning200;\r\n            case 'danger':\r\n                return props.theme.colors.danger200;\r\n            default:\r\n                return props.theme.colors.info200;\r\n        }\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success700;\r\n        case 'warning':\r\n            return props.theme.colors.warning700;\r\n        case 'danger':\r\n            return props.theme.colors.danger700;\r\n        default:\r\n            return props.theme.colors.info700;\r\n    }\r\n}\r\nexport function buildLinkHoverColor(props) {\r\n    if (props.isInverse) {\r\n        return props.theme.colors.neutral100;\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success;\r\n        case 'warning':\r\n            return props.theme.colors.warning;\r\n        case 'danger':\r\n            return props.theme.colors.danger;\r\n        default:\r\n            return props.theme.colors.info;\r\n    }\r\n}\r\nconst StyledAlert = styled.div `\n  align-items: stretch;\n  animation: ${props => props.isExiting\r\n    ? `fadeout ${transitionDuration}ms`\r\n    : `fadein ${transitionDuration}ms`};\n  display: flex;\n  flex-direction: column;\n  font-size: ${props => props.theme.typeScale.size03.fontSize};\n  font-family: ${props => props.theme.bodyFont};\n  line-height: ${props => props.theme.typeScale.size03.lineHeight};\n  margin-bottom: ${props => props.theme.spaceScale.spacing06};\n  max-width: 100%;\n  padding: 0;\n  position: relative;\n\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    font-size: ${props => props.theme.typeScale.size02.fontSize};\n    letter-spacing: ${props => props.theme.typeScale.size02.letterSpacing};\n    line-height: ${props => props.theme.typeScale.size02.lineHeight};\n  }\n\n  &:focus {\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n  }\n\n  ${props => props.isToast &&\r\n    css `\n      animation: ${props.isExiting\r\n        ? `slideout ${transitionDuration}ms`\r\n        : `slidein ${transitionDuration}ms`};\n      min-width: 375px;\n      margin: 0 auto;\n\n      @media (max-width: ${props.theme.breakpoints.small}px) {\n        min-width: 0;\n        width: 100%;\n      }\n    `}\n\n  @keyframes fadein {\n    from {\n      opacity: 0;\n    }\n    to {\n      opacity: 1;\n    }\n  }\n\n  @keyframes fadeout {\n    from {\n      opacity: 1;\n    }\n    to {\n      opacity: 0;\n    }\n  }\n\n  @keyframes slidein {\n    from {\n      left: -500px;\n    }\n    to {\n      left: 0;\n    }\n  }\n\n  @keyframes slideout {\n    from {\n      left: 0;\n    }\n    to {\n      left: -500px;\n    }\n  }\n\n  a {\n    color: ${props => buildLinkColor(props)};\n    font-weight: 400;\n    text-decoration: underline;\n    &:not([disabled]) {\n      &:focus,\n      &:hover {\n        color: ${props => buildLinkHoverColor(props)};\n      }\n    }\n  }\n`;\r\nconst StyledAlertInner = styled.div `\n  background: ${buildAlertBackground};\n  border: 1px solid ${buildAlertBorder};\n  border-radius: ${props => props.theme.borderRadius};\n  color: ${buildAlertColor};\n  display: flex;\n  position: relative;\n\n  ${props => props.isToast &&\r\n    css `\n      box-shadow: ${props.isInverse\r\n        ? `0 2px 8px 0 ${transparentize(0.3, props.theme.colors.neutral900)}`\r\n        : `0 2px 8px 0 ${transparentize(0.6, props.theme.colors.neutral900)}`};\n      padding-right: 0;\n      height: ${props.theme.spaceScale.spacing11};\n    `}\n`;\r\nconst AlertContents = styled.div `\n  align-items: ${props => (props.additionalContent ? 'center' : '')};\n  align-self: center;\n  flex-grow: 1;\n  font-family: ${props => props.theme.bodyFont};\n  padding: ${props => props.theme.spaceScale.spacing04} 0;\n  display: ${props => (props.additionalContent ? 'flex' : '')};\n  margin-right: ${props => props.additionalContent && !props.isDismissible\r\n    ? props.theme.spaceScale.spacing03\r\n    : ''};\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    padding-left: 0;\n  }\n`;\r\nexport const AdditionalContentWrapper = styled.div `\n  flex: 1 0 auto;\n  justify-content: flex-end;\n  display: flex;\n  margin-left: ${props => props.theme.spaceScale.spacing05};\n`;\r\nconst IconWrapperStyles = css `\n  align-items: center;\n  display: flex;\n  flex-shrink: 0;\n  margin-right: 1px;\n`;\r\nconst IconWrapper = styled.span `\n  ${IconWrapperStyles}\n  padding: 0 ${props => props.theme.spaceScale.spacing03} 0 ${props => props.theme.spaceScale.spacing04};\n\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    padding: 0 ${props => props.theme.spaceScale.spacing03};\n    svg {\n      width: 20px;\n    }\n  }\n`;\r\nconst ProgressRingWrapper = styled.div `\n  margin-top: 6px;\n  position: absolute;\n  top: auto;\n  right: ${props => props.theme.spaceScale.spacing02};\n`;\r\nconst DismissibleIconWrapper = styled.span `\n  ${IconWrapperStyles}\n  margin-left: ${props => props.additionalContent ? props.theme.spaceScale.spacing03 : ''};\n`;\r\nconst whitelistProps = ['icon', 'isInverse', 'theme', 'variant'];\r\nconst shouldForwardProp = prop => {\r\n    return isPropValid(prop) || whitelistProps.includes(prop);\r\n};\r\nconst DismissButton = styled(IconButton, { shouldForwardProp }) `\n  align-self: stretch;\n  border-radius: 0 ${props => props.theme.borderRadius}\n    ${props => props.theme.borderRadius} 0;\n  color: inherit;\n  height: auto;\n  margin: ${props => (props.isToast ? '4px' : '0 -1px 0 0')};\n  padding: ${props => props.isToast\r\n    ? `0 ${props.theme.spaceScale.spacing04}`\r\n    : `0 ${props.theme.spaceScale.spacing03}`};\n  width: auto;\n  &:not(:disabled):hover {\n    background: none;\n    color: inherit;\n  }\n  &:focus:not(:disabled) {\n    background: none;\n    color: inherit;\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n    outline-offset: 0 !important;\n  }\n  &:not(:disabled):active {\n    background: none;\n    color: inherit;\n  }\n`;\r\nconst AlertSpan = styled.span `\n  white-space: pre-line;\n`;\r\nfunction getAriaLabelIcon(variant, i18n) {\r\n    switch (variant) {\r\n        case 'success':\r\n            return i18n.alertVariants.success;\r\n        case 'warning':\r\n            return i18n.alertVariants.warning;\r\n        case 'danger':\r\n            return i18n.alertVariants.danger;\r\n        default:\r\n            return i18n.alertVariants.info;\r\n    }\r\n}\r\nfunction renderIcon(variant = 'info', isToast, theme, i18n) {\r\n    const Icon = VARIANT_ICON[variant];\r\n    return (React.createElement(IconWrapper, { \"aria-label\": getAriaLabelIcon(variant, i18n), role: \"img\", isToast: isToast, theme: theme },\r\n        React.createElement(Icon, { size: theme.iconSizes.medium })));\r\n}\r\nexport const AlertBase = React.forwardRef((props, ref) => {\r\n    const { additionalContent, children, closeAriaLabel, forceDismiss, hasTimerRing, id: defaultId, isDismissed, isDismissible, isExiting: externalIsExiting, isPaused, isToast, onDismiss, testId, toastDuration, variant, ...other } = props;\r\n    const id = useGenerateId(defaultId);\r\n    const [isExiting, setIsExiting] = React.useState(false);\r\n    const isInverse = useIsInverse(props.isInverse);\r\n    React.useEffect(() => {\r\n        if (isExiting) {\r\n            setTimeout(() => {\r\n                setIsExiting(false);\r\n                onDismiss && typeof onDismiss === 'function' && onDismiss();\r\n            }, transitionDuration - 300);\r\n        }\r\n    }, [isExiting]);\r\n    React.useEffect(() => {\r\n        if (isDismissed) {\r\n            handleDismiss();\r\n        }\r\n    }, [isDismissed]);\r\n    function handleDismiss() {\r\n        setIsExiting(true);\r\n    }\r\n    const theme = React.useContext(ThemeContext);\r\n    const i18n = React.useContext(I18nContext);\r\n    function progressRingColor() {\r\n        if (isInverse) {\r\n            return theme.colors.neutral100;\r\n        }\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return theme.colors.success500;\r\n            case 'warning':\r\n                return theme.colors.warning500;\r\n            case 'danger':\r\n                return theme.colors.danger500;\r\n            default:\r\n                return theme.colors.info500;\r\n        }\r\n    }\r\n    return (React.createElement(StyledAlert, Object.assign({}, other, { \"data-testid\": testId, id: id, tabIndex: -1, isInverse: isInverse, isExiting: isExiting, isToast: isToast, ref: ref, theme: theme, variant: variant }),\r\n        React.createElement(InverseContext.Provider, { value: { isInverse } },\r\n            React.createElement(StyledAlertInner, { isInverse: isInverse, isToast: isToast, theme: theme, variant: variant },\r\n                renderIcon(variant, isToast, theme, i18n),\r\n                React.createElement(AlertContents, { additionalContent: additionalContent, isDismissible: isDismissible, theme: theme },\r\n                    React.createElement(AlertSpan, null, children),\r\n                    additionalContent && (React.createElement(AdditionalContentWrapper, { theme: theme }, additionalContent))),\r\n                isDismissible && (React.createElement(DismissibleIconWrapper, { isInverse: isInverse, variant: variant, theme: theme },\r\n                    hasTimerRing && isToast && (React.createElement(ProgressRingWrapper, { theme: theme },\r\n                        React.createElement(ProgressRing, { color: progressRingColor(), isActive: !isPaused, duration: toastDuration }))),\r\n                    React.createElement(DismissButton, Object.assign({ alertVariant: variant }, (isToast\r\n                        ? { title: closeAriaLabel || i18n.alert.dismissAriaLabel }\r\n                        : {\r\n                            'aria-label': closeAriaLabel || i18n.alert.dismissAriaLabel,\r\n                        }), { icon: React.createElement(CloseIcon, { size: hasTimerRing\r\n                                ? theme.iconSizes.xSmall\r\n                                : theme.iconSizes.small }), isInverse: isInverse, isToast: isToast, onClick: forceDismiss || handleDismiss, theme: theme, variant: ButtonVariant.link }))))))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */"));
|
|
3627
3633
|
var StyledAlertInner = /*#__PURE__*/_styled("div", {
|
|
3628
3634
|
target: "e126n3g87",
|
|
3629
3635
|
label: "StyledAlertInner"
|
|
3630
3636
|
})("background:", buildAlertBackground, ";border:1px solid ", buildAlertBorder, ";border-radius:", function (props) {
|
|
3631
3637
|
return props.theme.borderRadius;
|
|
3632
3638
|
}, ";color:", buildAlertColor, ";display:flex;position:relative;", function (props) {
|
|
3633
|
-
return props.isToast && /*#__PURE__*/css("box-shadow:", props.isInverse ? "0 2px 8px 0 " + curriedTransparentize(0.3, props.theme.colors.neutral900) : "0 2px 8px 0 " + curriedTransparentize(0.6, props.theme.colors.neutral900), ";padding-right:0;height:", props.theme.spaceScale.spacing11, ";;label:StyledAlertInner;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAoOQ","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport isPropValid from '@emotion/is-prop-valid';\r\nimport { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport { InfoIcon, CheckCircleIcon, WarningIcon, ErrorIcon, CloseIcon, } from 'react-magma-icons';\r\nimport { I18nContext } from '../../i18n';\r\nimport { InverseContext, useIsInverse } from '../../inverse';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { useGenerateId } from '../../utils';\r\nimport { ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { ProgressRing } from '../ProgressRing';\r\nexport const VARIANT_ICON = {\r\n    info: InfoIcon,\r\n    success: CheckCircleIcon,\r\n    warning: WarningIcon,\r\n    danger: ErrorIcon,\r\n};\r\nexport var AlertVariant;\r\n(function (AlertVariant) {\r\n    AlertVariant[\"info\"] = \"info\";\r\n    AlertVariant[\"success\"] = \"success\";\r\n    AlertVariant[\"warning\"] = \"warning\";\r\n    AlertVariant[\"danger\"] = \"danger\";\r\n})(AlertVariant || (AlertVariant = {}));\r\nexport const transitionDuration = 500;\r\nexport function buildAlertBackground(props) {\r\n    if (props.isInverse) {\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return props.theme.colors.success700;\r\n            case 'warning':\r\n                return props.theme.colors.warning700;\r\n            case 'danger':\r\n                return props.theme.colors.danger700;\r\n            default:\r\n                return props.theme.colors.info700;\r\n        }\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success100;\r\n        case 'warning':\r\n            return props.theme.colors.warning100;\r\n        case 'danger':\r\n            return props.theme.colors.danger100;\r\n        default:\r\n            return props.theme.colors.info100;\r\n    }\r\n}\r\nexport function buildAlertBorder(props) {\r\n    if (props.isInverse) {\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return props.theme.colors.success300;\r\n            case 'warning':\r\n                return props.theme.colors.warning300;\r\n            case 'danger':\r\n                return props.theme.colors.danger200;\r\n            default:\r\n                return props.theme.colors.info300;\r\n        }\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success500;\r\n        case 'warning':\r\n            return props.theme.colors.warning500;\r\n        case 'danger':\r\n            return props.theme.colors.danger500;\r\n        default:\r\n            return props.theme.colors.info500;\r\n    }\r\n}\r\nexport function buildAlertColor(props) {\r\n    if (props.isInverse) {\r\n        return props.theme.colors.neutral100;\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success500;\r\n        case 'warning':\r\n            return props.theme.colors.warning500;\r\n        case 'danger':\r\n            return props.theme.colors.danger500;\r\n        default:\r\n            return props.theme.colors.info500;\r\n    }\r\n}\r\nexport function buildLinkColor(props) {\r\n    if (props.isInverse) {\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return props.theme.colors.success200;\r\n            case 'warning':\r\n                return props.theme.colors.warning200;\r\n            case 'danger':\r\n                return props.theme.colors.danger200;\r\n            default:\r\n                return props.theme.colors.info200;\r\n        }\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success700;\r\n        case 'warning':\r\n            return props.theme.colors.warning700;\r\n        case 'danger':\r\n            return props.theme.colors.danger700;\r\n        default:\r\n            return props.theme.colors.info700;\r\n    }\r\n}\r\nexport function buildLinkHoverColor(props) {\r\n    if (props.isInverse) {\r\n        return props.theme.colors.neutral100;\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success;\r\n        case 'warning':\r\n            return props.theme.colors.warning;\r\n        case 'danger':\r\n            return props.theme.colors.danger;\r\n        default:\r\n            return props.theme.colors.info;\r\n    }\r\n}\r\nconst StyledAlert = styled.div `\n  align-items: stretch;\n  animation: ${props => props.isExiting\r\n    ? `fadeout ${transitionDuration}ms`\r\n    : `fadein ${transitionDuration}ms`};\n  display: flex;\n  flex-direction: column;\n  font-size: ${props => props.theme.typeScale.size03.fontSize};\n  font-family: ${props => props.theme.bodyFont};\n  line-height: ${props => props.theme.typeScale.size03.lineHeight};\n  margin-bottom: ${props => props.theme.spaceScale.spacing06};\n  max-width: 100%;\n  padding: 0;\n  position: relative;\n\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    font-size: ${props => props.theme.typeScale.size02.fontSize};\n    letter-spacing: ${props => props.theme.typeScale.size02.letterSpacing};\n    line-height: ${props => props.theme.typeScale.size02.lineHeight};\n  }\n\n  &:focus {\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n  }\n\n  ${props => props.isToast &&\r\n    css `\n      animation: ${props.isExiting\r\n        ? `slideout ${transitionDuration}ms`\r\n        : `slidein ${transitionDuration}ms`};\n      min-width: 375px;\n      margin: 0 auto;\n\n      @media (max-width: ${props.theme.breakpoints.small}px) {\n        min-width: 0;\n        width: 100%;\n      }\n    `}\n\n  @keyframes fadein {\n    from {\n      opacity: 0;\n    }\n    to {\n      opacity: 1;\n    }\n  }\n\n  @keyframes fadeout {\n    from {\n      opacity: 1;\n    }\n    to {\n      opacity: 0;\n    }\n  }\n\n  @keyframes slidein {\n    from {\n      left: -500px;\n    }\n    to {\n      left: 0;\n    }\n  }\n\n  @keyframes slideout {\n    from {\n      left: 0;\n    }\n    to {\n      left: -500px;\n    }\n  }\n\n  a {\n    color: ${props => buildLinkColor(props)};\n    font-weight: 400;\n    text-decoration: underline;\n    &:not([disabled]) {\n      &:focus,\n      &:hover {\n        color: ${props => buildLinkHoverColor(props)};\n      }\n    }\n  }\n`;\r\nconst StyledAlertInner = styled.div `\n  background: ${buildAlertBackground};\n  border: 1px solid ${buildAlertBorder};\n  border-radius: ${props => props.theme.borderRadius};\n  color: ${buildAlertColor};\n  display: flex;\n  position: relative;\n\n  ${props => props.isToast &&\r\n    css `\n      box-shadow: ${props.isInverse\r\n        ? `0 2px 8px 0 ${transparentize(0.3, props.theme.colors.neutral900)}`\r\n        : `0 2px 8px 0 ${transparentize(0.6, props.theme.colors.neutral900)}`};\n      padding-right: 0;\n      height: ${props.theme.spaceScale.spacing11};\n    `}\n`;\r\nconst AlertContents = styled.div `\n  align-items: ${props => (props.additionalContent ? 'center' : '')};\n  align-self: center;\n  flex-grow: 1;\n  font-family: ${props => props.theme.bodyFont};\n  padding: ${props => props.theme.spaceScale.spacing04} 0;\n  display: ${props => (props.additionalContent ? 'flex' : '')};\n  margin-right: ${props => props.additionalContent && !props.isDismissible\r\n    ? props.theme.spaceScale.spacing03\r\n    : ''};\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    padding-left: 0;\n  }\n`;\r\nexport const AdditionalContentWrapper = styled.div `\n  flex: 1 0 auto;\n  justify-content: flex-end;\n  display: flex;\n  margin-left: ${props => props.theme.spaceScale.spacing05};\n`;\r\nconst IconWrapperStyles = css `\n  align-items: center;\n  display: flex;\n  flex-shrink: 0;\n  margin-right: 1px;\n`;\r\nconst IconWrapper = styled.span `\n  ${IconWrapperStyles}\n  padding: 0 ${props => props.theme.spaceScale.spacing03} 0 ${props => props.theme.spaceScale.spacing04};\n\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    padding: 0 ${props => props.theme.spaceScale.spacing03};\n    svg {\n      width: 20px;\n    }\n  }\n`;\r\nconst ProgressRingWrapper = styled.div `\n  margin-top: 6px;\n  position: absolute;\n  top: auto;\n  right: ${props => props.theme.spaceScale.spacing02};\n`;\r\nconst DismissibleIconWrapper = styled.span `\n  ${IconWrapperStyles}\n  margin-left: ${props => props.additionalContent ? props.theme.spaceScale.spacing03 : ''};\n`;\r\nconst whitelistProps = ['icon', 'isInverse', 'theme', 'variant'];\r\nconst shouldForwardProp = prop => {\r\n    return isPropValid(prop) || whitelistProps.includes(prop);\r\n};\r\nconst DismissButton = styled(IconButton, { shouldForwardProp }) `\n  align-self: stretch;\n  border-radius: 0 ${props => props.theme.borderRadius}\n    ${props => props.theme.borderRadius} 0;\n  color: inherit;\n  height: auto;\n  margin: ${props => (props.isToast ? '4px' : '0 -1px 0 0')};\n  padding: ${props => props.isToast\r\n    ? `0 ${props.theme.spaceScale.spacing04}`\r\n    : `0 ${props.theme.spaceScale.spacing03}`};\n  width: auto;\n  &:not(:disabled):hover {\n    background: none;\n    color: inherit;\n  }\n  &:focus:not(:disabled) {\n    background: none;\n    color: inherit;\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n    outline-offset: 0 !important;\n  }\n  &:not(:disabled):active {\n    background: none;\n    color: inherit;\n  }\n`;\r\nconst AlertSpan = styled.span `\n  white-space: pre-line;\n`;\r\nfunction renderIcon(variant = 'info', isToast, theme) {\r\n    const Icon = VARIANT_ICON[variant];\r\n    return (React.createElement(IconWrapper, { isToast: isToast, theme: theme },\r\n        React.createElement(Icon, { size: theme.iconSizes.medium })));\r\n}\r\nexport const AlertBase = React.forwardRef((props, ref) => {\r\n    const { additionalContent, children, closeAriaLabel, forceDismiss, hasTimerRing, id: defaultId, isDismissed, isDismissible, isExiting: externalIsExiting, isPaused, isToast, onDismiss, testId, toastDuration, variant, ...other } = props;\r\n    const id = useGenerateId(defaultId);\r\n    const [isExiting, setIsExiting] = React.useState(false);\r\n    const isInverse = useIsInverse(props.isInverse);\r\n    React.useEffect(() => {\r\n        if (isExiting) {\r\n            setTimeout(() => {\r\n                setIsExiting(false);\r\n                onDismiss && typeof onDismiss === 'function' && onDismiss();\r\n            }, transitionDuration - 300);\r\n        }\r\n    }, [isExiting]);\r\n    React.useEffect(() => {\r\n        if (isDismissed) {\r\n            handleDismiss();\r\n        }\r\n    }, [isDismissed]);\r\n    function handleDismiss() {\r\n        setIsExiting(true);\r\n    }\r\n    const theme = React.useContext(ThemeContext);\r\n    const i18n = React.useContext(I18nContext);\r\n    function progressRingColor() {\r\n        if (isInverse) {\r\n            return theme.colors.neutral100;\r\n        }\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return theme.colors.success500;\r\n            case 'warning':\r\n                return theme.colors.warning500;\r\n            case 'danger':\r\n                return theme.colors.danger500;\r\n            default:\r\n                return theme.colors.info500;\r\n        }\r\n    }\r\n    return (React.createElement(StyledAlert, Object.assign({}, other, { \"data-testid\": testId, id: id, tabIndex: -1, isInverse: isInverse, isExiting: isExiting, isToast: isToast, ref: ref, theme: theme, variant: variant }),\r\n        React.createElement(InverseContext.Provider, { value: { isInverse } },\r\n            React.createElement(StyledAlertInner, { isInverse: isInverse, isToast: isToast, theme: theme, variant: variant },\r\n                renderIcon(variant, isToast, theme),\r\n                React.createElement(AlertContents, { additionalContent: additionalContent, isDismissible: isDismissible, theme: theme },\r\n                    React.createElement(AlertSpan, null, children),\r\n                    additionalContent && (React.createElement(AdditionalContentWrapper, { theme: theme }, additionalContent))),\r\n                isDismissible && (React.createElement(DismissibleIconWrapper, { isInverse: isInverse, variant: variant, theme: theme },\r\n                    hasTimerRing && isToast && (React.createElement(ProgressRingWrapper, { theme: theme },\r\n                        React.createElement(ProgressRing, { color: progressRingColor(), isActive: !isPaused, duration: toastDuration }))),\r\n                    React.createElement(DismissButton, Object.assign({ alertVariant: variant }, (isToast\r\n                        ? { title: closeAriaLabel || i18n.alert.dismissAriaLabel }\r\n                        : {\r\n                            'aria-label': closeAriaLabel || i18n.alert.dismissAriaLabel,\r\n                        }), { icon: React.createElement(CloseIcon, { size: hasTimerRing\r\n                                ? theme.iconSizes.xSmall\r\n                                : theme.iconSizes.small }), isInverse: isInverse, isToast: isToast, onClick: forceDismiss || handleDismiss, theme: theme, variant: ButtonVariant.link }))))))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */"));
|
|
3634
|
-
}, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AA2NoC","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport isPropValid from '@emotion/is-prop-valid';\r\nimport { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport { InfoIcon, CheckCircleIcon, WarningIcon, ErrorIcon, CloseIcon, } from 'react-magma-icons';\r\nimport { I18nContext } from '../../i18n';\r\nimport { InverseContext, useIsInverse } from '../../inverse';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { useGenerateId } from '../../utils';\r\nimport { ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { ProgressRing } from '../ProgressRing';\r\nexport const VARIANT_ICON = {\r\n    info: InfoIcon,\r\n    success: CheckCircleIcon,\r\n    warning: WarningIcon,\r\n    danger: ErrorIcon,\r\n};\r\nexport var AlertVariant;\r\n(function (AlertVariant) {\r\n    AlertVariant[\"info\"] = \"info\";\r\n    AlertVariant[\"success\"] = \"success\";\r\n    AlertVariant[\"warning\"] = \"warning\";\r\n    AlertVariant[\"danger\"] = \"danger\";\r\n})(AlertVariant || (AlertVariant = {}));\r\nexport const transitionDuration = 500;\r\nexport function buildAlertBackground(props) {\r\n    if (props.isInverse) {\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return props.theme.colors.success700;\r\n            case 'warning':\r\n                return props.theme.colors.warning700;\r\n            case 'danger':\r\n                return props.theme.colors.danger700;\r\n            default:\r\n                return props.theme.colors.info700;\r\n        }\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success100;\r\n        case 'warning':\r\n            return props.theme.colors.warning100;\r\n        case 'danger':\r\n            return props.theme.colors.danger100;\r\n        default:\r\n            return props.theme.colors.info100;\r\n    }\r\n}\r\nexport function buildAlertBorder(props) {\r\n    if (props.isInverse) {\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return props.theme.colors.success300;\r\n            case 'warning':\r\n                return props.theme.colors.warning300;\r\n            case 'danger':\r\n                return props.theme.colors.danger200;\r\n            default:\r\n                return props.theme.colors.info300;\r\n        }\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success500;\r\n        case 'warning':\r\n            return props.theme.colors.warning500;\r\n        case 'danger':\r\n            return props.theme.colors.danger500;\r\n        default:\r\n            return props.theme.colors.info500;\r\n    }\r\n}\r\nexport function buildAlertColor(props) {\r\n    if (props.isInverse) {\r\n        return props.theme.colors.neutral100;\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success500;\r\n        case 'warning':\r\n            return props.theme.colors.warning500;\r\n        case 'danger':\r\n            return props.theme.colors.danger500;\r\n        default:\r\n            return props.theme.colors.info500;\r\n    }\r\n}\r\nexport function buildLinkColor(props) {\r\n    if (props.isInverse) {\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return props.theme.colors.success200;\r\n            case 'warning':\r\n                return props.theme.colors.warning200;\r\n            case 'danger':\r\n                return props.theme.colors.danger200;\r\n            default:\r\n                return props.theme.colors.info200;\r\n        }\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success700;\r\n        case 'warning':\r\n            return props.theme.colors.warning700;\r\n        case 'danger':\r\n            return props.theme.colors.danger700;\r\n        default:\r\n            return props.theme.colors.info700;\r\n    }\r\n}\r\nexport function buildLinkHoverColor(props) {\r\n    if (props.isInverse) {\r\n        return props.theme.colors.neutral100;\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success;\r\n        case 'warning':\r\n            return props.theme.colors.warning;\r\n        case 'danger':\r\n            return props.theme.colors.danger;\r\n        default:\r\n            return props.theme.colors.info;\r\n    }\r\n}\r\nconst StyledAlert = styled.div `\n  align-items: stretch;\n  animation: ${props => props.isExiting\r\n    ? `fadeout ${transitionDuration}ms`\r\n    : `fadein ${transitionDuration}ms`};\n  display: flex;\n  flex-direction: column;\n  font-size: ${props => props.theme.typeScale.size03.fontSize};\n  font-family: ${props => props.theme.bodyFont};\n  line-height: ${props => props.theme.typeScale.size03.lineHeight};\n  margin-bottom: ${props => props.theme.spaceScale.spacing06};\n  max-width: 100%;\n  padding: 0;\n  position: relative;\n\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    font-size: ${props => props.theme.typeScale.size02.fontSize};\n    letter-spacing: ${props => props.theme.typeScale.size02.letterSpacing};\n    line-height: ${props => props.theme.typeScale.size02.lineHeight};\n  }\n\n  &:focus {\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n  }\n\n  ${props => props.isToast &&\r\n    css `\n      animation: ${props.isExiting\r\n        ? `slideout ${transitionDuration}ms`\r\n        : `slidein ${transitionDuration}ms`};\n      min-width: 375px;\n      margin: 0 auto;\n\n      @media (max-width: ${props.theme.breakpoints.small}px) {\n        min-width: 0;\n        width: 100%;\n      }\n    `}\n\n  @keyframes fadein {\n    from {\n      opacity: 0;\n    }\n    to {\n      opacity: 1;\n    }\n  }\n\n  @keyframes fadeout {\n    from {\n      opacity: 1;\n    }\n    to {\n      opacity: 0;\n    }\n  }\n\n  @keyframes slidein {\n    from {\n      left: -500px;\n    }\n    to {\n      left: 0;\n    }\n  }\n\n  @keyframes slideout {\n    from {\n      left: 0;\n    }\n    to {\n      left: -500px;\n    }\n  }\n\n  a {\n    color: ${props => buildLinkColor(props)};\n    font-weight: 400;\n    text-decoration: underline;\n    &:not([disabled]) {\n      &:focus,\n      &:hover {\n        color: ${props => buildLinkHoverColor(props)};\n      }\n    }\n  }\n`;\r\nconst StyledAlertInner = styled.div `\n  background: ${buildAlertBackground};\n  border: 1px solid ${buildAlertBorder};\n  border-radius: ${props => props.theme.borderRadius};\n  color: ${buildAlertColor};\n  display: flex;\n  position: relative;\n\n  ${props => props.isToast &&\r\n    css `\n      box-shadow: ${props.isInverse\r\n        ? `0 2px 8px 0 ${transparentize(0.3, props.theme.colors.neutral900)}`\r\n        : `0 2px 8px 0 ${transparentize(0.6, props.theme.colors.neutral900)}`};\n      padding-right: 0;\n      height: ${props.theme.spaceScale.spacing11};\n    `}\n`;\r\nconst AlertContents = styled.div `\n  align-items: ${props => (props.additionalContent ? 'center' : '')};\n  align-self: center;\n  flex-grow: 1;\n  font-family: ${props => props.theme.bodyFont};\n  padding: ${props => props.theme.spaceScale.spacing04} 0;\n  display: ${props => (props.additionalContent ? 'flex' : '')};\n  margin-right: ${props => props.additionalContent && !props.isDismissible\r\n    ? props.theme.spaceScale.spacing03\r\n    : ''};\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    padding-left: 0;\n  }\n`;\r\nexport const AdditionalContentWrapper = styled.div `\n  flex: 1 0 auto;\n  justify-content: flex-end;\n  display: flex;\n  margin-left: ${props => props.theme.spaceScale.spacing05};\n`;\r\nconst IconWrapperStyles = css `\n  align-items: center;\n  display: flex;\n  flex-shrink: 0;\n  margin-right: 1px;\n`;\r\nconst IconWrapper = styled.span `\n  ${IconWrapperStyles}\n  padding: 0 ${props => props.theme.spaceScale.spacing03} 0 ${props => props.theme.spaceScale.spacing04};\n\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    padding: 0 ${props => props.theme.spaceScale.spacing03};\n    svg {\n      width: 20px;\n    }\n  }\n`;\r\nconst ProgressRingWrapper = styled.div `\n  margin-top: 6px;\n  position: absolute;\n  top: auto;\n  right: ${props => props.theme.spaceScale.spacing02};\n`;\r\nconst DismissibleIconWrapper = styled.span `\n  ${IconWrapperStyles}\n  margin-left: ${props => props.additionalContent ? props.theme.spaceScale.spacing03 : ''};\n`;\r\nconst whitelistProps = ['icon', 'isInverse', 'theme', 'variant'];\r\nconst shouldForwardProp = prop => {\r\n    return isPropValid(prop) || whitelistProps.includes(prop);\r\n};\r\nconst DismissButton = styled(IconButton, { shouldForwardProp }) `\n  align-self: stretch;\n  border-radius: 0 ${props => props.theme.borderRadius}\n    ${props => props.theme.borderRadius} 0;\n  color: inherit;\n  height: auto;\n  margin: ${props => (props.isToast ? '4px' : '0 -1px 0 0')};\n  padding: ${props => props.isToast\r\n    ? `0 ${props.theme.spaceScale.spacing04}`\r\n    : `0 ${props.theme.spaceScale.spacing03}`};\n  width: auto;\n  &:not(:disabled):hover {\n    background: none;\n    color: inherit;\n  }\n  &:focus:not(:disabled) {\n    background: none;\n    color: inherit;\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n    outline-offset: 0 !important;\n  }\n  &:not(:disabled):active {\n    background: none;\n    color: inherit;\n  }\n`;\r\nconst AlertSpan = styled.span `\n  white-space: pre-line;\n`;\r\nfunction renderIcon(variant = 'info', isToast, theme) {\r\n    const Icon = VARIANT_ICON[variant];\r\n    return (React.createElement(IconWrapper, { isToast: isToast, theme: theme },\r\n        React.createElement(Icon, { size: theme.iconSizes.medium })));\r\n}\r\nexport const AlertBase = React.forwardRef((props, ref) => {\r\n    const { additionalContent, children, closeAriaLabel, forceDismiss, hasTimerRing, id: defaultId, isDismissed, isDismissible, isExiting: externalIsExiting, isPaused, isToast, onDismiss, testId, toastDuration, variant, ...other } = props;\r\n    const id = useGenerateId(defaultId);\r\n    const [isExiting, setIsExiting] = React.useState(false);\r\n    const isInverse = useIsInverse(props.isInverse);\r\n    React.useEffect(() => {\r\n        if (isExiting) {\r\n            setTimeout(() => {\r\n                setIsExiting(false);\r\n                onDismiss && typeof onDismiss === 'function' && onDismiss();\r\n            }, transitionDuration - 300);\r\n        }\r\n    }, [isExiting]);\r\n    React.useEffect(() => {\r\n        if (isDismissed) {\r\n            handleDismiss();\r\n        }\r\n    }, [isDismissed]);\r\n    function handleDismiss() {\r\n        setIsExiting(true);\r\n    }\r\n    const theme = React.useContext(ThemeContext);\r\n    const i18n = React.useContext(I18nContext);\r\n    function progressRingColor() {\r\n        if (isInverse) {\r\n            return theme.colors.neutral100;\r\n        }\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return theme.colors.success500;\r\n            case 'warning':\r\n                return theme.colors.warning500;\r\n            case 'danger':\r\n                return theme.colors.danger500;\r\n            default:\r\n                return theme.colors.info500;\r\n        }\r\n    }\r\n    return (React.createElement(StyledAlert, Object.assign({}, other, { \"data-testid\": testId, id: id, tabIndex: -1, isInverse: isInverse, isExiting: isExiting, isToast: isToast, ref: ref, theme: theme, variant: variant }),\r\n        React.createElement(InverseContext.Provider, { value: { isInverse } },\r\n            React.createElement(StyledAlertInner, { isInverse: isInverse, isToast: isToast, theme: theme, variant: variant },\r\n                renderIcon(variant, isToast, theme),\r\n                React.createElement(AlertContents, { additionalContent: additionalContent, isDismissible: isDismissible, theme: theme },\r\n                    React.createElement(AlertSpan, null, children),\r\n                    additionalContent && (React.createElement(AdditionalContentWrapper, { theme: theme }, additionalContent))),\r\n                isDismissible && (React.createElement(DismissibleIconWrapper, { isInverse: isInverse, variant: variant, theme: theme },\r\n                    hasTimerRing && isToast && (React.createElement(ProgressRingWrapper, { theme: theme },\r\n                        React.createElement(ProgressRing, { color: progressRingColor(), isActive: !isPaused, duration: toastDuration }))),\r\n                    React.createElement(DismissButton, Object.assign({ alertVariant: variant }, (isToast\r\n                        ? { title: closeAriaLabel || i18n.alert.dismissAriaLabel }\r\n                        : {\r\n                            'aria-label': closeAriaLabel || i18n.alert.dismissAriaLabel,\r\n                        }), { icon: React.createElement(CloseIcon, { size: hasTimerRing\r\n                                ? theme.iconSizes.xSmall\r\n                                : theme.iconSizes.small }), isInverse: isInverse, isToast: isToast, onClick: forceDismiss || handleDismiss, theme: theme, variant: ButtonVariant.link }))))))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */"));
|
|
3639
|
+
return props.isToast && /*#__PURE__*/css("box-shadow:", props.isInverse ? "0 2px 8px 0 " + curriedTransparentize(0.3, props.theme.colors.neutral900) : "0 2px 8px 0 " + curriedTransparentize(0.6, props.theme.colors.neutral900), ";padding-right:0;height:", props.theme.spaceScale.spacing11, ";;label:StyledAlertInner;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAoOQ","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport isPropValid from '@emotion/is-prop-valid';\r\nimport { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport { InfoIcon, CheckCircleIcon, WarningIcon, ErrorIcon, CloseIcon, } from 'react-magma-icons';\r\nimport { I18nContext } from '../..';\r\nimport { InverseContext, useIsInverse } from '../../inverse';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { useGenerateId } from '../../utils';\r\nimport { ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { ProgressRing } from '../ProgressRing';\r\nexport const VARIANT_ICON = {\r\n    info: InfoIcon,\r\n    success: CheckCircleIcon,\r\n    warning: WarningIcon,\r\n    danger: ErrorIcon,\r\n};\r\nexport var AlertVariant;\r\n(function (AlertVariant) {\r\n    AlertVariant[\"info\"] = \"info\";\r\n    AlertVariant[\"success\"] = \"success\";\r\n    AlertVariant[\"warning\"] = \"warning\";\r\n    AlertVariant[\"danger\"] = \"danger\";\r\n})(AlertVariant || (AlertVariant = {}));\r\nexport const transitionDuration = 500;\r\nexport function buildAlertBackground(props) {\r\n    if (props.isInverse) {\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return props.theme.colors.success700;\r\n            case 'warning':\r\n                return props.theme.colors.warning700;\r\n            case 'danger':\r\n                return props.theme.colors.danger700;\r\n            default:\r\n                return props.theme.colors.info700;\r\n        }\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success100;\r\n        case 'warning':\r\n            return props.theme.colors.warning100;\r\n        case 'danger':\r\n            return props.theme.colors.danger100;\r\n        default:\r\n            return props.theme.colors.info100;\r\n    }\r\n}\r\nexport function buildAlertBorder(props) {\r\n    if (props.isInverse) {\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return props.theme.colors.success300;\r\n            case 'warning':\r\n                return props.theme.colors.warning300;\r\n            case 'danger':\r\n                return props.theme.colors.danger200;\r\n            default:\r\n                return props.theme.colors.info300;\r\n        }\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success500;\r\n        case 'warning':\r\n            return props.theme.colors.warning500;\r\n        case 'danger':\r\n            return props.theme.colors.danger500;\r\n        default:\r\n            return props.theme.colors.info500;\r\n    }\r\n}\r\nexport function buildAlertColor(props) {\r\n    if (props.isInverse) {\r\n        return props.theme.colors.neutral100;\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success500;\r\n        case 'warning':\r\n            return props.theme.colors.warning500;\r\n        case 'danger':\r\n            return props.theme.colors.danger500;\r\n        default:\r\n            return props.theme.colors.info500;\r\n    }\r\n}\r\nexport function buildLinkColor(props) {\r\n    if (props.isInverse) {\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return props.theme.colors.success200;\r\n            case 'warning':\r\n                return props.theme.colors.warning200;\r\n            case 'danger':\r\n                return props.theme.colors.danger200;\r\n            default:\r\n                return props.theme.colors.info200;\r\n        }\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success700;\r\n        case 'warning':\r\n            return props.theme.colors.warning700;\r\n        case 'danger':\r\n            return props.theme.colors.danger700;\r\n        default:\r\n            return props.theme.colors.info700;\r\n    }\r\n}\r\nexport function buildLinkHoverColor(props) {\r\n    if (props.isInverse) {\r\n        return props.theme.colors.neutral100;\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success;\r\n        case 'warning':\r\n            return props.theme.colors.warning;\r\n        case 'danger':\r\n            return props.theme.colors.danger;\r\n        default:\r\n            return props.theme.colors.info;\r\n    }\r\n}\r\nconst StyledAlert = styled.div `\n  align-items: stretch;\n  animation: ${props => props.isExiting\r\n    ? `fadeout ${transitionDuration}ms`\r\n    : `fadein ${transitionDuration}ms`};\n  display: flex;\n  flex-direction: column;\n  font-size: ${props => props.theme.typeScale.size03.fontSize};\n  font-family: ${props => props.theme.bodyFont};\n  line-height: ${props => props.theme.typeScale.size03.lineHeight};\n  margin-bottom: ${props => props.theme.spaceScale.spacing06};\n  max-width: 100%;\n  padding: 0;\n  position: relative;\n\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    font-size: ${props => props.theme.typeScale.size02.fontSize};\n    letter-spacing: ${props => props.theme.typeScale.size02.letterSpacing};\n    line-height: ${props => props.theme.typeScale.size02.lineHeight};\n  }\n\n  &:focus {\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n  }\n\n  ${props => props.isToast &&\r\n    css `\n      animation: ${props.isExiting\r\n        ? `slideout ${transitionDuration}ms`\r\n        : `slidein ${transitionDuration}ms`};\n      min-width: 375px;\n      margin: 0 auto;\n\n      @media (max-width: ${props.theme.breakpoints.small}px) {\n        min-width: 0;\n        width: 100%;\n      }\n    `}\n\n  @keyframes fadein {\n    from {\n      opacity: 0;\n    }\n    to {\n      opacity: 1;\n    }\n  }\n\n  @keyframes fadeout {\n    from {\n      opacity: 1;\n    }\n    to {\n      opacity: 0;\n    }\n  }\n\n  @keyframes slidein {\n    from {\n      left: -500px;\n    }\n    to {\n      left: 0;\n    }\n  }\n\n  @keyframes slideout {\n    from {\n      left: 0;\n    }\n    to {\n      left: -500px;\n    }\n  }\n\n  a {\n    color: ${props => buildLinkColor(props)};\n    font-weight: 400;\n    text-decoration: underline;\n    &:not([disabled]) {\n      &:focus,\n      &:hover {\n        color: ${props => buildLinkHoverColor(props)};\n      }\n    }\n  }\n`;\r\nconst StyledAlertInner = styled.div `\n  background: ${buildAlertBackground};\n  border: 1px solid ${buildAlertBorder};\n  border-radius: ${props => props.theme.borderRadius};\n  color: ${buildAlertColor};\n  display: flex;\n  position: relative;\n\n  ${props => props.isToast &&\r\n    css `\n      box-shadow: ${props.isInverse\r\n        ? `0 2px 8px 0 ${transparentize(0.3, props.theme.colors.neutral900)}`\r\n        : `0 2px 8px 0 ${transparentize(0.6, props.theme.colors.neutral900)}`};\n      padding-right: 0;\n      height: ${props.theme.spaceScale.spacing11};\n    `}\n`;\r\nconst AlertContents = styled.div `\n  align-items: ${props => (props.additionalContent ? 'center' : '')};\n  align-self: center;\n  flex-grow: 1;\n  font-family: ${props => props.theme.bodyFont};\n  padding: ${props => props.theme.spaceScale.spacing04} 0;\n  display: ${props => (props.additionalContent ? 'flex' : '')};\n  margin-right: ${props => props.additionalContent && !props.isDismissible\r\n    ? props.theme.spaceScale.spacing03\r\n    : ''};\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    padding-left: 0;\n  }\n`;\r\nexport const AdditionalContentWrapper = styled.div `\n  flex: 1 0 auto;\n  justify-content: flex-end;\n  display: flex;\n  margin-left: ${props => props.theme.spaceScale.spacing05};\n`;\r\nconst IconWrapperStyles = css `\n  align-items: center;\n  display: flex;\n  flex-shrink: 0;\n  margin-right: 1px;\n`;\r\nconst IconWrapper = styled.span `\n  ${IconWrapperStyles}\n  padding: 0 ${props => props.theme.spaceScale.spacing03} 0 ${props => props.theme.spaceScale.spacing04};\n\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    padding: 0 ${props => props.theme.spaceScale.spacing03};\n    svg {\n      width: 20px;\n    }\n  }\n`;\r\nconst ProgressRingWrapper = styled.div `\n  margin-top: 6px;\n  position: absolute;\n  top: auto;\n  right: ${props => props.theme.spaceScale.spacing02};\n`;\r\nconst DismissibleIconWrapper = styled.span `\n  ${IconWrapperStyles}\n  margin-left: ${props => props.additionalContent ? props.theme.spaceScale.spacing03 : ''};\n`;\r\nconst whitelistProps = ['icon', 'isInverse', 'theme', 'variant'];\r\nconst shouldForwardProp = prop => {\r\n    return isPropValid(prop) || whitelistProps.includes(prop);\r\n};\r\nconst DismissButton = styled(IconButton, { shouldForwardProp }) `\n  align-self: stretch;\n  border-radius: 0 ${props => props.theme.borderRadius}\n    ${props => props.theme.borderRadius} 0;\n  color: inherit;\n  height: auto;\n  margin: ${props => (props.isToast ? '4px' : '0 -1px 0 0')};\n  padding: ${props => props.isToast\r\n    ? `0 ${props.theme.spaceScale.spacing04}`\r\n    : `0 ${props.theme.spaceScale.spacing03}`};\n  width: auto;\n  &:not(:disabled):hover {\n    background: none;\n    color: inherit;\n  }\n  &:focus:not(:disabled) {\n    background: none;\n    color: inherit;\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n    outline-offset: 0 !important;\n  }\n  &:not(:disabled):active {\n    background: none;\n    color: inherit;\n  }\n`;\r\nconst AlertSpan = styled.span `\n  white-space: pre-line;\n`;\r\nfunction getAriaLabelIcon(variant, i18n) {\r\n    switch (variant) {\r\n        case 'success':\r\n            return i18n.alertVariants.success;\r\n        case 'warning':\r\n            return i18n.alertVariants.warning;\r\n        case 'danger':\r\n            return i18n.alertVariants.danger;\r\n        default:\r\n            return i18n.alertVariants.info;\r\n    }\r\n}\r\nfunction renderIcon(variant = 'info', isToast, theme, i18n) {\r\n    const Icon = VARIANT_ICON[variant];\r\n    return (React.createElement(IconWrapper, { \"aria-label\": getAriaLabelIcon(variant, i18n), role: \"img\", isToast: isToast, theme: theme },\r\n        React.createElement(Icon, { size: theme.iconSizes.medium })));\r\n}\r\nexport const AlertBase = React.forwardRef((props, ref) => {\r\n    const { additionalContent, children, closeAriaLabel, forceDismiss, hasTimerRing, id: defaultId, isDismissed, isDismissible, isExiting: externalIsExiting, isPaused, isToast, onDismiss, testId, toastDuration, variant, ...other } = props;\r\n    const id = useGenerateId(defaultId);\r\n    const [isExiting, setIsExiting] = React.useState(false);\r\n    const isInverse = useIsInverse(props.isInverse);\r\n    React.useEffect(() => {\r\n        if (isExiting) {\r\n            setTimeout(() => {\r\n                setIsExiting(false);\r\n                onDismiss && typeof onDismiss === 'function' && onDismiss();\r\n            }, transitionDuration - 300);\r\n        }\r\n    }, [isExiting]);\r\n    React.useEffect(() => {\r\n        if (isDismissed) {\r\n            handleDismiss();\r\n        }\r\n    }, [isDismissed]);\r\n    function handleDismiss() {\r\n        setIsExiting(true);\r\n    }\r\n    const theme = React.useContext(ThemeContext);\r\n    const i18n = React.useContext(I18nContext);\r\n    function progressRingColor() {\r\n        if (isInverse) {\r\n            return theme.colors.neutral100;\r\n        }\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return theme.colors.success500;\r\n            case 'warning':\r\n                return theme.colors.warning500;\r\n            case 'danger':\r\n                return theme.colors.danger500;\r\n            default:\r\n                return theme.colors.info500;\r\n        }\r\n    }\r\n    return (React.createElement(StyledAlert, Object.assign({}, other, { \"data-testid\": testId, id: id, tabIndex: -1, isInverse: isInverse, isExiting: isExiting, isToast: isToast, ref: ref, theme: theme, variant: variant }),\r\n        React.createElement(InverseContext.Provider, { value: { isInverse } },\r\n            React.createElement(StyledAlertInner, { isInverse: isInverse, isToast: isToast, theme: theme, variant: variant },\r\n                renderIcon(variant, isToast, theme, i18n),\r\n                React.createElement(AlertContents, { additionalContent: additionalContent, isDismissible: isDismissible, theme: theme },\r\n                    React.createElement(AlertSpan, null, children),\r\n                    additionalContent && (React.createElement(AdditionalContentWrapper, { theme: theme }, additionalContent))),\r\n                isDismissible && (React.createElement(DismissibleIconWrapper, { isInverse: isInverse, variant: variant, theme: theme },\r\n                    hasTimerRing && isToast && (React.createElement(ProgressRingWrapper, { theme: theme },\r\n                        React.createElement(ProgressRing, { color: progressRingColor(), isActive: !isPaused, duration: toastDuration }))),\r\n                    React.createElement(DismissButton, Object.assign({ alertVariant: variant }, (isToast\r\n                        ? { title: closeAriaLabel || i18n.alert.dismissAriaLabel }\r\n                        : {\r\n                            'aria-label': closeAriaLabel || i18n.alert.dismissAriaLabel,\r\n                        }), { icon: React.createElement(CloseIcon, { size: hasTimerRing\r\n                                ? theme.iconSizes.xSmall\r\n                                : theme.iconSizes.small }), isInverse: isInverse, isToast: isToast, onClick: forceDismiss || handleDismiss, theme: theme, variant: ButtonVariant.link }))))))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */"));
|
|
3640
|
+
}, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AA2NoC","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport isPropValid from '@emotion/is-prop-valid';\r\nimport { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport { InfoIcon, CheckCircleIcon, WarningIcon, ErrorIcon, CloseIcon, } from 'react-magma-icons';\r\nimport { I18nContext } from '../..';\r\nimport { InverseContext, useIsInverse } from '../../inverse';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { useGenerateId } from '../../utils';\r\nimport { ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { ProgressRing } from '../ProgressRing';\r\nexport const VARIANT_ICON = {\r\n    info: InfoIcon,\r\n    success: CheckCircleIcon,\r\n    warning: WarningIcon,\r\n    danger: ErrorIcon,\r\n};\r\nexport var AlertVariant;\r\n(function (AlertVariant) {\r\n    AlertVariant[\"info\"] = \"info\";\r\n    AlertVariant[\"success\"] = \"success\";\r\n    AlertVariant[\"warning\"] = \"warning\";\r\n    AlertVariant[\"danger\"] = \"danger\";\r\n})(AlertVariant || (AlertVariant = {}));\r\nexport const transitionDuration = 500;\r\nexport function buildAlertBackground(props) {\r\n    if (props.isInverse) {\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return props.theme.colors.success700;\r\n            case 'warning':\r\n                return props.theme.colors.warning700;\r\n            case 'danger':\r\n                return props.theme.colors.danger700;\r\n            default:\r\n                return props.theme.colors.info700;\r\n        }\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success100;\r\n        case 'warning':\r\n            return props.theme.colors.warning100;\r\n        case 'danger':\r\n            return props.theme.colors.danger100;\r\n        default:\r\n            return props.theme.colors.info100;\r\n    }\r\n}\r\nexport function buildAlertBorder(props) {\r\n    if (props.isInverse) {\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return props.theme.colors.success300;\r\n            case 'warning':\r\n                return props.theme.colors.warning300;\r\n            case 'danger':\r\n                return props.theme.colors.danger200;\r\n            default:\r\n                return props.theme.colors.info300;\r\n        }\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success500;\r\n        case 'warning':\r\n            return props.theme.colors.warning500;\r\n        case 'danger':\r\n            return props.theme.colors.danger500;\r\n        default:\r\n            return props.theme.colors.info500;\r\n    }\r\n}\r\nexport function buildAlertColor(props) {\r\n    if (props.isInverse) {\r\n        return props.theme.colors.neutral100;\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success500;\r\n        case 'warning':\r\n            return props.theme.colors.warning500;\r\n        case 'danger':\r\n            return props.theme.colors.danger500;\r\n        default:\r\n            return props.theme.colors.info500;\r\n    }\r\n}\r\nexport function buildLinkColor(props) {\r\n    if (props.isInverse) {\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return props.theme.colors.success200;\r\n            case 'warning':\r\n                return props.theme.colors.warning200;\r\n            case 'danger':\r\n                return props.theme.colors.danger200;\r\n            default:\r\n                return props.theme.colors.info200;\r\n        }\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success700;\r\n        case 'warning':\r\n            return props.theme.colors.warning700;\r\n        case 'danger':\r\n            return props.theme.colors.danger700;\r\n        default:\r\n            return props.theme.colors.info700;\r\n    }\r\n}\r\nexport function buildLinkHoverColor(props) {\r\n    if (props.isInverse) {\r\n        return props.theme.colors.neutral100;\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success;\r\n        case 'warning':\r\n            return props.theme.colors.warning;\r\n        case 'danger':\r\n            return props.theme.colors.danger;\r\n        default:\r\n            return props.theme.colors.info;\r\n    }\r\n}\r\nconst StyledAlert = styled.div `\n  align-items: stretch;\n  animation: ${props => props.isExiting\r\n    ? `fadeout ${transitionDuration}ms`\r\n    : `fadein ${transitionDuration}ms`};\n  display: flex;\n  flex-direction: column;\n  font-size: ${props => props.theme.typeScale.size03.fontSize};\n  font-family: ${props => props.theme.bodyFont};\n  line-height: ${props => props.theme.typeScale.size03.lineHeight};\n  margin-bottom: ${props => props.theme.spaceScale.spacing06};\n  max-width: 100%;\n  padding: 0;\n  position: relative;\n\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    font-size: ${props => props.theme.typeScale.size02.fontSize};\n    letter-spacing: ${props => props.theme.typeScale.size02.letterSpacing};\n    line-height: ${props => props.theme.typeScale.size02.lineHeight};\n  }\n\n  &:focus {\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n  }\n\n  ${props => props.isToast &&\r\n    css `\n      animation: ${props.isExiting\r\n        ? `slideout ${transitionDuration}ms`\r\n        : `slidein ${transitionDuration}ms`};\n      min-width: 375px;\n      margin: 0 auto;\n\n      @media (max-width: ${props.theme.breakpoints.small}px) {\n        min-width: 0;\n        width: 100%;\n      }\n    `}\n\n  @keyframes fadein {\n    from {\n      opacity: 0;\n    }\n    to {\n      opacity: 1;\n    }\n  }\n\n  @keyframes fadeout {\n    from {\n      opacity: 1;\n    }\n    to {\n      opacity: 0;\n    }\n  }\n\n  @keyframes slidein {\n    from {\n      left: -500px;\n    }\n    to {\n      left: 0;\n    }\n  }\n\n  @keyframes slideout {\n    from {\n      left: 0;\n    }\n    to {\n      left: -500px;\n    }\n  }\n\n  a {\n    color: ${props => buildLinkColor(props)};\n    font-weight: 400;\n    text-decoration: underline;\n    &:not([disabled]) {\n      &:focus,\n      &:hover {\n        color: ${props => buildLinkHoverColor(props)};\n      }\n    }\n  }\n`;\r\nconst StyledAlertInner = styled.div `\n  background: ${buildAlertBackground};\n  border: 1px solid ${buildAlertBorder};\n  border-radius: ${props => props.theme.borderRadius};\n  color: ${buildAlertColor};\n  display: flex;\n  position: relative;\n\n  ${props => props.isToast &&\r\n    css `\n      box-shadow: ${props.isInverse\r\n        ? `0 2px 8px 0 ${transparentize(0.3, props.theme.colors.neutral900)}`\r\n        : `0 2px 8px 0 ${transparentize(0.6, props.theme.colors.neutral900)}`};\n      padding-right: 0;\n      height: ${props.theme.spaceScale.spacing11};\n    `}\n`;\r\nconst AlertContents = styled.div `\n  align-items: ${props => (props.additionalContent ? 'center' : '')};\n  align-self: center;\n  flex-grow: 1;\n  font-family: ${props => props.theme.bodyFont};\n  padding: ${props => props.theme.spaceScale.spacing04} 0;\n  display: ${props => (props.additionalContent ? 'flex' : '')};\n  margin-right: ${props => props.additionalContent && !props.isDismissible\r\n    ? props.theme.spaceScale.spacing03\r\n    : ''};\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    padding-left: 0;\n  }\n`;\r\nexport const AdditionalContentWrapper = styled.div `\n  flex: 1 0 auto;\n  justify-content: flex-end;\n  display: flex;\n  margin-left: ${props => props.theme.spaceScale.spacing05};\n`;\r\nconst IconWrapperStyles = css `\n  align-items: center;\n  display: flex;\n  flex-shrink: 0;\n  margin-right: 1px;\n`;\r\nconst IconWrapper = styled.span `\n  ${IconWrapperStyles}\n  padding: 0 ${props => props.theme.spaceScale.spacing03} 0 ${props => props.theme.spaceScale.spacing04};\n\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    padding: 0 ${props => props.theme.spaceScale.spacing03};\n    svg {\n      width: 20px;\n    }\n  }\n`;\r\nconst ProgressRingWrapper = styled.div `\n  margin-top: 6px;\n  position: absolute;\n  top: auto;\n  right: ${props => props.theme.spaceScale.spacing02};\n`;\r\nconst DismissibleIconWrapper = styled.span `\n  ${IconWrapperStyles}\n  margin-left: ${props => props.additionalContent ? props.theme.spaceScale.spacing03 : ''};\n`;\r\nconst whitelistProps = ['icon', 'isInverse', 'theme', 'variant'];\r\nconst shouldForwardProp = prop => {\r\n    return isPropValid(prop) || whitelistProps.includes(prop);\r\n};\r\nconst DismissButton = styled(IconButton, { shouldForwardProp }) `\n  align-self: stretch;\n  border-radius: 0 ${props => props.theme.borderRadius}\n    ${props => props.theme.borderRadius} 0;\n  color: inherit;\n  height: auto;\n  margin: ${props => (props.isToast ? '4px' : '0 -1px 0 0')};\n  padding: ${props => props.isToast\r\n    ? `0 ${props.theme.spaceScale.spacing04}`\r\n    : `0 ${props.theme.spaceScale.spacing03}`};\n  width: auto;\n  &:not(:disabled):hover {\n    background: none;\n    color: inherit;\n  }\n  &:focus:not(:disabled) {\n    background: none;\n    color: inherit;\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n    outline-offset: 0 !important;\n  }\n  &:not(:disabled):active {\n    background: none;\n    color: inherit;\n  }\n`;\r\nconst AlertSpan = styled.span `\n  white-space: pre-line;\n`;\r\nfunction getAriaLabelIcon(variant, i18n) {\r\n    switch (variant) {\r\n        case 'success':\r\n            return i18n.alertVariants.success;\r\n        case 'warning':\r\n            return i18n.alertVariants.warning;\r\n        case 'danger':\r\n            return i18n.alertVariants.danger;\r\n        default:\r\n            return i18n.alertVariants.info;\r\n    }\r\n}\r\nfunction renderIcon(variant = 'info', isToast, theme, i18n) {\r\n    const Icon = VARIANT_ICON[variant];\r\n    return (React.createElement(IconWrapper, { \"aria-label\": getAriaLabelIcon(variant, i18n), role: \"img\", isToast: isToast, theme: theme },\r\n        React.createElement(Icon, { size: theme.iconSizes.medium })));\r\n}\r\nexport const AlertBase = React.forwardRef((props, ref) => {\r\n    const { additionalContent, children, closeAriaLabel, forceDismiss, hasTimerRing, id: defaultId, isDismissed, isDismissible, isExiting: externalIsExiting, isPaused, isToast, onDismiss, testId, toastDuration, variant, ...other } = props;\r\n    const id = useGenerateId(defaultId);\r\n    const [isExiting, setIsExiting] = React.useState(false);\r\n    const isInverse = useIsInverse(props.isInverse);\r\n    React.useEffect(() => {\r\n        if (isExiting) {\r\n            setTimeout(() => {\r\n                setIsExiting(false);\r\n                onDismiss && typeof onDismiss === 'function' && onDismiss();\r\n            }, transitionDuration - 300);\r\n        }\r\n    }, [isExiting]);\r\n    React.useEffect(() => {\r\n        if (isDismissed) {\r\n            handleDismiss();\r\n        }\r\n    }, [isDismissed]);\r\n    function handleDismiss() {\r\n        setIsExiting(true);\r\n    }\r\n    const theme = React.useContext(ThemeContext);\r\n    const i18n = React.useContext(I18nContext);\r\n    function progressRingColor() {\r\n        if (isInverse) {\r\n            return theme.colors.neutral100;\r\n        }\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return theme.colors.success500;\r\n            case 'warning':\r\n                return theme.colors.warning500;\r\n            case 'danger':\r\n                return theme.colors.danger500;\r\n            default:\r\n                return theme.colors.info500;\r\n        }\r\n    }\r\n    return (React.createElement(StyledAlert, Object.assign({}, other, { \"data-testid\": testId, id: id, tabIndex: -1, isInverse: isInverse, isExiting: isExiting, isToast: isToast, ref: ref, theme: theme, variant: variant }),\r\n        React.createElement(InverseContext.Provider, { value: { isInverse } },\r\n            React.createElement(StyledAlertInner, { isInverse: isInverse, isToast: isToast, theme: theme, variant: variant },\r\n                renderIcon(variant, isToast, theme, i18n),\r\n                React.createElement(AlertContents, { additionalContent: additionalContent, isDismissible: isDismissible, theme: theme },\r\n                    React.createElement(AlertSpan, null, children),\r\n                    additionalContent && (React.createElement(AdditionalContentWrapper, { theme: theme }, additionalContent))),\r\n                isDismissible && (React.createElement(DismissibleIconWrapper, { isInverse: isInverse, variant: variant, theme: theme },\r\n                    hasTimerRing && isToast && (React.createElement(ProgressRingWrapper, { theme: theme },\r\n                        React.createElement(ProgressRing, { color: progressRingColor(), isActive: !isPaused, duration: toastDuration }))),\r\n                    React.createElement(DismissButton, Object.assign({ alertVariant: variant }, (isToast\r\n                        ? { title: closeAriaLabel || i18n.alert.dismissAriaLabel }\r\n                        : {\r\n                            'aria-label': closeAriaLabel || i18n.alert.dismissAriaLabel,\r\n                        }), { icon: React.createElement(CloseIcon, { size: hasTimerRing\r\n                                ? theme.iconSizes.xSmall\r\n                                : theme.iconSizes.small }), isInverse: isInverse, isToast: isToast, onClick: forceDismiss || handleDismiss, theme: theme, variant: ButtonVariant.link }))))))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */"));
|
|
3635
3641
|
var AlertContents = /*#__PURE__*/_styled("div", {
|
|
3636
3642
|
target: "e126n3g86",
|
|
3637
3643
|
label: "AlertContents"
|
|
@@ -3647,19 +3653,19 @@ var AlertContents = /*#__PURE__*/_styled("div", {
|
|
|
3647
3653
|
return props.additionalContent && !props.isDismissible ? props.theme.spaceScale.spacing03 : '';
|
|
3648
3654
|
}, ";@media (max-width: ", function (props) {
|
|
3649
3655
|
return props.theme.breakpoints.small;
|
|
3650
|
-
}, "px){padding-left:0;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AA4OiC","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport isPropValid from '@emotion/is-prop-valid';\r\nimport { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport { InfoIcon, CheckCircleIcon, WarningIcon, ErrorIcon, CloseIcon, } from 'react-magma-icons';\r\nimport { I18nContext } from '../../i18n';\r\nimport { InverseContext, useIsInverse } from '../../inverse';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { useGenerateId } from '../../utils';\r\nimport { ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { ProgressRing } from '../ProgressRing';\r\nexport const VARIANT_ICON = {\r\n    info: InfoIcon,\r\n    success: CheckCircleIcon,\r\n    warning: WarningIcon,\r\n    danger: ErrorIcon,\r\n};\r\nexport var AlertVariant;\r\n(function (AlertVariant) {\r\n    AlertVariant[\"info\"] = \"info\";\r\n    AlertVariant[\"success\"] = \"success\";\r\n    AlertVariant[\"warning\"] = \"warning\";\r\n    AlertVariant[\"danger\"] = \"danger\";\r\n})(AlertVariant || (AlertVariant = {}));\r\nexport const transitionDuration = 500;\r\nexport function buildAlertBackground(props) {\r\n    if (props.isInverse) {\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return props.theme.colors.success700;\r\n            case 'warning':\r\n                return props.theme.colors.warning700;\r\n            case 'danger':\r\n                return props.theme.colors.danger700;\r\n            default:\r\n                return props.theme.colors.info700;\r\n        }\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success100;\r\n        case 'warning':\r\n            return props.theme.colors.warning100;\r\n        case 'danger':\r\n            return props.theme.colors.danger100;\r\n        default:\r\n            return props.theme.colors.info100;\r\n    }\r\n}\r\nexport function buildAlertBorder(props) {\r\n    if (props.isInverse) {\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return props.theme.colors.success300;\r\n            case 'warning':\r\n                return props.theme.colors.warning300;\r\n            case 'danger':\r\n                return props.theme.colors.danger200;\r\n            default:\r\n                return props.theme.colors.info300;\r\n        }\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success500;\r\n        case 'warning':\r\n            return props.theme.colors.warning500;\r\n        case 'danger':\r\n            return props.theme.colors.danger500;\r\n        default:\r\n            return props.theme.colors.info500;\r\n    }\r\n}\r\nexport function buildAlertColor(props) {\r\n    if (props.isInverse) {\r\n        return props.theme.colors.neutral100;\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success500;\r\n        case 'warning':\r\n            return props.theme.colors.warning500;\r\n        case 'danger':\r\n            return props.theme.colors.danger500;\r\n        default:\r\n            return props.theme.colors.info500;\r\n    }\r\n}\r\nexport function buildLinkColor(props) {\r\n    if (props.isInverse) {\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return props.theme.colors.success200;\r\n            case 'warning':\r\n                return props.theme.colors.warning200;\r\n            case 'danger':\r\n                return props.theme.colors.danger200;\r\n            default:\r\n                return props.theme.colors.info200;\r\n        }\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success700;\r\n        case 'warning':\r\n            return props.theme.colors.warning700;\r\n        case 'danger':\r\n            return props.theme.colors.danger700;\r\n        default:\r\n            return props.theme.colors.info700;\r\n    }\r\n}\r\nexport function buildLinkHoverColor(props) {\r\n    if (props.isInverse) {\r\n        return props.theme.colors.neutral100;\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success;\r\n        case 'warning':\r\n            return props.theme.colors.warning;\r\n        case 'danger':\r\n            return props.theme.colors.danger;\r\n        default:\r\n            return props.theme.colors.info;\r\n    }\r\n}\r\nconst StyledAlert = styled.div `\n  align-items: stretch;\n  animation: ${props => props.isExiting\r\n    ? `fadeout ${transitionDuration}ms`\r\n    : `fadein ${transitionDuration}ms`};\n  display: flex;\n  flex-direction: column;\n  font-size: ${props => props.theme.typeScale.size03.fontSize};\n  font-family: ${props => props.theme.bodyFont};\n  line-height: ${props => props.theme.typeScale.size03.lineHeight};\n  margin-bottom: ${props => props.theme.spaceScale.spacing06};\n  max-width: 100%;\n  padding: 0;\n  position: relative;\n\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    font-size: ${props => props.theme.typeScale.size02.fontSize};\n    letter-spacing: ${props => props.theme.typeScale.size02.letterSpacing};\n    line-height: ${props => props.theme.typeScale.size02.lineHeight};\n  }\n\n  &:focus {\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n  }\n\n  ${props => props.isToast &&\r\n    css `\n      animation: ${props.isExiting\r\n        ? `slideout ${transitionDuration}ms`\r\n        : `slidein ${transitionDuration}ms`};\n      min-width: 375px;\n      margin: 0 auto;\n\n      @media (max-width: ${props.theme.breakpoints.small}px) {\n        min-width: 0;\n        width: 100%;\n      }\n    `}\n\n  @keyframes fadein {\n    from {\n      opacity: 0;\n    }\n    to {\n      opacity: 1;\n    }\n  }\n\n  @keyframes fadeout {\n    from {\n      opacity: 1;\n    }\n    to {\n      opacity: 0;\n    }\n  }\n\n  @keyframes slidein {\n    from {\n      left: -500px;\n    }\n    to {\n      left: 0;\n    }\n  }\n\n  @keyframes slideout {\n    from {\n      left: 0;\n    }\n    to {\n      left: -500px;\n    }\n  }\n\n  a {\n    color: ${props => buildLinkColor(props)};\n    font-weight: 400;\n    text-decoration: underline;\n    &:not([disabled]) {\n      &:focus,\n      &:hover {\n        color: ${props => buildLinkHoverColor(props)};\n      }\n    }\n  }\n`;\r\nconst StyledAlertInner = styled.div `\n  background: ${buildAlertBackground};\n  border: 1px solid ${buildAlertBorder};\n  border-radius: ${props => props.theme.borderRadius};\n  color: ${buildAlertColor};\n  display: flex;\n  position: relative;\n\n  ${props => props.isToast &&\r\n    css `\n      box-shadow: ${props.isInverse\r\n        ? `0 2px 8px 0 ${transparentize(0.3, props.theme.colors.neutral900)}`\r\n        : `0 2px 8px 0 ${transparentize(0.6, props.theme.colors.neutral900)}`};\n      padding-right: 0;\n      height: ${props.theme.spaceScale.spacing11};\n    `}\n`;\r\nconst AlertContents = styled.div `\n  align-items: ${props => (props.additionalContent ? 'center' : '')};\n  align-self: center;\n  flex-grow: 1;\n  font-family: ${props => props.theme.bodyFont};\n  padding: ${props => props.theme.spaceScale.spacing04} 0;\n  display: ${props => (props.additionalContent ? 'flex' : '')};\n  margin-right: ${props => props.additionalContent && !props.isDismissible\r\n    ? props.theme.spaceScale.spacing03\r\n    : ''};\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    padding-left: 0;\n  }\n`;\r\nexport const AdditionalContentWrapper = styled.div `\n  flex: 1 0 auto;\n  justify-content: flex-end;\n  display: flex;\n  margin-left: ${props => props.theme.spaceScale.spacing05};\n`;\r\nconst IconWrapperStyles = css `\n  align-items: center;\n  display: flex;\n  flex-shrink: 0;\n  margin-right: 1px;\n`;\r\nconst IconWrapper = styled.span `\n  ${IconWrapperStyles}\n  padding: 0 ${props => props.theme.spaceScale.spacing03} 0 ${props => props.theme.spaceScale.spacing04};\n\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    padding: 0 ${props => props.theme.spaceScale.spacing03};\n    svg {\n      width: 20px;\n    }\n  }\n`;\r\nconst ProgressRingWrapper = styled.div `\n  margin-top: 6px;\n  position: absolute;\n  top: auto;\n  right: ${props => props.theme.spaceScale.spacing02};\n`;\r\nconst DismissibleIconWrapper = styled.span `\n  ${IconWrapperStyles}\n  margin-left: ${props => props.additionalContent ? props.theme.spaceScale.spacing03 : ''};\n`;\r\nconst whitelistProps = ['icon', 'isInverse', 'theme', 'variant'];\r\nconst shouldForwardProp = prop => {\r\n    return isPropValid(prop) || whitelistProps.includes(prop);\r\n};\r\nconst DismissButton = styled(IconButton, { shouldForwardProp }) `\n  align-self: stretch;\n  border-radius: 0 ${props => props.theme.borderRadius}\n    ${props => props.theme.borderRadius} 0;\n  color: inherit;\n  height: auto;\n  margin: ${props => (props.isToast ? '4px' : '0 -1px 0 0')};\n  padding: ${props => props.isToast\r\n    ? `0 ${props.theme.spaceScale.spacing04}`\r\n    : `0 ${props.theme.spaceScale.spacing03}`};\n  width: auto;\n  &:not(:disabled):hover {\n    background: none;\n    color: inherit;\n  }\n  &:focus:not(:disabled) {\n    background: none;\n    color: inherit;\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n    outline-offset: 0 !important;\n  }\n  &:not(:disabled):active {\n    background: none;\n    color: inherit;\n  }\n`;\r\nconst AlertSpan = styled.span `\n  white-space: pre-line;\n`;\r\nfunction renderIcon(variant = 'info', isToast, theme) {\r\n    const Icon = VARIANT_ICON[variant];\r\n    return (React.createElement(IconWrapper, { isToast: isToast, theme: theme },\r\n        React.createElement(Icon, { size: theme.iconSizes.medium })));\r\n}\r\nexport const AlertBase = React.forwardRef((props, ref) => {\r\n    const { additionalContent, children, closeAriaLabel, forceDismiss, hasTimerRing, id: defaultId, isDismissed, isDismissible, isExiting: externalIsExiting, isPaused, isToast, onDismiss, testId, toastDuration, variant, ...other } = props;\r\n    const id = useGenerateId(defaultId);\r\n    const [isExiting, setIsExiting] = React.useState(false);\r\n    const isInverse = useIsInverse(props.isInverse);\r\n    React.useEffect(() => {\r\n        if (isExiting) {\r\n            setTimeout(() => {\r\n                setIsExiting(false);\r\n                onDismiss && typeof onDismiss === 'function' && onDismiss();\r\n            }, transitionDuration - 300);\r\n        }\r\n    }, [isExiting]);\r\n    React.useEffect(() => {\r\n        if (isDismissed) {\r\n            handleDismiss();\r\n        }\r\n    }, [isDismissed]);\r\n    function handleDismiss() {\r\n        setIsExiting(true);\r\n    }\r\n    const theme = React.useContext(ThemeContext);\r\n    const i18n = React.useContext(I18nContext);\r\n    function progressRingColor() {\r\n        if (isInverse) {\r\n            return theme.colors.neutral100;\r\n        }\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return theme.colors.success500;\r\n            case 'warning':\r\n                return theme.colors.warning500;\r\n            case 'danger':\r\n                return theme.colors.danger500;\r\n            default:\r\n                return theme.colors.info500;\r\n        }\r\n    }\r\n    return (React.createElement(StyledAlert, Object.assign({}, other, { \"data-testid\": testId, id: id, tabIndex: -1, isInverse: isInverse, isExiting: isExiting, isToast: isToast, ref: ref, theme: theme, variant: variant }),\r\n        React.createElement(InverseContext.Provider, { value: { isInverse } },\r\n            React.createElement(StyledAlertInner, { isInverse: isInverse, isToast: isToast, theme: theme, variant: variant },\r\n                renderIcon(variant, isToast, theme),\r\n                React.createElement(AlertContents, { additionalContent: additionalContent, isDismissible: isDismissible, theme: theme },\r\n                    React.createElement(AlertSpan, null, children),\r\n                    additionalContent && (React.createElement(AdditionalContentWrapper, { theme: theme }, additionalContent))),\r\n                isDismissible && (React.createElement(DismissibleIconWrapper, { isInverse: isInverse, variant: variant, theme: theme },\r\n                    hasTimerRing && isToast && (React.createElement(ProgressRingWrapper, { theme: theme },\r\n                        React.createElement(ProgressRing, { color: progressRingColor(), isActive: !isPaused, duration: toastDuration }))),\r\n                    React.createElement(DismissButton, Object.assign({ alertVariant: variant }, (isToast\r\n                        ? { title: closeAriaLabel || i18n.alert.dismissAriaLabel }\r\n                        : {\r\n                            'aria-label': closeAriaLabel || i18n.alert.dismissAriaLabel,\r\n                        }), { icon: React.createElement(CloseIcon, { size: hasTimerRing\r\n                                ? theme.iconSizes.xSmall\r\n                                : theme.iconSizes.small }), isInverse: isInverse, isToast: isToast, onClick: forceDismiss || handleDismiss, theme: theme, variant: ButtonVariant.link }))))))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */"));
|
|
3656
|
+
}, "px){padding-left:0;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AA4OiC","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport isPropValid from '@emotion/is-prop-valid';\r\nimport { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport { InfoIcon, CheckCircleIcon, WarningIcon, ErrorIcon, CloseIcon, } from 'react-magma-icons';\r\nimport { I18nContext } from '../..';\r\nimport { InverseContext, useIsInverse } from '../../inverse';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { useGenerateId } from '../../utils';\r\nimport { ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { ProgressRing } from '../ProgressRing';\r\nexport const VARIANT_ICON = {\r\n    info: InfoIcon,\r\n    success: CheckCircleIcon,\r\n    warning: WarningIcon,\r\n    danger: ErrorIcon,\r\n};\r\nexport var AlertVariant;\r\n(function (AlertVariant) {\r\n    AlertVariant[\"info\"] = \"info\";\r\n    AlertVariant[\"success\"] = \"success\";\r\n    AlertVariant[\"warning\"] = \"warning\";\r\n    AlertVariant[\"danger\"] = \"danger\";\r\n})(AlertVariant || (AlertVariant = {}));\r\nexport const transitionDuration = 500;\r\nexport function buildAlertBackground(props) {\r\n    if (props.isInverse) {\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return props.theme.colors.success700;\r\n            case 'warning':\r\n                return props.theme.colors.warning700;\r\n            case 'danger':\r\n                return props.theme.colors.danger700;\r\n            default:\r\n                return props.theme.colors.info700;\r\n        }\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success100;\r\n        case 'warning':\r\n            return props.theme.colors.warning100;\r\n        case 'danger':\r\n            return props.theme.colors.danger100;\r\n        default:\r\n            return props.theme.colors.info100;\r\n    }\r\n}\r\nexport function buildAlertBorder(props) {\r\n    if (props.isInverse) {\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return props.theme.colors.success300;\r\n            case 'warning':\r\n                return props.theme.colors.warning300;\r\n            case 'danger':\r\n                return props.theme.colors.danger200;\r\n            default:\r\n                return props.theme.colors.info300;\r\n        }\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success500;\r\n        case 'warning':\r\n            return props.theme.colors.warning500;\r\n        case 'danger':\r\n            return props.theme.colors.danger500;\r\n        default:\r\n            return props.theme.colors.info500;\r\n    }\r\n}\r\nexport function buildAlertColor(props) {\r\n    if (props.isInverse) {\r\n        return props.theme.colors.neutral100;\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success500;\r\n        case 'warning':\r\n            return props.theme.colors.warning500;\r\n        case 'danger':\r\n            return props.theme.colors.danger500;\r\n        default:\r\n            return props.theme.colors.info500;\r\n    }\r\n}\r\nexport function buildLinkColor(props) {\r\n    if (props.isInverse) {\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return props.theme.colors.success200;\r\n            case 'warning':\r\n                return props.theme.colors.warning200;\r\n            case 'danger':\r\n                return props.theme.colors.danger200;\r\n            default:\r\n                return props.theme.colors.info200;\r\n        }\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success700;\r\n        case 'warning':\r\n            return props.theme.colors.warning700;\r\n        case 'danger':\r\n            return props.theme.colors.danger700;\r\n        default:\r\n            return props.theme.colors.info700;\r\n    }\r\n}\r\nexport function buildLinkHoverColor(props) {\r\n    if (props.isInverse) {\r\n        return props.theme.colors.neutral100;\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success;\r\n        case 'warning':\r\n            return props.theme.colors.warning;\r\n        case 'danger':\r\n            return props.theme.colors.danger;\r\n        default:\r\n            return props.theme.colors.info;\r\n    }\r\n}\r\nconst StyledAlert = styled.div `\n  align-items: stretch;\n  animation: ${props => props.isExiting\r\n    ? `fadeout ${transitionDuration}ms`\r\n    : `fadein ${transitionDuration}ms`};\n  display: flex;\n  flex-direction: column;\n  font-size: ${props => props.theme.typeScale.size03.fontSize};\n  font-family: ${props => props.theme.bodyFont};\n  line-height: ${props => props.theme.typeScale.size03.lineHeight};\n  margin-bottom: ${props => props.theme.spaceScale.spacing06};\n  max-width: 100%;\n  padding: 0;\n  position: relative;\n\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    font-size: ${props => props.theme.typeScale.size02.fontSize};\n    letter-spacing: ${props => props.theme.typeScale.size02.letterSpacing};\n    line-height: ${props => props.theme.typeScale.size02.lineHeight};\n  }\n\n  &:focus {\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n  }\n\n  ${props => props.isToast &&\r\n    css `\n      animation: ${props.isExiting\r\n        ? `slideout ${transitionDuration}ms`\r\n        : `slidein ${transitionDuration}ms`};\n      min-width: 375px;\n      margin: 0 auto;\n\n      @media (max-width: ${props.theme.breakpoints.small}px) {\n        min-width: 0;\n        width: 100%;\n      }\n    `}\n\n  @keyframes fadein {\n    from {\n      opacity: 0;\n    }\n    to {\n      opacity: 1;\n    }\n  }\n\n  @keyframes fadeout {\n    from {\n      opacity: 1;\n    }\n    to {\n      opacity: 0;\n    }\n  }\n\n  @keyframes slidein {\n    from {\n      left: -500px;\n    }\n    to {\n      left: 0;\n    }\n  }\n\n  @keyframes slideout {\n    from {\n      left: 0;\n    }\n    to {\n      left: -500px;\n    }\n  }\n\n  a {\n    color: ${props => buildLinkColor(props)};\n    font-weight: 400;\n    text-decoration: underline;\n    &:not([disabled]) {\n      &:focus,\n      &:hover {\n        color: ${props => buildLinkHoverColor(props)};\n      }\n    }\n  }\n`;\r\nconst StyledAlertInner = styled.div `\n  background: ${buildAlertBackground};\n  border: 1px solid ${buildAlertBorder};\n  border-radius: ${props => props.theme.borderRadius};\n  color: ${buildAlertColor};\n  display: flex;\n  position: relative;\n\n  ${props => props.isToast &&\r\n    css `\n      box-shadow: ${props.isInverse\r\n        ? `0 2px 8px 0 ${transparentize(0.3, props.theme.colors.neutral900)}`\r\n        : `0 2px 8px 0 ${transparentize(0.6, props.theme.colors.neutral900)}`};\n      padding-right: 0;\n      height: ${props.theme.spaceScale.spacing11};\n    `}\n`;\r\nconst AlertContents = styled.div `\n  align-items: ${props => (props.additionalContent ? 'center' : '')};\n  align-self: center;\n  flex-grow: 1;\n  font-family: ${props => props.theme.bodyFont};\n  padding: ${props => props.theme.spaceScale.spacing04} 0;\n  display: ${props => (props.additionalContent ? 'flex' : '')};\n  margin-right: ${props => props.additionalContent && !props.isDismissible\r\n    ? props.theme.spaceScale.spacing03\r\n    : ''};\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    padding-left: 0;\n  }\n`;\r\nexport const AdditionalContentWrapper = styled.div `\n  flex: 1 0 auto;\n  justify-content: flex-end;\n  display: flex;\n  margin-left: ${props => props.theme.spaceScale.spacing05};\n`;\r\nconst IconWrapperStyles = css `\n  align-items: center;\n  display: flex;\n  flex-shrink: 0;\n  margin-right: 1px;\n`;\r\nconst IconWrapper = styled.span `\n  ${IconWrapperStyles}\n  padding: 0 ${props => props.theme.spaceScale.spacing03} 0 ${props => props.theme.spaceScale.spacing04};\n\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    padding: 0 ${props => props.theme.spaceScale.spacing03};\n    svg {\n      width: 20px;\n    }\n  }\n`;\r\nconst ProgressRingWrapper = styled.div `\n  margin-top: 6px;\n  position: absolute;\n  top: auto;\n  right: ${props => props.theme.spaceScale.spacing02};\n`;\r\nconst DismissibleIconWrapper = styled.span `\n  ${IconWrapperStyles}\n  margin-left: ${props => props.additionalContent ? props.theme.spaceScale.spacing03 : ''};\n`;\r\nconst whitelistProps = ['icon', 'isInverse', 'theme', 'variant'];\r\nconst shouldForwardProp = prop => {\r\n    return isPropValid(prop) || whitelistProps.includes(prop);\r\n};\r\nconst DismissButton = styled(IconButton, { shouldForwardProp }) `\n  align-self: stretch;\n  border-radius: 0 ${props => props.theme.borderRadius}\n    ${props => props.theme.borderRadius} 0;\n  color: inherit;\n  height: auto;\n  margin: ${props => (props.isToast ? '4px' : '0 -1px 0 0')};\n  padding: ${props => props.isToast\r\n    ? `0 ${props.theme.spaceScale.spacing04}`\r\n    : `0 ${props.theme.spaceScale.spacing03}`};\n  width: auto;\n  &:not(:disabled):hover {\n    background: none;\n    color: inherit;\n  }\n  &:focus:not(:disabled) {\n    background: none;\n    color: inherit;\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n    outline-offset: 0 !important;\n  }\n  &:not(:disabled):active {\n    background: none;\n    color: inherit;\n  }\n`;\r\nconst AlertSpan = styled.span `\n  white-space: pre-line;\n`;\r\nfunction getAriaLabelIcon(variant, i18n) {\r\n    switch (variant) {\r\n        case 'success':\r\n            return i18n.alertVariants.success;\r\n        case 'warning':\r\n            return i18n.alertVariants.warning;\r\n        case 'danger':\r\n            return i18n.alertVariants.danger;\r\n        default:\r\n            return i18n.alertVariants.info;\r\n    }\r\n}\r\nfunction renderIcon(variant = 'info', isToast, theme, i18n) {\r\n    const Icon = VARIANT_ICON[variant];\r\n    return (React.createElement(IconWrapper, { \"aria-label\": getAriaLabelIcon(variant, i18n), role: \"img\", isToast: isToast, theme: theme },\r\n        React.createElement(Icon, { size: theme.iconSizes.medium })));\r\n}\r\nexport const AlertBase = React.forwardRef((props, ref) => {\r\n    const { additionalContent, children, closeAriaLabel, forceDismiss, hasTimerRing, id: defaultId, isDismissed, isDismissible, isExiting: externalIsExiting, isPaused, isToast, onDismiss, testId, toastDuration, variant, ...other } = props;\r\n    const id = useGenerateId(defaultId);\r\n    const [isExiting, setIsExiting] = React.useState(false);\r\n    const isInverse = useIsInverse(props.isInverse);\r\n    React.useEffect(() => {\r\n        if (isExiting) {\r\n            setTimeout(() => {\r\n                setIsExiting(false);\r\n                onDismiss && typeof onDismiss === 'function' && onDismiss();\r\n            }, transitionDuration - 300);\r\n        }\r\n    }, [isExiting]);\r\n    React.useEffect(() => {\r\n        if (isDismissed) {\r\n            handleDismiss();\r\n        }\r\n    }, [isDismissed]);\r\n    function handleDismiss() {\r\n        setIsExiting(true);\r\n    }\r\n    const theme = React.useContext(ThemeContext);\r\n    const i18n = React.useContext(I18nContext);\r\n    function progressRingColor() {\r\n        if (isInverse) {\r\n            return theme.colors.neutral100;\r\n        }\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return theme.colors.success500;\r\n            case 'warning':\r\n                return theme.colors.warning500;\r\n            case 'danger':\r\n                return theme.colors.danger500;\r\n            default:\r\n                return theme.colors.info500;\r\n        }\r\n    }\r\n    return (React.createElement(StyledAlert, Object.assign({}, other, { \"data-testid\": testId, id: id, tabIndex: -1, isInverse: isInverse, isExiting: isExiting, isToast: isToast, ref: ref, theme: theme, variant: variant }),\r\n        React.createElement(InverseContext.Provider, { value: { isInverse } },\r\n            React.createElement(StyledAlertInner, { isInverse: isInverse, isToast: isToast, theme: theme, variant: variant },\r\n                renderIcon(variant, isToast, theme, i18n),\r\n                React.createElement(AlertContents, { additionalContent: additionalContent, isDismissible: isDismissible, theme: theme },\r\n                    React.createElement(AlertSpan, null, children),\r\n                    additionalContent && (React.createElement(AdditionalContentWrapper, { theme: theme }, additionalContent))),\r\n                isDismissible && (React.createElement(DismissibleIconWrapper, { isInverse: isInverse, variant: variant, theme: theme },\r\n                    hasTimerRing && isToast && (React.createElement(ProgressRingWrapper, { theme: theme },\r\n                        React.createElement(ProgressRing, { color: progressRingColor(), isActive: !isPaused, duration: toastDuration }))),\r\n                    React.createElement(DismissButton, Object.assign({ alertVariant: variant }, (isToast\r\n                        ? { title: closeAriaLabel || i18n.alert.dismissAriaLabel }\r\n                        : {\r\n                            'aria-label': closeAriaLabel || i18n.alert.dismissAriaLabel,\r\n                        }), { icon: React.createElement(CloseIcon, { size: hasTimerRing\r\n                                ? theme.iconSizes.xSmall\r\n                                : theme.iconSizes.small }), isInverse: isInverse, isToast: isToast, onClick: forceDismiss || handleDismiss, theme: theme, variant: ButtonVariant.link }))))))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */"));
|
|
3651
3657
|
var AdditionalContentWrapper = /*#__PURE__*/_styled("div", {
|
|
3652
3658
|
target: "e126n3g85",
|
|
3653
3659
|
label: "AdditionalContentWrapper"
|
|
3654
3660
|
})("flex:1 0 auto;justify-content:flex-end;display:flex;margin-left:", function (props) {
|
|
3655
3661
|
return props.theme.spaceScale.spacing05;
|
|
3656
|
-
}, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AA0PmD","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport isPropValid from '@emotion/is-prop-valid';\r\nimport { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport { InfoIcon, CheckCircleIcon, WarningIcon, ErrorIcon, CloseIcon, } from 'react-magma-icons';\r\nimport { I18nContext } from '../../i18n';\r\nimport { InverseContext, useIsInverse } from '../../inverse';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { useGenerateId } from '../../utils';\r\nimport { ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { ProgressRing } from '../ProgressRing';\r\nexport const VARIANT_ICON = {\r\n    info: InfoIcon,\r\n    success: CheckCircleIcon,\r\n    warning: WarningIcon,\r\n    danger: ErrorIcon,\r\n};\r\nexport var AlertVariant;\r\n(function (AlertVariant) {\r\n    AlertVariant[\"info\"] = \"info\";\r\n    AlertVariant[\"success\"] = \"success\";\r\n    AlertVariant[\"warning\"] = \"warning\";\r\n    AlertVariant[\"danger\"] = \"danger\";\r\n})(AlertVariant || (AlertVariant = {}));\r\nexport const transitionDuration = 500;\r\nexport function buildAlertBackground(props) {\r\n    if (props.isInverse) {\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return props.theme.colors.success700;\r\n            case 'warning':\r\n                return props.theme.colors.warning700;\r\n            case 'danger':\r\n                return props.theme.colors.danger700;\r\n            default:\r\n                return props.theme.colors.info700;\r\n        }\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success100;\r\n        case 'warning':\r\n            return props.theme.colors.warning100;\r\n        case 'danger':\r\n            return props.theme.colors.danger100;\r\n        default:\r\n            return props.theme.colors.info100;\r\n    }\r\n}\r\nexport function buildAlertBorder(props) {\r\n    if (props.isInverse) {\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return props.theme.colors.success300;\r\n            case 'warning':\r\n                return props.theme.colors.warning300;\r\n            case 'danger':\r\n                return props.theme.colors.danger200;\r\n            default:\r\n                return props.theme.colors.info300;\r\n        }\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success500;\r\n        case 'warning':\r\n            return props.theme.colors.warning500;\r\n        case 'danger':\r\n            return props.theme.colors.danger500;\r\n        default:\r\n            return props.theme.colors.info500;\r\n    }\r\n}\r\nexport function buildAlertColor(props) {\r\n    if (props.isInverse) {\r\n        return props.theme.colors.neutral100;\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success500;\r\n        case 'warning':\r\n            return props.theme.colors.warning500;\r\n        case 'danger':\r\n            return props.theme.colors.danger500;\r\n        default:\r\n            return props.theme.colors.info500;\r\n    }\r\n}\r\nexport function buildLinkColor(props) {\r\n    if (props.isInverse) {\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return props.theme.colors.success200;\r\n            case 'warning':\r\n                return props.theme.colors.warning200;\r\n            case 'danger':\r\n                return props.theme.colors.danger200;\r\n            default:\r\n                return props.theme.colors.info200;\r\n        }\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success700;\r\n        case 'warning':\r\n            return props.theme.colors.warning700;\r\n        case 'danger':\r\n            return props.theme.colors.danger700;\r\n        default:\r\n            return props.theme.colors.info700;\r\n    }\r\n}\r\nexport function buildLinkHoverColor(props) {\r\n    if (props.isInverse) {\r\n        return props.theme.colors.neutral100;\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success;\r\n        case 'warning':\r\n            return props.theme.colors.warning;\r\n        case 'danger':\r\n            return props.theme.colors.danger;\r\n        default:\r\n            return props.theme.colors.info;\r\n    }\r\n}\r\nconst StyledAlert = styled.div `\n  align-items: stretch;\n  animation: ${props => props.isExiting\r\n    ? `fadeout ${transitionDuration}ms`\r\n    : `fadein ${transitionDuration}ms`};\n  display: flex;\n  flex-direction: column;\n  font-size: ${props => props.theme.typeScale.size03.fontSize};\n  font-family: ${props => props.theme.bodyFont};\n  line-height: ${props => props.theme.typeScale.size03.lineHeight};\n  margin-bottom: ${props => props.theme.spaceScale.spacing06};\n  max-width: 100%;\n  padding: 0;\n  position: relative;\n\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    font-size: ${props => props.theme.typeScale.size02.fontSize};\n    letter-spacing: ${props => props.theme.typeScale.size02.letterSpacing};\n    line-height: ${props => props.theme.typeScale.size02.lineHeight};\n  }\n\n  &:focus {\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n  }\n\n  ${props => props.isToast &&\r\n    css `\n      animation: ${props.isExiting\r\n        ? `slideout ${transitionDuration}ms`\r\n        : `slidein ${transitionDuration}ms`};\n      min-width: 375px;\n      margin: 0 auto;\n\n      @media (max-width: ${props.theme.breakpoints.small}px) {\n        min-width: 0;\n        width: 100%;\n      }\n    `}\n\n  @keyframes fadein {\n    from {\n      opacity: 0;\n    }\n    to {\n      opacity: 1;\n    }\n  }\n\n  @keyframes fadeout {\n    from {\n      opacity: 1;\n    }\n    to {\n      opacity: 0;\n    }\n  }\n\n  @keyframes slidein {\n    from {\n      left: -500px;\n    }\n    to {\n      left: 0;\n    }\n  }\n\n  @keyframes slideout {\n    from {\n      left: 0;\n    }\n    to {\n      left: -500px;\n    }\n  }\n\n  a {\n    color: ${props => buildLinkColor(props)};\n    font-weight: 400;\n    text-decoration: underline;\n    &:not([disabled]) {\n      &:focus,\n      &:hover {\n        color: ${props => buildLinkHoverColor(props)};\n      }\n    }\n  }\n`;\r\nconst StyledAlertInner = styled.div `\n  background: ${buildAlertBackground};\n  border: 1px solid ${buildAlertBorder};\n  border-radius: ${props => props.theme.borderRadius};\n  color: ${buildAlertColor};\n  display: flex;\n  position: relative;\n\n  ${props => props.isToast &&\r\n    css `\n      box-shadow: ${props.isInverse\r\n        ? `0 2px 8px 0 ${transparentize(0.3, props.theme.colors.neutral900)}`\r\n        : `0 2px 8px 0 ${transparentize(0.6, props.theme.colors.neutral900)}`};\n      padding-right: 0;\n      height: ${props.theme.spaceScale.spacing11};\n    `}\n`;\r\nconst AlertContents = styled.div `\n  align-items: ${props => (props.additionalContent ? 'center' : '')};\n  align-self: center;\n  flex-grow: 1;\n  font-family: ${props => props.theme.bodyFont};\n  padding: ${props => props.theme.spaceScale.spacing04} 0;\n  display: ${props => (props.additionalContent ? 'flex' : '')};\n  margin-right: ${props => props.additionalContent && !props.isDismissible\r\n    ? props.theme.spaceScale.spacing03\r\n    : ''};\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    padding-left: 0;\n  }\n`;\r\nexport const AdditionalContentWrapper = styled.div `\n  flex: 1 0 auto;\n  justify-content: flex-end;\n  display: flex;\n  margin-left: ${props => props.theme.spaceScale.spacing05};\n`;\r\nconst IconWrapperStyles = css `\n  align-items: center;\n  display: flex;\n  flex-shrink: 0;\n  margin-right: 1px;\n`;\r\nconst IconWrapper = styled.span `\n  ${IconWrapperStyles}\n  padding: 0 ${props => props.theme.spaceScale.spacing03} 0 ${props => props.theme.spaceScale.spacing04};\n\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    padding: 0 ${props => props.theme.spaceScale.spacing03};\n    svg {\n      width: 20px;\n    }\n  }\n`;\r\nconst ProgressRingWrapper = styled.div `\n  margin-top: 6px;\n  position: absolute;\n  top: auto;\n  right: ${props => props.theme.spaceScale.spacing02};\n`;\r\nconst DismissibleIconWrapper = styled.span `\n  ${IconWrapperStyles}\n  margin-left: ${props => props.additionalContent ? props.theme.spaceScale.spacing03 : ''};\n`;\r\nconst whitelistProps = ['icon', 'isInverse', 'theme', 'variant'];\r\nconst shouldForwardProp = prop => {\r\n    return isPropValid(prop) || whitelistProps.includes(prop);\r\n};\r\nconst DismissButton = styled(IconButton, { shouldForwardProp }) `\n  align-self: stretch;\n  border-radius: 0 ${props => props.theme.borderRadius}\n    ${props => props.theme.borderRadius} 0;\n  color: inherit;\n  height: auto;\n  margin: ${props => (props.isToast ? '4px' : '0 -1px 0 0')};\n  padding: ${props => props.isToast\r\n    ? `0 ${props.theme.spaceScale.spacing04}`\r\n    : `0 ${props.theme.spaceScale.spacing03}`};\n  width: auto;\n  &:not(:disabled):hover {\n    background: none;\n    color: inherit;\n  }\n  &:focus:not(:disabled) {\n    background: none;\n    color: inherit;\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n    outline-offset: 0 !important;\n  }\n  &:not(:disabled):active {\n    background: none;\n    color: inherit;\n  }\n`;\r\nconst AlertSpan = styled.span `\n  white-space: pre-line;\n`;\r\nfunction renderIcon(variant = 'info', isToast, theme) {\r\n    const Icon = VARIANT_ICON[variant];\r\n    return (React.createElement(IconWrapper, { isToast: isToast, theme: theme },\r\n        React.createElement(Icon, { size: theme.iconSizes.medium })));\r\n}\r\nexport const AlertBase = React.forwardRef((props, ref) => {\r\n    const { additionalContent, children, closeAriaLabel, forceDismiss, hasTimerRing, id: defaultId, isDismissed, isDismissible, isExiting: externalIsExiting, isPaused, isToast, onDismiss, testId, toastDuration, variant, ...other } = props;\r\n    const id = useGenerateId(defaultId);\r\n    const [isExiting, setIsExiting] = React.useState(false);\r\n    const isInverse = useIsInverse(props.isInverse);\r\n    React.useEffect(() => {\r\n        if (isExiting) {\r\n            setTimeout(() => {\r\n                setIsExiting(false);\r\n                onDismiss && typeof onDismiss === 'function' && onDismiss();\r\n            }, transitionDuration - 300);\r\n        }\r\n    }, [isExiting]);\r\n    React.useEffect(() => {\r\n        if (isDismissed) {\r\n            handleDismiss();\r\n        }\r\n    }, [isDismissed]);\r\n    function handleDismiss() {\r\n        setIsExiting(true);\r\n    }\r\n    const theme = React.useContext(ThemeContext);\r\n    const i18n = React.useContext(I18nContext);\r\n    function progressRingColor() {\r\n        if (isInverse) {\r\n            return theme.colors.neutral100;\r\n        }\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return theme.colors.success500;\r\n            case 'warning':\r\n                return theme.colors.warning500;\r\n            case 'danger':\r\n                return theme.colors.danger500;\r\n            default:\r\n                return theme.colors.info500;\r\n        }\r\n    }\r\n    return (React.createElement(StyledAlert, Object.assign({}, other, { \"data-testid\": testId, id: id, tabIndex: -1, isInverse: isInverse, isExiting: isExiting, isToast: isToast, ref: ref, theme: theme, variant: variant }),\r\n        React.createElement(InverseContext.Provider, { value: { isInverse } },\r\n            React.createElement(StyledAlertInner, { isInverse: isInverse, isToast: isToast, theme: theme, variant: variant },\r\n                renderIcon(variant, isToast, theme),\r\n                React.createElement(AlertContents, { additionalContent: additionalContent, isDismissible: isDismissible, theme: theme },\r\n                    React.createElement(AlertSpan, null, children),\r\n                    additionalContent && (React.createElement(AdditionalContentWrapper, { theme: theme }, additionalContent))),\r\n                isDismissible && (React.createElement(DismissibleIconWrapper, { isInverse: isInverse, variant: variant, theme: theme },\r\n                    hasTimerRing && isToast && (React.createElement(ProgressRingWrapper, { theme: theme },\r\n                        React.createElement(ProgressRing, { color: progressRingColor(), isActive: !isPaused, duration: toastDuration }))),\r\n                    React.createElement(DismissButton, Object.assign({ alertVariant: variant }, (isToast\r\n                        ? { title: closeAriaLabel || i18n.alert.dismissAriaLabel }\r\n                        : {\r\n                            'aria-label': closeAriaLabel || i18n.alert.dismissAriaLabel,\r\n                        }), { icon: React.createElement(CloseIcon, { size: hasTimerRing\r\n                                ? theme.iconSizes.xSmall\r\n                                : theme.iconSizes.small }), isInverse: isInverse, isToast: isToast, onClick: forceDismiss || handleDismiss, theme: theme, variant: ButtonVariant.link }))))))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */"));
|
|
3662
|
+
}, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AA0PmD","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport isPropValid from '@emotion/is-prop-valid';\r\nimport { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport { InfoIcon, CheckCircleIcon, WarningIcon, ErrorIcon, CloseIcon, } from 'react-magma-icons';\r\nimport { I18nContext } from '../..';\r\nimport { InverseContext, useIsInverse } from '../../inverse';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { useGenerateId } from '../../utils';\r\nimport { ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { ProgressRing } from '../ProgressRing';\r\nexport const VARIANT_ICON = {\r\n    info: InfoIcon,\r\n    success: CheckCircleIcon,\r\n    warning: WarningIcon,\r\n    danger: ErrorIcon,\r\n};\r\nexport var AlertVariant;\r\n(function (AlertVariant) {\r\n    AlertVariant[\"info\"] = \"info\";\r\n    AlertVariant[\"success\"] = \"success\";\r\n    AlertVariant[\"warning\"] = \"warning\";\r\n    AlertVariant[\"danger\"] = \"danger\";\r\n})(AlertVariant || (AlertVariant = {}));\r\nexport const transitionDuration = 500;\r\nexport function buildAlertBackground(props) {\r\n    if (props.isInverse) {\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return props.theme.colors.success700;\r\n            case 'warning':\r\n                return props.theme.colors.warning700;\r\n            case 'danger':\r\n                return props.theme.colors.danger700;\r\n            default:\r\n                return props.theme.colors.info700;\r\n        }\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success100;\r\n        case 'warning':\r\n            return props.theme.colors.warning100;\r\n        case 'danger':\r\n            return props.theme.colors.danger100;\r\n        default:\r\n            return props.theme.colors.info100;\r\n    }\r\n}\r\nexport function buildAlertBorder(props) {\r\n    if (props.isInverse) {\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return props.theme.colors.success300;\r\n            case 'warning':\r\n                return props.theme.colors.warning300;\r\n            case 'danger':\r\n                return props.theme.colors.danger200;\r\n            default:\r\n                return props.theme.colors.info300;\r\n        }\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success500;\r\n        case 'warning':\r\n            return props.theme.colors.warning500;\r\n        case 'danger':\r\n            return props.theme.colors.danger500;\r\n        default:\r\n            return props.theme.colors.info500;\r\n    }\r\n}\r\nexport function buildAlertColor(props) {\r\n    if (props.isInverse) {\r\n        return props.theme.colors.neutral100;\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success500;\r\n        case 'warning':\r\n            return props.theme.colors.warning500;\r\n        case 'danger':\r\n            return props.theme.colors.danger500;\r\n        default:\r\n            return props.theme.colors.info500;\r\n    }\r\n}\r\nexport function buildLinkColor(props) {\r\n    if (props.isInverse) {\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return props.theme.colors.success200;\r\n            case 'warning':\r\n                return props.theme.colors.warning200;\r\n            case 'danger':\r\n                return props.theme.colors.danger200;\r\n            default:\r\n                return props.theme.colors.info200;\r\n        }\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success700;\r\n        case 'warning':\r\n            return props.theme.colors.warning700;\r\n        case 'danger':\r\n            return props.theme.colors.danger700;\r\n        default:\r\n            return props.theme.colors.info700;\r\n    }\r\n}\r\nexport function buildLinkHoverColor(props) {\r\n    if (props.isInverse) {\r\n        return props.theme.colors.neutral100;\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success;\r\n        case 'warning':\r\n            return props.theme.colors.warning;\r\n        case 'danger':\r\n            return props.theme.colors.danger;\r\n        default:\r\n            return props.theme.colors.info;\r\n    }\r\n}\r\nconst StyledAlert = styled.div `\n  align-items: stretch;\n  animation: ${props => props.isExiting\r\n    ? `fadeout ${transitionDuration}ms`\r\n    : `fadein ${transitionDuration}ms`};\n  display: flex;\n  flex-direction: column;\n  font-size: ${props => props.theme.typeScale.size03.fontSize};\n  font-family: ${props => props.theme.bodyFont};\n  line-height: ${props => props.theme.typeScale.size03.lineHeight};\n  margin-bottom: ${props => props.theme.spaceScale.spacing06};\n  max-width: 100%;\n  padding: 0;\n  position: relative;\n\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    font-size: ${props => props.theme.typeScale.size02.fontSize};\n    letter-spacing: ${props => props.theme.typeScale.size02.letterSpacing};\n    line-height: ${props => props.theme.typeScale.size02.lineHeight};\n  }\n\n  &:focus {\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n  }\n\n  ${props => props.isToast &&\r\n    css `\n      animation: ${props.isExiting\r\n        ? `slideout ${transitionDuration}ms`\r\n        : `slidein ${transitionDuration}ms`};\n      min-width: 375px;\n      margin: 0 auto;\n\n      @media (max-width: ${props.theme.breakpoints.small}px) {\n        min-width: 0;\n        width: 100%;\n      }\n    `}\n\n  @keyframes fadein {\n    from {\n      opacity: 0;\n    }\n    to {\n      opacity: 1;\n    }\n  }\n\n  @keyframes fadeout {\n    from {\n      opacity: 1;\n    }\n    to {\n      opacity: 0;\n    }\n  }\n\n  @keyframes slidein {\n    from {\n      left: -500px;\n    }\n    to {\n      left: 0;\n    }\n  }\n\n  @keyframes slideout {\n    from {\n      left: 0;\n    }\n    to {\n      left: -500px;\n    }\n  }\n\n  a {\n    color: ${props => buildLinkColor(props)};\n    font-weight: 400;\n    text-decoration: underline;\n    &:not([disabled]) {\n      &:focus,\n      &:hover {\n        color: ${props => buildLinkHoverColor(props)};\n      }\n    }\n  }\n`;\r\nconst StyledAlertInner = styled.div `\n  background: ${buildAlertBackground};\n  border: 1px solid ${buildAlertBorder};\n  border-radius: ${props => props.theme.borderRadius};\n  color: ${buildAlertColor};\n  display: flex;\n  position: relative;\n\n  ${props => props.isToast &&\r\n    css `\n      box-shadow: ${props.isInverse\r\n        ? `0 2px 8px 0 ${transparentize(0.3, props.theme.colors.neutral900)}`\r\n        : `0 2px 8px 0 ${transparentize(0.6, props.theme.colors.neutral900)}`};\n      padding-right: 0;\n      height: ${props.theme.spaceScale.spacing11};\n    `}\n`;\r\nconst AlertContents = styled.div `\n  align-items: ${props => (props.additionalContent ? 'center' : '')};\n  align-self: center;\n  flex-grow: 1;\n  font-family: ${props => props.theme.bodyFont};\n  padding: ${props => props.theme.spaceScale.spacing04} 0;\n  display: ${props => (props.additionalContent ? 'flex' : '')};\n  margin-right: ${props => props.additionalContent && !props.isDismissible\r\n    ? props.theme.spaceScale.spacing03\r\n    : ''};\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    padding-left: 0;\n  }\n`;\r\nexport const AdditionalContentWrapper = styled.div `\n  flex: 1 0 auto;\n  justify-content: flex-end;\n  display: flex;\n  margin-left: ${props => props.theme.spaceScale.spacing05};\n`;\r\nconst IconWrapperStyles = css `\n  align-items: center;\n  display: flex;\n  flex-shrink: 0;\n  margin-right: 1px;\n`;\r\nconst IconWrapper = styled.span `\n  ${IconWrapperStyles}\n  padding: 0 ${props => props.theme.spaceScale.spacing03} 0 ${props => props.theme.spaceScale.spacing04};\n\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    padding: 0 ${props => props.theme.spaceScale.spacing03};\n    svg {\n      width: 20px;\n    }\n  }\n`;\r\nconst ProgressRingWrapper = styled.div `\n  margin-top: 6px;\n  position: absolute;\n  top: auto;\n  right: ${props => props.theme.spaceScale.spacing02};\n`;\r\nconst DismissibleIconWrapper = styled.span `\n  ${IconWrapperStyles}\n  margin-left: ${props => props.additionalContent ? props.theme.spaceScale.spacing03 : ''};\n`;\r\nconst whitelistProps = ['icon', 'isInverse', 'theme', 'variant'];\r\nconst shouldForwardProp = prop => {\r\n    return isPropValid(prop) || whitelistProps.includes(prop);\r\n};\r\nconst DismissButton = styled(IconButton, { shouldForwardProp }) `\n  align-self: stretch;\n  border-radius: 0 ${props => props.theme.borderRadius}\n    ${props => props.theme.borderRadius} 0;\n  color: inherit;\n  height: auto;\n  margin: ${props => (props.isToast ? '4px' : '0 -1px 0 0')};\n  padding: ${props => props.isToast\r\n    ? `0 ${props.theme.spaceScale.spacing04}`\r\n    : `0 ${props.theme.spaceScale.spacing03}`};\n  width: auto;\n  &:not(:disabled):hover {\n    background: none;\n    color: inherit;\n  }\n  &:focus:not(:disabled) {\n    background: none;\n    color: inherit;\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n    outline-offset: 0 !important;\n  }\n  &:not(:disabled):active {\n    background: none;\n    color: inherit;\n  }\n`;\r\nconst AlertSpan = styled.span `\n  white-space: pre-line;\n`;\r\nfunction getAriaLabelIcon(variant, i18n) {\r\n    switch (variant) {\r\n        case 'success':\r\n            return i18n.alertVariants.success;\r\n        case 'warning':\r\n            return i18n.alertVariants.warning;\r\n        case 'danger':\r\n            return i18n.alertVariants.danger;\r\n        default:\r\n            return i18n.alertVariants.info;\r\n    }\r\n}\r\nfunction renderIcon(variant = 'info', isToast, theme, i18n) {\r\n    const Icon = VARIANT_ICON[variant];\r\n    return (React.createElement(IconWrapper, { \"aria-label\": getAriaLabelIcon(variant, i18n), role: \"img\", isToast: isToast, theme: theme },\r\n        React.createElement(Icon, { size: theme.iconSizes.medium })));\r\n}\r\nexport const AlertBase = React.forwardRef((props, ref) => {\r\n    const { additionalContent, children, closeAriaLabel, forceDismiss, hasTimerRing, id: defaultId, isDismissed, isDismissible, isExiting: externalIsExiting, isPaused, isToast, onDismiss, testId, toastDuration, variant, ...other } = props;\r\n    const id = useGenerateId(defaultId);\r\n    const [isExiting, setIsExiting] = React.useState(false);\r\n    const isInverse = useIsInverse(props.isInverse);\r\n    React.useEffect(() => {\r\n        if (isExiting) {\r\n            setTimeout(() => {\r\n                setIsExiting(false);\r\n                onDismiss && typeof onDismiss === 'function' && onDismiss();\r\n            }, transitionDuration - 300);\r\n        }\r\n    }, [isExiting]);\r\n    React.useEffect(() => {\r\n        if (isDismissed) {\r\n            handleDismiss();\r\n        }\r\n    }, [isDismissed]);\r\n    function handleDismiss() {\r\n        setIsExiting(true);\r\n    }\r\n    const theme = React.useContext(ThemeContext);\r\n    const i18n = React.useContext(I18nContext);\r\n    function progressRingColor() {\r\n        if (isInverse) {\r\n            return theme.colors.neutral100;\r\n        }\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return theme.colors.success500;\r\n            case 'warning':\r\n                return theme.colors.warning500;\r\n            case 'danger':\r\n                return theme.colors.danger500;\r\n            default:\r\n                return theme.colors.info500;\r\n        }\r\n    }\r\n    return (React.createElement(StyledAlert, Object.assign({}, other, { \"data-testid\": testId, id: id, tabIndex: -1, isInverse: isInverse, isExiting: isExiting, isToast: isToast, ref: ref, theme: theme, variant: variant }),\r\n        React.createElement(InverseContext.Provider, { value: { isInverse } },\r\n            React.createElement(StyledAlertInner, { isInverse: isInverse, isToast: isToast, theme: theme, variant: variant },\r\n                renderIcon(variant, isToast, theme, i18n),\r\n                React.createElement(AlertContents, { additionalContent: additionalContent, isDismissible: isDismissible, theme: theme },\r\n                    React.createElement(AlertSpan, null, children),\r\n                    additionalContent && (React.createElement(AdditionalContentWrapper, { theme: theme }, additionalContent))),\r\n                isDismissible && (React.createElement(DismissibleIconWrapper, { isInverse: isInverse, variant: variant, theme: theme },\r\n                    hasTimerRing && isToast && (React.createElement(ProgressRingWrapper, { theme: theme },\r\n                        React.createElement(ProgressRing, { color: progressRingColor(), isActive: !isPaused, duration: toastDuration }))),\r\n                    React.createElement(DismissButton, Object.assign({ alertVariant: variant }, (isToast\r\n                        ? { title: closeAriaLabel || i18n.alert.dismissAriaLabel }\r\n                        : {\r\n                            'aria-label': closeAriaLabel || i18n.alert.dismissAriaLabel,\r\n                        }), { icon: React.createElement(CloseIcon, { size: hasTimerRing\r\n                                ? theme.iconSizes.xSmall\r\n                                : theme.iconSizes.small }), isInverse: isInverse, isToast: isToast, onClick: forceDismiss || handleDismiss, theme: theme, variant: ButtonVariant.link }))))))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */"));
|
|
3657
3663
|
var IconWrapperStyles = process.env.NODE_ENV === "production" ? {
|
|
3658
3664
|
name: "1tjzeyt-IconWrapperStyles",
|
|
3659
3665
|
styles: "align-items:center;display:flex;flex-shrink:0;margin-right:1px;label:IconWrapperStyles;"
|
|
3660
3666
|
} : {
|
|
3661
3667
|
name: "1tjzeyt-IconWrapperStyles",
|
|
3662
|
-
styles: "align-items:center;display:flex;flex-shrink:0;margin-right:1px;label:IconWrapperStyles;/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAgQ8B","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport isPropValid from '@emotion/is-prop-valid';\r\nimport { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport { InfoIcon, CheckCircleIcon, WarningIcon, ErrorIcon, CloseIcon, } from 'react-magma-icons';\r\nimport { I18nContext } from '../../i18n';\r\nimport { InverseContext, useIsInverse } from '../../inverse';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { useGenerateId } from '../../utils';\r\nimport { ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { ProgressRing } from '../ProgressRing';\r\nexport const VARIANT_ICON = {\r\n    info: InfoIcon,\r\n    success: CheckCircleIcon,\r\n    warning: WarningIcon,\r\n    danger: ErrorIcon,\r\n};\r\nexport var AlertVariant;\r\n(function (AlertVariant) {\r\n    AlertVariant[\"info\"] = \"info\";\r\n    AlertVariant[\"success\"] = \"success\";\r\n    AlertVariant[\"warning\"] = \"warning\";\r\n    AlertVariant[\"danger\"] = \"danger\";\r\n})(AlertVariant || (AlertVariant = {}));\r\nexport const transitionDuration = 500;\r\nexport function buildAlertBackground(props) {\r\n    if (props.isInverse) {\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return props.theme.colors.success700;\r\n            case 'warning':\r\n                return props.theme.colors.warning700;\r\n            case 'danger':\r\n                return props.theme.colors.danger700;\r\n            default:\r\n                return props.theme.colors.info700;\r\n        }\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success100;\r\n        case 'warning':\r\n            return props.theme.colors.warning100;\r\n        case 'danger':\r\n            return props.theme.colors.danger100;\r\n        default:\r\n            return props.theme.colors.info100;\r\n    }\r\n}\r\nexport function buildAlertBorder(props) {\r\n    if (props.isInverse) {\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return props.theme.colors.success300;\r\n            case 'warning':\r\n                return props.theme.colors.warning300;\r\n            case 'danger':\r\n                return props.theme.colors.danger200;\r\n            default:\r\n                return props.theme.colors.info300;\r\n        }\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success500;\r\n        case 'warning':\r\n            return props.theme.colors.warning500;\r\n        case 'danger':\r\n            return props.theme.colors.danger500;\r\n        default:\r\n            return props.theme.colors.info500;\r\n    }\r\n}\r\nexport function buildAlertColor(props) {\r\n    if (props.isInverse) {\r\n        return props.theme.colors.neutral100;\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success500;\r\n        case 'warning':\r\n            return props.theme.colors.warning500;\r\n        case 'danger':\r\n            return props.theme.colors.danger500;\r\n        default:\r\n            return props.theme.colors.info500;\r\n    }\r\n}\r\nexport function buildLinkColor(props) {\r\n    if (props.isInverse) {\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return props.theme.colors.success200;\r\n            case 'warning':\r\n                return props.theme.colors.warning200;\r\n            case 'danger':\r\n                return props.theme.colors.danger200;\r\n            default:\r\n                return props.theme.colors.info200;\r\n        }\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success700;\r\n        case 'warning':\r\n            return props.theme.colors.warning700;\r\n        case 'danger':\r\n            return props.theme.colors.danger700;\r\n        default:\r\n            return props.theme.colors.info700;\r\n    }\r\n}\r\nexport function buildLinkHoverColor(props) {\r\n    if (props.isInverse) {\r\n        return props.theme.colors.neutral100;\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success;\r\n        case 'warning':\r\n            return props.theme.colors.warning;\r\n        case 'danger':\r\n            return props.theme.colors.danger;\r\n        default:\r\n            return props.theme.colors.info;\r\n    }\r\n}\r\nconst StyledAlert = styled.div `\n  align-items: stretch;\n  animation: ${props => props.isExiting\r\n    ? `fadeout ${transitionDuration}ms`\r\n    : `fadein ${transitionDuration}ms`};\n  display: flex;\n  flex-direction: column;\n  font-size: ${props => props.theme.typeScale.size03.fontSize};\n  font-family: ${props => props.theme.bodyFont};\n  line-height: ${props => props.theme.typeScale.size03.lineHeight};\n  margin-bottom: ${props => props.theme.spaceScale.spacing06};\n  max-width: 100%;\n  padding: 0;\n  position: relative;\n\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    font-size: ${props => props.theme.typeScale.size02.fontSize};\n    letter-spacing: ${props => props.theme.typeScale.size02.letterSpacing};\n    line-height: ${props => props.theme.typeScale.size02.lineHeight};\n  }\n\n  &:focus {\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n  }\n\n  ${props => props.isToast &&\r\n    css `\n      animation: ${props.isExiting\r\n        ? `slideout ${transitionDuration}ms`\r\n        : `slidein ${transitionDuration}ms`};\n      min-width: 375px;\n      margin: 0 auto;\n\n      @media (max-width: ${props.theme.breakpoints.small}px) {\n        min-width: 0;\n        width: 100%;\n      }\n    `}\n\n  @keyframes fadein {\n    from {\n      opacity: 0;\n    }\n    to {\n      opacity: 1;\n    }\n  }\n\n  @keyframes fadeout {\n    from {\n      opacity: 1;\n    }\n    to {\n      opacity: 0;\n    }\n  }\n\n  @keyframes slidein {\n    from {\n      left: -500px;\n    }\n    to {\n      left: 0;\n    }\n  }\n\n  @keyframes slideout {\n    from {\n      left: 0;\n    }\n    to {\n      left: -500px;\n    }\n  }\n\n  a {\n    color: ${props => buildLinkColor(props)};\n    font-weight: 400;\n    text-decoration: underline;\n    &:not([disabled]) {\n      &:focus,\n      &:hover {\n        color: ${props => buildLinkHoverColor(props)};\n      }\n    }\n  }\n`;\r\nconst StyledAlertInner = styled.div `\n  background: ${buildAlertBackground};\n  border: 1px solid ${buildAlertBorder};\n  border-radius: ${props => props.theme.borderRadius};\n  color: ${buildAlertColor};\n  display: flex;\n  position: relative;\n\n  ${props => props.isToast &&\r\n    css `\n      box-shadow: ${props.isInverse\r\n        ? `0 2px 8px 0 ${transparentize(0.3, props.theme.colors.neutral900)}`\r\n        : `0 2px 8px 0 ${transparentize(0.6, props.theme.colors.neutral900)}`};\n      padding-right: 0;\n      height: ${props.theme.spaceScale.spacing11};\n    `}\n`;\r\nconst AlertContents = styled.div `\n  align-items: ${props => (props.additionalContent ? 'center' : '')};\n  align-self: center;\n  flex-grow: 1;\n  font-family: ${props => props.theme.bodyFont};\n  padding: ${props => props.theme.spaceScale.spacing04} 0;\n  display: ${props => (props.additionalContent ? 'flex' : '')};\n  margin-right: ${props => props.additionalContent && !props.isDismissible\r\n    ? props.theme.spaceScale.spacing03\r\n    : ''};\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    padding-left: 0;\n  }\n`;\r\nexport const AdditionalContentWrapper = styled.div `\n  flex: 1 0 auto;\n  justify-content: flex-end;\n  display: flex;\n  margin-left: ${props => props.theme.spaceScale.spacing05};\n`;\r\nconst IconWrapperStyles = css `\n  align-items: center;\n  display: flex;\n  flex-shrink: 0;\n  margin-right: 1px;\n`;\r\nconst IconWrapper = styled.span `\n  ${IconWrapperStyles}\n  padding: 0 ${props => props.theme.spaceScale.spacing03} 0 ${props => props.theme.spaceScale.spacing04};\n\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    padding: 0 ${props => props.theme.spaceScale.spacing03};\n    svg {\n      width: 20px;\n    }\n  }\n`;\r\nconst ProgressRingWrapper = styled.div `\n  margin-top: 6px;\n  position: absolute;\n  top: auto;\n  right: ${props => props.theme.spaceScale.spacing02};\n`;\r\nconst DismissibleIconWrapper = styled.span `\n  ${IconWrapperStyles}\n  margin-left: ${props => props.additionalContent ? props.theme.spaceScale.spacing03 : ''};\n`;\r\nconst whitelistProps = ['icon', 'isInverse', 'theme', 'variant'];\r\nconst shouldForwardProp = prop => {\r\n    return isPropValid(prop) || whitelistProps.includes(prop);\r\n};\r\nconst DismissButton = styled(IconButton, { shouldForwardProp }) `\n  align-self: stretch;\n  border-radius: 0 ${props => props.theme.borderRadius}\n    ${props => props.theme.borderRadius} 0;\n  color: inherit;\n  height: auto;\n  margin: ${props => (props.isToast ? '4px' : '0 -1px 0 0')};\n  padding: ${props => props.isToast\r\n    ? `0 ${props.theme.spaceScale.spacing04}`\r\n    : `0 ${props.theme.spaceScale.spacing03}`};\n  width: auto;\n  &:not(:disabled):hover {\n    background: none;\n    color: inherit;\n  }\n  &:focus:not(:disabled) {\n    background: none;\n    color: inherit;\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n    outline-offset: 0 !important;\n  }\n  &:not(:disabled):active {\n    background: none;\n    color: inherit;\n  }\n`;\r\nconst AlertSpan = styled.span `\n  white-space: pre-line;\n`;\r\nfunction renderIcon(variant = 'info', isToast, theme) {\r\n    const Icon = VARIANT_ICON[variant];\r\n    return (React.createElement(IconWrapper, { isToast: isToast, theme: theme },\r\n        React.createElement(Icon, { size: theme.iconSizes.medium })));\r\n}\r\nexport const AlertBase = React.forwardRef((props, ref) => {\r\n    const { additionalContent, children, closeAriaLabel, forceDismiss, hasTimerRing, id: defaultId, isDismissed, isDismissible, isExiting: externalIsExiting, isPaused, isToast, onDismiss, testId, toastDuration, variant, ...other } = props;\r\n    const id = useGenerateId(defaultId);\r\n    const [isExiting, setIsExiting] = React.useState(false);\r\n    const isInverse = useIsInverse(props.isInverse);\r\n    React.useEffect(() => {\r\n        if (isExiting) {\r\n            setTimeout(() => {\r\n                setIsExiting(false);\r\n                onDismiss && typeof onDismiss === 'function' && onDismiss();\r\n            }, transitionDuration - 300);\r\n        }\r\n    }, [isExiting]);\r\n    React.useEffect(() => {\r\n        if (isDismissed) {\r\n            handleDismiss();\r\n        }\r\n    }, [isDismissed]);\r\n    function handleDismiss() {\r\n        setIsExiting(true);\r\n    }\r\n    const theme = React.useContext(ThemeContext);\r\n    const i18n = React.useContext(I18nContext);\r\n    function progressRingColor() {\r\n        if (isInverse) {\r\n            return theme.colors.neutral100;\r\n        }\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return theme.colors.success500;\r\n            case 'warning':\r\n                return theme.colors.warning500;\r\n            case 'danger':\r\n                return theme.colors.danger500;\r\n            default:\r\n                return theme.colors.info500;\r\n        }\r\n    }\r\n    return (React.createElement(StyledAlert, Object.assign({}, other, { \"data-testid\": testId, id: id, tabIndex: -1, isInverse: isInverse, isExiting: isExiting, isToast: isToast, ref: ref, theme: theme, variant: variant }),\r\n        React.createElement(InverseContext.Provider, { value: { isInverse } },\r\n            React.createElement(StyledAlertInner, { isInverse: isInverse, isToast: isToast, theme: theme, variant: variant },\r\n                renderIcon(variant, isToast, theme),\r\n                React.createElement(AlertContents, { additionalContent: additionalContent, isDismissible: isDismissible, theme: theme },\r\n                    React.createElement(AlertSpan, null, children),\r\n                    additionalContent && (React.createElement(AdditionalContentWrapper, { theme: theme }, additionalContent))),\r\n                isDismissible && (React.createElement(DismissibleIconWrapper, { isInverse: isInverse, variant: variant, theme: theme },\r\n                    hasTimerRing && isToast && (React.createElement(ProgressRingWrapper, { theme: theme },\r\n                        React.createElement(ProgressRing, { color: progressRingColor(), isActive: !isPaused, duration: toastDuration }))),\r\n                    React.createElement(DismissButton, Object.assign({ alertVariant: variant }, (isToast\r\n                        ? { title: closeAriaLabel || i18n.alert.dismissAriaLabel }\r\n                        : {\r\n                            'aria-label': closeAriaLabel || i18n.alert.dismissAriaLabel,\r\n                        }), { icon: React.createElement(CloseIcon, { size: hasTimerRing\r\n                                ? theme.iconSizes.xSmall\r\n                                : theme.iconSizes.small }), isInverse: isInverse, isToast: isToast, onClick: forceDismiss || handleDismiss, theme: theme, variant: ButtonVariant.link }))))))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */",
|
|
3668
|
+
styles: "align-items:center;display:flex;flex-shrink:0;margin-right:1px;label:IconWrapperStyles;/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAgQ8B","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport isPropValid from '@emotion/is-prop-valid';\r\nimport { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport { InfoIcon, CheckCircleIcon, WarningIcon, ErrorIcon, CloseIcon, } from 'react-magma-icons';\r\nimport { I18nContext } from '../..';\r\nimport { InverseContext, useIsInverse } from '../../inverse';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { useGenerateId } from '../../utils';\r\nimport { ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { ProgressRing } from '../ProgressRing';\r\nexport const VARIANT_ICON = {\r\n    info: InfoIcon,\r\n    success: CheckCircleIcon,\r\n    warning: WarningIcon,\r\n    danger: ErrorIcon,\r\n};\r\nexport var AlertVariant;\r\n(function (AlertVariant) {\r\n    AlertVariant[\"info\"] = \"info\";\r\n    AlertVariant[\"success\"] = \"success\";\r\n    AlertVariant[\"warning\"] = \"warning\";\r\n    AlertVariant[\"danger\"] = \"danger\";\r\n})(AlertVariant || (AlertVariant = {}));\r\nexport const transitionDuration = 500;\r\nexport function buildAlertBackground(props) {\r\n    if (props.isInverse) {\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return props.theme.colors.success700;\r\n            case 'warning':\r\n                return props.theme.colors.warning700;\r\n            case 'danger':\r\n                return props.theme.colors.danger700;\r\n            default:\r\n                return props.theme.colors.info700;\r\n        }\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success100;\r\n        case 'warning':\r\n            return props.theme.colors.warning100;\r\n        case 'danger':\r\n            return props.theme.colors.danger100;\r\n        default:\r\n            return props.theme.colors.info100;\r\n    }\r\n}\r\nexport function buildAlertBorder(props) {\r\n    if (props.isInverse) {\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return props.theme.colors.success300;\r\n            case 'warning':\r\n                return props.theme.colors.warning300;\r\n            case 'danger':\r\n                return props.theme.colors.danger200;\r\n            default:\r\n                return props.theme.colors.info300;\r\n        }\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success500;\r\n        case 'warning':\r\n            return props.theme.colors.warning500;\r\n        case 'danger':\r\n            return props.theme.colors.danger500;\r\n        default:\r\n            return props.theme.colors.info500;\r\n    }\r\n}\r\nexport function buildAlertColor(props) {\r\n    if (props.isInverse) {\r\n        return props.theme.colors.neutral100;\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success500;\r\n        case 'warning':\r\n            return props.theme.colors.warning500;\r\n        case 'danger':\r\n            return props.theme.colors.danger500;\r\n        default:\r\n            return props.theme.colors.info500;\r\n    }\r\n}\r\nexport function buildLinkColor(props) {\r\n    if (props.isInverse) {\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return props.theme.colors.success200;\r\n            case 'warning':\r\n                return props.theme.colors.warning200;\r\n            case 'danger':\r\n                return props.theme.colors.danger200;\r\n            default:\r\n                return props.theme.colors.info200;\r\n        }\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success700;\r\n        case 'warning':\r\n            return props.theme.colors.warning700;\r\n        case 'danger':\r\n            return props.theme.colors.danger700;\r\n        default:\r\n            return props.theme.colors.info700;\r\n    }\r\n}\r\nexport function buildLinkHoverColor(props) {\r\n    if (props.isInverse) {\r\n        return props.theme.colors.neutral100;\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success;\r\n        case 'warning':\r\n            return props.theme.colors.warning;\r\n        case 'danger':\r\n            return props.theme.colors.danger;\r\n        default:\r\n            return props.theme.colors.info;\r\n    }\r\n}\r\nconst StyledAlert = styled.div `\n  align-items: stretch;\n  animation: ${props => props.isExiting\r\n    ? `fadeout ${transitionDuration}ms`\r\n    : `fadein ${transitionDuration}ms`};\n  display: flex;\n  flex-direction: column;\n  font-size: ${props => props.theme.typeScale.size03.fontSize};\n  font-family: ${props => props.theme.bodyFont};\n  line-height: ${props => props.theme.typeScale.size03.lineHeight};\n  margin-bottom: ${props => props.theme.spaceScale.spacing06};\n  max-width: 100%;\n  padding: 0;\n  position: relative;\n\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    font-size: ${props => props.theme.typeScale.size02.fontSize};\n    letter-spacing: ${props => props.theme.typeScale.size02.letterSpacing};\n    line-height: ${props => props.theme.typeScale.size02.lineHeight};\n  }\n\n  &:focus {\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n  }\n\n  ${props => props.isToast &&\r\n    css `\n      animation: ${props.isExiting\r\n        ? `slideout ${transitionDuration}ms`\r\n        : `slidein ${transitionDuration}ms`};\n      min-width: 375px;\n      margin: 0 auto;\n\n      @media (max-width: ${props.theme.breakpoints.small}px) {\n        min-width: 0;\n        width: 100%;\n      }\n    `}\n\n  @keyframes fadein {\n    from {\n      opacity: 0;\n    }\n    to {\n      opacity: 1;\n    }\n  }\n\n  @keyframes fadeout {\n    from {\n      opacity: 1;\n    }\n    to {\n      opacity: 0;\n    }\n  }\n\n  @keyframes slidein {\n    from {\n      left: -500px;\n    }\n    to {\n      left: 0;\n    }\n  }\n\n  @keyframes slideout {\n    from {\n      left: 0;\n    }\n    to {\n      left: -500px;\n    }\n  }\n\n  a {\n    color: ${props => buildLinkColor(props)};\n    font-weight: 400;\n    text-decoration: underline;\n    &:not([disabled]) {\n      &:focus,\n      &:hover {\n        color: ${props => buildLinkHoverColor(props)};\n      }\n    }\n  }\n`;\r\nconst StyledAlertInner = styled.div `\n  background: ${buildAlertBackground};\n  border: 1px solid ${buildAlertBorder};\n  border-radius: ${props => props.theme.borderRadius};\n  color: ${buildAlertColor};\n  display: flex;\n  position: relative;\n\n  ${props => props.isToast &&\r\n    css `\n      box-shadow: ${props.isInverse\r\n        ? `0 2px 8px 0 ${transparentize(0.3, props.theme.colors.neutral900)}`\r\n        : `0 2px 8px 0 ${transparentize(0.6, props.theme.colors.neutral900)}`};\n      padding-right: 0;\n      height: ${props.theme.spaceScale.spacing11};\n    `}\n`;\r\nconst AlertContents = styled.div `\n  align-items: ${props => (props.additionalContent ? 'center' : '')};\n  align-self: center;\n  flex-grow: 1;\n  font-family: ${props => props.theme.bodyFont};\n  padding: ${props => props.theme.spaceScale.spacing04} 0;\n  display: ${props => (props.additionalContent ? 'flex' : '')};\n  margin-right: ${props => props.additionalContent && !props.isDismissible\r\n    ? props.theme.spaceScale.spacing03\r\n    : ''};\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    padding-left: 0;\n  }\n`;\r\nexport const AdditionalContentWrapper = styled.div `\n  flex: 1 0 auto;\n  justify-content: flex-end;\n  display: flex;\n  margin-left: ${props => props.theme.spaceScale.spacing05};\n`;\r\nconst IconWrapperStyles = css `\n  align-items: center;\n  display: flex;\n  flex-shrink: 0;\n  margin-right: 1px;\n`;\r\nconst IconWrapper = styled.span `\n  ${IconWrapperStyles}\n  padding: 0 ${props => props.theme.spaceScale.spacing03} 0 ${props => props.theme.spaceScale.spacing04};\n\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    padding: 0 ${props => props.theme.spaceScale.spacing03};\n    svg {\n      width: 20px;\n    }\n  }\n`;\r\nconst ProgressRingWrapper = styled.div `\n  margin-top: 6px;\n  position: absolute;\n  top: auto;\n  right: ${props => props.theme.spaceScale.spacing02};\n`;\r\nconst DismissibleIconWrapper = styled.span `\n  ${IconWrapperStyles}\n  margin-left: ${props => props.additionalContent ? props.theme.spaceScale.spacing03 : ''};\n`;\r\nconst whitelistProps = ['icon', 'isInverse', 'theme', 'variant'];\r\nconst shouldForwardProp = prop => {\r\n    return isPropValid(prop) || whitelistProps.includes(prop);\r\n};\r\nconst DismissButton = styled(IconButton, { shouldForwardProp }) `\n  align-self: stretch;\n  border-radius: 0 ${props => props.theme.borderRadius}\n    ${props => props.theme.borderRadius} 0;\n  color: inherit;\n  height: auto;\n  margin: ${props => (props.isToast ? '4px' : '0 -1px 0 0')};\n  padding: ${props => props.isToast\r\n    ? `0 ${props.theme.spaceScale.spacing04}`\r\n    : `0 ${props.theme.spaceScale.spacing03}`};\n  width: auto;\n  &:not(:disabled):hover {\n    background: none;\n    color: inherit;\n  }\n  &:focus:not(:disabled) {\n    background: none;\n    color: inherit;\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n    outline-offset: 0 !important;\n  }\n  &:not(:disabled):active {\n    background: none;\n    color: inherit;\n  }\n`;\r\nconst AlertSpan = styled.span `\n  white-space: pre-line;\n`;\r\nfunction getAriaLabelIcon(variant, i18n) {\r\n    switch (variant) {\r\n        case 'success':\r\n            return i18n.alertVariants.success;\r\n        case 'warning':\r\n            return i18n.alertVariants.warning;\r\n        case 'danger':\r\n            return i18n.alertVariants.danger;\r\n        default:\r\n            return i18n.alertVariants.info;\r\n    }\r\n}\r\nfunction renderIcon(variant = 'info', isToast, theme, i18n) {\r\n    const Icon = VARIANT_ICON[variant];\r\n    return (React.createElement(IconWrapper, { \"aria-label\": getAriaLabelIcon(variant, i18n), role: \"img\", isToast: isToast, theme: theme },\r\n        React.createElement(Icon, { size: theme.iconSizes.medium })));\r\n}\r\nexport const AlertBase = React.forwardRef((props, ref) => {\r\n    const { additionalContent, children, closeAriaLabel, forceDismiss, hasTimerRing, id: defaultId, isDismissed, isDismissible, isExiting: externalIsExiting, isPaused, isToast, onDismiss, testId, toastDuration, variant, ...other } = props;\r\n    const id = useGenerateId(defaultId);\r\n    const [isExiting, setIsExiting] = React.useState(false);\r\n    const isInverse = useIsInverse(props.isInverse);\r\n    React.useEffect(() => {\r\n        if (isExiting) {\r\n            setTimeout(() => {\r\n                setIsExiting(false);\r\n                onDismiss && typeof onDismiss === 'function' && onDismiss();\r\n            }, transitionDuration - 300);\r\n        }\r\n    }, [isExiting]);\r\n    React.useEffect(() => {\r\n        if (isDismissed) {\r\n            handleDismiss();\r\n        }\r\n    }, [isDismissed]);\r\n    function handleDismiss() {\r\n        setIsExiting(true);\r\n    }\r\n    const theme = React.useContext(ThemeContext);\r\n    const i18n = React.useContext(I18nContext);\r\n    function progressRingColor() {\r\n        if (isInverse) {\r\n            return theme.colors.neutral100;\r\n        }\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return theme.colors.success500;\r\n            case 'warning':\r\n                return theme.colors.warning500;\r\n            case 'danger':\r\n                return theme.colors.danger500;\r\n            default:\r\n                return theme.colors.info500;\r\n        }\r\n    }\r\n    return (React.createElement(StyledAlert, Object.assign({}, other, { \"data-testid\": testId, id: id, tabIndex: -1, isInverse: isInverse, isExiting: isExiting, isToast: isToast, ref: ref, theme: theme, variant: variant }),\r\n        React.createElement(InverseContext.Provider, { value: { isInverse } },\r\n            React.createElement(StyledAlertInner, { isInverse: isInverse, isToast: isToast, theme: theme, variant: variant },\r\n                renderIcon(variant, isToast, theme, i18n),\r\n                React.createElement(AlertContents, { additionalContent: additionalContent, isDismissible: isDismissible, theme: theme },\r\n                    React.createElement(AlertSpan, null, children),\r\n                    additionalContent && (React.createElement(AdditionalContentWrapper, { theme: theme }, additionalContent))),\r\n                isDismissible && (React.createElement(DismissibleIconWrapper, { isInverse: isInverse, variant: variant, theme: theme },\r\n                    hasTimerRing && isToast && (React.createElement(ProgressRingWrapper, { theme: theme },\r\n                        React.createElement(ProgressRing, { color: progressRingColor(), isActive: !isPaused, duration: toastDuration }))),\r\n                    React.createElement(DismissButton, Object.assign({ alertVariant: variant }, (isToast\r\n                        ? { title: closeAriaLabel || i18n.alert.dismissAriaLabel }\r\n                        : {\r\n                            'aria-label': closeAriaLabel || i18n.alert.dismissAriaLabel,\r\n                        }), { icon: React.createElement(CloseIcon, { size: hasTimerRing\r\n                                ? theme.iconSizes.xSmall\r\n                                : theme.iconSizes.small }), isInverse: isInverse, isToast: isToast, onClick: forceDismiss || handleDismiss, theme: theme, variant: ButtonVariant.link }))))))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */",
|
|
3663
3669
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$4
|
|
3664
3670
|
};
|
|
3665
3671
|
var IconWrapper = /*#__PURE__*/_styled("span", {
|
|
@@ -3673,19 +3679,19 @@ var IconWrapper = /*#__PURE__*/_styled("span", {
|
|
|
3673
3679
|
return props.theme.breakpoints.small;
|
|
3674
3680
|
}, "px){padding:0 ", function (props) {
|
|
3675
3681
|
return props.theme.spaceScale.spacing03;
|
|
3676
|
-
}, ";svg{width:20px;}}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAsQgC","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport isPropValid from '@emotion/is-prop-valid';\r\nimport { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport { InfoIcon, CheckCircleIcon, WarningIcon, ErrorIcon, CloseIcon, } from 'react-magma-icons';\r\nimport { I18nContext } from '../../i18n';\r\nimport { InverseContext, useIsInverse } from '../../inverse';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { useGenerateId } from '../../utils';\r\nimport { ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { ProgressRing } from '../ProgressRing';\r\nexport const VARIANT_ICON = {\r\n    info: InfoIcon,\r\n    success: CheckCircleIcon,\r\n    warning: WarningIcon,\r\n    danger: ErrorIcon,\r\n};\r\nexport var AlertVariant;\r\n(function (AlertVariant) {\r\n    AlertVariant[\"info\"] = \"info\";\r\n    AlertVariant[\"success\"] = \"success\";\r\n    AlertVariant[\"warning\"] = \"warning\";\r\n    AlertVariant[\"danger\"] = \"danger\";\r\n})(AlertVariant || (AlertVariant = {}));\r\nexport const transitionDuration = 500;\r\nexport function buildAlertBackground(props) {\r\n    if (props.isInverse) {\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return props.theme.colors.success700;\r\n            case 'warning':\r\n                return props.theme.colors.warning700;\r\n            case 'danger':\r\n                return props.theme.colors.danger700;\r\n            default:\r\n                return props.theme.colors.info700;\r\n        }\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success100;\r\n        case 'warning':\r\n            return props.theme.colors.warning100;\r\n        case 'danger':\r\n            return props.theme.colors.danger100;\r\n        default:\r\n            return props.theme.colors.info100;\r\n    }\r\n}\r\nexport function buildAlertBorder(props) {\r\n    if (props.isInverse) {\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return props.theme.colors.success300;\r\n            case 'warning':\r\n                return props.theme.colors.warning300;\r\n            case 'danger':\r\n                return props.theme.colors.danger200;\r\n            default:\r\n                return props.theme.colors.info300;\r\n        }\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success500;\r\n        case 'warning':\r\n            return props.theme.colors.warning500;\r\n        case 'danger':\r\n            return props.theme.colors.danger500;\r\n        default:\r\n            return props.theme.colors.info500;\r\n    }\r\n}\r\nexport function buildAlertColor(props) {\r\n    if (props.isInverse) {\r\n        return props.theme.colors.neutral100;\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success500;\r\n        case 'warning':\r\n            return props.theme.colors.warning500;\r\n        case 'danger':\r\n            return props.theme.colors.danger500;\r\n        default:\r\n            return props.theme.colors.info500;\r\n    }\r\n}\r\nexport function buildLinkColor(props) {\r\n    if (props.isInverse) {\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return props.theme.colors.success200;\r\n            case 'warning':\r\n                return props.theme.colors.warning200;\r\n            case 'danger':\r\n                return props.theme.colors.danger200;\r\n            default:\r\n                return props.theme.colors.info200;\r\n        }\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success700;\r\n        case 'warning':\r\n            return props.theme.colors.warning700;\r\n        case 'danger':\r\n            return props.theme.colors.danger700;\r\n        default:\r\n            return props.theme.colors.info700;\r\n    }\r\n}\r\nexport function buildLinkHoverColor(props) {\r\n    if (props.isInverse) {\r\n        return props.theme.colors.neutral100;\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success;\r\n        case 'warning':\r\n            return props.theme.colors.warning;\r\n        case 'danger':\r\n            return props.theme.colors.danger;\r\n        default:\r\n            return props.theme.colors.info;\r\n    }\r\n}\r\nconst StyledAlert = styled.div `\n  align-items: stretch;\n  animation: ${props => props.isExiting\r\n    ? `fadeout ${transitionDuration}ms`\r\n    : `fadein ${transitionDuration}ms`};\n  display: flex;\n  flex-direction: column;\n  font-size: ${props => props.theme.typeScale.size03.fontSize};\n  font-family: ${props => props.theme.bodyFont};\n  line-height: ${props => props.theme.typeScale.size03.lineHeight};\n  margin-bottom: ${props => props.theme.spaceScale.spacing06};\n  max-width: 100%;\n  padding: 0;\n  position: relative;\n\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    font-size: ${props => props.theme.typeScale.size02.fontSize};\n    letter-spacing: ${props => props.theme.typeScale.size02.letterSpacing};\n    line-height: ${props => props.theme.typeScale.size02.lineHeight};\n  }\n\n  &:focus {\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n  }\n\n  ${props => props.isToast &&\r\n    css `\n      animation: ${props.isExiting\r\n        ? `slideout ${transitionDuration}ms`\r\n        : `slidein ${transitionDuration}ms`};\n      min-width: 375px;\n      margin: 0 auto;\n\n      @media (max-width: ${props.theme.breakpoints.small}px) {\n        min-width: 0;\n        width: 100%;\n      }\n    `}\n\n  @keyframes fadein {\n    from {\n      opacity: 0;\n    }\n    to {\n      opacity: 1;\n    }\n  }\n\n  @keyframes fadeout {\n    from {\n      opacity: 1;\n    }\n    to {\n      opacity: 0;\n    }\n  }\n\n  @keyframes slidein {\n    from {\n      left: -500px;\n    }\n    to {\n      left: 0;\n    }\n  }\n\n  @keyframes slideout {\n    from {\n      left: 0;\n    }\n    to {\n      left: -500px;\n    }\n  }\n\n  a {\n    color: ${props => buildLinkColor(props)};\n    font-weight: 400;\n    text-decoration: underline;\n    &:not([disabled]) {\n      &:focus,\n      &:hover {\n        color: ${props => buildLinkHoverColor(props)};\n      }\n    }\n  }\n`;\r\nconst StyledAlertInner = styled.div `\n  background: ${buildAlertBackground};\n  border: 1px solid ${buildAlertBorder};\n  border-radius: ${props => props.theme.borderRadius};\n  color: ${buildAlertColor};\n  display: flex;\n  position: relative;\n\n  ${props => props.isToast &&\r\n    css `\n      box-shadow: ${props.isInverse\r\n        ? `0 2px 8px 0 ${transparentize(0.3, props.theme.colors.neutral900)}`\r\n        : `0 2px 8px 0 ${transparentize(0.6, props.theme.colors.neutral900)}`};\n      padding-right: 0;\n      height: ${props.theme.spaceScale.spacing11};\n    `}\n`;\r\nconst AlertContents = styled.div `\n  align-items: ${props => (props.additionalContent ? 'center' : '')};\n  align-self: center;\n  flex-grow: 1;\n  font-family: ${props => props.theme.bodyFont};\n  padding: ${props => props.theme.spaceScale.spacing04} 0;\n  display: ${props => (props.additionalContent ? 'flex' : '')};\n  margin-right: ${props => props.additionalContent && !props.isDismissible\r\n    ? props.theme.spaceScale.spacing03\r\n    : ''};\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    padding-left: 0;\n  }\n`;\r\nexport const AdditionalContentWrapper = styled.div `\n  flex: 1 0 auto;\n  justify-content: flex-end;\n  display: flex;\n  margin-left: ${props => props.theme.spaceScale.spacing05};\n`;\r\nconst IconWrapperStyles = css `\n  align-items: center;\n  display: flex;\n  flex-shrink: 0;\n  margin-right: 1px;\n`;\r\nconst IconWrapper = styled.span `\n  ${IconWrapperStyles}\n  padding: 0 ${props => props.theme.spaceScale.spacing03} 0 ${props => props.theme.spaceScale.spacing04};\n\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    padding: 0 ${props => props.theme.spaceScale.spacing03};\n    svg {\n      width: 20px;\n    }\n  }\n`;\r\nconst ProgressRingWrapper = styled.div `\n  margin-top: 6px;\n  position: absolute;\n  top: auto;\n  right: ${props => props.theme.spaceScale.spacing02};\n`;\r\nconst DismissibleIconWrapper = styled.span `\n  ${IconWrapperStyles}\n  margin-left: ${props => props.additionalContent ? props.theme.spaceScale.spacing03 : ''};\n`;\r\nconst whitelistProps = ['icon', 'isInverse', 'theme', 'variant'];\r\nconst shouldForwardProp = prop => {\r\n    return isPropValid(prop) || whitelistProps.includes(prop);\r\n};\r\nconst DismissButton = styled(IconButton, { shouldForwardProp }) `\n  align-self: stretch;\n  border-radius: 0 ${props => props.theme.borderRadius}\n    ${props => props.theme.borderRadius} 0;\n  color: inherit;\n  height: auto;\n  margin: ${props => (props.isToast ? '4px' : '0 -1px 0 0')};\n  padding: ${props => props.isToast\r\n    ? `0 ${props.theme.spaceScale.spacing04}`\r\n    : `0 ${props.theme.spaceScale.spacing03}`};\n  width: auto;\n  &:not(:disabled):hover {\n    background: none;\n    color: inherit;\n  }\n  &:focus:not(:disabled) {\n    background: none;\n    color: inherit;\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n    outline-offset: 0 !important;\n  }\n  &:not(:disabled):active {\n    background: none;\n    color: inherit;\n  }\n`;\r\nconst AlertSpan = styled.span `\n  white-space: pre-line;\n`;\r\nfunction renderIcon(variant = 'info', isToast, theme) {\r\n    const Icon = VARIANT_ICON[variant];\r\n    return (React.createElement(IconWrapper, { isToast: isToast, theme: theme },\r\n        React.createElement(Icon, { size: theme.iconSizes.medium })));\r\n}\r\nexport const AlertBase = React.forwardRef((props, ref) => {\r\n    const { additionalContent, children, closeAriaLabel, forceDismiss, hasTimerRing, id: defaultId, isDismissed, isDismissible, isExiting: externalIsExiting, isPaused, isToast, onDismiss, testId, toastDuration, variant, ...other } = props;\r\n    const id = useGenerateId(defaultId);\r\n    const [isExiting, setIsExiting] = React.useState(false);\r\n    const isInverse = useIsInverse(props.isInverse);\r\n    React.useEffect(() => {\r\n        if (isExiting) {\r\n            setTimeout(() => {\r\n                setIsExiting(false);\r\n                onDismiss && typeof onDismiss === 'function' && onDismiss();\r\n            }, transitionDuration - 300);\r\n        }\r\n    }, [isExiting]);\r\n    React.useEffect(() => {\r\n        if (isDismissed) {\r\n            handleDismiss();\r\n        }\r\n    }, [isDismissed]);\r\n    function handleDismiss() {\r\n        setIsExiting(true);\r\n    }\r\n    const theme = React.useContext(ThemeContext);\r\n    const i18n = React.useContext(I18nContext);\r\n    function progressRingColor() {\r\n        if (isInverse) {\r\n            return theme.colors.neutral100;\r\n        }\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return theme.colors.success500;\r\n            case 'warning':\r\n                return theme.colors.warning500;\r\n            case 'danger':\r\n                return theme.colors.danger500;\r\n            default:\r\n                return theme.colors.info500;\r\n        }\r\n    }\r\n    return (React.createElement(StyledAlert, Object.assign({}, other, { \"data-testid\": testId, id: id, tabIndex: -1, isInverse: isInverse, isExiting: isExiting, isToast: isToast, ref: ref, theme: theme, variant: variant }),\r\n        React.createElement(InverseContext.Provider, { value: { isInverse } },\r\n            React.createElement(StyledAlertInner, { isInverse: isInverse, isToast: isToast, theme: theme, variant: variant },\r\n                renderIcon(variant, isToast, theme),\r\n                React.createElement(AlertContents, { additionalContent: additionalContent, isDismissible: isDismissible, theme: theme },\r\n                    React.createElement(AlertSpan, null, children),\r\n                    additionalContent && (React.createElement(AdditionalContentWrapper, { theme: theme }, additionalContent))),\r\n                isDismissible && (React.createElement(DismissibleIconWrapper, { isInverse: isInverse, variant: variant, theme: theme },\r\n                    hasTimerRing && isToast && (React.createElement(ProgressRingWrapper, { theme: theme },\r\n                        React.createElement(ProgressRing, { color: progressRingColor(), isActive: !isPaused, duration: toastDuration }))),\r\n                    React.createElement(DismissButton, Object.assign({ alertVariant: variant }, (isToast\r\n                        ? { title: closeAriaLabel || i18n.alert.dismissAriaLabel }\r\n                        : {\r\n                            'aria-label': closeAriaLabel || i18n.alert.dismissAriaLabel,\r\n                        }), { icon: React.createElement(CloseIcon, { size: hasTimerRing\r\n                                ? theme.iconSizes.xSmall\r\n                                : theme.iconSizes.small }), isInverse: isInverse, isToast: isToast, onClick: forceDismiss || handleDismiss, theme: theme, variant: ButtonVariant.link }))))))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */"));
|
|
3682
|
+
}, ";svg{width:20px;}}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAsQgC","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport isPropValid from '@emotion/is-prop-valid';\r\nimport { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport { InfoIcon, CheckCircleIcon, WarningIcon, ErrorIcon, CloseIcon, } from 'react-magma-icons';\r\nimport { I18nContext } from '../..';\r\nimport { InverseContext, useIsInverse } from '../../inverse';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { useGenerateId } from '../../utils';\r\nimport { ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { ProgressRing } from '../ProgressRing';\r\nexport const VARIANT_ICON = {\r\n    info: InfoIcon,\r\n    success: CheckCircleIcon,\r\n    warning: WarningIcon,\r\n    danger: ErrorIcon,\r\n};\r\nexport var AlertVariant;\r\n(function (AlertVariant) {\r\n    AlertVariant[\"info\"] = \"info\";\r\n    AlertVariant[\"success\"] = \"success\";\r\n    AlertVariant[\"warning\"] = \"warning\";\r\n    AlertVariant[\"danger\"] = \"danger\";\r\n})(AlertVariant || (AlertVariant = {}));\r\nexport const transitionDuration = 500;\r\nexport function buildAlertBackground(props) {\r\n    if (props.isInverse) {\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return props.theme.colors.success700;\r\n            case 'warning':\r\n                return props.theme.colors.warning700;\r\n            case 'danger':\r\n                return props.theme.colors.danger700;\r\n            default:\r\n                return props.theme.colors.info700;\r\n        }\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success100;\r\n        case 'warning':\r\n            return props.theme.colors.warning100;\r\n        case 'danger':\r\n            return props.theme.colors.danger100;\r\n        default:\r\n            return props.theme.colors.info100;\r\n    }\r\n}\r\nexport function buildAlertBorder(props) {\r\n    if (props.isInverse) {\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return props.theme.colors.success300;\r\n            case 'warning':\r\n                return props.theme.colors.warning300;\r\n            case 'danger':\r\n                return props.theme.colors.danger200;\r\n            default:\r\n                return props.theme.colors.info300;\r\n        }\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success500;\r\n        case 'warning':\r\n            return props.theme.colors.warning500;\r\n        case 'danger':\r\n            return props.theme.colors.danger500;\r\n        default:\r\n            return props.theme.colors.info500;\r\n    }\r\n}\r\nexport function buildAlertColor(props) {\r\n    if (props.isInverse) {\r\n        return props.theme.colors.neutral100;\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success500;\r\n        case 'warning':\r\n            return props.theme.colors.warning500;\r\n        case 'danger':\r\n            return props.theme.colors.danger500;\r\n        default:\r\n            return props.theme.colors.info500;\r\n    }\r\n}\r\nexport function buildLinkColor(props) {\r\n    if (props.isInverse) {\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return props.theme.colors.success200;\r\n            case 'warning':\r\n                return props.theme.colors.warning200;\r\n            case 'danger':\r\n                return props.theme.colors.danger200;\r\n            default:\r\n                return props.theme.colors.info200;\r\n        }\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success700;\r\n        case 'warning':\r\n            return props.theme.colors.warning700;\r\n        case 'danger':\r\n            return props.theme.colors.danger700;\r\n        default:\r\n            return props.theme.colors.info700;\r\n    }\r\n}\r\nexport function buildLinkHoverColor(props) {\r\n    if (props.isInverse) {\r\n        return props.theme.colors.neutral100;\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success;\r\n        case 'warning':\r\n            return props.theme.colors.warning;\r\n        case 'danger':\r\n            return props.theme.colors.danger;\r\n        default:\r\n            return props.theme.colors.info;\r\n    }\r\n}\r\nconst StyledAlert = styled.div `\n  align-items: stretch;\n  animation: ${props => props.isExiting\r\n    ? `fadeout ${transitionDuration}ms`\r\n    : `fadein ${transitionDuration}ms`};\n  display: flex;\n  flex-direction: column;\n  font-size: ${props => props.theme.typeScale.size03.fontSize};\n  font-family: ${props => props.theme.bodyFont};\n  line-height: ${props => props.theme.typeScale.size03.lineHeight};\n  margin-bottom: ${props => props.theme.spaceScale.spacing06};\n  max-width: 100%;\n  padding: 0;\n  position: relative;\n\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    font-size: ${props => props.theme.typeScale.size02.fontSize};\n    letter-spacing: ${props => props.theme.typeScale.size02.letterSpacing};\n    line-height: ${props => props.theme.typeScale.size02.lineHeight};\n  }\n\n  &:focus {\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n  }\n\n  ${props => props.isToast &&\r\n    css `\n      animation: ${props.isExiting\r\n        ? `slideout ${transitionDuration}ms`\r\n        : `slidein ${transitionDuration}ms`};\n      min-width: 375px;\n      margin: 0 auto;\n\n      @media (max-width: ${props.theme.breakpoints.small}px) {\n        min-width: 0;\n        width: 100%;\n      }\n    `}\n\n  @keyframes fadein {\n    from {\n      opacity: 0;\n    }\n    to {\n      opacity: 1;\n    }\n  }\n\n  @keyframes fadeout {\n    from {\n      opacity: 1;\n    }\n    to {\n      opacity: 0;\n    }\n  }\n\n  @keyframes slidein {\n    from {\n      left: -500px;\n    }\n    to {\n      left: 0;\n    }\n  }\n\n  @keyframes slideout {\n    from {\n      left: 0;\n    }\n    to {\n      left: -500px;\n    }\n  }\n\n  a {\n    color: ${props => buildLinkColor(props)};\n    font-weight: 400;\n    text-decoration: underline;\n    &:not([disabled]) {\n      &:focus,\n      &:hover {\n        color: ${props => buildLinkHoverColor(props)};\n      }\n    }\n  }\n`;\r\nconst StyledAlertInner = styled.div `\n  background: ${buildAlertBackground};\n  border: 1px solid ${buildAlertBorder};\n  border-radius: ${props => props.theme.borderRadius};\n  color: ${buildAlertColor};\n  display: flex;\n  position: relative;\n\n  ${props => props.isToast &&\r\n    css `\n      box-shadow: ${props.isInverse\r\n        ? `0 2px 8px 0 ${transparentize(0.3, props.theme.colors.neutral900)}`\r\n        : `0 2px 8px 0 ${transparentize(0.6, props.theme.colors.neutral900)}`};\n      padding-right: 0;\n      height: ${props.theme.spaceScale.spacing11};\n    `}\n`;\r\nconst AlertContents = styled.div `\n  align-items: ${props => (props.additionalContent ? 'center' : '')};\n  align-self: center;\n  flex-grow: 1;\n  font-family: ${props => props.theme.bodyFont};\n  padding: ${props => props.theme.spaceScale.spacing04} 0;\n  display: ${props => (props.additionalContent ? 'flex' : '')};\n  margin-right: ${props => props.additionalContent && !props.isDismissible\r\n    ? props.theme.spaceScale.spacing03\r\n    : ''};\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    padding-left: 0;\n  }\n`;\r\nexport const AdditionalContentWrapper = styled.div `\n  flex: 1 0 auto;\n  justify-content: flex-end;\n  display: flex;\n  margin-left: ${props => props.theme.spaceScale.spacing05};\n`;\r\nconst IconWrapperStyles = css `\n  align-items: center;\n  display: flex;\n  flex-shrink: 0;\n  margin-right: 1px;\n`;\r\nconst IconWrapper = styled.span `\n  ${IconWrapperStyles}\n  padding: 0 ${props => props.theme.spaceScale.spacing03} 0 ${props => props.theme.spaceScale.spacing04};\n\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    padding: 0 ${props => props.theme.spaceScale.spacing03};\n    svg {\n      width: 20px;\n    }\n  }\n`;\r\nconst ProgressRingWrapper = styled.div `\n  margin-top: 6px;\n  position: absolute;\n  top: auto;\n  right: ${props => props.theme.spaceScale.spacing02};\n`;\r\nconst DismissibleIconWrapper = styled.span `\n  ${IconWrapperStyles}\n  margin-left: ${props => props.additionalContent ? props.theme.spaceScale.spacing03 : ''};\n`;\r\nconst whitelistProps = ['icon', 'isInverse', 'theme', 'variant'];\r\nconst shouldForwardProp = prop => {\r\n    return isPropValid(prop) || whitelistProps.includes(prop);\r\n};\r\nconst DismissButton = styled(IconButton, { shouldForwardProp }) `\n  align-self: stretch;\n  border-radius: 0 ${props => props.theme.borderRadius}\n    ${props => props.theme.borderRadius} 0;\n  color: inherit;\n  height: auto;\n  margin: ${props => (props.isToast ? '4px' : '0 -1px 0 0')};\n  padding: ${props => props.isToast\r\n    ? `0 ${props.theme.spaceScale.spacing04}`\r\n    : `0 ${props.theme.spaceScale.spacing03}`};\n  width: auto;\n  &:not(:disabled):hover {\n    background: none;\n    color: inherit;\n  }\n  &:focus:not(:disabled) {\n    background: none;\n    color: inherit;\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n    outline-offset: 0 !important;\n  }\n  &:not(:disabled):active {\n    background: none;\n    color: inherit;\n  }\n`;\r\nconst AlertSpan = styled.span `\n  white-space: pre-line;\n`;\r\nfunction getAriaLabelIcon(variant, i18n) {\r\n    switch (variant) {\r\n        case 'success':\r\n            return i18n.alertVariants.success;\r\n        case 'warning':\r\n            return i18n.alertVariants.warning;\r\n        case 'danger':\r\n            return i18n.alertVariants.danger;\r\n        default:\r\n            return i18n.alertVariants.info;\r\n    }\r\n}\r\nfunction renderIcon(variant = 'info', isToast, theme, i18n) {\r\n    const Icon = VARIANT_ICON[variant];\r\n    return (React.createElement(IconWrapper, { \"aria-label\": getAriaLabelIcon(variant, i18n), role: \"img\", isToast: isToast, theme: theme },\r\n        React.createElement(Icon, { size: theme.iconSizes.medium })));\r\n}\r\nexport const AlertBase = React.forwardRef((props, ref) => {\r\n    const { additionalContent, children, closeAriaLabel, forceDismiss, hasTimerRing, id: defaultId, isDismissed, isDismissible, isExiting: externalIsExiting, isPaused, isToast, onDismiss, testId, toastDuration, variant, ...other } = props;\r\n    const id = useGenerateId(defaultId);\r\n    const [isExiting, setIsExiting] = React.useState(false);\r\n    const isInverse = useIsInverse(props.isInverse);\r\n    React.useEffect(() => {\r\n        if (isExiting) {\r\n            setTimeout(() => {\r\n                setIsExiting(false);\r\n                onDismiss && typeof onDismiss === 'function' && onDismiss();\r\n            }, transitionDuration - 300);\r\n        }\r\n    }, [isExiting]);\r\n    React.useEffect(() => {\r\n        if (isDismissed) {\r\n            handleDismiss();\r\n        }\r\n    }, [isDismissed]);\r\n    function handleDismiss() {\r\n        setIsExiting(true);\r\n    }\r\n    const theme = React.useContext(ThemeContext);\r\n    const i18n = React.useContext(I18nContext);\r\n    function progressRingColor() {\r\n        if (isInverse) {\r\n            return theme.colors.neutral100;\r\n        }\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return theme.colors.success500;\r\n            case 'warning':\r\n                return theme.colors.warning500;\r\n            case 'danger':\r\n                return theme.colors.danger500;\r\n            default:\r\n                return theme.colors.info500;\r\n        }\r\n    }\r\n    return (React.createElement(StyledAlert, Object.assign({}, other, { \"data-testid\": testId, id: id, tabIndex: -1, isInverse: isInverse, isExiting: isExiting, isToast: isToast, ref: ref, theme: theme, variant: variant }),\r\n        React.createElement(InverseContext.Provider, { value: { isInverse } },\r\n            React.createElement(StyledAlertInner, { isInverse: isInverse, isToast: isToast, theme: theme, variant: variant },\r\n                renderIcon(variant, isToast, theme, i18n),\r\n                React.createElement(AlertContents, { additionalContent: additionalContent, isDismissible: isDismissible, theme: theme },\r\n                    React.createElement(AlertSpan, null, children),\r\n                    additionalContent && (React.createElement(AdditionalContentWrapper, { theme: theme }, additionalContent))),\r\n                isDismissible && (React.createElement(DismissibleIconWrapper, { isInverse: isInverse, variant: variant, theme: theme },\r\n                    hasTimerRing && isToast && (React.createElement(ProgressRingWrapper, { theme: theme },\r\n                        React.createElement(ProgressRing, { color: progressRingColor(), isActive: !isPaused, duration: toastDuration }))),\r\n                    React.createElement(DismissButton, Object.assign({ alertVariant: variant }, (isToast\r\n                        ? { title: closeAriaLabel || i18n.alert.dismissAriaLabel }\r\n                        : {\r\n                            'aria-label': closeAriaLabel || i18n.alert.dismissAriaLabel,\r\n                        }), { icon: React.createElement(CloseIcon, { size: hasTimerRing\r\n                                ? theme.iconSizes.xSmall\r\n                                : theme.iconSizes.small }), isInverse: isInverse, isToast: isToast, onClick: forceDismiss || handleDismiss, theme: theme, variant: ButtonVariant.link }))))))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */"));
|
|
3677
3683
|
var ProgressRingWrapper = /*#__PURE__*/_styled("div", {
|
|
3678
3684
|
target: "e126n3g83",
|
|
3679
3685
|
label: "ProgressRingWrapper"
|
|
3680
3686
|
})("margin-top:6px;position:absolute;top:auto;right:", function (props) {
|
|
3681
3687
|
return props.theme.spaceScale.spacing02;
|
|
3682
|
-
}, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAiRuC","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport isPropValid from '@emotion/is-prop-valid';\r\nimport { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport { InfoIcon, CheckCircleIcon, WarningIcon, ErrorIcon, CloseIcon, } from 'react-magma-icons';\r\nimport { I18nContext } from '../../i18n';\r\nimport { InverseContext, useIsInverse } from '../../inverse';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { useGenerateId } from '../../utils';\r\nimport { ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { ProgressRing } from '../ProgressRing';\r\nexport const VARIANT_ICON = {\r\n    info: InfoIcon,\r\n    success: CheckCircleIcon,\r\n    warning: WarningIcon,\r\n    danger: ErrorIcon,\r\n};\r\nexport var AlertVariant;\r\n(function (AlertVariant) {\r\n    AlertVariant[\"info\"] = \"info\";\r\n    AlertVariant[\"success\"] = \"success\";\r\n    AlertVariant[\"warning\"] = \"warning\";\r\n    AlertVariant[\"danger\"] = \"danger\";\r\n})(AlertVariant || (AlertVariant = {}));\r\nexport const transitionDuration = 500;\r\nexport function buildAlertBackground(props) {\r\n    if (props.isInverse) {\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return props.theme.colors.success700;\r\n            case 'warning':\r\n                return props.theme.colors.warning700;\r\n            case 'danger':\r\n                return props.theme.colors.danger700;\r\n            default:\r\n                return props.theme.colors.info700;\r\n        }\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success100;\r\n        case 'warning':\r\n            return props.theme.colors.warning100;\r\n        case 'danger':\r\n            return props.theme.colors.danger100;\r\n        default:\r\n            return props.theme.colors.info100;\r\n    }\r\n}\r\nexport function buildAlertBorder(props) {\r\n    if (props.isInverse) {\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return props.theme.colors.success300;\r\n            case 'warning':\r\n                return props.theme.colors.warning300;\r\n            case 'danger':\r\n                return props.theme.colors.danger200;\r\n            default:\r\n                return props.theme.colors.info300;\r\n        }\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success500;\r\n        case 'warning':\r\n            return props.theme.colors.warning500;\r\n        case 'danger':\r\n            return props.theme.colors.danger500;\r\n        default:\r\n            return props.theme.colors.info500;\r\n    }\r\n}\r\nexport function buildAlertColor(props) {\r\n    if (props.isInverse) {\r\n        return props.theme.colors.neutral100;\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success500;\r\n        case 'warning':\r\n            return props.theme.colors.warning500;\r\n        case 'danger':\r\n            return props.theme.colors.danger500;\r\n        default:\r\n            return props.theme.colors.info500;\r\n    }\r\n}\r\nexport function buildLinkColor(props) {\r\n    if (props.isInverse) {\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return props.theme.colors.success200;\r\n            case 'warning':\r\n                return props.theme.colors.warning200;\r\n            case 'danger':\r\n                return props.theme.colors.danger200;\r\n            default:\r\n                return props.theme.colors.info200;\r\n        }\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success700;\r\n        case 'warning':\r\n            return props.theme.colors.warning700;\r\n        case 'danger':\r\n            return props.theme.colors.danger700;\r\n        default:\r\n            return props.theme.colors.info700;\r\n    }\r\n}\r\nexport function buildLinkHoverColor(props) {\r\n    if (props.isInverse) {\r\n        return props.theme.colors.neutral100;\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success;\r\n        case 'warning':\r\n            return props.theme.colors.warning;\r\n        case 'danger':\r\n            return props.theme.colors.danger;\r\n        default:\r\n            return props.theme.colors.info;\r\n    }\r\n}\r\nconst StyledAlert = styled.div `\n  align-items: stretch;\n  animation: ${props => props.isExiting\r\n    ? `fadeout ${transitionDuration}ms`\r\n    : `fadein ${transitionDuration}ms`};\n  display: flex;\n  flex-direction: column;\n  font-size: ${props => props.theme.typeScale.size03.fontSize};\n  font-family: ${props => props.theme.bodyFont};\n  line-height: ${props => props.theme.typeScale.size03.lineHeight};\n  margin-bottom: ${props => props.theme.spaceScale.spacing06};\n  max-width: 100%;\n  padding: 0;\n  position: relative;\n\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    font-size: ${props => props.theme.typeScale.size02.fontSize};\n    letter-spacing: ${props => props.theme.typeScale.size02.letterSpacing};\n    line-height: ${props => props.theme.typeScale.size02.lineHeight};\n  }\n\n  &:focus {\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n  }\n\n  ${props => props.isToast &&\r\n    css `\n      animation: ${props.isExiting\r\n        ? `slideout ${transitionDuration}ms`\r\n        : `slidein ${transitionDuration}ms`};\n      min-width: 375px;\n      margin: 0 auto;\n\n      @media (max-width: ${props.theme.breakpoints.small}px) {\n        min-width: 0;\n        width: 100%;\n      }\n    `}\n\n  @keyframes fadein {\n    from {\n      opacity: 0;\n    }\n    to {\n      opacity: 1;\n    }\n  }\n\n  @keyframes fadeout {\n    from {\n      opacity: 1;\n    }\n    to {\n      opacity: 0;\n    }\n  }\n\n  @keyframes slidein {\n    from {\n      left: -500px;\n    }\n    to {\n      left: 0;\n    }\n  }\n\n  @keyframes slideout {\n    from {\n      left: 0;\n    }\n    to {\n      left: -500px;\n    }\n  }\n\n  a {\n    color: ${props => buildLinkColor(props)};\n    font-weight: 400;\n    text-decoration: underline;\n    &:not([disabled]) {\n      &:focus,\n      &:hover {\n        color: ${props => buildLinkHoverColor(props)};\n      }\n    }\n  }\n`;\r\nconst StyledAlertInner = styled.div `\n  background: ${buildAlertBackground};\n  border: 1px solid ${buildAlertBorder};\n  border-radius: ${props => props.theme.borderRadius};\n  color: ${buildAlertColor};\n  display: flex;\n  position: relative;\n\n  ${props => props.isToast &&\r\n    css `\n      box-shadow: ${props.isInverse\r\n        ? `0 2px 8px 0 ${transparentize(0.3, props.theme.colors.neutral900)}`\r\n        : `0 2px 8px 0 ${transparentize(0.6, props.theme.colors.neutral900)}`};\n      padding-right: 0;\n      height: ${props.theme.spaceScale.spacing11};\n    `}\n`;\r\nconst AlertContents = styled.div `\n  align-items: ${props => (props.additionalContent ? 'center' : '')};\n  align-self: center;\n  flex-grow: 1;\n  font-family: ${props => props.theme.bodyFont};\n  padding: ${props => props.theme.spaceScale.spacing04} 0;\n  display: ${props => (props.additionalContent ? 'flex' : '')};\n  margin-right: ${props => props.additionalContent && !props.isDismissible\r\n    ? props.theme.spaceScale.spacing03\r\n    : ''};\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    padding-left: 0;\n  }\n`;\r\nexport const AdditionalContentWrapper = styled.div `\n  flex: 1 0 auto;\n  justify-content: flex-end;\n  display: flex;\n  margin-left: ${props => props.theme.spaceScale.spacing05};\n`;\r\nconst IconWrapperStyles = css `\n  align-items: center;\n  display: flex;\n  flex-shrink: 0;\n  margin-right: 1px;\n`;\r\nconst IconWrapper = styled.span `\n  ${IconWrapperStyles}\n  padding: 0 ${props => props.theme.spaceScale.spacing03} 0 ${props => props.theme.spaceScale.spacing04};\n\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    padding: 0 ${props => props.theme.spaceScale.spacing03};\n    svg {\n      width: 20px;\n    }\n  }\n`;\r\nconst ProgressRingWrapper = styled.div `\n  margin-top: 6px;\n  position: absolute;\n  top: auto;\n  right: ${props => props.theme.spaceScale.spacing02};\n`;\r\nconst DismissibleIconWrapper = styled.span `\n  ${IconWrapperStyles}\n  margin-left: ${props => props.additionalContent ? props.theme.spaceScale.spacing03 : ''};\n`;\r\nconst whitelistProps = ['icon', 'isInverse', 'theme', 'variant'];\r\nconst shouldForwardProp = prop => {\r\n    return isPropValid(prop) || whitelistProps.includes(prop);\r\n};\r\nconst DismissButton = styled(IconButton, { shouldForwardProp }) `\n  align-self: stretch;\n  border-radius: 0 ${props => props.theme.borderRadius}\n    ${props => props.theme.borderRadius} 0;\n  color: inherit;\n  height: auto;\n  margin: ${props => (props.isToast ? '4px' : '0 -1px 0 0')};\n  padding: ${props => props.isToast\r\n    ? `0 ${props.theme.spaceScale.spacing04}`\r\n    : `0 ${props.theme.spaceScale.spacing03}`};\n  width: auto;\n  &:not(:disabled):hover {\n    background: none;\n    color: inherit;\n  }\n  &:focus:not(:disabled) {\n    background: none;\n    color: inherit;\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n    outline-offset: 0 !important;\n  }\n  &:not(:disabled):active {\n    background: none;\n    color: inherit;\n  }\n`;\r\nconst AlertSpan = styled.span `\n  white-space: pre-line;\n`;\r\nfunction renderIcon(variant = 'info', isToast, theme) {\r\n    const Icon = VARIANT_ICON[variant];\r\n    return (React.createElement(IconWrapper, { isToast: isToast, theme: theme },\r\n        React.createElement(Icon, { size: theme.iconSizes.medium })));\r\n}\r\nexport const AlertBase = React.forwardRef((props, ref) => {\r\n    const { additionalContent, children, closeAriaLabel, forceDismiss, hasTimerRing, id: defaultId, isDismissed, isDismissible, isExiting: externalIsExiting, isPaused, isToast, onDismiss, testId, toastDuration, variant, ...other } = props;\r\n    const id = useGenerateId(defaultId);\r\n    const [isExiting, setIsExiting] = React.useState(false);\r\n    const isInverse = useIsInverse(props.isInverse);\r\n    React.useEffect(() => {\r\n        if (isExiting) {\r\n            setTimeout(() => {\r\n                setIsExiting(false);\r\n                onDismiss && typeof onDismiss === 'function' && onDismiss();\r\n            }, transitionDuration - 300);\r\n        }\r\n    }, [isExiting]);\r\n    React.useEffect(() => {\r\n        if (isDismissed) {\r\n            handleDismiss();\r\n        }\r\n    }, [isDismissed]);\r\n    function handleDismiss() {\r\n        setIsExiting(true);\r\n    }\r\n    const theme = React.useContext(ThemeContext);\r\n    const i18n = React.useContext(I18nContext);\r\n    function progressRingColor() {\r\n        if (isInverse) {\r\n            return theme.colors.neutral100;\r\n        }\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return theme.colors.success500;\r\n            case 'warning':\r\n                return theme.colors.warning500;\r\n            case 'danger':\r\n                return theme.colors.danger500;\r\n            default:\r\n                return theme.colors.info500;\r\n        }\r\n    }\r\n    return (React.createElement(StyledAlert, Object.assign({}, other, { \"data-testid\": testId, id: id, tabIndex: -1, isInverse: isInverse, isExiting: isExiting, isToast: isToast, ref: ref, theme: theme, variant: variant }),\r\n        React.createElement(InverseContext.Provider, { value: { isInverse } },\r\n            React.createElement(StyledAlertInner, { isInverse: isInverse, isToast: isToast, theme: theme, variant: variant },\r\n                renderIcon(variant, isToast, theme),\r\n                React.createElement(AlertContents, { additionalContent: additionalContent, isDismissible: isDismissible, theme: theme },\r\n                    React.createElement(AlertSpan, null, children),\r\n                    additionalContent && (React.createElement(AdditionalContentWrapper, { theme: theme }, additionalContent))),\r\n                isDismissible && (React.createElement(DismissibleIconWrapper, { isInverse: isInverse, variant: variant, theme: theme },\r\n                    hasTimerRing && isToast && (React.createElement(ProgressRingWrapper, { theme: theme },\r\n                        React.createElement(ProgressRing, { color: progressRingColor(), isActive: !isPaused, duration: toastDuration }))),\r\n                    React.createElement(DismissButton, Object.assign({ alertVariant: variant }, (isToast\r\n                        ? { title: closeAriaLabel || i18n.alert.dismissAriaLabel }\r\n                        : {\r\n                            'aria-label': closeAriaLabel || i18n.alert.dismissAriaLabel,\r\n                        }), { icon: React.createElement(CloseIcon, { size: hasTimerRing\r\n                                ? theme.iconSizes.xSmall\r\n                                : theme.iconSizes.small }), isInverse: isInverse, isToast: isToast, onClick: forceDismiss || handleDismiss, theme: theme, variant: ButtonVariant.link }))))))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */"));
|
|
3688
|
+
}, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAiRuC","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport isPropValid from '@emotion/is-prop-valid';\r\nimport { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport { InfoIcon, CheckCircleIcon, WarningIcon, ErrorIcon, CloseIcon, } from 'react-magma-icons';\r\nimport { I18nContext } from '../..';\r\nimport { InverseContext, useIsInverse } from '../../inverse';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { useGenerateId } from '../../utils';\r\nimport { ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { ProgressRing } from '../ProgressRing';\r\nexport const VARIANT_ICON = {\r\n    info: InfoIcon,\r\n    success: CheckCircleIcon,\r\n    warning: WarningIcon,\r\n    danger: ErrorIcon,\r\n};\r\nexport var AlertVariant;\r\n(function (AlertVariant) {\r\n    AlertVariant[\"info\"] = \"info\";\r\n    AlertVariant[\"success\"] = \"success\";\r\n    AlertVariant[\"warning\"] = \"warning\";\r\n    AlertVariant[\"danger\"] = \"danger\";\r\n})(AlertVariant || (AlertVariant = {}));\r\nexport const transitionDuration = 500;\r\nexport function buildAlertBackground(props) {\r\n    if (props.isInverse) {\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return props.theme.colors.success700;\r\n            case 'warning':\r\n                return props.theme.colors.warning700;\r\n            case 'danger':\r\n                return props.theme.colors.danger700;\r\n            default:\r\n                return props.theme.colors.info700;\r\n        }\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success100;\r\n        case 'warning':\r\n            return props.theme.colors.warning100;\r\n        case 'danger':\r\n            return props.theme.colors.danger100;\r\n        default:\r\n            return props.theme.colors.info100;\r\n    }\r\n}\r\nexport function buildAlertBorder(props) {\r\n    if (props.isInverse) {\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return props.theme.colors.success300;\r\n            case 'warning':\r\n                return props.theme.colors.warning300;\r\n            case 'danger':\r\n                return props.theme.colors.danger200;\r\n            default:\r\n                return props.theme.colors.info300;\r\n        }\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success500;\r\n        case 'warning':\r\n            return props.theme.colors.warning500;\r\n        case 'danger':\r\n            return props.theme.colors.danger500;\r\n        default:\r\n            return props.theme.colors.info500;\r\n    }\r\n}\r\nexport function buildAlertColor(props) {\r\n    if (props.isInverse) {\r\n        return props.theme.colors.neutral100;\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success500;\r\n        case 'warning':\r\n            return props.theme.colors.warning500;\r\n        case 'danger':\r\n            return props.theme.colors.danger500;\r\n        default:\r\n            return props.theme.colors.info500;\r\n    }\r\n}\r\nexport function buildLinkColor(props) {\r\n    if (props.isInverse) {\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return props.theme.colors.success200;\r\n            case 'warning':\r\n                return props.theme.colors.warning200;\r\n            case 'danger':\r\n                return props.theme.colors.danger200;\r\n            default:\r\n                return props.theme.colors.info200;\r\n        }\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success700;\r\n        case 'warning':\r\n            return props.theme.colors.warning700;\r\n        case 'danger':\r\n            return props.theme.colors.danger700;\r\n        default:\r\n            return props.theme.colors.info700;\r\n    }\r\n}\r\nexport function buildLinkHoverColor(props) {\r\n    if (props.isInverse) {\r\n        return props.theme.colors.neutral100;\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success;\r\n        case 'warning':\r\n            return props.theme.colors.warning;\r\n        case 'danger':\r\n            return props.theme.colors.danger;\r\n        default:\r\n            return props.theme.colors.info;\r\n    }\r\n}\r\nconst StyledAlert = styled.div `\n  align-items: stretch;\n  animation: ${props => props.isExiting\r\n    ? `fadeout ${transitionDuration}ms`\r\n    : `fadein ${transitionDuration}ms`};\n  display: flex;\n  flex-direction: column;\n  font-size: ${props => props.theme.typeScale.size03.fontSize};\n  font-family: ${props => props.theme.bodyFont};\n  line-height: ${props => props.theme.typeScale.size03.lineHeight};\n  margin-bottom: ${props => props.theme.spaceScale.spacing06};\n  max-width: 100%;\n  padding: 0;\n  position: relative;\n\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    font-size: ${props => props.theme.typeScale.size02.fontSize};\n    letter-spacing: ${props => props.theme.typeScale.size02.letterSpacing};\n    line-height: ${props => props.theme.typeScale.size02.lineHeight};\n  }\n\n  &:focus {\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n  }\n\n  ${props => props.isToast &&\r\n    css `\n      animation: ${props.isExiting\r\n        ? `slideout ${transitionDuration}ms`\r\n        : `slidein ${transitionDuration}ms`};\n      min-width: 375px;\n      margin: 0 auto;\n\n      @media (max-width: ${props.theme.breakpoints.small}px) {\n        min-width: 0;\n        width: 100%;\n      }\n    `}\n\n  @keyframes fadein {\n    from {\n      opacity: 0;\n    }\n    to {\n      opacity: 1;\n    }\n  }\n\n  @keyframes fadeout {\n    from {\n      opacity: 1;\n    }\n    to {\n      opacity: 0;\n    }\n  }\n\n  @keyframes slidein {\n    from {\n      left: -500px;\n    }\n    to {\n      left: 0;\n    }\n  }\n\n  @keyframes slideout {\n    from {\n      left: 0;\n    }\n    to {\n      left: -500px;\n    }\n  }\n\n  a {\n    color: ${props => buildLinkColor(props)};\n    font-weight: 400;\n    text-decoration: underline;\n    &:not([disabled]) {\n      &:focus,\n      &:hover {\n        color: ${props => buildLinkHoverColor(props)};\n      }\n    }\n  }\n`;\r\nconst StyledAlertInner = styled.div `\n  background: ${buildAlertBackground};\n  border: 1px solid ${buildAlertBorder};\n  border-radius: ${props => props.theme.borderRadius};\n  color: ${buildAlertColor};\n  display: flex;\n  position: relative;\n\n  ${props => props.isToast &&\r\n    css `\n      box-shadow: ${props.isInverse\r\n        ? `0 2px 8px 0 ${transparentize(0.3, props.theme.colors.neutral900)}`\r\n        : `0 2px 8px 0 ${transparentize(0.6, props.theme.colors.neutral900)}`};\n      padding-right: 0;\n      height: ${props.theme.spaceScale.spacing11};\n    `}\n`;\r\nconst AlertContents = styled.div `\n  align-items: ${props => (props.additionalContent ? 'center' : '')};\n  align-self: center;\n  flex-grow: 1;\n  font-family: ${props => props.theme.bodyFont};\n  padding: ${props => props.theme.spaceScale.spacing04} 0;\n  display: ${props => (props.additionalContent ? 'flex' : '')};\n  margin-right: ${props => props.additionalContent && !props.isDismissible\r\n    ? props.theme.spaceScale.spacing03\r\n    : ''};\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    padding-left: 0;\n  }\n`;\r\nexport const AdditionalContentWrapper = styled.div `\n  flex: 1 0 auto;\n  justify-content: flex-end;\n  display: flex;\n  margin-left: ${props => props.theme.spaceScale.spacing05};\n`;\r\nconst IconWrapperStyles = css `\n  align-items: center;\n  display: flex;\n  flex-shrink: 0;\n  margin-right: 1px;\n`;\r\nconst IconWrapper = styled.span `\n  ${IconWrapperStyles}\n  padding: 0 ${props => props.theme.spaceScale.spacing03} 0 ${props => props.theme.spaceScale.spacing04};\n\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    padding: 0 ${props => props.theme.spaceScale.spacing03};\n    svg {\n      width: 20px;\n    }\n  }\n`;\r\nconst ProgressRingWrapper = styled.div `\n  margin-top: 6px;\n  position: absolute;\n  top: auto;\n  right: ${props => props.theme.spaceScale.spacing02};\n`;\r\nconst DismissibleIconWrapper = styled.span `\n  ${IconWrapperStyles}\n  margin-left: ${props => props.additionalContent ? props.theme.spaceScale.spacing03 : ''};\n`;\r\nconst whitelistProps = ['icon', 'isInverse', 'theme', 'variant'];\r\nconst shouldForwardProp = prop => {\r\n    return isPropValid(prop) || whitelistProps.includes(prop);\r\n};\r\nconst DismissButton = styled(IconButton, { shouldForwardProp }) `\n  align-self: stretch;\n  border-radius: 0 ${props => props.theme.borderRadius}\n    ${props => props.theme.borderRadius} 0;\n  color: inherit;\n  height: auto;\n  margin: ${props => (props.isToast ? '4px' : '0 -1px 0 0')};\n  padding: ${props => props.isToast\r\n    ? `0 ${props.theme.spaceScale.spacing04}`\r\n    : `0 ${props.theme.spaceScale.spacing03}`};\n  width: auto;\n  &:not(:disabled):hover {\n    background: none;\n    color: inherit;\n  }\n  &:focus:not(:disabled) {\n    background: none;\n    color: inherit;\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n    outline-offset: 0 !important;\n  }\n  &:not(:disabled):active {\n    background: none;\n    color: inherit;\n  }\n`;\r\nconst AlertSpan = styled.span `\n  white-space: pre-line;\n`;\r\nfunction getAriaLabelIcon(variant, i18n) {\r\n    switch (variant) {\r\n        case 'success':\r\n            return i18n.alertVariants.success;\r\n        case 'warning':\r\n            return i18n.alertVariants.warning;\r\n        case 'danger':\r\n            return i18n.alertVariants.danger;\r\n        default:\r\n            return i18n.alertVariants.info;\r\n    }\r\n}\r\nfunction renderIcon(variant = 'info', isToast, theme, i18n) {\r\n    const Icon = VARIANT_ICON[variant];\r\n    return (React.createElement(IconWrapper, { \"aria-label\": getAriaLabelIcon(variant, i18n), role: \"img\", isToast: isToast, theme: theme },\r\n        React.createElement(Icon, { size: theme.iconSizes.medium })));\r\n}\r\nexport const AlertBase = React.forwardRef((props, ref) => {\r\n    const { additionalContent, children, closeAriaLabel, forceDismiss, hasTimerRing, id: defaultId, isDismissed, isDismissible, isExiting: externalIsExiting, isPaused, isToast, onDismiss, testId, toastDuration, variant, ...other } = props;\r\n    const id = useGenerateId(defaultId);\r\n    const [isExiting, setIsExiting] = React.useState(false);\r\n    const isInverse = useIsInverse(props.isInverse);\r\n    React.useEffect(() => {\r\n        if (isExiting) {\r\n            setTimeout(() => {\r\n                setIsExiting(false);\r\n                onDismiss && typeof onDismiss === 'function' && onDismiss();\r\n            }, transitionDuration - 300);\r\n        }\r\n    }, [isExiting]);\r\n    React.useEffect(() => {\r\n        if (isDismissed) {\r\n            handleDismiss();\r\n        }\r\n    }, [isDismissed]);\r\n    function handleDismiss() {\r\n        setIsExiting(true);\r\n    }\r\n    const theme = React.useContext(ThemeContext);\r\n    const i18n = React.useContext(I18nContext);\r\n    function progressRingColor() {\r\n        if (isInverse) {\r\n            return theme.colors.neutral100;\r\n        }\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return theme.colors.success500;\r\n            case 'warning':\r\n                return theme.colors.warning500;\r\n            case 'danger':\r\n                return theme.colors.danger500;\r\n            default:\r\n                return theme.colors.info500;\r\n        }\r\n    }\r\n    return (React.createElement(StyledAlert, Object.assign({}, other, { \"data-testid\": testId, id: id, tabIndex: -1, isInverse: isInverse, isExiting: isExiting, isToast: isToast, ref: ref, theme: theme, variant: variant }),\r\n        React.createElement(InverseContext.Provider, { value: { isInverse } },\r\n            React.createElement(StyledAlertInner, { isInverse: isInverse, isToast: isToast, theme: theme, variant: variant },\r\n                renderIcon(variant, isToast, theme, i18n),\r\n                React.createElement(AlertContents, { additionalContent: additionalContent, isDismissible: isDismissible, theme: theme },\r\n                    React.createElement(AlertSpan, null, children),\r\n                    additionalContent && (React.createElement(AdditionalContentWrapper, { theme: theme }, additionalContent))),\r\n                isDismissible && (React.createElement(DismissibleIconWrapper, { isInverse: isInverse, variant: variant, theme: theme },\r\n                    hasTimerRing && isToast && (React.createElement(ProgressRingWrapper, { theme: theme },\r\n                        React.createElement(ProgressRing, { color: progressRingColor(), isActive: !isPaused, duration: toastDuration }))),\r\n                    React.createElement(DismissButton, Object.assign({ alertVariant: variant }, (isToast\r\n                        ? { title: closeAriaLabel || i18n.alert.dismissAriaLabel }\r\n                        : {\r\n                            'aria-label': closeAriaLabel || i18n.alert.dismissAriaLabel,\r\n                        }), { icon: React.createElement(CloseIcon, { size: hasTimerRing\r\n                                ? theme.iconSizes.xSmall\r\n                                : theme.iconSizes.small }), isInverse: isInverse, isToast: isToast, onClick: forceDismiss || handleDismiss, theme: theme, variant: ButtonVariant.link }))))))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */"));
|
|
3683
3689
|
var DismissibleIconWrapper = /*#__PURE__*/_styled("span", {
|
|
3684
3690
|
target: "e126n3g82",
|
|
3685
3691
|
label: "DismissibleIconWrapper"
|
|
3686
3692
|
})(IconWrapperStyles, " margin-left:", function (props) {
|
|
3687
3693
|
return props.additionalContent ? props.theme.spaceScale.spacing03 : '';
|
|
3688
|
-
}, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAuR2C","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport isPropValid from '@emotion/is-prop-valid';\r\nimport { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport { InfoIcon, CheckCircleIcon, WarningIcon, ErrorIcon, CloseIcon, } from 'react-magma-icons';\r\nimport { I18nContext } from '../../i18n';\r\nimport { InverseContext, useIsInverse } from '../../inverse';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { useGenerateId } from '../../utils';\r\nimport { ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { ProgressRing } from '../ProgressRing';\r\nexport const VARIANT_ICON = {\r\n    info: InfoIcon,\r\n    success: CheckCircleIcon,\r\n    warning: WarningIcon,\r\n    danger: ErrorIcon,\r\n};\r\nexport var AlertVariant;\r\n(function (AlertVariant) {\r\n    AlertVariant[\"info\"] = \"info\";\r\n    AlertVariant[\"success\"] = \"success\";\r\n    AlertVariant[\"warning\"] = \"warning\";\r\n    AlertVariant[\"danger\"] = \"danger\";\r\n})(AlertVariant || (AlertVariant = {}));\r\nexport const transitionDuration = 500;\r\nexport function buildAlertBackground(props) {\r\n    if (props.isInverse) {\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return props.theme.colors.success700;\r\n            case 'warning':\r\n                return props.theme.colors.warning700;\r\n            case 'danger':\r\n                return props.theme.colors.danger700;\r\n            default:\r\n                return props.theme.colors.info700;\r\n        }\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success100;\r\n        case 'warning':\r\n            return props.theme.colors.warning100;\r\n        case 'danger':\r\n            return props.theme.colors.danger100;\r\n        default:\r\n            return props.theme.colors.info100;\r\n    }\r\n}\r\nexport function buildAlertBorder(props) {\r\n    if (props.isInverse) {\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return props.theme.colors.success300;\r\n            case 'warning':\r\n                return props.theme.colors.warning300;\r\n            case 'danger':\r\n                return props.theme.colors.danger200;\r\n            default:\r\n                return props.theme.colors.info300;\r\n        }\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success500;\r\n        case 'warning':\r\n            return props.theme.colors.warning500;\r\n        case 'danger':\r\n            return props.theme.colors.danger500;\r\n        default:\r\n            return props.theme.colors.info500;\r\n    }\r\n}\r\nexport function buildAlertColor(props) {\r\n    if (props.isInverse) {\r\n        return props.theme.colors.neutral100;\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success500;\r\n        case 'warning':\r\n            return props.theme.colors.warning500;\r\n        case 'danger':\r\n            return props.theme.colors.danger500;\r\n        default:\r\n            return props.theme.colors.info500;\r\n    }\r\n}\r\nexport function buildLinkColor(props) {\r\n    if (props.isInverse) {\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return props.theme.colors.success200;\r\n            case 'warning':\r\n                return props.theme.colors.warning200;\r\n            case 'danger':\r\n                return props.theme.colors.danger200;\r\n            default:\r\n                return props.theme.colors.info200;\r\n        }\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success700;\r\n        case 'warning':\r\n            return props.theme.colors.warning700;\r\n        case 'danger':\r\n            return props.theme.colors.danger700;\r\n        default:\r\n            return props.theme.colors.info700;\r\n    }\r\n}\r\nexport function buildLinkHoverColor(props) {\r\n    if (props.isInverse) {\r\n        return props.theme.colors.neutral100;\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success;\r\n        case 'warning':\r\n            return props.theme.colors.warning;\r\n        case 'danger':\r\n            return props.theme.colors.danger;\r\n        default:\r\n            return props.theme.colors.info;\r\n    }\r\n}\r\nconst StyledAlert = styled.div `\n  align-items: stretch;\n  animation: ${props => props.isExiting\r\n    ? `fadeout ${transitionDuration}ms`\r\n    : `fadein ${transitionDuration}ms`};\n  display: flex;\n  flex-direction: column;\n  font-size: ${props => props.theme.typeScale.size03.fontSize};\n  font-family: ${props => props.theme.bodyFont};\n  line-height: ${props => props.theme.typeScale.size03.lineHeight};\n  margin-bottom: ${props => props.theme.spaceScale.spacing06};\n  max-width: 100%;\n  padding: 0;\n  position: relative;\n\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    font-size: ${props => props.theme.typeScale.size02.fontSize};\n    letter-spacing: ${props => props.theme.typeScale.size02.letterSpacing};\n    line-height: ${props => props.theme.typeScale.size02.lineHeight};\n  }\n\n  &:focus {\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n  }\n\n  ${props => props.isToast &&\r\n    css `\n      animation: ${props.isExiting\r\n        ? `slideout ${transitionDuration}ms`\r\n        : `slidein ${transitionDuration}ms`};\n      min-width: 375px;\n      margin: 0 auto;\n\n      @media (max-width: ${props.theme.breakpoints.small}px) {\n        min-width: 0;\n        width: 100%;\n      }\n    `}\n\n  @keyframes fadein {\n    from {\n      opacity: 0;\n    }\n    to {\n      opacity: 1;\n    }\n  }\n\n  @keyframes fadeout {\n    from {\n      opacity: 1;\n    }\n    to {\n      opacity: 0;\n    }\n  }\n\n  @keyframes slidein {\n    from {\n      left: -500px;\n    }\n    to {\n      left: 0;\n    }\n  }\n\n  @keyframes slideout {\n    from {\n      left: 0;\n    }\n    to {\n      left: -500px;\n    }\n  }\n\n  a {\n    color: ${props => buildLinkColor(props)};\n    font-weight: 400;\n    text-decoration: underline;\n    &:not([disabled]) {\n      &:focus,\n      &:hover {\n        color: ${props => buildLinkHoverColor(props)};\n      }\n    }\n  }\n`;\r\nconst StyledAlertInner = styled.div `\n  background: ${buildAlertBackground};\n  border: 1px solid ${buildAlertBorder};\n  border-radius: ${props => props.theme.borderRadius};\n  color: ${buildAlertColor};\n  display: flex;\n  position: relative;\n\n  ${props => props.isToast &&\r\n    css `\n      box-shadow: ${props.isInverse\r\n        ? `0 2px 8px 0 ${transparentize(0.3, props.theme.colors.neutral900)}`\r\n        : `0 2px 8px 0 ${transparentize(0.6, props.theme.colors.neutral900)}`};\n      padding-right: 0;\n      height: ${props.theme.spaceScale.spacing11};\n    `}\n`;\r\nconst AlertContents = styled.div `\n  align-items: ${props => (props.additionalContent ? 'center' : '')};\n  align-self: center;\n  flex-grow: 1;\n  font-family: ${props => props.theme.bodyFont};\n  padding: ${props => props.theme.spaceScale.spacing04} 0;\n  display: ${props => (props.additionalContent ? 'flex' : '')};\n  margin-right: ${props => props.additionalContent && !props.isDismissible\r\n    ? props.theme.spaceScale.spacing03\r\n    : ''};\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    padding-left: 0;\n  }\n`;\r\nexport const AdditionalContentWrapper = styled.div `\n  flex: 1 0 auto;\n  justify-content: flex-end;\n  display: flex;\n  margin-left: ${props => props.theme.spaceScale.spacing05};\n`;\r\nconst IconWrapperStyles = css `\n  align-items: center;\n  display: flex;\n  flex-shrink: 0;\n  margin-right: 1px;\n`;\r\nconst IconWrapper = styled.span `\n  ${IconWrapperStyles}\n  padding: 0 ${props => props.theme.spaceScale.spacing03} 0 ${props => props.theme.spaceScale.spacing04};\n\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    padding: 0 ${props => props.theme.spaceScale.spacing03};\n    svg {\n      width: 20px;\n    }\n  }\n`;\r\nconst ProgressRingWrapper = styled.div `\n  margin-top: 6px;\n  position: absolute;\n  top: auto;\n  right: ${props => props.theme.spaceScale.spacing02};\n`;\r\nconst DismissibleIconWrapper = styled.span `\n  ${IconWrapperStyles}\n  margin-left: ${props => props.additionalContent ? props.theme.spaceScale.spacing03 : ''};\n`;\r\nconst whitelistProps = ['icon', 'isInverse', 'theme', 'variant'];\r\nconst shouldForwardProp = prop => {\r\n    return isPropValid(prop) || whitelistProps.includes(prop);\r\n};\r\nconst DismissButton = styled(IconButton, { shouldForwardProp }) `\n  align-self: stretch;\n  border-radius: 0 ${props => props.theme.borderRadius}\n    ${props => props.theme.borderRadius} 0;\n  color: inherit;\n  height: auto;\n  margin: ${props => (props.isToast ? '4px' : '0 -1px 0 0')};\n  padding: ${props => props.isToast\r\n    ? `0 ${props.theme.spaceScale.spacing04}`\r\n    : `0 ${props.theme.spaceScale.spacing03}`};\n  width: auto;\n  &:not(:disabled):hover {\n    background: none;\n    color: inherit;\n  }\n  &:focus:not(:disabled) {\n    background: none;\n    color: inherit;\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n    outline-offset: 0 !important;\n  }\n  &:not(:disabled):active {\n    background: none;\n    color: inherit;\n  }\n`;\r\nconst AlertSpan = styled.span `\n  white-space: pre-line;\n`;\r\nfunction renderIcon(variant = 'info', isToast, theme) {\r\n    const Icon = VARIANT_ICON[variant];\r\n    return (React.createElement(IconWrapper, { isToast: isToast, theme: theme },\r\n        React.createElement(Icon, { size: theme.iconSizes.medium })));\r\n}\r\nexport const AlertBase = React.forwardRef((props, ref) => {\r\n    const { additionalContent, children, closeAriaLabel, forceDismiss, hasTimerRing, id: defaultId, isDismissed, isDismissible, isExiting: externalIsExiting, isPaused, isToast, onDismiss, testId, toastDuration, variant, ...other } = props;\r\n    const id = useGenerateId(defaultId);\r\n    const [isExiting, setIsExiting] = React.useState(false);\r\n    const isInverse = useIsInverse(props.isInverse);\r\n    React.useEffect(() => {\r\n        if (isExiting) {\r\n            setTimeout(() => {\r\n                setIsExiting(false);\r\n                onDismiss && typeof onDismiss === 'function' && onDismiss();\r\n            }, transitionDuration - 300);\r\n        }\r\n    }, [isExiting]);\r\n    React.useEffect(() => {\r\n        if (isDismissed) {\r\n            handleDismiss();\r\n        }\r\n    }, [isDismissed]);\r\n    function handleDismiss() {\r\n        setIsExiting(true);\r\n    }\r\n    const theme = React.useContext(ThemeContext);\r\n    const i18n = React.useContext(I18nContext);\r\n    function progressRingColor() {\r\n        if (isInverse) {\r\n            return theme.colors.neutral100;\r\n        }\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return theme.colors.success500;\r\n            case 'warning':\r\n                return theme.colors.warning500;\r\n            case 'danger':\r\n                return theme.colors.danger500;\r\n            default:\r\n                return theme.colors.info500;\r\n        }\r\n    }\r\n    return (React.createElement(StyledAlert, Object.assign({}, other, { \"data-testid\": testId, id: id, tabIndex: -1, isInverse: isInverse, isExiting: isExiting, isToast: isToast, ref: ref, theme: theme, variant: variant }),\r\n        React.createElement(InverseContext.Provider, { value: { isInverse } },\r\n            React.createElement(StyledAlertInner, { isInverse: isInverse, isToast: isToast, theme: theme, variant: variant },\r\n                renderIcon(variant, isToast, theme),\r\n                React.createElement(AlertContents, { additionalContent: additionalContent, isDismissible: isDismissible, theme: theme },\r\n                    React.createElement(AlertSpan, null, children),\r\n                    additionalContent && (React.createElement(AdditionalContentWrapper, { theme: theme }, additionalContent))),\r\n                isDismissible && (React.createElement(DismissibleIconWrapper, { isInverse: isInverse, variant: variant, theme: theme },\r\n                    hasTimerRing && isToast && (React.createElement(ProgressRingWrapper, { theme: theme },\r\n                        React.createElement(ProgressRing, { color: progressRingColor(), isActive: !isPaused, duration: toastDuration }))),\r\n                    React.createElement(DismissButton, Object.assign({ alertVariant: variant }, (isToast\r\n                        ? { title: closeAriaLabel || i18n.alert.dismissAriaLabel }\r\n                        : {\r\n                            'aria-label': closeAriaLabel || i18n.alert.dismissAriaLabel,\r\n                        }), { icon: React.createElement(CloseIcon, { size: hasTimerRing\r\n                                ? theme.iconSizes.xSmall\r\n                                : theme.iconSizes.small }), isInverse: isInverse, isToast: isToast, onClick: forceDismiss || handleDismiss, theme: theme, variant: ButtonVariant.link }))))))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */"));
|
|
3694
|
+
}, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAuR2C","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport isPropValid from '@emotion/is-prop-valid';\r\nimport { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport { InfoIcon, CheckCircleIcon, WarningIcon, ErrorIcon, CloseIcon, } from 'react-magma-icons';\r\nimport { I18nContext } from '../..';\r\nimport { InverseContext, useIsInverse } from '../../inverse';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { useGenerateId } from '../../utils';\r\nimport { ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { ProgressRing } from '../ProgressRing';\r\nexport const VARIANT_ICON = {\r\n    info: InfoIcon,\r\n    success: CheckCircleIcon,\r\n    warning: WarningIcon,\r\n    danger: ErrorIcon,\r\n};\r\nexport var AlertVariant;\r\n(function (AlertVariant) {\r\n    AlertVariant[\"info\"] = \"info\";\r\n    AlertVariant[\"success\"] = \"success\";\r\n    AlertVariant[\"warning\"] = \"warning\";\r\n    AlertVariant[\"danger\"] = \"danger\";\r\n})(AlertVariant || (AlertVariant = {}));\r\nexport const transitionDuration = 500;\r\nexport function buildAlertBackground(props) {\r\n    if (props.isInverse) {\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return props.theme.colors.success700;\r\n            case 'warning':\r\n                return props.theme.colors.warning700;\r\n            case 'danger':\r\n                return props.theme.colors.danger700;\r\n            default:\r\n                return props.theme.colors.info700;\r\n        }\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success100;\r\n        case 'warning':\r\n            return props.theme.colors.warning100;\r\n        case 'danger':\r\n            return props.theme.colors.danger100;\r\n        default:\r\n            return props.theme.colors.info100;\r\n    }\r\n}\r\nexport function buildAlertBorder(props) {\r\n    if (props.isInverse) {\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return props.theme.colors.success300;\r\n            case 'warning':\r\n                return props.theme.colors.warning300;\r\n            case 'danger':\r\n                return props.theme.colors.danger200;\r\n            default:\r\n                return props.theme.colors.info300;\r\n        }\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success500;\r\n        case 'warning':\r\n            return props.theme.colors.warning500;\r\n        case 'danger':\r\n            return props.theme.colors.danger500;\r\n        default:\r\n            return props.theme.colors.info500;\r\n    }\r\n}\r\nexport function buildAlertColor(props) {\r\n    if (props.isInverse) {\r\n        return props.theme.colors.neutral100;\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success500;\r\n        case 'warning':\r\n            return props.theme.colors.warning500;\r\n        case 'danger':\r\n            return props.theme.colors.danger500;\r\n        default:\r\n            return props.theme.colors.info500;\r\n    }\r\n}\r\nexport function buildLinkColor(props) {\r\n    if (props.isInverse) {\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return props.theme.colors.success200;\r\n            case 'warning':\r\n                return props.theme.colors.warning200;\r\n            case 'danger':\r\n                return props.theme.colors.danger200;\r\n            default:\r\n                return props.theme.colors.info200;\r\n        }\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success700;\r\n        case 'warning':\r\n            return props.theme.colors.warning700;\r\n        case 'danger':\r\n            return props.theme.colors.danger700;\r\n        default:\r\n            return props.theme.colors.info700;\r\n    }\r\n}\r\nexport function buildLinkHoverColor(props) {\r\n    if (props.isInverse) {\r\n        return props.theme.colors.neutral100;\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success;\r\n        case 'warning':\r\n            return props.theme.colors.warning;\r\n        case 'danger':\r\n            return props.theme.colors.danger;\r\n        default:\r\n            return props.theme.colors.info;\r\n    }\r\n}\r\nconst StyledAlert = styled.div `\n  align-items: stretch;\n  animation: ${props => props.isExiting\r\n    ? `fadeout ${transitionDuration}ms`\r\n    : `fadein ${transitionDuration}ms`};\n  display: flex;\n  flex-direction: column;\n  font-size: ${props => props.theme.typeScale.size03.fontSize};\n  font-family: ${props => props.theme.bodyFont};\n  line-height: ${props => props.theme.typeScale.size03.lineHeight};\n  margin-bottom: ${props => props.theme.spaceScale.spacing06};\n  max-width: 100%;\n  padding: 0;\n  position: relative;\n\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    font-size: ${props => props.theme.typeScale.size02.fontSize};\n    letter-spacing: ${props => props.theme.typeScale.size02.letterSpacing};\n    line-height: ${props => props.theme.typeScale.size02.lineHeight};\n  }\n\n  &:focus {\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n  }\n\n  ${props => props.isToast &&\r\n    css `\n      animation: ${props.isExiting\r\n        ? `slideout ${transitionDuration}ms`\r\n        : `slidein ${transitionDuration}ms`};\n      min-width: 375px;\n      margin: 0 auto;\n\n      @media (max-width: ${props.theme.breakpoints.small}px) {\n        min-width: 0;\n        width: 100%;\n      }\n    `}\n\n  @keyframes fadein {\n    from {\n      opacity: 0;\n    }\n    to {\n      opacity: 1;\n    }\n  }\n\n  @keyframes fadeout {\n    from {\n      opacity: 1;\n    }\n    to {\n      opacity: 0;\n    }\n  }\n\n  @keyframes slidein {\n    from {\n      left: -500px;\n    }\n    to {\n      left: 0;\n    }\n  }\n\n  @keyframes slideout {\n    from {\n      left: 0;\n    }\n    to {\n      left: -500px;\n    }\n  }\n\n  a {\n    color: ${props => buildLinkColor(props)};\n    font-weight: 400;\n    text-decoration: underline;\n    &:not([disabled]) {\n      &:focus,\n      &:hover {\n        color: ${props => buildLinkHoverColor(props)};\n      }\n    }\n  }\n`;\r\nconst StyledAlertInner = styled.div `\n  background: ${buildAlertBackground};\n  border: 1px solid ${buildAlertBorder};\n  border-radius: ${props => props.theme.borderRadius};\n  color: ${buildAlertColor};\n  display: flex;\n  position: relative;\n\n  ${props => props.isToast &&\r\n    css `\n      box-shadow: ${props.isInverse\r\n        ? `0 2px 8px 0 ${transparentize(0.3, props.theme.colors.neutral900)}`\r\n        : `0 2px 8px 0 ${transparentize(0.6, props.theme.colors.neutral900)}`};\n      padding-right: 0;\n      height: ${props.theme.spaceScale.spacing11};\n    `}\n`;\r\nconst AlertContents = styled.div `\n  align-items: ${props => (props.additionalContent ? 'center' : '')};\n  align-self: center;\n  flex-grow: 1;\n  font-family: ${props => props.theme.bodyFont};\n  padding: ${props => props.theme.spaceScale.spacing04} 0;\n  display: ${props => (props.additionalContent ? 'flex' : '')};\n  margin-right: ${props => props.additionalContent && !props.isDismissible\r\n    ? props.theme.spaceScale.spacing03\r\n    : ''};\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    padding-left: 0;\n  }\n`;\r\nexport const AdditionalContentWrapper = styled.div `\n  flex: 1 0 auto;\n  justify-content: flex-end;\n  display: flex;\n  margin-left: ${props => props.theme.spaceScale.spacing05};\n`;\r\nconst IconWrapperStyles = css `\n  align-items: center;\n  display: flex;\n  flex-shrink: 0;\n  margin-right: 1px;\n`;\r\nconst IconWrapper = styled.span `\n  ${IconWrapperStyles}\n  padding: 0 ${props => props.theme.spaceScale.spacing03} 0 ${props => props.theme.spaceScale.spacing04};\n\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    padding: 0 ${props => props.theme.spaceScale.spacing03};\n    svg {\n      width: 20px;\n    }\n  }\n`;\r\nconst ProgressRingWrapper = styled.div `\n  margin-top: 6px;\n  position: absolute;\n  top: auto;\n  right: ${props => props.theme.spaceScale.spacing02};\n`;\r\nconst DismissibleIconWrapper = styled.span `\n  ${IconWrapperStyles}\n  margin-left: ${props => props.additionalContent ? props.theme.spaceScale.spacing03 : ''};\n`;\r\nconst whitelistProps = ['icon', 'isInverse', 'theme', 'variant'];\r\nconst shouldForwardProp = prop => {\r\n    return isPropValid(prop) || whitelistProps.includes(prop);\r\n};\r\nconst DismissButton = styled(IconButton, { shouldForwardProp }) `\n  align-self: stretch;\n  border-radius: 0 ${props => props.theme.borderRadius}\n    ${props => props.theme.borderRadius} 0;\n  color: inherit;\n  height: auto;\n  margin: ${props => (props.isToast ? '4px' : '0 -1px 0 0')};\n  padding: ${props => props.isToast\r\n    ? `0 ${props.theme.spaceScale.spacing04}`\r\n    : `0 ${props.theme.spaceScale.spacing03}`};\n  width: auto;\n  &:not(:disabled):hover {\n    background: none;\n    color: inherit;\n  }\n  &:focus:not(:disabled) {\n    background: none;\n    color: inherit;\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n    outline-offset: 0 !important;\n  }\n  &:not(:disabled):active {\n    background: none;\n    color: inherit;\n  }\n`;\r\nconst AlertSpan = styled.span `\n  white-space: pre-line;\n`;\r\nfunction getAriaLabelIcon(variant, i18n) {\r\n    switch (variant) {\r\n        case 'success':\r\n            return i18n.alertVariants.success;\r\n        case 'warning':\r\n            return i18n.alertVariants.warning;\r\n        case 'danger':\r\n            return i18n.alertVariants.danger;\r\n        default:\r\n            return i18n.alertVariants.info;\r\n    }\r\n}\r\nfunction renderIcon(variant = 'info', isToast, theme, i18n) {\r\n    const Icon = VARIANT_ICON[variant];\r\n    return (React.createElement(IconWrapper, { \"aria-label\": getAriaLabelIcon(variant, i18n), role: \"img\", isToast: isToast, theme: theme },\r\n        React.createElement(Icon, { size: theme.iconSizes.medium })));\r\n}\r\nexport const AlertBase = React.forwardRef((props, ref) => {\r\n    const { additionalContent, children, closeAriaLabel, forceDismiss, hasTimerRing, id: defaultId, isDismissed, isDismissible, isExiting: externalIsExiting, isPaused, isToast, onDismiss, testId, toastDuration, variant, ...other } = props;\r\n    const id = useGenerateId(defaultId);\r\n    const [isExiting, setIsExiting] = React.useState(false);\r\n    const isInverse = useIsInverse(props.isInverse);\r\n    React.useEffect(() => {\r\n        if (isExiting) {\r\n            setTimeout(() => {\r\n                setIsExiting(false);\r\n                onDismiss && typeof onDismiss === 'function' && onDismiss();\r\n            }, transitionDuration - 300);\r\n        }\r\n    }, [isExiting]);\r\n    React.useEffect(() => {\r\n        if (isDismissed) {\r\n            handleDismiss();\r\n        }\r\n    }, [isDismissed]);\r\n    function handleDismiss() {\r\n        setIsExiting(true);\r\n    }\r\n    const theme = React.useContext(ThemeContext);\r\n    const i18n = React.useContext(I18nContext);\r\n    function progressRingColor() {\r\n        if (isInverse) {\r\n            return theme.colors.neutral100;\r\n        }\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return theme.colors.success500;\r\n            case 'warning':\r\n                return theme.colors.warning500;\r\n            case 'danger':\r\n                return theme.colors.danger500;\r\n            default:\r\n                return theme.colors.info500;\r\n        }\r\n    }\r\n    return (React.createElement(StyledAlert, Object.assign({}, other, { \"data-testid\": testId, id: id, tabIndex: -1, isInverse: isInverse, isExiting: isExiting, isToast: isToast, ref: ref, theme: theme, variant: variant }),\r\n        React.createElement(InverseContext.Provider, { value: { isInverse } },\r\n            React.createElement(StyledAlertInner, { isInverse: isInverse, isToast: isToast, theme: theme, variant: variant },\r\n                renderIcon(variant, isToast, theme, i18n),\r\n                React.createElement(AlertContents, { additionalContent: additionalContent, isDismissible: isDismissible, theme: theme },\r\n                    React.createElement(AlertSpan, null, children),\r\n                    additionalContent && (React.createElement(AdditionalContentWrapper, { theme: theme }, additionalContent))),\r\n                isDismissible && (React.createElement(DismissibleIconWrapper, { isInverse: isInverse, variant: variant, theme: theme },\r\n                    hasTimerRing && isToast && (React.createElement(ProgressRingWrapper, { theme: theme },\r\n                        React.createElement(ProgressRing, { color: progressRingColor(), isActive: !isPaused, duration: toastDuration }))),\r\n                    React.createElement(DismissButton, Object.assign({ alertVariant: variant }, (isToast\r\n                        ? { title: closeAriaLabel || i18n.alert.dismissAriaLabel }\r\n                        : {\r\n                            'aria-label': closeAriaLabel || i18n.alert.dismissAriaLabel,\r\n                        }), { icon: React.createElement(CloseIcon, { size: hasTimerRing\r\n                                ? theme.iconSizes.xSmall\r\n                                : theme.iconSizes.small }), isInverse: isInverse, isToast: isToast, onClick: forceDismiss || handleDismiss, theme: theme, variant: ButtonVariant.link }))))))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */"));
|
|
3689
3695
|
var whitelistProps = ['icon', 'isInverse', 'theme', 'variant'];
|
|
3690
3696
|
var shouldForwardProp = function shouldForwardProp(prop) {
|
|
3691
3697
|
return isPropValid(prop) || whitelistProps.includes(prop);
|
|
@@ -3704,7 +3710,7 @@ var DismissButton = /*#__PURE__*/_styled(IconButton, {
|
|
|
3704
3710
|
return props.isToast ? "0 " + props.theme.spaceScale.spacing04 : "0 " + props.theme.spaceScale.spacing03;
|
|
3705
3711
|
}, ";width:auto;&:not(:disabled):hover{background:none;color:inherit;}&:focus:not(:disabled){background:none;color:inherit;outline:2px solid ", function (props) {
|
|
3706
3712
|
return props.isInverse ? props.theme.colors.focusInverse : props.theme.colors.focus;
|
|
3707
|
-
}, ";outline-offset:0!important;}&:not(:disabled):active{background:none;color:inherit;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AA+RgE","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport isPropValid from '@emotion/is-prop-valid';\r\nimport { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport { InfoIcon, CheckCircleIcon, WarningIcon, ErrorIcon, CloseIcon, } from 'react-magma-icons';\r\nimport { I18nContext } from '../../i18n';\r\nimport { InverseContext, useIsInverse } from '../../inverse';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { useGenerateId } from '../../utils';\r\nimport { ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { ProgressRing } from '../ProgressRing';\r\nexport const VARIANT_ICON = {\r\n    info: InfoIcon,\r\n    success: CheckCircleIcon,\r\n    warning: WarningIcon,\r\n    danger: ErrorIcon,\r\n};\r\nexport var AlertVariant;\r\n(function (AlertVariant) {\r\n    AlertVariant[\"info\"] = \"info\";\r\n    AlertVariant[\"success\"] = \"success\";\r\n    AlertVariant[\"warning\"] = \"warning\";\r\n    AlertVariant[\"danger\"] = \"danger\";\r\n})(AlertVariant || (AlertVariant = {}));\r\nexport const transitionDuration = 500;\r\nexport function buildAlertBackground(props) {\r\n    if (props.isInverse) {\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return props.theme.colors.success700;\r\n            case 'warning':\r\n                return props.theme.colors.warning700;\r\n            case 'danger':\r\n                return props.theme.colors.danger700;\r\n            default:\r\n                return props.theme.colors.info700;\r\n        }\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success100;\r\n        case 'warning':\r\n            return props.theme.colors.warning100;\r\n        case 'danger':\r\n            return props.theme.colors.danger100;\r\n        default:\r\n            return props.theme.colors.info100;\r\n    }\r\n}\r\nexport function buildAlertBorder(props) {\r\n    if (props.isInverse) {\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return props.theme.colors.success300;\r\n            case 'warning':\r\n                return props.theme.colors.warning300;\r\n            case 'danger':\r\n                return props.theme.colors.danger200;\r\n            default:\r\n                return props.theme.colors.info300;\r\n        }\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success500;\r\n        case 'warning':\r\n            return props.theme.colors.warning500;\r\n        case 'danger':\r\n            return props.theme.colors.danger500;\r\n        default:\r\n            return props.theme.colors.info500;\r\n    }\r\n}\r\nexport function buildAlertColor(props) {\r\n    if (props.isInverse) {\r\n        return props.theme.colors.neutral100;\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success500;\r\n        case 'warning':\r\n            return props.theme.colors.warning500;\r\n        case 'danger':\r\n            return props.theme.colors.danger500;\r\n        default:\r\n            return props.theme.colors.info500;\r\n    }\r\n}\r\nexport function buildLinkColor(props) {\r\n    if (props.isInverse) {\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return props.theme.colors.success200;\r\n            case 'warning':\r\n                return props.theme.colors.warning200;\r\n            case 'danger':\r\n                return props.theme.colors.danger200;\r\n            default:\r\n                return props.theme.colors.info200;\r\n        }\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success700;\r\n        case 'warning':\r\n            return props.theme.colors.warning700;\r\n        case 'danger':\r\n            return props.theme.colors.danger700;\r\n        default:\r\n            return props.theme.colors.info700;\r\n    }\r\n}\r\nexport function buildLinkHoverColor(props) {\r\n    if (props.isInverse) {\r\n        return props.theme.colors.neutral100;\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success;\r\n        case 'warning':\r\n            return props.theme.colors.warning;\r\n        case 'danger':\r\n            return props.theme.colors.danger;\r\n        default:\r\n            return props.theme.colors.info;\r\n    }\r\n}\r\nconst StyledAlert = styled.div `\n  align-items: stretch;\n  animation: ${props => props.isExiting\r\n    ? `fadeout ${transitionDuration}ms`\r\n    : `fadein ${transitionDuration}ms`};\n  display: flex;\n  flex-direction: column;\n  font-size: ${props => props.theme.typeScale.size03.fontSize};\n  font-family: ${props => props.theme.bodyFont};\n  line-height: ${props => props.theme.typeScale.size03.lineHeight};\n  margin-bottom: ${props => props.theme.spaceScale.spacing06};\n  max-width: 100%;\n  padding: 0;\n  position: relative;\n\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    font-size: ${props => props.theme.typeScale.size02.fontSize};\n    letter-spacing: ${props => props.theme.typeScale.size02.letterSpacing};\n    line-height: ${props => props.theme.typeScale.size02.lineHeight};\n  }\n\n  &:focus {\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n  }\n\n  ${props => props.isToast &&\r\n    css `\n      animation: ${props.isExiting\r\n        ? `slideout ${transitionDuration}ms`\r\n        : `slidein ${transitionDuration}ms`};\n      min-width: 375px;\n      margin: 0 auto;\n\n      @media (max-width: ${props.theme.breakpoints.small}px) {\n        min-width: 0;\n        width: 100%;\n      }\n    `}\n\n  @keyframes fadein {\n    from {\n      opacity: 0;\n    }\n    to {\n      opacity: 1;\n    }\n  }\n\n  @keyframes fadeout {\n    from {\n      opacity: 1;\n    }\n    to {\n      opacity: 0;\n    }\n  }\n\n  @keyframes slidein {\n    from {\n      left: -500px;\n    }\n    to {\n      left: 0;\n    }\n  }\n\n  @keyframes slideout {\n    from {\n      left: 0;\n    }\n    to {\n      left: -500px;\n    }\n  }\n\n  a {\n    color: ${props => buildLinkColor(props)};\n    font-weight: 400;\n    text-decoration: underline;\n    &:not([disabled]) {\n      &:focus,\n      &:hover {\n        color: ${props => buildLinkHoverColor(props)};\n      }\n    }\n  }\n`;\r\nconst StyledAlertInner = styled.div `\n  background: ${buildAlertBackground};\n  border: 1px solid ${buildAlertBorder};\n  border-radius: ${props => props.theme.borderRadius};\n  color: ${buildAlertColor};\n  display: flex;\n  position: relative;\n\n  ${props => props.isToast &&\r\n    css `\n      box-shadow: ${props.isInverse\r\n        ? `0 2px 8px 0 ${transparentize(0.3, props.theme.colors.neutral900)}`\r\n        : `0 2px 8px 0 ${transparentize(0.6, props.theme.colors.neutral900)}`};\n      padding-right: 0;\n      height: ${props.theme.spaceScale.spacing11};\n    `}\n`;\r\nconst AlertContents = styled.div `\n  align-items: ${props => (props.additionalContent ? 'center' : '')};\n  align-self: center;\n  flex-grow: 1;\n  font-family: ${props => props.theme.bodyFont};\n  padding: ${props => props.theme.spaceScale.spacing04} 0;\n  display: ${props => (props.additionalContent ? 'flex' : '')};\n  margin-right: ${props => props.additionalContent && !props.isDismissible\r\n    ? props.theme.spaceScale.spacing03\r\n    : ''};\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    padding-left: 0;\n  }\n`;\r\nexport const AdditionalContentWrapper = styled.div `\n  flex: 1 0 auto;\n  justify-content: flex-end;\n  display: flex;\n  margin-left: ${props => props.theme.spaceScale.spacing05};\n`;\r\nconst IconWrapperStyles = css `\n  align-items: center;\n  display: flex;\n  flex-shrink: 0;\n  margin-right: 1px;\n`;\r\nconst IconWrapper = styled.span `\n  ${IconWrapperStyles}\n  padding: 0 ${props => props.theme.spaceScale.spacing03} 0 ${props => props.theme.spaceScale.spacing04};\n\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    padding: 0 ${props => props.theme.spaceScale.spacing03};\n    svg {\n      width: 20px;\n    }\n  }\n`;\r\nconst ProgressRingWrapper = styled.div `\n  margin-top: 6px;\n  position: absolute;\n  top: auto;\n  right: ${props => props.theme.spaceScale.spacing02};\n`;\r\nconst DismissibleIconWrapper = styled.span `\n  ${IconWrapperStyles}\n  margin-left: ${props => props.additionalContent ? props.theme.spaceScale.spacing03 : ''};\n`;\r\nconst whitelistProps = ['icon', 'isInverse', 'theme', 'variant'];\r\nconst shouldForwardProp = prop => {\r\n    return isPropValid(prop) || whitelistProps.includes(prop);\r\n};\r\nconst DismissButton = styled(IconButton, { shouldForwardProp }) `\n  align-self: stretch;\n  border-radius: 0 ${props => props.theme.borderRadius}\n    ${props => props.theme.borderRadius} 0;\n  color: inherit;\n  height: auto;\n  margin: ${props => (props.isToast ? '4px' : '0 -1px 0 0')};\n  padding: ${props => props.isToast\r\n    ? `0 ${props.theme.spaceScale.spacing04}`\r\n    : `0 ${props.theme.spaceScale.spacing03}`};\n  width: auto;\n  &:not(:disabled):hover {\n    background: none;\n    color: inherit;\n  }\n  &:focus:not(:disabled) {\n    background: none;\n    color: inherit;\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n    outline-offset: 0 !important;\n  }\n  &:not(:disabled):active {\n    background: none;\n    color: inherit;\n  }\n`;\r\nconst AlertSpan = styled.span `\n  white-space: pre-line;\n`;\r\nfunction renderIcon(variant = 'info', isToast, theme) {\r\n    const Icon = VARIANT_ICON[variant];\r\n    return (React.createElement(IconWrapper, { isToast: isToast, theme: theme },\r\n        React.createElement(Icon, { size: theme.iconSizes.medium })));\r\n}\r\nexport const AlertBase = React.forwardRef((props, ref) => {\r\n    const { additionalContent, children, closeAriaLabel, forceDismiss, hasTimerRing, id: defaultId, isDismissed, isDismissible, isExiting: externalIsExiting, isPaused, isToast, onDismiss, testId, toastDuration, variant, ...other } = props;\r\n    const id = useGenerateId(defaultId);\r\n    const [isExiting, setIsExiting] = React.useState(false);\r\n    const isInverse = useIsInverse(props.isInverse);\r\n    React.useEffect(() => {\r\n        if (isExiting) {\r\n            setTimeout(() => {\r\n                setIsExiting(false);\r\n                onDismiss && typeof onDismiss === 'function' && onDismiss();\r\n            }, transitionDuration - 300);\r\n        }\r\n    }, [isExiting]);\r\n    React.useEffect(() => {\r\n        if (isDismissed) {\r\n            handleDismiss();\r\n        }\r\n    }, [isDismissed]);\r\n    function handleDismiss() {\r\n        setIsExiting(true);\r\n    }\r\n    const theme = React.useContext(ThemeContext);\r\n    const i18n = React.useContext(I18nContext);\r\n    function progressRingColor() {\r\n        if (isInverse) {\r\n            return theme.colors.neutral100;\r\n        }\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return theme.colors.success500;\r\n            case 'warning':\r\n                return theme.colors.warning500;\r\n            case 'danger':\r\n                return theme.colors.danger500;\r\n            default:\r\n                return theme.colors.info500;\r\n        }\r\n    }\r\n    return (React.createElement(StyledAlert, Object.assign({}, other, { \"data-testid\": testId, id: id, tabIndex: -1, isInverse: isInverse, isExiting: isExiting, isToast: isToast, ref: ref, theme: theme, variant: variant }),\r\n        React.createElement(InverseContext.Provider, { value: { isInverse } },\r\n            React.createElement(StyledAlertInner, { isInverse: isInverse, isToast: isToast, theme: theme, variant: variant },\r\n                renderIcon(variant, isToast, theme),\r\n                React.createElement(AlertContents, { additionalContent: additionalContent, isDismissible: isDismissible, theme: theme },\r\n                    React.createElement(AlertSpan, null, children),\r\n                    additionalContent && (React.createElement(AdditionalContentWrapper, { theme: theme }, additionalContent))),\r\n                isDismissible && (React.createElement(DismissibleIconWrapper, { isInverse: isInverse, variant: variant, theme: theme },\r\n                    hasTimerRing && isToast && (React.createElement(ProgressRingWrapper, { theme: theme },\r\n                        React.createElement(ProgressRing, { color: progressRingColor(), isActive: !isPaused, duration: toastDuration }))),\r\n                    React.createElement(DismissButton, Object.assign({ alertVariant: variant }, (isToast\r\n                        ? { title: closeAriaLabel || i18n.alert.dismissAriaLabel }\r\n                        : {\r\n                            'aria-label': closeAriaLabel || i18n.alert.dismissAriaLabel,\r\n                        }), { icon: React.createElement(CloseIcon, { size: hasTimerRing\r\n                                ? theme.iconSizes.xSmall\r\n                                : theme.iconSizes.small }), isInverse: isInverse, isToast: isToast, onClick: forceDismiss || handleDismiss, theme: theme, variant: ButtonVariant.link }))))))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */"));
|
|
3713
|
+
}, ";outline-offset:0!important;}&:not(:disabled):active{background:none;color:inherit;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AA+RgE","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport isPropValid from '@emotion/is-prop-valid';\r\nimport { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport { InfoIcon, CheckCircleIcon, WarningIcon, ErrorIcon, CloseIcon, } from 'react-magma-icons';\r\nimport { I18nContext } from '../..';\r\nimport { InverseContext, useIsInverse } from '../../inverse';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { useGenerateId } from '../../utils';\r\nimport { ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { ProgressRing } from '../ProgressRing';\r\nexport const VARIANT_ICON = {\r\n    info: InfoIcon,\r\n    success: CheckCircleIcon,\r\n    warning: WarningIcon,\r\n    danger: ErrorIcon,\r\n};\r\nexport var AlertVariant;\r\n(function (AlertVariant) {\r\n    AlertVariant[\"info\"] = \"info\";\r\n    AlertVariant[\"success\"] = \"success\";\r\n    AlertVariant[\"warning\"] = \"warning\";\r\n    AlertVariant[\"danger\"] = \"danger\";\r\n})(AlertVariant || (AlertVariant = {}));\r\nexport const transitionDuration = 500;\r\nexport function buildAlertBackground(props) {\r\n    if (props.isInverse) {\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return props.theme.colors.success700;\r\n            case 'warning':\r\n                return props.theme.colors.warning700;\r\n            case 'danger':\r\n                return props.theme.colors.danger700;\r\n            default:\r\n                return props.theme.colors.info700;\r\n        }\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success100;\r\n        case 'warning':\r\n            return props.theme.colors.warning100;\r\n        case 'danger':\r\n            return props.theme.colors.danger100;\r\n        default:\r\n            return props.theme.colors.info100;\r\n    }\r\n}\r\nexport function buildAlertBorder(props) {\r\n    if (props.isInverse) {\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return props.theme.colors.success300;\r\n            case 'warning':\r\n                return props.theme.colors.warning300;\r\n            case 'danger':\r\n                return props.theme.colors.danger200;\r\n            default:\r\n                return props.theme.colors.info300;\r\n        }\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success500;\r\n        case 'warning':\r\n            return props.theme.colors.warning500;\r\n        case 'danger':\r\n            return props.theme.colors.danger500;\r\n        default:\r\n            return props.theme.colors.info500;\r\n    }\r\n}\r\nexport function buildAlertColor(props) {\r\n    if (props.isInverse) {\r\n        return props.theme.colors.neutral100;\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success500;\r\n        case 'warning':\r\n            return props.theme.colors.warning500;\r\n        case 'danger':\r\n            return props.theme.colors.danger500;\r\n        default:\r\n            return props.theme.colors.info500;\r\n    }\r\n}\r\nexport function buildLinkColor(props) {\r\n    if (props.isInverse) {\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return props.theme.colors.success200;\r\n            case 'warning':\r\n                return props.theme.colors.warning200;\r\n            case 'danger':\r\n                return props.theme.colors.danger200;\r\n            default:\r\n                return props.theme.colors.info200;\r\n        }\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success700;\r\n        case 'warning':\r\n            return props.theme.colors.warning700;\r\n        case 'danger':\r\n            return props.theme.colors.danger700;\r\n        default:\r\n            return props.theme.colors.info700;\r\n    }\r\n}\r\nexport function buildLinkHoverColor(props) {\r\n    if (props.isInverse) {\r\n        return props.theme.colors.neutral100;\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success;\r\n        case 'warning':\r\n            return props.theme.colors.warning;\r\n        case 'danger':\r\n            return props.theme.colors.danger;\r\n        default:\r\n            return props.theme.colors.info;\r\n    }\r\n}\r\nconst StyledAlert = styled.div `\n  align-items: stretch;\n  animation: ${props => props.isExiting\r\n    ? `fadeout ${transitionDuration}ms`\r\n    : `fadein ${transitionDuration}ms`};\n  display: flex;\n  flex-direction: column;\n  font-size: ${props => props.theme.typeScale.size03.fontSize};\n  font-family: ${props => props.theme.bodyFont};\n  line-height: ${props => props.theme.typeScale.size03.lineHeight};\n  margin-bottom: ${props => props.theme.spaceScale.spacing06};\n  max-width: 100%;\n  padding: 0;\n  position: relative;\n\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    font-size: ${props => props.theme.typeScale.size02.fontSize};\n    letter-spacing: ${props => props.theme.typeScale.size02.letterSpacing};\n    line-height: ${props => props.theme.typeScale.size02.lineHeight};\n  }\n\n  &:focus {\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n  }\n\n  ${props => props.isToast &&\r\n    css `\n      animation: ${props.isExiting\r\n        ? `slideout ${transitionDuration}ms`\r\n        : `slidein ${transitionDuration}ms`};\n      min-width: 375px;\n      margin: 0 auto;\n\n      @media (max-width: ${props.theme.breakpoints.small}px) {\n        min-width: 0;\n        width: 100%;\n      }\n    `}\n\n  @keyframes fadein {\n    from {\n      opacity: 0;\n    }\n    to {\n      opacity: 1;\n    }\n  }\n\n  @keyframes fadeout {\n    from {\n      opacity: 1;\n    }\n    to {\n      opacity: 0;\n    }\n  }\n\n  @keyframes slidein {\n    from {\n      left: -500px;\n    }\n    to {\n      left: 0;\n    }\n  }\n\n  @keyframes slideout {\n    from {\n      left: 0;\n    }\n    to {\n      left: -500px;\n    }\n  }\n\n  a {\n    color: ${props => buildLinkColor(props)};\n    font-weight: 400;\n    text-decoration: underline;\n    &:not([disabled]) {\n      &:focus,\n      &:hover {\n        color: ${props => buildLinkHoverColor(props)};\n      }\n    }\n  }\n`;\r\nconst StyledAlertInner = styled.div `\n  background: ${buildAlertBackground};\n  border: 1px solid ${buildAlertBorder};\n  border-radius: ${props => props.theme.borderRadius};\n  color: ${buildAlertColor};\n  display: flex;\n  position: relative;\n\n  ${props => props.isToast &&\r\n    css `\n      box-shadow: ${props.isInverse\r\n        ? `0 2px 8px 0 ${transparentize(0.3, props.theme.colors.neutral900)}`\r\n        : `0 2px 8px 0 ${transparentize(0.6, props.theme.colors.neutral900)}`};\n      padding-right: 0;\n      height: ${props.theme.spaceScale.spacing11};\n    `}\n`;\r\nconst AlertContents = styled.div `\n  align-items: ${props => (props.additionalContent ? 'center' : '')};\n  align-self: center;\n  flex-grow: 1;\n  font-family: ${props => props.theme.bodyFont};\n  padding: ${props => props.theme.spaceScale.spacing04} 0;\n  display: ${props => (props.additionalContent ? 'flex' : '')};\n  margin-right: ${props => props.additionalContent && !props.isDismissible\r\n    ? props.theme.spaceScale.spacing03\r\n    : ''};\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    padding-left: 0;\n  }\n`;\r\nexport const AdditionalContentWrapper = styled.div `\n  flex: 1 0 auto;\n  justify-content: flex-end;\n  display: flex;\n  margin-left: ${props => props.theme.spaceScale.spacing05};\n`;\r\nconst IconWrapperStyles = css `\n  align-items: center;\n  display: flex;\n  flex-shrink: 0;\n  margin-right: 1px;\n`;\r\nconst IconWrapper = styled.span `\n  ${IconWrapperStyles}\n  padding: 0 ${props => props.theme.spaceScale.spacing03} 0 ${props => props.theme.spaceScale.spacing04};\n\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    padding: 0 ${props => props.theme.spaceScale.spacing03};\n    svg {\n      width: 20px;\n    }\n  }\n`;\r\nconst ProgressRingWrapper = styled.div `\n  margin-top: 6px;\n  position: absolute;\n  top: auto;\n  right: ${props => props.theme.spaceScale.spacing02};\n`;\r\nconst DismissibleIconWrapper = styled.span `\n  ${IconWrapperStyles}\n  margin-left: ${props => props.additionalContent ? props.theme.spaceScale.spacing03 : ''};\n`;\r\nconst whitelistProps = ['icon', 'isInverse', 'theme', 'variant'];\r\nconst shouldForwardProp = prop => {\r\n    return isPropValid(prop) || whitelistProps.includes(prop);\r\n};\r\nconst DismissButton = styled(IconButton, { shouldForwardProp }) `\n  align-self: stretch;\n  border-radius: 0 ${props => props.theme.borderRadius}\n    ${props => props.theme.borderRadius} 0;\n  color: inherit;\n  height: auto;\n  margin: ${props => (props.isToast ? '4px' : '0 -1px 0 0')};\n  padding: ${props => props.isToast\r\n    ? `0 ${props.theme.spaceScale.spacing04}`\r\n    : `0 ${props.theme.spaceScale.spacing03}`};\n  width: auto;\n  &:not(:disabled):hover {\n    background: none;\n    color: inherit;\n  }\n  &:focus:not(:disabled) {\n    background: none;\n    color: inherit;\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n    outline-offset: 0 !important;\n  }\n  &:not(:disabled):active {\n    background: none;\n    color: inherit;\n  }\n`;\r\nconst AlertSpan = styled.span `\n  white-space: pre-line;\n`;\r\nfunction getAriaLabelIcon(variant, i18n) {\r\n    switch (variant) {\r\n        case 'success':\r\n            return i18n.alertVariants.success;\r\n        case 'warning':\r\n            return i18n.alertVariants.warning;\r\n        case 'danger':\r\n            return i18n.alertVariants.danger;\r\n        default:\r\n            return i18n.alertVariants.info;\r\n    }\r\n}\r\nfunction renderIcon(variant = 'info', isToast, theme, i18n) {\r\n    const Icon = VARIANT_ICON[variant];\r\n    return (React.createElement(IconWrapper, { \"aria-label\": getAriaLabelIcon(variant, i18n), role: \"img\", isToast: isToast, theme: theme },\r\n        React.createElement(Icon, { size: theme.iconSizes.medium })));\r\n}\r\nexport const AlertBase = React.forwardRef((props, ref) => {\r\n    const { additionalContent, children, closeAriaLabel, forceDismiss, hasTimerRing, id: defaultId, isDismissed, isDismissible, isExiting: externalIsExiting, isPaused, isToast, onDismiss, testId, toastDuration, variant, ...other } = props;\r\n    const id = useGenerateId(defaultId);\r\n    const [isExiting, setIsExiting] = React.useState(false);\r\n    const isInverse = useIsInverse(props.isInverse);\r\n    React.useEffect(() => {\r\n        if (isExiting) {\r\n            setTimeout(() => {\r\n                setIsExiting(false);\r\n                onDismiss && typeof onDismiss === 'function' && onDismiss();\r\n            }, transitionDuration - 300);\r\n        }\r\n    }, [isExiting]);\r\n    React.useEffect(() => {\r\n        if (isDismissed) {\r\n            handleDismiss();\r\n        }\r\n    }, [isDismissed]);\r\n    function handleDismiss() {\r\n        setIsExiting(true);\r\n    }\r\n    const theme = React.useContext(ThemeContext);\r\n    const i18n = React.useContext(I18nContext);\r\n    function progressRingColor() {\r\n        if (isInverse) {\r\n            return theme.colors.neutral100;\r\n        }\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return theme.colors.success500;\r\n            case 'warning':\r\n                return theme.colors.warning500;\r\n            case 'danger':\r\n                return theme.colors.danger500;\r\n            default:\r\n                return theme.colors.info500;\r\n        }\r\n    }\r\n    return (React.createElement(StyledAlert, Object.assign({}, other, { \"data-testid\": testId, id: id, tabIndex: -1, isInverse: isInverse, isExiting: isExiting, isToast: isToast, ref: ref, theme: theme, variant: variant }),\r\n        React.createElement(InverseContext.Provider, { value: { isInverse } },\r\n            React.createElement(StyledAlertInner, { isInverse: isInverse, isToast: isToast, theme: theme, variant: variant },\r\n                renderIcon(variant, isToast, theme, i18n),\r\n                React.createElement(AlertContents, { additionalContent: additionalContent, isDismissible: isDismissible, theme: theme },\r\n                    React.createElement(AlertSpan, null, children),\r\n                    additionalContent && (React.createElement(AdditionalContentWrapper, { theme: theme }, additionalContent))),\r\n                isDismissible && (React.createElement(DismissibleIconWrapper, { isInverse: isInverse, variant: variant, theme: theme },\r\n                    hasTimerRing && isToast && (React.createElement(ProgressRingWrapper, { theme: theme },\r\n                        React.createElement(ProgressRing, { color: progressRingColor(), isActive: !isPaused, duration: toastDuration }))),\r\n                    React.createElement(DismissButton, Object.assign({ alertVariant: variant }, (isToast\r\n                        ? { title: closeAriaLabel || i18n.alert.dismissAriaLabel }\r\n                        : {\r\n                            'aria-label': closeAriaLabel || i18n.alert.dismissAriaLabel,\r\n                        }), { icon: React.createElement(CloseIcon, { size: hasTimerRing\r\n                                ? theme.iconSizes.xSmall\r\n                                : theme.iconSizes.small }), isInverse: isInverse, isToast: isToast, onClick: forceDismiss || handleDismiss, theme: theme, variant: ButtonVariant.link }))))))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */"));
|
|
3708
3714
|
var AlertSpan = /*#__PURE__*/_styled("span", {
|
|
3709
3715
|
target: "e126n3g80",
|
|
3710
3716
|
label: "AlertSpan"
|
|
@@ -3713,15 +3719,29 @@ var AlertSpan = /*#__PURE__*/_styled("span", {
|
|
|
3713
3719
|
styles: "white-space:pre-line"
|
|
3714
3720
|
} : {
|
|
3715
3721
|
name: "1l0p3iw",
|
|
3716
|
-
styles: "white-space:pre-line/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AA4T8B","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport isPropValid from '@emotion/is-prop-valid';\r\nimport { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport { InfoIcon, CheckCircleIcon, WarningIcon, ErrorIcon, CloseIcon, } from 'react-magma-icons';\r\nimport { I18nContext } from '../../i18n';\r\nimport { InverseContext, useIsInverse } from '../../inverse';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { useGenerateId } from '../../utils';\r\nimport { ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { ProgressRing } from '../ProgressRing';\r\nexport const VARIANT_ICON = {\r\n    info: InfoIcon,\r\n    success: CheckCircleIcon,\r\n    warning: WarningIcon,\r\n    danger: ErrorIcon,\r\n};\r\nexport var AlertVariant;\r\n(function (AlertVariant) {\r\n    AlertVariant[\"info\"] = \"info\";\r\n    AlertVariant[\"success\"] = \"success\";\r\n    AlertVariant[\"warning\"] = \"warning\";\r\n    AlertVariant[\"danger\"] = \"danger\";\r\n})(AlertVariant || (AlertVariant = {}));\r\nexport const transitionDuration = 500;\r\nexport function buildAlertBackground(props) {\r\n    if (props.isInverse) {\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return props.theme.colors.success700;\r\n            case 'warning':\r\n                return props.theme.colors.warning700;\r\n            case 'danger':\r\n                return props.theme.colors.danger700;\r\n            default:\r\n                return props.theme.colors.info700;\r\n        }\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success100;\r\n        case 'warning':\r\n            return props.theme.colors.warning100;\r\n        case 'danger':\r\n            return props.theme.colors.danger100;\r\n        default:\r\n            return props.theme.colors.info100;\r\n    }\r\n}\r\nexport function buildAlertBorder(props) {\r\n    if (props.isInverse) {\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return props.theme.colors.success300;\r\n            case 'warning':\r\n                return props.theme.colors.warning300;\r\n            case 'danger':\r\n                return props.theme.colors.danger200;\r\n            default:\r\n                return props.theme.colors.info300;\r\n        }\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success500;\r\n        case 'warning':\r\n            return props.theme.colors.warning500;\r\n        case 'danger':\r\n            return props.theme.colors.danger500;\r\n        default:\r\n            return props.theme.colors.info500;\r\n    }\r\n}\r\nexport function buildAlertColor(props) {\r\n    if (props.isInverse) {\r\n        return props.theme.colors.neutral100;\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success500;\r\n        case 'warning':\r\n            return props.theme.colors.warning500;\r\n        case 'danger':\r\n            return props.theme.colors.danger500;\r\n        default:\r\n            return props.theme.colors.info500;\r\n    }\r\n}\r\nexport function buildLinkColor(props) {\r\n    if (props.isInverse) {\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return props.theme.colors.success200;\r\n            case 'warning':\r\n                return props.theme.colors.warning200;\r\n            case 'danger':\r\n                return props.theme.colors.danger200;\r\n            default:\r\n                return props.theme.colors.info200;\r\n        }\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success700;\r\n        case 'warning':\r\n            return props.theme.colors.warning700;\r\n        case 'danger':\r\n            return props.theme.colors.danger700;\r\n        default:\r\n            return props.theme.colors.info700;\r\n    }\r\n}\r\nexport function buildLinkHoverColor(props) {\r\n    if (props.isInverse) {\r\n        return props.theme.colors.neutral100;\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success;\r\n        case 'warning':\r\n            return props.theme.colors.warning;\r\n        case 'danger':\r\n            return props.theme.colors.danger;\r\n        default:\r\n            return props.theme.colors.info;\r\n    }\r\n}\r\nconst StyledAlert = styled.div `\n  align-items: stretch;\n  animation: ${props => props.isExiting\r\n    ? `fadeout ${transitionDuration}ms`\r\n    : `fadein ${transitionDuration}ms`};\n  display: flex;\n  flex-direction: column;\n  font-size: ${props => props.theme.typeScale.size03.fontSize};\n  font-family: ${props => props.theme.bodyFont};\n  line-height: ${props => props.theme.typeScale.size03.lineHeight};\n  margin-bottom: ${props => props.theme.spaceScale.spacing06};\n  max-width: 100%;\n  padding: 0;\n  position: relative;\n\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    font-size: ${props => props.theme.typeScale.size02.fontSize};\n    letter-spacing: ${props => props.theme.typeScale.size02.letterSpacing};\n    line-height: ${props => props.theme.typeScale.size02.lineHeight};\n  }\n\n  &:focus {\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n  }\n\n  ${props => props.isToast &&\r\n    css `\n      animation: ${props.isExiting\r\n        ? `slideout ${transitionDuration}ms`\r\n        : `slidein ${transitionDuration}ms`};\n      min-width: 375px;\n      margin: 0 auto;\n\n      @media (max-width: ${props.theme.breakpoints.small}px) {\n        min-width: 0;\n        width: 100%;\n      }\n    `}\n\n  @keyframes fadein {\n    from {\n      opacity: 0;\n    }\n    to {\n      opacity: 1;\n    }\n  }\n\n  @keyframes fadeout {\n    from {\n      opacity: 1;\n    }\n    to {\n      opacity: 0;\n    }\n  }\n\n  @keyframes slidein {\n    from {\n      left: -500px;\n    }\n    to {\n      left: 0;\n    }\n  }\n\n  @keyframes slideout {\n    from {\n      left: 0;\n    }\n    to {\n      left: -500px;\n    }\n  }\n\n  a {\n    color: ${props => buildLinkColor(props)};\n    font-weight: 400;\n    text-decoration: underline;\n    &:not([disabled]) {\n      &:focus,\n      &:hover {\n        color: ${props => buildLinkHoverColor(props)};\n      }\n    }\n  }\n`;\r\nconst StyledAlertInner = styled.div `\n  background: ${buildAlertBackground};\n  border: 1px solid ${buildAlertBorder};\n  border-radius: ${props => props.theme.borderRadius};\n  color: ${buildAlertColor};\n  display: flex;\n  position: relative;\n\n  ${props => props.isToast &&\r\n    css `\n      box-shadow: ${props.isInverse\r\n        ? `0 2px 8px 0 ${transparentize(0.3, props.theme.colors.neutral900)}`\r\n        : `0 2px 8px 0 ${transparentize(0.6, props.theme.colors.neutral900)}`};\n      padding-right: 0;\n      height: ${props.theme.spaceScale.spacing11};\n    `}\n`;\r\nconst AlertContents = styled.div `\n  align-items: ${props => (props.additionalContent ? 'center' : '')};\n  align-self: center;\n  flex-grow: 1;\n  font-family: ${props => props.theme.bodyFont};\n  padding: ${props => props.theme.spaceScale.spacing04} 0;\n  display: ${props => (props.additionalContent ? 'flex' : '')};\n  margin-right: ${props => props.additionalContent && !props.isDismissible\r\n    ? props.theme.spaceScale.spacing03\r\n    : ''};\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    padding-left: 0;\n  }\n`;\r\nexport const AdditionalContentWrapper = styled.div `\n  flex: 1 0 auto;\n  justify-content: flex-end;\n  display: flex;\n  margin-left: ${props => props.theme.spaceScale.spacing05};\n`;\r\nconst IconWrapperStyles = css `\n  align-items: center;\n  display: flex;\n  flex-shrink: 0;\n  margin-right: 1px;\n`;\r\nconst IconWrapper = styled.span `\n  ${IconWrapperStyles}\n  padding: 0 ${props => props.theme.spaceScale.spacing03} 0 ${props => props.theme.spaceScale.spacing04};\n\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    padding: 0 ${props => props.theme.spaceScale.spacing03};\n    svg {\n      width: 20px;\n    }\n  }\n`;\r\nconst ProgressRingWrapper = styled.div `\n  margin-top: 6px;\n  position: absolute;\n  top: auto;\n  right: ${props => props.theme.spaceScale.spacing02};\n`;\r\nconst DismissibleIconWrapper = styled.span `\n  ${IconWrapperStyles}\n  margin-left: ${props => props.additionalContent ? props.theme.spaceScale.spacing03 : ''};\n`;\r\nconst whitelistProps = ['icon', 'isInverse', 'theme', 'variant'];\r\nconst shouldForwardProp = prop => {\r\n    return isPropValid(prop) || whitelistProps.includes(prop);\r\n};\r\nconst DismissButton = styled(IconButton, { shouldForwardProp }) `\n  align-self: stretch;\n  border-radius: 0 ${props => props.theme.borderRadius}\n    ${props => props.theme.borderRadius} 0;\n  color: inherit;\n  height: auto;\n  margin: ${props => (props.isToast ? '4px' : '0 -1px 0 0')};\n  padding: ${props => props.isToast\r\n    ? `0 ${props.theme.spaceScale.spacing04}`\r\n    : `0 ${props.theme.spaceScale.spacing03}`};\n  width: auto;\n  &:not(:disabled):hover {\n    background: none;\n    color: inherit;\n  }\n  &:focus:not(:disabled) {\n    background: none;\n    color: inherit;\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n    outline-offset: 0 !important;\n  }\n  &:not(:disabled):active {\n    background: none;\n    color: inherit;\n  }\n`;\r\nconst AlertSpan = styled.span `\n  white-space: pre-line;\n`;\r\nfunction renderIcon(variant = 'info', isToast, theme) {\r\n    const Icon = VARIANT_ICON[variant];\r\n    return (React.createElement(IconWrapper, { isToast: isToast, theme: theme },\r\n        React.createElement(Icon, { size: theme.iconSizes.medium })));\r\n}\r\nexport const AlertBase = React.forwardRef((props, ref) => {\r\n    const { additionalContent, children, closeAriaLabel, forceDismiss, hasTimerRing, id: defaultId, isDismissed, isDismissible, isExiting: externalIsExiting, isPaused, isToast, onDismiss, testId, toastDuration, variant, ...other } = props;\r\n    const id = useGenerateId(defaultId);\r\n    const [isExiting, setIsExiting] = React.useState(false);\r\n    const isInverse = useIsInverse(props.isInverse);\r\n    React.useEffect(() => {\r\n        if (isExiting) {\r\n            setTimeout(() => {\r\n                setIsExiting(false);\r\n                onDismiss && typeof onDismiss === 'function' && onDismiss();\r\n            }, transitionDuration - 300);\r\n        }\r\n    }, [isExiting]);\r\n    React.useEffect(() => {\r\n        if (isDismissed) {\r\n            handleDismiss();\r\n        }\r\n    }, [isDismissed]);\r\n    function handleDismiss() {\r\n        setIsExiting(true);\r\n    }\r\n    const theme = React.useContext(ThemeContext);\r\n    const i18n = React.useContext(I18nContext);\r\n    function progressRingColor() {\r\n        if (isInverse) {\r\n            return theme.colors.neutral100;\r\n        }\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return theme.colors.success500;\r\n            case 'warning':\r\n                return theme.colors.warning500;\r\n            case 'danger':\r\n                return theme.colors.danger500;\r\n            default:\r\n                return theme.colors.info500;\r\n        }\r\n    }\r\n    return (React.createElement(StyledAlert, Object.assign({}, other, { \"data-testid\": testId, id: id, tabIndex: -1, isInverse: isInverse, isExiting: isExiting, isToast: isToast, ref: ref, theme: theme, variant: variant }),\r\n        React.createElement(InverseContext.Provider, { value: { isInverse } },\r\n            React.createElement(StyledAlertInner, { isInverse: isInverse, isToast: isToast, theme: theme, variant: variant },\r\n                renderIcon(variant, isToast, theme),\r\n                React.createElement(AlertContents, { additionalContent: additionalContent, isDismissible: isDismissible, theme: theme },\r\n                    React.createElement(AlertSpan, null, children),\r\n                    additionalContent && (React.createElement(AdditionalContentWrapper, { theme: theme }, additionalContent))),\r\n                isDismissible && (React.createElement(DismissibleIconWrapper, { isInverse: isInverse, variant: variant, theme: theme },\r\n                    hasTimerRing && isToast && (React.createElement(ProgressRingWrapper, { theme: theme },\r\n                        React.createElement(ProgressRing, { color: progressRingColor(), isActive: !isPaused, duration: toastDuration }))),\r\n                    React.createElement(DismissButton, Object.assign({ alertVariant: variant }, (isToast\r\n                        ? { title: closeAriaLabel || i18n.alert.dismissAriaLabel }\r\n                        : {\r\n                            'aria-label': closeAriaLabel || i18n.alert.dismissAriaLabel,\r\n                        }), { icon: React.createElement(CloseIcon, { size: hasTimerRing\r\n                                ? theme.iconSizes.xSmall\r\n                                : theme.iconSizes.small }), isInverse: isInverse, isToast: isToast, onClick: forceDismiss || handleDismiss, theme: theme, variant: ButtonVariant.link }))))))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */",
|
|
3722
|
+
styles: "white-space:pre-line/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AA4T8B","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport isPropValid from '@emotion/is-prop-valid';\r\nimport { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport { InfoIcon, CheckCircleIcon, WarningIcon, ErrorIcon, CloseIcon, } from 'react-magma-icons';\r\nimport { I18nContext } from '../..';\r\nimport { InverseContext, useIsInverse } from '../../inverse';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { useGenerateId } from '../../utils';\r\nimport { ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { ProgressRing } from '../ProgressRing';\r\nexport const VARIANT_ICON = {\r\n    info: InfoIcon,\r\n    success: CheckCircleIcon,\r\n    warning: WarningIcon,\r\n    danger: ErrorIcon,\r\n};\r\nexport var AlertVariant;\r\n(function (AlertVariant) {\r\n    AlertVariant[\"info\"] = \"info\";\r\n    AlertVariant[\"success\"] = \"success\";\r\n    AlertVariant[\"warning\"] = \"warning\";\r\n    AlertVariant[\"danger\"] = \"danger\";\r\n})(AlertVariant || (AlertVariant = {}));\r\nexport const transitionDuration = 500;\r\nexport function buildAlertBackground(props) {\r\n    if (props.isInverse) {\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return props.theme.colors.success700;\r\n            case 'warning':\r\n                return props.theme.colors.warning700;\r\n            case 'danger':\r\n                return props.theme.colors.danger700;\r\n            default:\r\n                return props.theme.colors.info700;\r\n        }\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success100;\r\n        case 'warning':\r\n            return props.theme.colors.warning100;\r\n        case 'danger':\r\n            return props.theme.colors.danger100;\r\n        default:\r\n            return props.theme.colors.info100;\r\n    }\r\n}\r\nexport function buildAlertBorder(props) {\r\n    if (props.isInverse) {\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return props.theme.colors.success300;\r\n            case 'warning':\r\n                return props.theme.colors.warning300;\r\n            case 'danger':\r\n                return props.theme.colors.danger200;\r\n            default:\r\n                return props.theme.colors.info300;\r\n        }\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success500;\r\n        case 'warning':\r\n            return props.theme.colors.warning500;\r\n        case 'danger':\r\n            return props.theme.colors.danger500;\r\n        default:\r\n            return props.theme.colors.info500;\r\n    }\r\n}\r\nexport function buildAlertColor(props) {\r\n    if (props.isInverse) {\r\n        return props.theme.colors.neutral100;\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success500;\r\n        case 'warning':\r\n            return props.theme.colors.warning500;\r\n        case 'danger':\r\n            return props.theme.colors.danger500;\r\n        default:\r\n            return props.theme.colors.info500;\r\n    }\r\n}\r\nexport function buildLinkColor(props) {\r\n    if (props.isInverse) {\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return props.theme.colors.success200;\r\n            case 'warning':\r\n                return props.theme.colors.warning200;\r\n            case 'danger':\r\n                return props.theme.colors.danger200;\r\n            default:\r\n                return props.theme.colors.info200;\r\n        }\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success700;\r\n        case 'warning':\r\n            return props.theme.colors.warning700;\r\n        case 'danger':\r\n            return props.theme.colors.danger700;\r\n        default:\r\n            return props.theme.colors.info700;\r\n    }\r\n}\r\nexport function buildLinkHoverColor(props) {\r\n    if (props.isInverse) {\r\n        return props.theme.colors.neutral100;\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success;\r\n        case 'warning':\r\n            return props.theme.colors.warning;\r\n        case 'danger':\r\n            return props.theme.colors.danger;\r\n        default:\r\n            return props.theme.colors.info;\r\n    }\r\n}\r\nconst StyledAlert = styled.div `\n  align-items: stretch;\n  animation: ${props => props.isExiting\r\n    ? `fadeout ${transitionDuration}ms`\r\n    : `fadein ${transitionDuration}ms`};\n  display: flex;\n  flex-direction: column;\n  font-size: ${props => props.theme.typeScale.size03.fontSize};\n  font-family: ${props => props.theme.bodyFont};\n  line-height: ${props => props.theme.typeScale.size03.lineHeight};\n  margin-bottom: ${props => props.theme.spaceScale.spacing06};\n  max-width: 100%;\n  padding: 0;\n  position: relative;\n\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    font-size: ${props => props.theme.typeScale.size02.fontSize};\n    letter-spacing: ${props => props.theme.typeScale.size02.letterSpacing};\n    line-height: ${props => props.theme.typeScale.size02.lineHeight};\n  }\n\n  &:focus {\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n  }\n\n  ${props => props.isToast &&\r\n    css `\n      animation: ${props.isExiting\r\n        ? `slideout ${transitionDuration}ms`\r\n        : `slidein ${transitionDuration}ms`};\n      min-width: 375px;\n      margin: 0 auto;\n\n      @media (max-width: ${props.theme.breakpoints.small}px) {\n        min-width: 0;\n        width: 100%;\n      }\n    `}\n\n  @keyframes fadein {\n    from {\n      opacity: 0;\n    }\n    to {\n      opacity: 1;\n    }\n  }\n\n  @keyframes fadeout {\n    from {\n      opacity: 1;\n    }\n    to {\n      opacity: 0;\n    }\n  }\n\n  @keyframes slidein {\n    from {\n      left: -500px;\n    }\n    to {\n      left: 0;\n    }\n  }\n\n  @keyframes slideout {\n    from {\n      left: 0;\n    }\n    to {\n      left: -500px;\n    }\n  }\n\n  a {\n    color: ${props => buildLinkColor(props)};\n    font-weight: 400;\n    text-decoration: underline;\n    &:not([disabled]) {\n      &:focus,\n      &:hover {\n        color: ${props => buildLinkHoverColor(props)};\n      }\n    }\n  }\n`;\r\nconst StyledAlertInner = styled.div `\n  background: ${buildAlertBackground};\n  border: 1px solid ${buildAlertBorder};\n  border-radius: ${props => props.theme.borderRadius};\n  color: ${buildAlertColor};\n  display: flex;\n  position: relative;\n\n  ${props => props.isToast &&\r\n    css `\n      box-shadow: ${props.isInverse\r\n        ? `0 2px 8px 0 ${transparentize(0.3, props.theme.colors.neutral900)}`\r\n        : `0 2px 8px 0 ${transparentize(0.6, props.theme.colors.neutral900)}`};\n      padding-right: 0;\n      height: ${props.theme.spaceScale.spacing11};\n    `}\n`;\r\nconst AlertContents = styled.div `\n  align-items: ${props => (props.additionalContent ? 'center' : '')};\n  align-self: center;\n  flex-grow: 1;\n  font-family: ${props => props.theme.bodyFont};\n  padding: ${props => props.theme.spaceScale.spacing04} 0;\n  display: ${props => (props.additionalContent ? 'flex' : '')};\n  margin-right: ${props => props.additionalContent && !props.isDismissible\r\n    ? props.theme.spaceScale.spacing03\r\n    : ''};\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    padding-left: 0;\n  }\n`;\r\nexport const AdditionalContentWrapper = styled.div `\n  flex: 1 0 auto;\n  justify-content: flex-end;\n  display: flex;\n  margin-left: ${props => props.theme.spaceScale.spacing05};\n`;\r\nconst IconWrapperStyles = css `\n  align-items: center;\n  display: flex;\n  flex-shrink: 0;\n  margin-right: 1px;\n`;\r\nconst IconWrapper = styled.span `\n  ${IconWrapperStyles}\n  padding: 0 ${props => props.theme.spaceScale.spacing03} 0 ${props => props.theme.spaceScale.spacing04};\n\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    padding: 0 ${props => props.theme.spaceScale.spacing03};\n    svg {\n      width: 20px;\n    }\n  }\n`;\r\nconst ProgressRingWrapper = styled.div `\n  margin-top: 6px;\n  position: absolute;\n  top: auto;\n  right: ${props => props.theme.spaceScale.spacing02};\n`;\r\nconst DismissibleIconWrapper = styled.span `\n  ${IconWrapperStyles}\n  margin-left: ${props => props.additionalContent ? props.theme.spaceScale.spacing03 : ''};\n`;\r\nconst whitelistProps = ['icon', 'isInverse', 'theme', 'variant'];\r\nconst shouldForwardProp = prop => {\r\n    return isPropValid(prop) || whitelistProps.includes(prop);\r\n};\r\nconst DismissButton = styled(IconButton, { shouldForwardProp }) `\n  align-self: stretch;\n  border-radius: 0 ${props => props.theme.borderRadius}\n    ${props => props.theme.borderRadius} 0;\n  color: inherit;\n  height: auto;\n  margin: ${props => (props.isToast ? '4px' : '0 -1px 0 0')};\n  padding: ${props => props.isToast\r\n    ? `0 ${props.theme.spaceScale.spacing04}`\r\n    : `0 ${props.theme.spaceScale.spacing03}`};\n  width: auto;\n  &:not(:disabled):hover {\n    background: none;\n    color: inherit;\n  }\n  &:focus:not(:disabled) {\n    background: none;\n    color: inherit;\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n    outline-offset: 0 !important;\n  }\n  &:not(:disabled):active {\n    background: none;\n    color: inherit;\n  }\n`;\r\nconst AlertSpan = styled.span `\n  white-space: pre-line;\n`;\r\nfunction getAriaLabelIcon(variant, i18n) {\r\n    switch (variant) {\r\n        case 'success':\r\n            return i18n.alertVariants.success;\r\n        case 'warning':\r\n            return i18n.alertVariants.warning;\r\n        case 'danger':\r\n            return i18n.alertVariants.danger;\r\n        default:\r\n            return i18n.alertVariants.info;\r\n    }\r\n}\r\nfunction renderIcon(variant = 'info', isToast, theme, i18n) {\r\n    const Icon = VARIANT_ICON[variant];\r\n    return (React.createElement(IconWrapper, { \"aria-label\": getAriaLabelIcon(variant, i18n), role: \"img\", isToast: isToast, theme: theme },\r\n        React.createElement(Icon, { size: theme.iconSizes.medium })));\r\n}\r\nexport const AlertBase = React.forwardRef((props, ref) => {\r\n    const { additionalContent, children, closeAriaLabel, forceDismiss, hasTimerRing, id: defaultId, isDismissed, isDismissible, isExiting: externalIsExiting, isPaused, isToast, onDismiss, testId, toastDuration, variant, ...other } = props;\r\n    const id = useGenerateId(defaultId);\r\n    const [isExiting, setIsExiting] = React.useState(false);\r\n    const isInverse = useIsInverse(props.isInverse);\r\n    React.useEffect(() => {\r\n        if (isExiting) {\r\n            setTimeout(() => {\r\n                setIsExiting(false);\r\n                onDismiss && typeof onDismiss === 'function' && onDismiss();\r\n            }, transitionDuration - 300);\r\n        }\r\n    }, [isExiting]);\r\n    React.useEffect(() => {\r\n        if (isDismissed) {\r\n            handleDismiss();\r\n        }\r\n    }, [isDismissed]);\r\n    function handleDismiss() {\r\n        setIsExiting(true);\r\n    }\r\n    const theme = React.useContext(ThemeContext);\r\n    const i18n = React.useContext(I18nContext);\r\n    function progressRingColor() {\r\n        if (isInverse) {\r\n            return theme.colors.neutral100;\r\n        }\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return theme.colors.success500;\r\n            case 'warning':\r\n                return theme.colors.warning500;\r\n            case 'danger':\r\n                return theme.colors.danger500;\r\n            default:\r\n                return theme.colors.info500;\r\n        }\r\n    }\r\n    return (React.createElement(StyledAlert, Object.assign({}, other, { \"data-testid\": testId, id: id, tabIndex: -1, isInverse: isInverse, isExiting: isExiting, isToast: isToast, ref: ref, theme: theme, variant: variant }),\r\n        React.createElement(InverseContext.Provider, { value: { isInverse } },\r\n            React.createElement(StyledAlertInner, { isInverse: isInverse, isToast: isToast, theme: theme, variant: variant },\r\n                renderIcon(variant, isToast, theme, i18n),\r\n                React.createElement(AlertContents, { additionalContent: additionalContent, isDismissible: isDismissible, theme: theme },\r\n                    React.createElement(AlertSpan, null, children),\r\n                    additionalContent && (React.createElement(AdditionalContentWrapper, { theme: theme }, additionalContent))),\r\n                isDismissible && (React.createElement(DismissibleIconWrapper, { isInverse: isInverse, variant: variant, theme: theme },\r\n                    hasTimerRing && isToast && (React.createElement(ProgressRingWrapper, { theme: theme },\r\n                        React.createElement(ProgressRing, { color: progressRingColor(), isActive: !isPaused, duration: toastDuration }))),\r\n                    React.createElement(DismissButton, Object.assign({ alertVariant: variant }, (isToast\r\n                        ? { title: closeAriaLabel || i18n.alert.dismissAriaLabel }\r\n                        : {\r\n                            'aria-label': closeAriaLabel || i18n.alert.dismissAriaLabel,\r\n                        }), { icon: React.createElement(CloseIcon, { size: hasTimerRing\r\n                                ? theme.iconSizes.xSmall\r\n                                : theme.iconSizes.small }), isInverse: isInverse, isToast: isToast, onClick: forceDismiss || handleDismiss, theme: theme, variant: ButtonVariant.link }))))))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */",
|
|
3717
3723
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$4
|
|
3718
3724
|
});
|
|
3719
|
-
function
|
|
3725
|
+
function getAriaLabelIcon(variant, i18n) {
|
|
3726
|
+
switch (variant) {
|
|
3727
|
+
case 'success':
|
|
3728
|
+
return i18n.alertVariants.success;
|
|
3729
|
+
case 'warning':
|
|
3730
|
+
return i18n.alertVariants.warning;
|
|
3731
|
+
case 'danger':
|
|
3732
|
+
return i18n.alertVariants.danger;
|
|
3733
|
+
default:
|
|
3734
|
+
return i18n.alertVariants.info;
|
|
3735
|
+
}
|
|
3736
|
+
}
|
|
3737
|
+
function renderIcon(variant, isToast, theme, i18n) {
|
|
3720
3738
|
if (variant === void 0) {
|
|
3721
3739
|
variant = 'info';
|
|
3722
3740
|
}
|
|
3723
3741
|
var Icon = VARIANT_ICON[variant];
|
|
3724
3742
|
return createElement(IconWrapper, {
|
|
3743
|
+
"aria-label": getAriaLabelIcon(variant, i18n),
|
|
3744
|
+
role: "img",
|
|
3725
3745
|
isToast: isToast,
|
|
3726
3746
|
theme: theme
|
|
3727
3747
|
}, createElement(Icon, {
|
|
@@ -3801,7 +3821,7 @@ var AlertBase = /*#__PURE__*/forwardRef(function (props, ref) {
|
|
|
3801
3821
|
isToast: isToast,
|
|
3802
3822
|
theme: theme,
|
|
3803
3823
|
variant: variant
|
|
3804
|
-
}, renderIcon(variant, isToast, theme), createElement(AlertContents, {
|
|
3824
|
+
}, renderIcon(variant, isToast, theme, i18n), createElement(AlertContents, {
|
|
3805
3825
|
additionalContent: additionalContent,
|
|
3806
3826
|
isDismissible: isDismissible,
|
|
3807
3827
|
theme: theme
|
|
@@ -5780,7 +5800,7 @@ var IndeterminateCheckbox = /*#__PURE__*/forwardRef(function (props, _ref) {
|
|
|
5780
5800
|
}, errorMessage));
|
|
5781
5801
|
});
|
|
5782
5802
|
|
|
5783
|
-
var _excluded$r = ["children", "density", "hasHoverStyles", "hasSquareCorners", "hasVerticalBorders", "hasZebraStripes", "isSelectable", "minWidth", "rowCount", "selectedItems", "testId", "isSortableBySelected"];
|
|
5803
|
+
var _excluded$r = ["children", "density", "hasHoverStyles", "hasOutsideBorder", "hasSquareCorners", "hasTablePagination", "hasVerticalBorders", "hasZebraStripes", "isSelectable", "minWidth", "rowCount", "selectedItems", "tableTitle", "testId", "isSortableBySelected"];
|
|
5784
5804
|
var TableDensity;
|
|
5785
5805
|
(function (TableDensity) {
|
|
5786
5806
|
TableDensity["compact"] = "compact";
|
|
@@ -5812,6 +5832,7 @@ var TableContext = /*#__PURE__*/createContext({
|
|
|
5812
5832
|
density: TableDensity.normal,
|
|
5813
5833
|
hasHoverStyles: false,
|
|
5814
5834
|
hasSquareCorners: false,
|
|
5835
|
+
hasTablePagination: false,
|
|
5815
5836
|
hasZebraStripes: false,
|
|
5816
5837
|
hasVerticalBorders: false,
|
|
5817
5838
|
isInverse: false,
|
|
@@ -5821,22 +5842,40 @@ var TableContext = /*#__PURE__*/createContext({
|
|
|
5821
5842
|
selectedItems: []
|
|
5822
5843
|
});
|
|
5823
5844
|
var TableContainer = /*#__PURE__*/_styled("div", {
|
|
5824
|
-
target: "
|
|
5845
|
+
target: "esblka13",
|
|
5825
5846
|
label: "TableContainer"
|
|
5826
5847
|
})("container-type:inline-size;container-name:tableContainer;&:focus{outline:none;}&:focus-visible{outline:2px solid ", function (props) {
|
|
5827
5848
|
return props.isInverse ? props.theme.colors.focusInverse : props.theme.colors.focus;
|
|
5828
|
-
}, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
5849
|
+
}, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlRhYmxlLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUE4Q3lDIiwiZmlsZSI6IlRhYmxlLnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCAqIGFzIFJlYWN0IGZyb20gJ3JlYWN0JztcclxuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xyXG5pbXBvcnQgeyB0cmFuc3BhcmVudGl6ZSB9IGZyb20gJ3BvbGlzaGVkJztcclxuaW1wb3J0IHsgdXNlSXNJbnZlcnNlIH0gZnJvbSAnLi4vLi4vaW52ZXJzZSc7XHJcbmltcG9ydCB7IFRoZW1lQ29udGV4dCB9IGZyb20gJy4uLy4uL3RoZW1lL1RoZW1lQ29udGV4dCc7XHJcbmltcG9ydCB7IGhlYWRpbmdNZWRpdW1TdHlsZXMgfSBmcm9tICcuLi9UeXBvZ3JhcGh5JztcclxuZXhwb3J0IHZhciBUYWJsZURlbnNpdHk7XHJcbihmdW5jdGlvbiAoVGFibGVEZW5zaXR5KSB7XHJcbiAgICBUYWJsZURlbnNpdHlbXCJjb21wYWN0XCJdID0gXCJjb21wYWN0XCI7XHJcbiAgICBUYWJsZURlbnNpdHlbXCJsb29zZVwiXSA9IFwibG9vc2VcIjtcclxuICAgIFRhYmxlRGVuc2l0eVtcIm5vcm1hbFwiXSA9IFwibm9ybWFsXCI7XHJcbn0pKFRhYmxlRGVuc2l0eSB8fCAoVGFibGVEZW5zaXR5ID0ge30pKTtcclxuZXhwb3J0IHZhciBUYWJsZUNlbGxBbGlnbjtcclxuKGZ1bmN0aW9uIChUYWJsZUNlbGxBbGlnbikge1xyXG4gICAgVGFibGVDZWxsQWxpZ25bXCJjZW50ZXJcIl0gPSBcImNlbnRlclwiO1xyXG4gICAgVGFibGVDZWxsQWxpZ25bXCJpbmhlcml0XCJdID0gXCJpbmhlcml0XCI7XHJcbiAgICBUYWJsZUNlbGxBbGlnbltcImp1c3RpZnlcIl0gPSBcImp1c3RpZnlcIjtcclxuICAgIFRhYmxlQ2VsbEFsaWduW1wibGVmdFwiXSA9IFwibGVmdFwiO1xyXG4gICAgVGFibGVDZWxsQWxpZ25bXCJyaWdodFwiXSA9IFwicmlnaHRcIjtcclxufSkoVGFibGVDZWxsQWxpZ24gfHwgKFRhYmxlQ2VsbEFsaWduID0ge30pKTtcclxuZXhwb3J0IHZhciBUYWJsZVNvcnREaXJlY3Rpb247XHJcbihmdW5jdGlvbiAoVGFibGVTb3J0RGlyZWN0aW9uKSB7XHJcbiAgICBUYWJsZVNvcnREaXJlY3Rpb25bXCJhc2NlbmRpbmdcIl0gPSBcImFzY2VuZGluZ1wiO1xyXG4gICAgVGFibGVTb3J0RGlyZWN0aW9uW1wiZGVzY2VuZGluZ1wiXSA9IFwiZGVzY2VuZGluZ1wiO1xyXG4gICAgVGFibGVTb3J0RGlyZWN0aW9uW1wibm9uZVwiXSA9IFwibm9uZVwiO1xyXG59KShUYWJsZVNvcnREaXJlY3Rpb24gfHwgKFRhYmxlU29ydERpcmVjdGlvbiA9IHt9KSk7XHJcbmV4cG9ydCB2YXIgVGFibGVSb3dDb2xvcjtcclxuKGZ1bmN0aW9uIChUYWJsZVJvd0NvbG9yKSB7XHJcbiAgICBUYWJsZVJvd0NvbG9yW1wiZGFuZ2VyXCJdID0gXCJkYW5nZXJcIjtcclxuICAgIFRhYmxlUm93Q29sb3JbXCJpbmZvXCJdID0gXCJpbmZvXCI7XHJcbiAgICBUYWJsZVJvd0NvbG9yW1wic3VjY2Vzc1wiXSA9IFwic3VjY2Vzc1wiO1xyXG4gICAgVGFibGVSb3dDb2xvcltcIndhcm5pbmdcIl0gPSBcIndhcm5pbmdcIjtcclxufSkoVGFibGVSb3dDb2xvciB8fCAoVGFibGVSb3dDb2xvciA9IHt9KSk7XHJcbmV4cG9ydCBjb25zdCBUYWJsZUNvbnRleHQgPSBSZWFjdC5jcmVhdGVDb250ZXh0KHtcclxuICAgIGRlbnNpdHk6IFRhYmxlRGVuc2l0eS5ub3JtYWwsXHJcbiAgICBoYXNIb3ZlclN0eWxlczogZmFsc2UsXHJcbiAgICBoYXNTcXVhcmVDb3JuZXJzOiBmYWxzZSxcclxuICAgIGhhc1RhYmxlUGFnaW5hdGlvbjogZmFsc2UsXHJcbiAgICBoYXNaZWJyYVN0cmlwZXM6IGZhbHNlLFxyXG4gICAgaGFzVmVydGljYWxCb3JkZXJzOiBmYWxzZSxcclxuICAgIGlzSW52ZXJzZTogZmFsc2UsXHJcbiAgICBpc1NlbGVjdGFibGU6IGZhbHNlLFxyXG4gICAgaXNTb3J0YWJsZUJ5U2VsZWN0ZWQ6IGZhbHNlLFxyXG4gICAgcm93Q291bnQ6IDAsXHJcbiAgICBzZWxlY3RlZEl0ZW1zOiBbXSxcclxufSk7XHJcbmV4cG9ydCBjb25zdCBUYWJsZUNvbnRhaW5lciA9IHN0eWxlZC5kaXYgYFxuICBjb250YWluZXItdHlwZTogaW5saW5lLXNpemU7XG4gIGNvbnRhaW5lci1uYW1lOiB0YWJsZUNvbnRhaW5lcjtcblxuICAmOmZvY3VzIHtcbiAgICBvdXRsaW5lOiBub25lO1xuICB9XG4gICY6Zm9jdXMtdmlzaWJsZSB7XG4gICAgb3V0bGluZTogMnB4IHNvbGlkXG4gICAgICAke3Byb3BzID0+IHByb3BzLmlzSW52ZXJzZVxyXG4gICAgPyBwcm9wcy50aGVtZS5jb2xvcnMuZm9jdXNJbnZlcnNlXHJcbiAgICA6IHByb3BzLnRoZW1lLmNvbG9ycy5mb2N1c307XG4gIH1cbmA7XHJcbmV4cG9ydCBjb25zdCBUYWJsZVdyYXBwZXIgPSBzdHlsZWQuZGl2IGBcbiAgQGNvbnRhaW5lciB0YWJsZUNvbnRhaW5lciAobWF4LXdpZHRoOiAke3Byb3BzID0+IHByb3BzLm1pbldpZHRofXB4KSB7XG4gICAgb3ZlcmZsb3c6IGF1dG87XG4gIH1cbmA7XHJcbmV4cG9ydCBjb25zdCBTdHlsZWRUYWJsZVRpdGxlID0gc3R5bGVkLmNhcHRpb24gYFxuICAke2hlYWRpbmdNZWRpdW1TdHlsZXN9O1xuICBtYXJnaW4tYm90dG9tOiAke3Byb3BzID0+IHByb3BzLmlzVGl0bGVOb2RlIHx8IHByb3BzLnRoZW1lLnNwYWNlU2NhbGUuc3BhY2luZzA0fTtcbiAgbWFyZ2luLXRvcDogJHtwcm9wcyA9PiBwcm9wcy5pc1RpdGxlTm9kZSB8fCBwcm9wcy50aGVtZS5zcGFjZVNjYWxlLnNwYWNpbmcwNH07XG4gIHRleHQtYWxpZ246IGxlZnQ7XG5gO1xyXG5leHBvcnQgY29uc3QgU3R5bGVkVGFibGUgPSBzdHlsZWQudGFibGUgYFxuICBib3JkZXItY29sbGFwc2U6ICR7cHJvcHMgPT4gcHJvcHMuaGFzT3V0c2lkZUJvcmRlciAmJiAhcHJvcHMuaGFzU3F1YXJlQ29ybmVyc1xyXG4gICAgPyAnc2VwYXJhdGUnXHJcbiAgICA6ICdjb2xsYXBzZSd9O1xuICBib3JkZXItc3BhY2luZzogMDtcbiAgYm9yZGVyOiAke3Byb3BzID0+IHByb3BzLmhhc091dHNpZGVCb3JkZXJcclxuICAgID8gYDFweCBzb2xpZCAke3Byb3BzLmlzSW52ZXJzZVxyXG4gICAgICAgID8gdHJhbnNwYXJlbnRpemUoMC42LCBwcm9wcy50aGVtZS5jb2xvcnMubmV1dHJhbDEwMClcclxuICAgICAgICA6IHByb3BzLnRoZW1lLmNvbG9ycy5uZXV0cmFsMzAwfWBcclxuICAgIDogJ25vbmUnfTtcbiAgYm9yZGVyLXJhZGl1czogJHtwcm9wcyA9PiB7XHJcbiAgICBpZiAoIXByb3BzLmhhc1NxdWFyZUNvcm5lcnMpIHtcclxuICAgICAgICBpZiAocHJvcHMuaGFzVGFibGVQYWdpbmF0aW9uKSB7XHJcbiAgICAgICAgICAgIHJldHVybiBgJHtwcm9wcy50aGVtZS5ib3JkZXJSYWRpdXN9ICR7cHJvcHMudGhlbWUuYm9yZGVyUmFkaXVzfSAwIDBgO1xyXG4gICAgICAgIH1cclxuICAgICAgICByZXR1cm4gcHJvcHMudGhlbWUuYm9yZGVyUmFkaXVzO1xyXG4gICAgfVxyXG4gICAgcmV0dXJuICcwJztcclxufX07XG4gIGNvbG9yOiAke3Byb3BzID0+IHByb3BzLmlzSW52ZXJzZVxyXG4gICAgPyBwcm9wcy50aGVtZS5jb2xvcnMubmV1dHJhbDEwMFxyXG4gICAgOiBwcm9wcy50aGVtZS5jb2xvcnMubmV1dHJhbDcwMH07XG4gIGRpc3BsYXk6IHRhYmxlO1xuICBmb250LXNpemU6ICR7cHJvcHMgPT4gcHJvcHMudGhlbWUudHlwZVNjYWxlLnNpemUwMy5mb250U2l6ZX07XG4gIGZvbnQtZmFtaWx5OiAke3Byb3BzID0+IHByb3BzLnRoZW1lLmJvZHlGb250fTtcbiAgbGluZS1oZWlnaHQ6ICR7cHJvcHMgPT4gcHJvcHMudGhlbWUudHlwZVNjYWxlLnNpemUwMy5saW5lSGVpZ2h0fTtcbiAgbWluLXdpZHRoOiAke3Byb3BzID0+IHByb3BzLm1pbldpZHRofXB4O1xuICB3aWR0aDogMTAwJTtcbmA7XHJcbmV4cG9ydCBjb25zdCBUYWJsZSA9IFJlYWN0LmZvcndhcmRSZWYoKHByb3BzLCByZWYpID0+IHtcclxuICAgIGNvbnN0IHsgY2hpbGRyZW4sIGRlbnNpdHkgPSBUYWJsZURlbnNpdHkubm9ybWFsLCBoYXNIb3ZlclN0eWxlcywgaGFzT3V0c2lkZUJvcmRlciwgaGFzU3F1YXJlQ29ybmVycywgaGFzVGFibGVQYWdpbmF0aW9uLCBoYXNWZXJ0aWNhbEJvcmRlcnMsIGhhc1plYnJhU3RyaXBlcywgaXNTZWxlY3RhYmxlLCBtaW5XaWR0aCA9IDYwMCwgcm93Q291bnQsIHNlbGVjdGVkSXRlbXMsIHRhYmxlVGl0bGUsIHRlc3RJZCwgaXNTb3J0YWJsZUJ5U2VsZWN0ZWQsIC4uLm90aGVyIH0gPSBwcm9wcztcclxuICAgIGNvbnN0IHRoZW1lID0gUmVhY3QudXNlQ29udGV4dChUaGVtZUNvbnRleHQpO1xyXG4gICAgY29uc3QgaXNJbnZlcnNlID0gdXNlSXNJbnZlcnNlKHByb3BzLmlzSW52ZXJzZSk7XHJcbiAgICBjb25zdCB0YWJsZVdyYXBwZXIgPSBgdGFibGUtd3JhcHBlci0ke3Rlc3RJZH1gO1xyXG4gICAgcmV0dXJuIChSZWFjdC5jcmVhdGVFbGVtZW50KFRhYmxlQ29udGV4dC5Qcm92aWRlciwgeyB2YWx1ZToge1xyXG4gICAgICAgICAgICBkZW5zaXR5LFxyXG4gICAgICAgICAgICBoYXNIb3ZlclN0eWxlcyxcclxuICAgICAgICAgICAgaGFzU3F1YXJlQ29ybmVycyxcclxuICAgICAgICAgICAgaGFzVGFibGVQYWdpbmF0aW9uOiBoYXNUYWJsZVBhZ2luYXRpb24sXHJcbiAgICAgICAgICAgIGhhc1plYnJhU3RyaXBlcyxcclxuICAgICAgICAgICAgaGFzVmVydGljYWxCb3JkZXJzLFxyXG4gICAgICAgICAgICBpc0ludmVyc2U6IGlzSW52ZXJzZSxcclxuICAgICAgICAgICAgaXNTZWxlY3RhYmxlLFxyXG4gICAgICAgICAgICBpc1NvcnRhYmxlQnlTZWxlY3RlZCxcclxuICAgICAgICAgICAgcm93Q291bnQsXHJcbiAgICAgICAgfSB9LFxyXG4gICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoVGFibGVDb250YWluZXIsIHsgXCJkYXRhLXRlc3RpZFwiOiB0YWJsZVdyYXBwZXIsIGlzSW52ZXJzZTogaXNJbnZlcnNlLCBtaW5XaWR0aDogbWluV2lkdGgsIHRoZW1lOiB0aGVtZSwgdGFiSW5kZXg6IDAgfSxcclxuICAgICAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChUYWJsZVdyYXBwZXIsIHsgbWluV2lkdGg6IG1pbldpZHRoIH0sXHJcbiAgICAgICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KFN0eWxlZFRhYmxlLCBPYmplY3QuYXNzaWduKHt9LCBvdGhlciwgeyBcImRhdGEtdGVzdGlkXCI6IHRlc3RJZCwgaGFzT3V0c2lkZUJvcmRlcjogaGFzT3V0c2lkZUJvcmRlciwgaGFzU3F1YXJlQ29ybmVyczogaGFzU3F1YXJlQ29ybmVycywgaGFzVGFibGVQYWdpbmF0aW9uOiBoYXNUYWJsZVBhZ2luYXRpb24sIGlzSW52ZXJzZTogaXNJbnZlcnNlLCBtaW5XaWR0aDogbWluV2lkdGggfHwgdGhlbWUuYnJlYWtwb2ludHMuc21hbGwsIHJlZjogcmVmLCB0aGVtZTogdGhlbWUgfSksXHJcbiAgICAgICAgICAgICAgICAgICAgdGFibGVUaXRsZSAmJiAoUmVhY3QuY3JlYXRlRWxlbWVudChTdHlsZWRUYWJsZVRpdGxlLCB7IFwiZGF0YS10ZXN0aWRcIjogYCR7dGVzdElkfS10YWJsZS10aXRsZWAsIGlzSW52ZXJzZTogaXNJbnZlcnNlLCBpc1RpdGxlTm9kZTogdHlwZW9mIHRhYmxlVGl0bGUgIT09ICdzdHJpbmcnLCB0aGVtZTogdGhlbWUgfSwgdGFibGVUaXRsZSkpLFxyXG4gICAgICAgICAgICAgICAgICAgIGNoaWxkcmVuKSkpKSk7XHJcbn0pO1xyXG4vLyMgc291cmNlTWFwcGluZ1VSTD1UYWJsZS5qcy5tYXAiXX0= */"));
|
|
5829
5850
|
var TableWrapper = /*#__PURE__*/_styled("div", {
|
|
5830
|
-
target: "
|
|
5851
|
+
target: "esblka12",
|
|
5831
5852
|
label: "TableWrapper"
|
|
5832
5853
|
})("@container tableContainer (max-width: ", function (props) {
|
|
5833
5854
|
return props.minWidth;
|
|
5834
|
-
}, "px){overflow:auto;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
5855
|
+
}, "px){overflow:auto;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlRhYmxlLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUE0RHVDIiwiZmlsZSI6IlRhYmxlLnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCAqIGFzIFJlYWN0IGZyb20gJ3JlYWN0JztcclxuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xyXG5pbXBvcnQgeyB0cmFuc3BhcmVudGl6ZSB9IGZyb20gJ3BvbGlzaGVkJztcclxuaW1wb3J0IHsgdXNlSXNJbnZlcnNlIH0gZnJvbSAnLi4vLi4vaW52ZXJzZSc7XHJcbmltcG9ydCB7IFRoZW1lQ29udGV4dCB9IGZyb20gJy4uLy4uL3RoZW1lL1RoZW1lQ29udGV4dCc7XHJcbmltcG9ydCB7IGhlYWRpbmdNZWRpdW1TdHlsZXMgfSBmcm9tICcuLi9UeXBvZ3JhcGh5JztcclxuZXhwb3J0IHZhciBUYWJsZURlbnNpdHk7XHJcbihmdW5jdGlvbiAoVGFibGVEZW5zaXR5KSB7XHJcbiAgICBUYWJsZURlbnNpdHlbXCJjb21wYWN0XCJdID0gXCJjb21wYWN0XCI7XHJcbiAgICBUYWJsZURlbnNpdHlbXCJsb29zZVwiXSA9IFwibG9vc2VcIjtcclxuICAgIFRhYmxlRGVuc2l0eVtcIm5vcm1hbFwiXSA9IFwibm9ybWFsXCI7XHJcbn0pKFRhYmxlRGVuc2l0eSB8fCAoVGFibGVEZW5zaXR5ID0ge30pKTtcclxuZXhwb3J0IHZhciBUYWJsZUNlbGxBbGlnbjtcclxuKGZ1bmN0aW9uIChUYWJsZUNlbGxBbGlnbikge1xyXG4gICAgVGFibGVDZWxsQWxpZ25bXCJjZW50ZXJcIl0gPSBcImNlbnRlclwiO1xyXG4gICAgVGFibGVDZWxsQWxpZ25bXCJpbmhlcml0XCJdID0gXCJpbmhlcml0XCI7XHJcbiAgICBUYWJsZUNlbGxBbGlnbltcImp1c3RpZnlcIl0gPSBcImp1c3RpZnlcIjtcclxuICAgIFRhYmxlQ2VsbEFsaWduW1wibGVmdFwiXSA9IFwibGVmdFwiO1xyXG4gICAgVGFibGVDZWxsQWxpZ25bXCJyaWdodFwiXSA9IFwicmlnaHRcIjtcclxufSkoVGFibGVDZWxsQWxpZ24gfHwgKFRhYmxlQ2VsbEFsaWduID0ge30pKTtcclxuZXhwb3J0IHZhciBUYWJsZVNvcnREaXJlY3Rpb247XHJcbihmdW5jdGlvbiAoVGFibGVTb3J0RGlyZWN0aW9uKSB7XHJcbiAgICBUYWJsZVNvcnREaXJlY3Rpb25bXCJhc2NlbmRpbmdcIl0gPSBcImFzY2VuZGluZ1wiO1xyXG4gICAgVGFibGVTb3J0RGlyZWN0aW9uW1wiZGVzY2VuZGluZ1wiXSA9IFwiZGVzY2VuZGluZ1wiO1xyXG4gICAgVGFibGVTb3J0RGlyZWN0aW9uW1wibm9uZVwiXSA9IFwibm9uZVwiO1xyXG59KShUYWJsZVNvcnREaXJlY3Rpb24gfHwgKFRhYmxlU29ydERpcmVjdGlvbiA9IHt9KSk7XHJcbmV4cG9ydCB2YXIgVGFibGVSb3dDb2xvcjtcclxuKGZ1bmN0aW9uIChUYWJsZVJvd0NvbG9yKSB7XHJcbiAgICBUYWJsZVJvd0NvbG9yW1wiZGFuZ2VyXCJdID0gXCJkYW5nZXJcIjtcclxuICAgIFRhYmxlUm93Q29sb3JbXCJpbmZvXCJdID0gXCJpbmZvXCI7XHJcbiAgICBUYWJsZVJvd0NvbG9yW1wic3VjY2Vzc1wiXSA9IFwic3VjY2Vzc1wiO1xyXG4gICAgVGFibGVSb3dDb2xvcltcIndhcm5pbmdcIl0gPSBcIndhcm5pbmdcIjtcclxufSkoVGFibGVSb3dDb2xvciB8fCAoVGFibGVSb3dDb2xvciA9IHt9KSk7XHJcbmV4cG9ydCBjb25zdCBUYWJsZUNvbnRleHQgPSBSZWFjdC5jcmVhdGVDb250ZXh0KHtcclxuICAgIGRlbnNpdHk6IFRhYmxlRGVuc2l0eS5ub3JtYWwsXHJcbiAgICBoYXNIb3ZlclN0eWxlczogZmFsc2UsXHJcbiAgICBoYXNTcXVhcmVDb3JuZXJzOiBmYWxzZSxcclxuICAgIGhhc1RhYmxlUGFnaW5hdGlvbjogZmFsc2UsXHJcbiAgICBoYXNaZWJyYVN0cmlwZXM6IGZhbHNlLFxyXG4gICAgaGFzVmVydGljYWxCb3JkZXJzOiBmYWxzZSxcclxuICAgIGlzSW52ZXJzZTogZmFsc2UsXHJcbiAgICBpc1NlbGVjdGFibGU6IGZhbHNlLFxyXG4gICAgaXNTb3J0YWJsZUJ5U2VsZWN0ZWQ6IGZhbHNlLFxyXG4gICAgcm93Q291bnQ6IDAsXHJcbiAgICBzZWxlY3RlZEl0ZW1zOiBbXSxcclxufSk7XHJcbmV4cG9ydCBjb25zdCBUYWJsZUNvbnRhaW5lciA9IHN0eWxlZC5kaXYgYFxuICBjb250YWluZXItdHlwZTogaW5saW5lLXNpemU7XG4gIGNvbnRhaW5lci1uYW1lOiB0YWJsZUNvbnRhaW5lcjtcblxuICAmOmZvY3VzIHtcbiAgICBvdXRsaW5lOiBub25lO1xuICB9XG4gICY6Zm9jdXMtdmlzaWJsZSB7XG4gICAgb3V0bGluZTogMnB4IHNvbGlkXG4gICAgICAke3Byb3BzID0+IHByb3BzLmlzSW52ZXJzZVxyXG4gICAgPyBwcm9wcy50aGVtZS5jb2xvcnMuZm9jdXNJbnZlcnNlXHJcbiAgICA6IHByb3BzLnRoZW1lLmNvbG9ycy5mb2N1c307XG4gIH1cbmA7XHJcbmV4cG9ydCBjb25zdCBUYWJsZVdyYXBwZXIgPSBzdHlsZWQuZGl2IGBcbiAgQGNvbnRhaW5lciB0YWJsZUNvbnRhaW5lciAobWF4LXdpZHRoOiAke3Byb3BzID0+IHByb3BzLm1pbldpZHRofXB4KSB7XG4gICAgb3ZlcmZsb3c6IGF1dG87XG4gIH1cbmA7XHJcbmV4cG9ydCBjb25zdCBTdHlsZWRUYWJsZVRpdGxlID0gc3R5bGVkLmNhcHRpb24gYFxuICAke2hlYWRpbmdNZWRpdW1TdHlsZXN9O1xuICBtYXJnaW4tYm90dG9tOiAke3Byb3BzID0+IHByb3BzLmlzVGl0bGVOb2RlIHx8IHByb3BzLnRoZW1lLnNwYWNlU2NhbGUuc3BhY2luZzA0fTtcbiAgbWFyZ2luLXRvcDogJHtwcm9wcyA9PiBwcm9wcy5pc1RpdGxlTm9kZSB8fCBwcm9wcy50aGVtZS5zcGFjZVNjYWxlLnNwYWNpbmcwNH07XG4gIHRleHQtYWxpZ246IGxlZnQ7XG5gO1xyXG5leHBvcnQgY29uc3QgU3R5bGVkVGFibGUgPSBzdHlsZWQudGFibGUgYFxuICBib3JkZXItY29sbGFwc2U6ICR7cHJvcHMgPT4gcHJvcHMuaGFzT3V0c2lkZUJvcmRlciAmJiAhcHJvcHMuaGFzU3F1YXJlQ29ybmVyc1xyXG4gICAgPyAnc2VwYXJhdGUnXHJcbiAgICA6ICdjb2xsYXBzZSd9O1xuICBib3JkZXItc3BhY2luZzogMDtcbiAgYm9yZGVyOiAke3Byb3BzID0+IHByb3BzLmhhc091dHNpZGVCb3JkZXJcclxuICAgID8gYDFweCBzb2xpZCAke3Byb3BzLmlzSW52ZXJzZVxyXG4gICAgICAgID8gdHJhbnNwYXJlbnRpemUoMC42LCBwcm9wcy50aGVtZS5jb2xvcnMubmV1dHJhbDEwMClcclxuICAgICAgICA6IHByb3BzLnRoZW1lLmNvbG9ycy5uZXV0cmFsMzAwfWBcclxuICAgIDogJ25vbmUnfTtcbiAgYm9yZGVyLXJhZGl1czogJHtwcm9wcyA9PiB7XHJcbiAgICBpZiAoIXByb3BzLmhhc1NxdWFyZUNvcm5lcnMpIHtcclxuICAgICAgICBpZiAocHJvcHMuaGFzVGFibGVQYWdpbmF0aW9uKSB7XHJcbiAgICAgICAgICAgIHJldHVybiBgJHtwcm9wcy50aGVtZS5ib3JkZXJSYWRpdXN9ICR7cHJvcHMudGhlbWUuYm9yZGVyUmFkaXVzfSAwIDBgO1xyXG4gICAgICAgIH1cclxuICAgICAgICByZXR1cm4gcHJvcHMudGhlbWUuYm9yZGVyUmFkaXVzO1xyXG4gICAgfVxyXG4gICAgcmV0dXJuICcwJztcclxufX07XG4gIGNvbG9yOiAke3Byb3BzID0+IHByb3BzLmlzSW52ZXJzZVxyXG4gICAgPyBwcm9wcy50aGVtZS5jb2xvcnMubmV1dHJhbDEwMFxyXG4gICAgOiBwcm9wcy50aGVtZS5jb2xvcnMubmV1dHJhbDcwMH07XG4gIGRpc3BsYXk6IHRhYmxlO1xuICBmb250LXNpemU6ICR7cHJvcHMgPT4gcHJvcHMudGhlbWUudHlwZVNjYWxlLnNpemUwMy5mb250U2l6ZX07XG4gIGZvbnQtZmFtaWx5OiAke3Byb3BzID0+IHByb3BzLnRoZW1lLmJvZHlGb250fTtcbiAgbGluZS1oZWlnaHQ6ICR7cHJvcHMgPT4gcHJvcHMudGhlbWUudHlwZVNjYWxlLnNpemUwMy5saW5lSGVpZ2h0fTtcbiAgbWluLXdpZHRoOiAke3Byb3BzID0+IHByb3BzLm1pbldpZHRofXB4O1xuICB3aWR0aDogMTAwJTtcbmA7XHJcbmV4cG9ydCBjb25zdCBUYWJsZSA9IFJlYWN0LmZvcndhcmRSZWYoKHByb3BzLCByZWYpID0+IHtcclxuICAgIGNvbnN0IHsgY2hpbGRyZW4sIGRlbnNpdHkgPSBUYWJsZURlbnNpdHkubm9ybWFsLCBoYXNIb3ZlclN0eWxlcywgaGFzT3V0c2lkZUJvcmRlciwgaGFzU3F1YXJlQ29ybmVycywgaGFzVGFibGVQYWdpbmF0aW9uLCBoYXNWZXJ0aWNhbEJvcmRlcnMsIGhhc1plYnJhU3RyaXBlcywgaXNTZWxlY3RhYmxlLCBtaW5XaWR0aCA9IDYwMCwgcm93Q291bnQsIHNlbGVjdGVkSXRlbXMsIHRhYmxlVGl0bGUsIHRlc3RJZCwgaXNTb3J0YWJsZUJ5U2VsZWN0ZWQsIC4uLm90aGVyIH0gPSBwcm9wcztcclxuICAgIGNvbnN0IHRoZW1lID0gUmVhY3QudXNlQ29udGV4dChUaGVtZUNvbnRleHQpO1xyXG4gICAgY29uc3QgaXNJbnZlcnNlID0gdXNlSXNJbnZlcnNlKHByb3BzLmlzSW52ZXJzZSk7XHJcbiAgICBjb25zdCB0YWJsZVdyYXBwZXIgPSBgdGFibGUtd3JhcHBlci0ke3Rlc3RJZH1gO1xyXG4gICAgcmV0dXJuIChSZWFjdC5jcmVhdGVFbGVtZW50KFRhYmxlQ29udGV4dC5Qcm92aWRlciwgeyB2YWx1ZToge1xyXG4gICAgICAgICAgICBkZW5zaXR5LFxyXG4gICAgICAgICAgICBoYXNIb3ZlclN0eWxlcyxcclxuICAgICAgICAgICAgaGFzU3F1YXJlQ29ybmVycyxcclxuICAgICAgICAgICAgaGFzVGFibGVQYWdpbmF0aW9uOiBoYXNUYWJsZVBhZ2luYXRpb24sXHJcbiAgICAgICAgICAgIGhhc1plYnJhU3RyaXBlcyxcclxuICAgICAgICAgICAgaGFzVmVydGljYWxCb3JkZXJzLFxyXG4gICAgICAgICAgICBpc0ludmVyc2U6IGlzSW52ZXJzZSxcclxuICAgICAgICAgICAgaXNTZWxlY3RhYmxlLFxyXG4gICAgICAgICAgICBpc1NvcnRhYmxlQnlTZWxlY3RlZCxcclxuICAgICAgICAgICAgcm93Q291bnQsXHJcbiAgICAgICAgfSB9LFxyXG4gICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoVGFibGVDb250YWluZXIsIHsgXCJkYXRhLXRlc3RpZFwiOiB0YWJsZVdyYXBwZXIsIGlzSW52ZXJzZTogaXNJbnZlcnNlLCBtaW5XaWR0aDogbWluV2lkdGgsIHRoZW1lOiB0aGVtZSwgdGFiSW5kZXg6IDAgfSxcclxuICAgICAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChUYWJsZVdyYXBwZXIsIHsgbWluV2lkdGg6IG1pbldpZHRoIH0sXHJcbiAgICAgICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KFN0eWxlZFRhYmxlLCBPYmplY3QuYXNzaWduKHt9LCBvdGhlciwgeyBcImRhdGEtdGVzdGlkXCI6IHRlc3RJZCwgaGFzT3V0c2lkZUJvcmRlcjogaGFzT3V0c2lkZUJvcmRlciwgaGFzU3F1YXJlQ29ybmVyczogaGFzU3F1YXJlQ29ybmVycywgaGFzVGFibGVQYWdpbmF0aW9uOiBoYXNUYWJsZVBhZ2luYXRpb24sIGlzSW52ZXJzZTogaXNJbnZlcnNlLCBtaW5XaWR0aDogbWluV2lkdGggfHwgdGhlbWUuYnJlYWtwb2ludHMuc21hbGwsIHJlZjogcmVmLCB0aGVtZTogdGhlbWUgfSksXHJcbiAgICAgICAgICAgICAgICAgICAgdGFibGVUaXRsZSAmJiAoUmVhY3QuY3JlYXRlRWxlbWVudChTdHlsZWRUYWJsZVRpdGxlLCB7IFwiZGF0YS10ZXN0aWRcIjogYCR7dGVzdElkfS10YWJsZS10aXRsZWAsIGlzSW52ZXJzZTogaXNJbnZlcnNlLCBpc1RpdGxlTm9kZTogdHlwZW9mIHRhYmxlVGl0bGUgIT09ICdzdHJpbmcnLCB0aGVtZTogdGhlbWUgfSwgdGFibGVUaXRsZSkpLFxyXG4gICAgICAgICAgICAgICAgICAgIGNoaWxkcmVuKSkpKSk7XHJcbn0pO1xyXG4vLyMgc291cmNlTWFwcGluZ1VSTD1UYWJsZS5qcy5tYXAiXX0= */"));
|
|
5856
|
+
var StyledTableTitle = /*#__PURE__*/_styled("caption", {
|
|
5857
|
+
target: "esblka11",
|
|
5858
|
+
label: "StyledTableTitle"
|
|
5859
|
+
})(headingMediumStyles, ";margin-bottom:", function (props) {
|
|
5860
|
+
return props.isTitleNode || props.theme.spaceScale.spacing04;
|
|
5861
|
+
}, ";margin-top:", function (props) {
|
|
5862
|
+
return props.isTitleNode || props.theme.spaceScale.spacing04;
|
|
5863
|
+
}, ";text-align:left;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlRhYmxlLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFpRStDIiwiZmlsZSI6IlRhYmxlLnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCAqIGFzIFJlYWN0IGZyb20gJ3JlYWN0JztcclxuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xyXG5pbXBvcnQgeyB0cmFuc3BhcmVudGl6ZSB9IGZyb20gJ3BvbGlzaGVkJztcclxuaW1wb3J0IHsgdXNlSXNJbnZlcnNlIH0gZnJvbSAnLi4vLi4vaW52ZXJzZSc7XHJcbmltcG9ydCB7IFRoZW1lQ29udGV4dCB9IGZyb20gJy4uLy4uL3RoZW1lL1RoZW1lQ29udGV4dCc7XHJcbmltcG9ydCB7IGhlYWRpbmdNZWRpdW1TdHlsZXMgfSBmcm9tICcuLi9UeXBvZ3JhcGh5JztcclxuZXhwb3J0IHZhciBUYWJsZURlbnNpdHk7XHJcbihmdW5jdGlvbiAoVGFibGVEZW5zaXR5KSB7XHJcbiAgICBUYWJsZURlbnNpdHlbXCJjb21wYWN0XCJdID0gXCJjb21wYWN0XCI7XHJcbiAgICBUYWJsZURlbnNpdHlbXCJsb29zZVwiXSA9IFwibG9vc2VcIjtcclxuICAgIFRhYmxlRGVuc2l0eVtcIm5vcm1hbFwiXSA9IFwibm9ybWFsXCI7XHJcbn0pKFRhYmxlRGVuc2l0eSB8fCAoVGFibGVEZW5zaXR5ID0ge30pKTtcclxuZXhwb3J0IHZhciBUYWJsZUNlbGxBbGlnbjtcclxuKGZ1bmN0aW9uIChUYWJsZUNlbGxBbGlnbikge1xyXG4gICAgVGFibGVDZWxsQWxpZ25bXCJjZW50ZXJcIl0gPSBcImNlbnRlclwiO1xyXG4gICAgVGFibGVDZWxsQWxpZ25bXCJpbmhlcml0XCJdID0gXCJpbmhlcml0XCI7XHJcbiAgICBUYWJsZUNlbGxBbGlnbltcImp1c3RpZnlcIl0gPSBcImp1c3RpZnlcIjtcclxuICAgIFRhYmxlQ2VsbEFsaWduW1wibGVmdFwiXSA9IFwibGVmdFwiO1xyXG4gICAgVGFibGVDZWxsQWxpZ25bXCJyaWdodFwiXSA9IFwicmlnaHRcIjtcclxufSkoVGFibGVDZWxsQWxpZ24gfHwgKFRhYmxlQ2VsbEFsaWduID0ge30pKTtcclxuZXhwb3J0IHZhciBUYWJsZVNvcnREaXJlY3Rpb247XHJcbihmdW5jdGlvbiAoVGFibGVTb3J0RGlyZWN0aW9uKSB7XHJcbiAgICBUYWJsZVNvcnREaXJlY3Rpb25bXCJhc2NlbmRpbmdcIl0gPSBcImFzY2VuZGluZ1wiO1xyXG4gICAgVGFibGVTb3J0RGlyZWN0aW9uW1wiZGVzY2VuZGluZ1wiXSA9IFwiZGVzY2VuZGluZ1wiO1xyXG4gICAgVGFibGVTb3J0RGlyZWN0aW9uW1wibm9uZVwiXSA9IFwibm9uZVwiO1xyXG59KShUYWJsZVNvcnREaXJlY3Rpb24gfHwgKFRhYmxlU29ydERpcmVjdGlvbiA9IHt9KSk7XHJcbmV4cG9ydCB2YXIgVGFibGVSb3dDb2xvcjtcclxuKGZ1bmN0aW9uIChUYWJsZVJvd0NvbG9yKSB7XHJcbiAgICBUYWJsZVJvd0NvbG9yW1wiZGFuZ2VyXCJdID0gXCJkYW5nZXJcIjtcclxuICAgIFRhYmxlUm93Q29sb3JbXCJpbmZvXCJdID0gXCJpbmZvXCI7XHJcbiAgICBUYWJsZVJvd0NvbG9yW1wic3VjY2Vzc1wiXSA9IFwic3VjY2Vzc1wiO1xyXG4gICAgVGFibGVSb3dDb2xvcltcIndhcm5pbmdcIl0gPSBcIndhcm5pbmdcIjtcclxufSkoVGFibGVSb3dDb2xvciB8fCAoVGFibGVSb3dDb2xvciA9IHt9KSk7XHJcbmV4cG9ydCBjb25zdCBUYWJsZUNvbnRleHQgPSBSZWFjdC5jcmVhdGVDb250ZXh0KHtcclxuICAgIGRlbnNpdHk6IFRhYmxlRGVuc2l0eS5ub3JtYWwsXHJcbiAgICBoYXNIb3ZlclN0eWxlczogZmFsc2UsXHJcbiAgICBoYXNTcXVhcmVDb3JuZXJzOiBmYWxzZSxcclxuICAgIGhhc1RhYmxlUGFnaW5hdGlvbjogZmFsc2UsXHJcbiAgICBoYXNaZWJyYVN0cmlwZXM6IGZhbHNlLFxyXG4gICAgaGFzVmVydGljYWxCb3JkZXJzOiBmYWxzZSxcclxuICAgIGlzSW52ZXJzZTogZmFsc2UsXHJcbiAgICBpc1NlbGVjdGFibGU6IGZhbHNlLFxyXG4gICAgaXNTb3J0YWJsZUJ5U2VsZWN0ZWQ6IGZhbHNlLFxyXG4gICAgcm93Q291bnQ6IDAsXHJcbiAgICBzZWxlY3RlZEl0ZW1zOiBbXSxcclxufSk7XHJcbmV4cG9ydCBjb25zdCBUYWJsZUNvbnRhaW5lciA9IHN0eWxlZC5kaXYgYFxuICBjb250YWluZXItdHlwZTogaW5saW5lLXNpemU7XG4gIGNvbnRhaW5lci1uYW1lOiB0YWJsZUNvbnRhaW5lcjtcblxuICAmOmZvY3VzIHtcbiAgICBvdXRsaW5lOiBub25lO1xuICB9XG4gICY6Zm9jdXMtdmlzaWJsZSB7XG4gICAgb3V0bGluZTogMnB4IHNvbGlkXG4gICAgICAke3Byb3BzID0+IHByb3BzLmlzSW52ZXJzZVxyXG4gICAgPyBwcm9wcy50aGVtZS5jb2xvcnMuZm9jdXNJbnZlcnNlXHJcbiAgICA6IHByb3BzLnRoZW1lLmNvbG9ycy5mb2N1c307XG4gIH1cbmA7XHJcbmV4cG9ydCBjb25zdCBUYWJsZVdyYXBwZXIgPSBzdHlsZWQuZGl2IGBcbiAgQGNvbnRhaW5lciB0YWJsZUNvbnRhaW5lciAobWF4LXdpZHRoOiAke3Byb3BzID0+IHByb3BzLm1pbldpZHRofXB4KSB7XG4gICAgb3ZlcmZsb3c6IGF1dG87XG4gIH1cbmA7XHJcbmV4cG9ydCBjb25zdCBTdHlsZWRUYWJsZVRpdGxlID0gc3R5bGVkLmNhcHRpb24gYFxuICAke2hlYWRpbmdNZWRpdW1TdHlsZXN9O1xuICBtYXJnaW4tYm90dG9tOiAke3Byb3BzID0+IHByb3BzLmlzVGl0bGVOb2RlIHx8IHByb3BzLnRoZW1lLnNwYWNlU2NhbGUuc3BhY2luZzA0fTtcbiAgbWFyZ2luLXRvcDogJHtwcm9wcyA9PiBwcm9wcy5pc1RpdGxlTm9kZSB8fCBwcm9wcy50aGVtZS5zcGFjZVNjYWxlLnNwYWNpbmcwNH07XG4gIHRleHQtYWxpZ246IGxlZnQ7XG5gO1xyXG5leHBvcnQgY29uc3QgU3R5bGVkVGFibGUgPSBzdHlsZWQudGFibGUgYFxuICBib3JkZXItY29sbGFwc2U6ICR7cHJvcHMgPT4gcHJvcHMuaGFzT3V0c2lkZUJvcmRlciAmJiAhcHJvcHMuaGFzU3F1YXJlQ29ybmVyc1xyXG4gICAgPyAnc2VwYXJhdGUnXHJcbiAgICA6ICdjb2xsYXBzZSd9O1xuICBib3JkZXItc3BhY2luZzogMDtcbiAgYm9yZGVyOiAke3Byb3BzID0+IHByb3BzLmhhc091dHNpZGVCb3JkZXJcclxuICAgID8gYDFweCBzb2xpZCAke3Byb3BzLmlzSW52ZXJzZVxyXG4gICAgICAgID8gdHJhbnNwYXJlbnRpemUoMC42LCBwcm9wcy50aGVtZS5jb2xvcnMubmV1dHJhbDEwMClcclxuICAgICAgICA6IHByb3BzLnRoZW1lLmNvbG9ycy5uZXV0cmFsMzAwfWBcclxuICAgIDogJ25vbmUnfTtcbiAgYm9yZGVyLXJhZGl1czogJHtwcm9wcyA9PiB7XHJcbiAgICBpZiAoIXByb3BzLmhhc1NxdWFyZUNvcm5lcnMpIHtcclxuICAgICAgICBpZiAocHJvcHMuaGFzVGFibGVQYWdpbmF0aW9uKSB7XHJcbiAgICAgICAgICAgIHJldHVybiBgJHtwcm9wcy50aGVtZS5ib3JkZXJSYWRpdXN9ICR7cHJvcHMudGhlbWUuYm9yZGVyUmFkaXVzfSAwIDBgO1xyXG4gICAgICAgIH1cclxuICAgICAgICByZXR1cm4gcHJvcHMudGhlbWUuYm9yZGVyUmFkaXVzO1xyXG4gICAgfVxyXG4gICAgcmV0dXJuICcwJztcclxufX07XG4gIGNvbG9yOiAke3Byb3BzID0+IHByb3BzLmlzSW52ZXJzZVxyXG4gICAgPyBwcm9wcy50aGVtZS5jb2xvcnMubmV1dHJhbDEwMFxyXG4gICAgOiBwcm9wcy50aGVtZS5jb2xvcnMubmV1dHJhbDcwMH07XG4gIGRpc3BsYXk6IHRhYmxlO1xuICBmb250LXNpemU6ICR7cHJvcHMgPT4gcHJvcHMudGhlbWUudHlwZVNjYWxlLnNpemUwMy5mb250U2l6ZX07XG4gIGZvbnQtZmFtaWx5OiAke3Byb3BzID0+IHByb3BzLnRoZW1lLmJvZHlGb250fTtcbiAgbGluZS1oZWlnaHQ6ICR7cHJvcHMgPT4gcHJvcHMudGhlbWUudHlwZVNjYWxlLnNpemUwMy5saW5lSGVpZ2h0fTtcbiAgbWluLXdpZHRoOiAke3Byb3BzID0+IHByb3BzLm1pbldpZHRofXB4O1xuICB3aWR0aDogMTAwJTtcbmA7XHJcbmV4cG9ydCBjb25zdCBUYWJsZSA9IFJlYWN0LmZvcndhcmRSZWYoKHByb3BzLCByZWYpID0+IHtcclxuICAgIGNvbnN0IHsgY2hpbGRyZW4sIGRlbnNpdHkgPSBUYWJsZURlbnNpdHkubm9ybWFsLCBoYXNIb3ZlclN0eWxlcywgaGFzT3V0c2lkZUJvcmRlciwgaGFzU3F1YXJlQ29ybmVycywgaGFzVGFibGVQYWdpbmF0aW9uLCBoYXNWZXJ0aWNhbEJvcmRlcnMsIGhhc1plYnJhU3RyaXBlcywgaXNTZWxlY3RhYmxlLCBtaW5XaWR0aCA9IDYwMCwgcm93Q291bnQsIHNlbGVjdGVkSXRlbXMsIHRhYmxlVGl0bGUsIHRlc3RJZCwgaXNTb3J0YWJsZUJ5U2VsZWN0ZWQsIC4uLm90aGVyIH0gPSBwcm9wcztcclxuICAgIGNvbnN0IHRoZW1lID0gUmVhY3QudXNlQ29udGV4dChUaGVtZUNvbnRleHQpO1xyXG4gICAgY29uc3QgaXNJbnZlcnNlID0gdXNlSXNJbnZlcnNlKHByb3BzLmlzSW52ZXJzZSk7XHJcbiAgICBjb25zdCB0YWJsZVdyYXBwZXIgPSBgdGFibGUtd3JhcHBlci0ke3Rlc3RJZH1gO1xyXG4gICAgcmV0dXJuIChSZWFjdC5jcmVhdGVFbGVtZW50KFRhYmxlQ29udGV4dC5Qcm92aWRlciwgeyB2YWx1ZToge1xyXG4gICAgICAgICAgICBkZW5zaXR5LFxyXG4gICAgICAgICAgICBoYXNIb3ZlclN0eWxlcyxcclxuICAgICAgICAgICAgaGFzU3F1YXJlQ29ybmVycyxcclxuICAgICAgICAgICAgaGFzVGFibGVQYWdpbmF0aW9uOiBoYXNUYWJsZVBhZ2luYXRpb24sXHJcbiAgICAgICAgICAgIGhhc1plYnJhU3RyaXBlcyxcclxuICAgICAgICAgICAgaGFzVmVydGljYWxCb3JkZXJzLFxyXG4gICAgICAgICAgICBpc0ludmVyc2U6IGlzSW52ZXJzZSxcclxuICAgICAgICAgICAgaXNTZWxlY3RhYmxlLFxyXG4gICAgICAgICAgICBpc1NvcnRhYmxlQnlTZWxlY3RlZCxcclxuICAgICAgICAgICAgcm93Q291bnQsXHJcbiAgICAgICAgfSB9LFxyXG4gICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoVGFibGVDb250YWluZXIsIHsgXCJkYXRhLXRlc3RpZFwiOiB0YWJsZVdyYXBwZXIsIGlzSW52ZXJzZTogaXNJbnZlcnNlLCBtaW5XaWR0aDogbWluV2lkdGgsIHRoZW1lOiB0aGVtZSwgdGFiSW5kZXg6IDAgfSxcclxuICAgICAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChUYWJsZVdyYXBwZXIsIHsgbWluV2lkdGg6IG1pbldpZHRoIH0sXHJcbiAgICAgICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KFN0eWxlZFRhYmxlLCBPYmplY3QuYXNzaWduKHt9LCBvdGhlciwgeyBcImRhdGEtdGVzdGlkXCI6IHRlc3RJZCwgaGFzT3V0c2lkZUJvcmRlcjogaGFzT3V0c2lkZUJvcmRlciwgaGFzU3F1YXJlQ29ybmVyczogaGFzU3F1YXJlQ29ybmVycywgaGFzVGFibGVQYWdpbmF0aW9uOiBoYXNUYWJsZVBhZ2luYXRpb24sIGlzSW52ZXJzZTogaXNJbnZlcnNlLCBtaW5XaWR0aDogbWluV2lkdGggfHwgdGhlbWUuYnJlYWtwb2ludHMuc21hbGwsIHJlZjogcmVmLCB0aGVtZTogdGhlbWUgfSksXHJcbiAgICAgICAgICAgICAgICAgICAgdGFibGVUaXRsZSAmJiAoUmVhY3QuY3JlYXRlRWxlbWVudChTdHlsZWRUYWJsZVRpdGxlLCB7IFwiZGF0YS10ZXN0aWRcIjogYCR7dGVzdElkfS10YWJsZS10aXRsZWAsIGlzSW52ZXJzZTogaXNJbnZlcnNlLCBpc1RpdGxlTm9kZTogdHlwZW9mIHRhYmxlVGl0bGUgIT09ICdzdHJpbmcnLCB0aGVtZTogdGhlbWUgfSwgdGFibGVUaXRsZSkpLFxyXG4gICAgICAgICAgICAgICAgICAgIGNoaWxkcmVuKSkpKSk7XHJcbn0pO1xyXG4vLyMgc291cmNlTWFwcGluZ1VSTD1UYWJsZS5qcy5tYXAiXX0= */"));
|
|
5835
5864
|
var StyledTable = /*#__PURE__*/_styled("table", {
|
|
5836
5865
|
target: "esblka10",
|
|
5837
5866
|
label: "StyledTable"
|
|
5838
|
-
})("border-collapse:
|
|
5839
|
-
return props.hasSquareCorners ? '
|
|
5867
|
+
})("border-collapse:", function (props) {
|
|
5868
|
+
return props.hasOutsideBorder && !props.hasSquareCorners ? 'separate' : 'collapse';
|
|
5869
|
+
}, ";border-spacing:0;border:", function (props) {
|
|
5870
|
+
return props.hasOutsideBorder ? "1px solid " + (props.isInverse ? curriedTransparentize(0.6, props.theme.colors.neutral100) : props.theme.colors.neutral300) : 'none';
|
|
5871
|
+
}, ";border-radius:", function (props) {
|
|
5872
|
+
if (!props.hasSquareCorners) {
|
|
5873
|
+
if (props.hasTablePagination) {
|
|
5874
|
+
return props.theme.borderRadius + " " + props.theme.borderRadius + " 0 0";
|
|
5875
|
+
}
|
|
5876
|
+
return props.theme.borderRadius;
|
|
5877
|
+
}
|
|
5878
|
+
return '0';
|
|
5840
5879
|
}, ";color:", function (props) {
|
|
5841
5880
|
return props.isInverse ? props.theme.colors.neutral100 : props.theme.colors.neutral700;
|
|
5842
5881
|
}, ";display:table;font-size:", function (props) {
|
|
@@ -5847,19 +5886,22 @@ var StyledTable = /*#__PURE__*/_styled("table", {
|
|
|
5847
5886
|
return props.theme.typeScale.size03.lineHeight;
|
|
5848
5887
|
}, ";min-width:", function (props) {
|
|
5849
5888
|
return props.minWidth;
|
|
5850
|
-
}, "px;width:100%;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
5889
|
+
}, "px;width:100%;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlRhYmxlLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUF1RXdDIiwiZmlsZSI6IlRhYmxlLnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCAqIGFzIFJlYWN0IGZyb20gJ3JlYWN0JztcclxuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xyXG5pbXBvcnQgeyB0cmFuc3BhcmVudGl6ZSB9IGZyb20gJ3BvbGlzaGVkJztcclxuaW1wb3J0IHsgdXNlSXNJbnZlcnNlIH0gZnJvbSAnLi4vLi4vaW52ZXJzZSc7XHJcbmltcG9ydCB7IFRoZW1lQ29udGV4dCB9IGZyb20gJy4uLy4uL3RoZW1lL1RoZW1lQ29udGV4dCc7XHJcbmltcG9ydCB7IGhlYWRpbmdNZWRpdW1TdHlsZXMgfSBmcm9tICcuLi9UeXBvZ3JhcGh5JztcclxuZXhwb3J0IHZhciBUYWJsZURlbnNpdHk7XHJcbihmdW5jdGlvbiAoVGFibGVEZW5zaXR5KSB7XHJcbiAgICBUYWJsZURlbnNpdHlbXCJjb21wYWN0XCJdID0gXCJjb21wYWN0XCI7XHJcbiAgICBUYWJsZURlbnNpdHlbXCJsb29zZVwiXSA9IFwibG9vc2VcIjtcclxuICAgIFRhYmxlRGVuc2l0eVtcIm5vcm1hbFwiXSA9IFwibm9ybWFsXCI7XHJcbn0pKFRhYmxlRGVuc2l0eSB8fCAoVGFibGVEZW5zaXR5ID0ge30pKTtcclxuZXhwb3J0IHZhciBUYWJsZUNlbGxBbGlnbjtcclxuKGZ1bmN0aW9uIChUYWJsZUNlbGxBbGlnbikge1xyXG4gICAgVGFibGVDZWxsQWxpZ25bXCJjZW50ZXJcIl0gPSBcImNlbnRlclwiO1xyXG4gICAgVGFibGVDZWxsQWxpZ25bXCJpbmhlcml0XCJdID0gXCJpbmhlcml0XCI7XHJcbiAgICBUYWJsZUNlbGxBbGlnbltcImp1c3RpZnlcIl0gPSBcImp1c3RpZnlcIjtcclxuICAgIFRhYmxlQ2VsbEFsaWduW1wibGVmdFwiXSA9IFwibGVmdFwiO1xyXG4gICAgVGFibGVDZWxsQWxpZ25bXCJyaWdodFwiXSA9IFwicmlnaHRcIjtcclxufSkoVGFibGVDZWxsQWxpZ24gfHwgKFRhYmxlQ2VsbEFsaWduID0ge30pKTtcclxuZXhwb3J0IHZhciBUYWJsZVNvcnREaXJlY3Rpb247XHJcbihmdW5jdGlvbiAoVGFibGVTb3J0RGlyZWN0aW9uKSB7XHJcbiAgICBUYWJsZVNvcnREaXJlY3Rpb25bXCJhc2NlbmRpbmdcIl0gPSBcImFzY2VuZGluZ1wiO1xyXG4gICAgVGFibGVTb3J0RGlyZWN0aW9uW1wiZGVzY2VuZGluZ1wiXSA9IFwiZGVzY2VuZGluZ1wiO1xyXG4gICAgVGFibGVTb3J0RGlyZWN0aW9uW1wibm9uZVwiXSA9IFwibm9uZVwiO1xyXG59KShUYWJsZVNvcnREaXJlY3Rpb24gfHwgKFRhYmxlU29ydERpcmVjdGlvbiA9IHt9KSk7XHJcbmV4cG9ydCB2YXIgVGFibGVSb3dDb2xvcjtcclxuKGZ1bmN0aW9uIChUYWJsZVJvd0NvbG9yKSB7XHJcbiAgICBUYWJsZVJvd0NvbG9yW1wiZGFuZ2VyXCJdID0gXCJkYW5nZXJcIjtcclxuICAgIFRhYmxlUm93Q29sb3JbXCJpbmZvXCJdID0gXCJpbmZvXCI7XHJcbiAgICBUYWJsZVJvd0NvbG9yW1wic3VjY2Vzc1wiXSA9IFwic3VjY2Vzc1wiO1xyXG4gICAgVGFibGVSb3dDb2xvcltcIndhcm5pbmdcIl0gPSBcIndhcm5pbmdcIjtcclxufSkoVGFibGVSb3dDb2xvciB8fCAoVGFibGVSb3dDb2xvciA9IHt9KSk7XHJcbmV4cG9ydCBjb25zdCBUYWJsZUNvbnRleHQgPSBSZWFjdC5jcmVhdGVDb250ZXh0KHtcclxuICAgIGRlbnNpdHk6IFRhYmxlRGVuc2l0eS5ub3JtYWwsXHJcbiAgICBoYXNIb3ZlclN0eWxlczogZmFsc2UsXHJcbiAgICBoYXNTcXVhcmVDb3JuZXJzOiBmYWxzZSxcclxuICAgIGhhc1RhYmxlUGFnaW5hdGlvbjogZmFsc2UsXHJcbiAgICBoYXNaZWJyYVN0cmlwZXM6IGZhbHNlLFxyXG4gICAgaGFzVmVydGljYWxCb3JkZXJzOiBmYWxzZSxcclxuICAgIGlzSW52ZXJzZTogZmFsc2UsXHJcbiAgICBpc1NlbGVjdGFibGU6IGZhbHNlLFxyXG4gICAgaXNTb3J0YWJsZUJ5U2VsZWN0ZWQ6IGZhbHNlLFxyXG4gICAgcm93Q291bnQ6IDAsXHJcbiAgICBzZWxlY3RlZEl0ZW1zOiBbXSxcclxufSk7XHJcbmV4cG9ydCBjb25zdCBUYWJsZUNvbnRhaW5lciA9IHN0eWxlZC5kaXYgYFxuICBjb250YWluZXItdHlwZTogaW5saW5lLXNpemU7XG4gIGNvbnRhaW5lci1uYW1lOiB0YWJsZUNvbnRhaW5lcjtcblxuICAmOmZvY3VzIHtcbiAgICBvdXRsaW5lOiBub25lO1xuICB9XG4gICY6Zm9jdXMtdmlzaWJsZSB7XG4gICAgb3V0bGluZTogMnB4IHNvbGlkXG4gICAgICAke3Byb3BzID0+IHByb3BzLmlzSW52ZXJzZVxyXG4gICAgPyBwcm9wcy50aGVtZS5jb2xvcnMuZm9jdXNJbnZlcnNlXHJcbiAgICA6IHByb3BzLnRoZW1lLmNvbG9ycy5mb2N1c307XG4gIH1cbmA7XHJcbmV4cG9ydCBjb25zdCBUYWJsZVdyYXBwZXIgPSBzdHlsZWQuZGl2IGBcbiAgQGNvbnRhaW5lciB0YWJsZUNvbnRhaW5lciAobWF4LXdpZHRoOiAke3Byb3BzID0+IHByb3BzLm1pbldpZHRofXB4KSB7XG4gICAgb3ZlcmZsb3c6IGF1dG87XG4gIH1cbmA7XHJcbmV4cG9ydCBjb25zdCBTdHlsZWRUYWJsZVRpdGxlID0gc3R5bGVkLmNhcHRpb24gYFxuICAke2hlYWRpbmdNZWRpdW1TdHlsZXN9O1xuICBtYXJnaW4tYm90dG9tOiAke3Byb3BzID0+IHByb3BzLmlzVGl0bGVOb2RlIHx8IHByb3BzLnRoZW1lLnNwYWNlU2NhbGUuc3BhY2luZzA0fTtcbiAgbWFyZ2luLXRvcDogJHtwcm9wcyA9PiBwcm9wcy5pc1RpdGxlTm9kZSB8fCBwcm9wcy50aGVtZS5zcGFjZVNjYWxlLnNwYWNpbmcwNH07XG4gIHRleHQtYWxpZ246IGxlZnQ7XG5gO1xyXG5leHBvcnQgY29uc3QgU3R5bGVkVGFibGUgPSBzdHlsZWQudGFibGUgYFxuICBib3JkZXItY29sbGFwc2U6ICR7cHJvcHMgPT4gcHJvcHMuaGFzT3V0c2lkZUJvcmRlciAmJiAhcHJvcHMuaGFzU3F1YXJlQ29ybmVyc1xyXG4gICAgPyAnc2VwYXJhdGUnXHJcbiAgICA6ICdjb2xsYXBzZSd9O1xuICBib3JkZXItc3BhY2luZzogMDtcbiAgYm9yZGVyOiAke3Byb3BzID0+IHByb3BzLmhhc091dHNpZGVCb3JkZXJcclxuICAgID8gYDFweCBzb2xpZCAke3Byb3BzLmlzSW52ZXJzZVxyXG4gICAgICAgID8gdHJhbnNwYXJlbnRpemUoMC42LCBwcm9wcy50aGVtZS5jb2xvcnMubmV1dHJhbDEwMClcclxuICAgICAgICA6IHByb3BzLnRoZW1lLmNvbG9ycy5uZXV0cmFsMzAwfWBcclxuICAgIDogJ25vbmUnfTtcbiAgYm9yZGVyLXJhZGl1czogJHtwcm9wcyA9PiB7XHJcbiAgICBpZiAoIXByb3BzLmhhc1NxdWFyZUNvcm5lcnMpIHtcclxuICAgICAgICBpZiAocHJvcHMuaGFzVGFibGVQYWdpbmF0aW9uKSB7XHJcbiAgICAgICAgICAgIHJldHVybiBgJHtwcm9wcy50aGVtZS5ib3JkZXJSYWRpdXN9ICR7cHJvcHMudGhlbWUuYm9yZGVyUmFkaXVzfSAwIDBgO1xyXG4gICAgICAgIH1cclxuICAgICAgICByZXR1cm4gcHJvcHMudGhlbWUuYm9yZGVyUmFkaXVzO1xyXG4gICAgfVxyXG4gICAgcmV0dXJuICcwJztcclxufX07XG4gIGNvbG9yOiAke3Byb3BzID0+IHByb3BzLmlzSW52ZXJzZVxyXG4gICAgPyBwcm9wcy50aGVtZS5jb2xvcnMubmV1dHJhbDEwMFxyXG4gICAgOiBwcm9wcy50aGVtZS5jb2xvcnMubmV1dHJhbDcwMH07XG4gIGRpc3BsYXk6IHRhYmxlO1xuICBmb250LXNpemU6ICR7cHJvcHMgPT4gcHJvcHMudGhlbWUudHlwZVNjYWxlLnNpemUwMy5mb250U2l6ZX07XG4gIGZvbnQtZmFtaWx5OiAke3Byb3BzID0+IHByb3BzLnRoZW1lLmJvZHlGb250fTtcbiAgbGluZS1oZWlnaHQ6ICR7cHJvcHMgPT4gcHJvcHMudGhlbWUudHlwZVNjYWxlLnNpemUwMy5saW5lSGVpZ2h0fTtcbiAgbWluLXdpZHRoOiAke3Byb3BzID0+IHByb3BzLm1pbldpZHRofXB4O1xuICB3aWR0aDogMTAwJTtcbmA7XHJcbmV4cG9ydCBjb25zdCBUYWJsZSA9IFJlYWN0LmZvcndhcmRSZWYoKHByb3BzLCByZWYpID0+IHtcclxuICAgIGNvbnN0IHsgY2hpbGRyZW4sIGRlbnNpdHkgPSBUYWJsZURlbnNpdHkubm9ybWFsLCBoYXNIb3ZlclN0eWxlcywgaGFzT3V0c2lkZUJvcmRlciwgaGFzU3F1YXJlQ29ybmVycywgaGFzVGFibGVQYWdpbmF0aW9uLCBoYXNWZXJ0aWNhbEJvcmRlcnMsIGhhc1plYnJhU3RyaXBlcywgaXNTZWxlY3RhYmxlLCBtaW5XaWR0aCA9IDYwMCwgcm93Q291bnQsIHNlbGVjdGVkSXRlbXMsIHRhYmxlVGl0bGUsIHRlc3RJZCwgaXNTb3J0YWJsZUJ5U2VsZWN0ZWQsIC4uLm90aGVyIH0gPSBwcm9wcztcclxuICAgIGNvbnN0IHRoZW1lID0gUmVhY3QudXNlQ29udGV4dChUaGVtZUNvbnRleHQpO1xyXG4gICAgY29uc3QgaXNJbnZlcnNlID0gdXNlSXNJbnZlcnNlKHByb3BzLmlzSW52ZXJzZSk7XHJcbiAgICBjb25zdCB0YWJsZVdyYXBwZXIgPSBgdGFibGUtd3JhcHBlci0ke3Rlc3RJZH1gO1xyXG4gICAgcmV0dXJuIChSZWFjdC5jcmVhdGVFbGVtZW50KFRhYmxlQ29udGV4dC5Qcm92aWRlciwgeyB2YWx1ZToge1xyXG4gICAgICAgICAgICBkZW5zaXR5LFxyXG4gICAgICAgICAgICBoYXNIb3ZlclN0eWxlcyxcclxuICAgICAgICAgICAgaGFzU3F1YXJlQ29ybmVycyxcclxuICAgICAgICAgICAgaGFzVGFibGVQYWdpbmF0aW9uOiBoYXNUYWJsZVBhZ2luYXRpb24sXHJcbiAgICAgICAgICAgIGhhc1plYnJhU3RyaXBlcyxcclxuICAgICAgICAgICAgaGFzVmVydGljYWxCb3JkZXJzLFxyXG4gICAgICAgICAgICBpc0ludmVyc2U6IGlzSW52ZXJzZSxcclxuICAgICAgICAgICAgaXNTZWxlY3RhYmxlLFxyXG4gICAgICAgICAgICBpc1NvcnRhYmxlQnlTZWxlY3RlZCxcclxuICAgICAgICAgICAgcm93Q291bnQsXHJcbiAgICAgICAgfSB9LFxyXG4gICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoVGFibGVDb250YWluZXIsIHsgXCJkYXRhLXRlc3RpZFwiOiB0YWJsZVdyYXBwZXIsIGlzSW52ZXJzZTogaXNJbnZlcnNlLCBtaW5XaWR0aDogbWluV2lkdGgsIHRoZW1lOiB0aGVtZSwgdGFiSW5kZXg6IDAgfSxcclxuICAgICAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChUYWJsZVdyYXBwZXIsIHsgbWluV2lkdGg6IG1pbldpZHRoIH0sXHJcbiAgICAgICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KFN0eWxlZFRhYmxlLCBPYmplY3QuYXNzaWduKHt9LCBvdGhlciwgeyBcImRhdGEtdGVzdGlkXCI6IHRlc3RJZCwgaGFzT3V0c2lkZUJvcmRlcjogaGFzT3V0c2lkZUJvcmRlciwgaGFzU3F1YXJlQ29ybmVyczogaGFzU3F1YXJlQ29ybmVycywgaGFzVGFibGVQYWdpbmF0aW9uOiBoYXNUYWJsZVBhZ2luYXRpb24sIGlzSW52ZXJzZTogaXNJbnZlcnNlLCBtaW5XaWR0aDogbWluV2lkdGggfHwgdGhlbWUuYnJlYWtwb2ludHMuc21hbGwsIHJlZjogcmVmLCB0aGVtZTogdGhlbWUgfSksXHJcbiAgICAgICAgICAgICAgICAgICAgdGFibGVUaXRsZSAmJiAoUmVhY3QuY3JlYXRlRWxlbWVudChTdHlsZWRUYWJsZVRpdGxlLCB7IFwiZGF0YS10ZXN0aWRcIjogYCR7dGVzdElkfS10YWJsZS10aXRsZWAsIGlzSW52ZXJzZTogaXNJbnZlcnNlLCBpc1RpdGxlTm9kZTogdHlwZW9mIHRhYmxlVGl0bGUgIT09ICdzdHJpbmcnLCB0aGVtZTogdGhlbWUgfSwgdGFibGVUaXRsZSkpLFxyXG4gICAgICAgICAgICAgICAgICAgIGNoaWxkcmVuKSkpKSk7XHJcbn0pO1xyXG4vLyMgc291cmNlTWFwcGluZ1VSTD1UYWJsZS5qcy5tYXAiXX0= */"));
|
|
5851
5890
|
var Table = /*#__PURE__*/forwardRef(function (props, ref) {
|
|
5852
5891
|
var children = props.children,
|
|
5853
5892
|
_props$density = props.density,
|
|
5854
5893
|
density = _props$density === void 0 ? TableDensity.normal : _props$density,
|
|
5855
5894
|
hasHoverStyles = props.hasHoverStyles,
|
|
5895
|
+
hasOutsideBorder = props.hasOutsideBorder,
|
|
5856
5896
|
hasSquareCorners = props.hasSquareCorners,
|
|
5897
|
+
hasTablePagination = props.hasTablePagination,
|
|
5857
5898
|
hasVerticalBorders = props.hasVerticalBorders,
|
|
5858
5899
|
hasZebraStripes = props.hasZebraStripes,
|
|
5859
5900
|
isSelectable = props.isSelectable,
|
|
5860
5901
|
_props$minWidth = props.minWidth,
|
|
5861
5902
|
minWidth = _props$minWidth === void 0 ? 600 : _props$minWidth,
|
|
5862
5903
|
rowCount = props.rowCount,
|
|
5904
|
+
tableTitle = props.tableTitle,
|
|
5863
5905
|
testId = props.testId,
|
|
5864
5906
|
isSortableBySelected = props.isSortableBySelected,
|
|
5865
5907
|
other = _objectWithoutPropertiesLoose(props, _excluded$r);
|
|
@@ -5871,6 +5913,7 @@ var Table = /*#__PURE__*/forwardRef(function (props, ref) {
|
|
|
5871
5913
|
density: density,
|
|
5872
5914
|
hasHoverStyles: hasHoverStyles,
|
|
5873
5915
|
hasSquareCorners: hasSquareCorners,
|
|
5916
|
+
hasTablePagination: hasTablePagination,
|
|
5874
5917
|
hasZebraStripes: hasZebraStripes,
|
|
5875
5918
|
hasVerticalBorders: hasVerticalBorders,
|
|
5876
5919
|
isInverse: isInverse,
|
|
@@ -5888,12 +5931,19 @@ var Table = /*#__PURE__*/forwardRef(function (props, ref) {
|
|
|
5888
5931
|
minWidth: minWidth
|
|
5889
5932
|
}, createElement(StyledTable, Object.assign({}, other, {
|
|
5890
5933
|
"data-testid": testId,
|
|
5934
|
+
hasOutsideBorder: hasOutsideBorder,
|
|
5891
5935
|
hasSquareCorners: hasSquareCorners,
|
|
5936
|
+
hasTablePagination: hasTablePagination,
|
|
5892
5937
|
isInverse: isInverse,
|
|
5893
5938
|
minWidth: minWidth || theme.breakpoints.small,
|
|
5894
5939
|
ref: ref,
|
|
5895
5940
|
theme: theme
|
|
5896
|
-
}),
|
|
5941
|
+
}), tableTitle && createElement(StyledTableTitle, {
|
|
5942
|
+
"data-testid": testId + "-table-title",
|
|
5943
|
+
isInverse: isInverse,
|
|
5944
|
+
isTitleNode: typeof tableTitle !== 'string',
|
|
5945
|
+
theme: theme
|
|
5946
|
+
}, tableTitle), children))));
|
|
5897
5947
|
});
|
|
5898
5948
|
|
|
5899
5949
|
var _excluded$s = ["children", "testId"];
|
|
@@ -6072,6 +6122,54 @@ var TableHeaderCell = /*#__PURE__*/forwardRef(function (props, ref) {
|
|
|
6072
6122
|
});
|
|
6073
6123
|
TableHeaderCell.displayName = 'TableHeaderCell';
|
|
6074
6124
|
|
|
6125
|
+
var useDeviceDetect = function useDeviceDetect() {
|
|
6126
|
+
var userAgent = useMemo(function () {
|
|
6127
|
+
return navigator.userAgent.toLowerCase();
|
|
6128
|
+
}, []);
|
|
6129
|
+
var isSafari = useMemo(function () {
|
|
6130
|
+
return /^((?!chrome|android).)*safari/i.test(userAgent);
|
|
6131
|
+
}, [userAgent]);
|
|
6132
|
+
var isChrome = useMemo(function () {
|
|
6133
|
+
return /chrome|crios/i.test(userAgent) && !/edge|edg/i.test(userAgent);
|
|
6134
|
+
}, [userAgent]);
|
|
6135
|
+
var isFirefox = useMemo(function () {
|
|
6136
|
+
return /firefox|fxios/i.test(userAgent);
|
|
6137
|
+
}, [userAgent]);
|
|
6138
|
+
var isEdge = useMemo(function () {
|
|
6139
|
+
return /edge|edg/i.test(userAgent);
|
|
6140
|
+
}, [userAgent]);
|
|
6141
|
+
var isMobile = useMemo(function () {
|
|
6142
|
+
return /mobi|android|touch|mini/i.test(userAgent);
|
|
6143
|
+
}, [userAgent]);
|
|
6144
|
+
var isWindows = useMemo(function () {
|
|
6145
|
+
return /windows nt/.test(userAgent);
|
|
6146
|
+
}, [userAgent]);
|
|
6147
|
+
var isMacOS = useMemo(function () {
|
|
6148
|
+
return /macintosh/.test(userAgent);
|
|
6149
|
+
}, [userAgent]);
|
|
6150
|
+
var isAndroid = useMemo(function () {
|
|
6151
|
+
return /android/.test(userAgent);
|
|
6152
|
+
}, [userAgent]);
|
|
6153
|
+
var isIOS = useMemo(function () {
|
|
6154
|
+
return /iphone|ipad|ipod/.test(userAgent);
|
|
6155
|
+
}, [userAgent]);
|
|
6156
|
+
var isLinux = useMemo(function () {
|
|
6157
|
+
return /linux/.test(userAgent) && !isAndroid;
|
|
6158
|
+
}, [userAgent, isAndroid]);
|
|
6159
|
+
return {
|
|
6160
|
+
isSafari: isSafari,
|
|
6161
|
+
isChrome: isChrome,
|
|
6162
|
+
isFirefox: isFirefox,
|
|
6163
|
+
isEdge: isEdge,
|
|
6164
|
+
isMobile: isMobile,
|
|
6165
|
+
isWindows: isWindows,
|
|
6166
|
+
isMacOS: isMacOS,
|
|
6167
|
+
isLinux: isLinux,
|
|
6168
|
+
isAndroid: isAndroid,
|
|
6169
|
+
isIOS: isIOS
|
|
6170
|
+
};
|
|
6171
|
+
};
|
|
6172
|
+
|
|
6075
6173
|
var _excluded$w = ["children", "hasCharacterCounter", "id", "inputLength", "maxCount", "maxLength", "testId", "isInverse"];
|
|
6076
6174
|
// Changes the font weight to bold based on maxCount.
|
|
6077
6175
|
function buildFontWeight(props) {
|
|
@@ -6085,7 +6183,7 @@ var StyledInputMessage = /*#__PURE__*/_styled(InputMessage, {
|
|
|
6085
6183
|
label: "StyledInputMessage"
|
|
6086
6184
|
})("font-weight:", buildFontWeight, ";font-family:", function (props) {
|
|
6087
6185
|
return props.theme.bodyFont;
|
|
6088
|
-
}, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
6186
|
+
}, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkNoYXJhY3RlckNvdW50ZXIudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQWdCZ0QiLCJmaWxlIjoiQ2hhcmFjdGVyQ291bnRlci50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgKiBhcyBSZWFjdCBmcm9tICdyZWFjdCc7XHJcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcclxuaW1wb3J0IHVzZURldmljZURldGVjdCBmcm9tICcuLi8uLi9ob29rcy91c2VEZXZpY2VEZXRlY3QnO1xyXG5pbXBvcnQgeyBJMThuQ29udGV4dCB9IGZyb20gJy4uLy4uL2kxOG4nO1xyXG5pbXBvcnQgeyBtYWdtYSB9IGZyb20gJy4uLy4uL3RoZW1lL21hZ21hJztcclxuaW1wb3J0IHsgZGVib3VuY2UgfSBmcm9tICcuLi8uLi91dGlscyc7XHJcbmltcG9ydCB7IEhpZGRlbkxhYmVsVGV4dCB9IGZyb20gJy4uL0NoZWNrYm94JztcclxuaW1wb3J0IHsgSW5wdXRNZXNzYWdlIH0gZnJvbSAnLi4vSW5wdXQvSW5wdXRNZXNzYWdlJztcclxuLy8gQ2hhbmdlcyB0aGUgZm9udCB3ZWlnaHQgdG8gYm9sZCBiYXNlZCBvbiBtYXhDb3VudC5cclxuZnVuY3Rpb24gYnVpbGRGb250V2VpZ2h0KHByb3BzKSB7XHJcbiAgICBpZiAoKHByb3BzLmlucHV0TGVuZ3RoIDwgcHJvcHMubWF4Q291bnQgJiYgcHJvcHMuaW5wdXRMZW5ndGggPj0gMSkgfHxcclxuICAgICAgICBwcm9wcy5pbnB1dExlbmd0aCA9PT0gcHJvcHMubWF4Q291bnQpIHtcclxuICAgICAgICByZXR1cm4gbWFnbWEudHlwb2dyYXBoeVZpc3VhbFN0eWxlcy5oZWFkaW5nWFNtYWxsLmZvbnRXZWlnaHQ7XHJcbiAgICB9XHJcbiAgICByZXR1cm4gJ2luaGVyaXQnO1xyXG59XHJcbmNvbnN0IFN0eWxlZElucHV0TWVzc2FnZSA9IHN0eWxlZChJbnB1dE1lc3NhZ2UpIGBcbiAgZm9udC13ZWlnaHQ6ICR7YnVpbGRGb250V2VpZ2h0fTtcbiAgZm9udC1mYW1pbHk6ICR7cHJvcHMgPT4gcHJvcHMudGhlbWUuYm9keUZvbnR9O1xuYDtcclxuZXhwb3J0IGNvbnN0IENoYXJhY3RlckNvdW50ZXIgPSBSZWFjdC5mb3J3YXJkUmVmKChwcm9wcywgcmVmKSA9PiB7XHJcbiAgICBjb25zdCB7IGNoaWxkcmVuLCBoYXNDaGFyYWN0ZXJDb3VudGVyLCBpZCwgaW5wdXRMZW5ndGgsIG1heENvdW50LCBtYXhMZW5ndGgsIHRlc3RJZCwgaXNJbnZlcnNlLCAuLi5yZXN0IH0gPSBwcm9wcztcclxuICAgIGNvbnN0IGkxOG4gPSBSZWFjdC51c2VDb250ZXh0KEkxOG5Db250ZXh0KTtcclxuICAgIC8vIFRlbXBvcmFyeSB3aGlsZSBib3RoICdtYXhMZW5ndGgnIGFuZCAnbWF4Q291bnQnIGFyZSBzdXBwb3J0ZWQuIFRvIGJlIHJlbW92ZWQgaW4gZnV0dXJlIGl0ZXJhdGlvbnMuXHJcbiAgICBjb25zdCBtYXhDaGFyYWN0ZXJzID0gdHlwZW9mIG1heENvdW50ID09PSAnbnVtYmVyJyA/IG1heENvdW50IDogbWF4TGVuZ3RoO1xyXG4gICAgY29uc3QgaXNPdmVyTWF4Q291bnQgPSBpbnB1dExlbmd0aCA+IG1heENoYXJhY3RlcnM7XHJcbiAgICAvLyBHZXRzIHBlcmNlbnRhZ2UgdmFsdWUgb2YgdG90YWwgY2hhcmFjdGVycyB3aXRoaW4gSW5wdXQgdG8gbGV0IGFyaWEtbGl2ZSBoYXZlIGR5bmFtaWMgc3RhdGVzLlxyXG4gICAgY29uc3QgZ2V0UGVyY2VudGFnZSA9IChpbnB1dExlbmd0aCAvIG1heENoYXJhY3RlcnMpICogMTAwO1xyXG4gICAgLy8gUmV0dXJucyBhcmlhLWxpdmUgc3RhdGVzIGJhc2VkIG9uIHBlcmNlbnRhZ2Ugb2YgY2hhcmFjdGVycyB3aXRoaW4gSW5wdXQuXHJcbiAgICBmdW5jdGlvbiBnZXRBcmlhTGl2ZVN0YXRlKCkge1xyXG4gICAgICAgIGlmIChnZXRQZXJjZW50YWdlID4gMTAwKSB7XHJcbiAgICAgICAgICAgIHJldHVybiAnYXNzZXJ0aXZlJztcclxuICAgICAgICB9XHJcbiAgICAgICAgcmV0dXJuICdwb2xpdGUnO1xyXG4gICAgfVxyXG4gICAgLy8gQXMgdGhlIHVzZXIgdHlwZXMsIHRoaXMgY2FsY3VsYXRlcyB0aGUgcmVtYWluaW5nIGNoYXJhY3RlcnMgc2V0IGJ5IG1heENvdW50IHdoaWNoIGNvdW50cyBkb3duIHRvIHplcm8gdGhlbiBjb3VudHMgdXAgaWYgb3ZlciB0aGUgbGltaXQuXHJcbiAgICBjb25zdCBjaGFyYWN0ZXJMaW1pdCA9IG1heENoYXJhY3RlcnMgPiBpbnB1dExlbmd0aFxyXG4gICAgICAgID8gbWF4Q2hhcmFjdGVycyAtIGlucHV0TGVuZ3RoXHJcbiAgICAgICAgOiBpbnB1dExlbmd0aCAtIG1heENoYXJhY3RlcnM7XHJcbiAgICAvKlxyXG4gICAgICogUmV0dXJucyB0aGUgY2hhcmFjdGVyIGNvdW50ZXIgZGVzY3JpcHRpb24uXHJcbiAgICAgKiBXaGVuIHRoZXJlJ3Mgbm8gaW5wdXRMZW5ndGgsIHJldHVybnMgXCIjIGNoYXJhY3RlcihzKSBhbGxvd2VkXCJcclxuICAgICAqIFdoZW4gaW5wdXRMZW5ndGggPCBtYXhDb3VudCBvciBpbnB1dExlbmd0aCA9PT0gbWF4Q291bnQsIHJldHVybnMgXCIjIGNoYXJhY3RlcihzKSBsZWZ0XCJcclxuICAgICAqIFdoZW4gaW5wdXRMZW5ndGggPiBtYXhDb3VudCwgcmV0dXJucyBcIiMgY2hhcmFjdGVyKHMpIG92ZXIgbGltaXRcIlxyXG4gICAgICovXHJcbiAgICBjb25zdCBjaGFyYWN0ZXJUaXRsZSA9IFJlYWN0LnVzZU1lbW8oKCkgPT4ge1xyXG4gICAgICAgIGlmIChpbnB1dExlbmd0aCA+IDApIHtcclxuICAgICAgICAgICAgaWYgKGlucHV0TGVuZ3RoIDwgbWF4Q2hhcmFjdGVycykge1xyXG4gICAgICAgICAgICAgICAgaWYgKGlucHV0TGVuZ3RoID09PSBtYXhDaGFyYWN0ZXJzIC0gMSkge1xyXG4gICAgICAgICAgICAgICAgICAgIHJldHVybiBgJHtjaGFyYWN0ZXJMaW1pdH0gJHtpMThuLmNoYXJhY3RlckNvdW50ZXIuY2hhcmFjdGVyTGVmdH1gO1xyXG4gICAgICAgICAgICAgICAgfVxyXG4gICAgICAgICAgICAgICAgZWxzZSBpZiAoY2hhcmFjdGVyTGltaXQgPiAxKSB7XHJcbiAgICAgICAgICAgICAgICAgICAgcmV0dXJuIGAke2NoYXJhY3RlckxpbWl0fSAke2kxOG4uY2hhcmFjdGVyQ291bnRlci5jaGFyYWN0ZXJzTGVmdH1gO1xyXG4gICAgICAgICAgICAgICAgfVxyXG4gICAgICAgICAgICB9XHJcbiAgICAgICAgICAgIGlmIChpbnB1dExlbmd0aCA+IG1heENoYXJhY3RlcnMpIHtcclxuICAgICAgICAgICAgICAgIGlmIChpbnB1dExlbmd0aCA9PT0gbWF4Q2hhcmFjdGVycyArIDEpIHtcclxuICAgICAgICAgICAgICAgICAgICByZXR1cm4gYCR7Y2hhcmFjdGVyTGltaXR9ICR7aTE4bi5jaGFyYWN0ZXJDb3VudGVyLmNoYXJhY3Rlck92ZXJ9YDtcclxuICAgICAgICAgICAgICAgIH1cclxuICAgICAgICAgICAgICAgIHJldHVybiBgJHtjaGFyYWN0ZXJMaW1pdH0gJHtpMThuLmNoYXJhY3RlckNvdW50ZXIuY2hhcmFjdGVyc092ZXJ9YDtcclxuICAgICAgICAgICAgfVxyXG4gICAgICAgICAgICBpZiAoaW5wdXRMZW5ndGggPT09IG1heENoYXJhY3RlcnMpIHtcclxuICAgICAgICAgICAgICAgIHJldHVybiBgMCAke2kxOG4uY2hhcmFjdGVyQ291bnRlci5jaGFyYWN0ZXJzTGVmdH1gO1xyXG4gICAgICAgICAgICB9XHJcbiAgICAgICAgfVxyXG4gICAgICAgIGVsc2Uge1xyXG4gICAgICAgICAgICBpZiAobWF4Q2hhcmFjdGVycyA9PT0gMSkge1xyXG4gICAgICAgICAgICAgICAgcmV0dXJuIGAke21heENoYXJhY3RlcnN9ICR7aTE4bi5jaGFyYWN0ZXJDb3VudGVyLmNoYXJhY3RlckFsbG93ZWR9YDtcclxuICAgICAgICAgICAgfVxyXG4gICAgICAgICAgICByZXR1cm4gYCR7bWF4Q2hhcmFjdGVyc30gJHtpMThuLmNoYXJhY3RlckNvdW50ZXIuY2hhcmFjdGVyc0FsbG93ZWR9YDtcclxuICAgICAgICB9XHJcbiAgICB9LCBbY2hhcmFjdGVyTGltaXQsIGlucHV0TGVuZ3RoLCBpMThuLmNoYXJhY3RlckNvdW50ZXIsIG1heENoYXJhY3RlcnNdKTtcclxuICAgIC8vIFNldHMgdGhlIHNjcmVlbiByZWFkZXIgbWVzc2FnZSB0byBhbm5vdW5jZSB0aGUgY2hhcmFjdGVyIGNvdW50ZXIuXHJcbiAgICBjb25zdCBbc2NyZWVuUmVhZGVyTWVzc2FnZSwgc2V0U2NyZWVuUmVhZGVyTWVzc2FnZV0gPSBSZWFjdC51c2VTdGF0ZSgpO1xyXG4gICAgY29uc3QgZGVib3VuY2VkU2V0U2NyZWVuUmVhZGVyTWVzc2FnZSA9IFJlYWN0LnVzZU1lbW8oKCkgPT4gZGVib3VuY2UoKHN0YXR1c01lc3NhZ2UpID0+IHtcclxuICAgICAgICBzZXRTY3JlZW5SZWFkZXJNZXNzYWdlKHN0YXR1c01lc3NhZ2UpO1xyXG4gICAgfSwgMzAwMCksIFtdKTtcclxuICAgIFJlYWN0LnVzZUVmZmVjdCgoKSA9PiB7XHJcbiAgICAgICAgZGVib3VuY2VkU2V0U2NyZWVuUmVhZGVyTWVzc2FnZShjaGFyYWN0ZXJUaXRsZSk7XHJcbiAgICAgICAgcmV0dXJuICgpID0+IHtcclxuICAgICAgICAgICAgZGVib3VuY2VkU2V0U2NyZWVuUmVhZGVyTWVzc2FnZS5jbGVhcigpO1xyXG4gICAgICAgIH07XHJcbiAgICB9LCBbaW5wdXRMZW5ndGgsIGRlYm91bmNlZFNldFNjcmVlblJlYWRlck1lc3NhZ2UsIGNoYXJhY3RlclRpdGxlXSk7XHJcbiAgICBjb25zdCB7IGlzTWFjT1MgfSA9IHVzZURldmljZURldGVjdCgpO1xyXG4gICAgcmV0dXJuIChSZWFjdC5jcmVhdGVFbGVtZW50KFJlYWN0LkZyYWdtZW50LCBudWxsLFxyXG4gICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoXCJkaXZcIiwgT2JqZWN0LmFzc2lnbih7IHJlZjogcmVmLCBcImRhdGEtdGVzdGlkXCI6IHRlc3RJZCB9LCByZXN0LCB7IGlkOiBpZCB9KSxcclxuICAgICAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChTdHlsZWRJbnB1dE1lc3NhZ2UsIHsgXCJhcmlhLWxpdmVcIjogZ2V0QXJpYUxpdmVTdGF0ZSgpLCBoYXNDaGFyYWN0ZXJDb3VudGVyOiBoYXNDaGFyYWN0ZXJDb3VudGVyLCBoYXNFcnJvcjogaXNPdmVyTWF4Q291bnQsIGlzSW52ZXJzZTogaXNJbnZlcnNlLCBpbnB1dExlbmd0aDogaW5wdXRMZW5ndGgsIG1heENvdW50OiBtYXhDaGFyYWN0ZXJzLCBtYXhMZW5ndGg6IG1heENoYXJhY3RlcnMgfSwgY2hhcmFjdGVyVGl0bGUpLFxyXG4gICAgICAgICAgICBpc01hY09TICYmIHNjcmVlblJlYWRlck1lc3NhZ2UgJiYgKFJlYWN0LmNyZWF0ZUVsZW1lbnQoSGlkZGVuTGFiZWxUZXh0LCB7IFwiYXJpYS1saXZlXCI6IFwiYXNzZXJ0aXZlXCIsIFwiZGF0YS10ZXN0aWRcIjogXCJzY3JlZW5SZWFkZXJNZXNzYWdlXCIgfSwgc2NyZWVuUmVhZGVyTWVzc2FnZSkpKSkpO1xyXG59KTtcclxuLy8jIHNvdXJjZU1hcHBpbmdVUkw9Q2hhcmFjdGVyQ291bnRlci5qcy5tYXAiXX0= */"));
|
|
6089
6187
|
var CharacterCounter = /*#__PURE__*/forwardRef(function (props, ref) {
|
|
6090
6188
|
var hasCharacterCounter = props.hasCharacterCounter,
|
|
6091
6189
|
id = props.id,
|
|
@@ -6103,13 +6201,10 @@ var CharacterCounter = /*#__PURE__*/forwardRef(function (props, ref) {
|
|
|
6103
6201
|
var getPercentage = inputLength / maxCharacters * 100;
|
|
6104
6202
|
// Returns aria-live states based on percentage of characters within Input.
|
|
6105
6203
|
function getAriaLiveState() {
|
|
6106
|
-
if (getPercentage
|
|
6107
|
-
|
|
6108
|
-
return 'assertive';
|
|
6109
|
-
}
|
|
6110
|
-
return 'polite';
|
|
6204
|
+
if (getPercentage > 100) {
|
|
6205
|
+
return 'assertive';
|
|
6111
6206
|
}
|
|
6112
|
-
return '
|
|
6207
|
+
return 'polite';
|
|
6113
6208
|
}
|
|
6114
6209
|
// As the user types, this calculates the remaining characters set by maxCount which counts down to zero then counts up if over the limit.
|
|
6115
6210
|
var characterLimit = maxCharacters > inputLength ? maxCharacters - inputLength : inputLength - maxCharacters;
|
|
@@ -6119,7 +6214,7 @@ var CharacterCounter = /*#__PURE__*/forwardRef(function (props, ref) {
|
|
|
6119
6214
|
* When inputLength < maxCount or inputLength === maxCount, returns "# character(s) left"
|
|
6120
6215
|
* When inputLength > maxCount, returns "# character(s) over limit"
|
|
6121
6216
|
*/
|
|
6122
|
-
|
|
6217
|
+
var characterTitle = useMemo(function () {
|
|
6123
6218
|
if (inputLength > 0) {
|
|
6124
6219
|
if (inputLength < maxCharacters) {
|
|
6125
6220
|
if (inputLength === maxCharacters - 1) {
|
|
@@ -6143,12 +6238,30 @@ var CharacterCounter = /*#__PURE__*/forwardRef(function (props, ref) {
|
|
|
6143
6238
|
}
|
|
6144
6239
|
return maxCharacters + " " + i18n.characterCounter.charactersAllowed;
|
|
6145
6240
|
}
|
|
6146
|
-
}
|
|
6147
|
-
|
|
6148
|
-
|
|
6149
|
-
|
|
6150
|
-
|
|
6151
|
-
|
|
6241
|
+
}, [characterLimit, inputLength, i18n.characterCounter, maxCharacters]);
|
|
6242
|
+
// Sets the screen reader message to announce the character counter.
|
|
6243
|
+
var _React$useState = useState(),
|
|
6244
|
+
screenReaderMessage = _React$useState[0],
|
|
6245
|
+
setScreenReaderMessage = _React$useState[1];
|
|
6246
|
+
var debouncedSetScreenReaderMessage = useMemo(function () {
|
|
6247
|
+
return debounce(function (statusMessage) {
|
|
6248
|
+
setScreenReaderMessage(statusMessage);
|
|
6249
|
+
}, 3000);
|
|
6250
|
+
}, []);
|
|
6251
|
+
useEffect(function () {
|
|
6252
|
+
debouncedSetScreenReaderMessage(characterTitle);
|
|
6253
|
+
return function () {
|
|
6254
|
+
debouncedSetScreenReaderMessage.clear();
|
|
6255
|
+
};
|
|
6256
|
+
}, [inputLength, debouncedSetScreenReaderMessage, characterTitle]);
|
|
6257
|
+
var _useDeviceDetect = useDeviceDetect(),
|
|
6258
|
+
isMacOS = _useDeviceDetect.isMacOS;
|
|
6259
|
+
return createElement(Fragment, null, createElement("div", Object.assign({
|
|
6260
|
+
ref: ref,
|
|
6261
|
+
"data-testid": testId
|
|
6262
|
+
}, rest, {
|
|
6263
|
+
id: id
|
|
6264
|
+
}), createElement(StyledInputMessage, {
|
|
6152
6265
|
"aria-live": getAriaLiveState(),
|
|
6153
6266
|
hasCharacterCounter: hasCharacterCounter,
|
|
6154
6267
|
hasError: isOverMaxCount,
|
|
@@ -6156,7 +6269,10 @@ var CharacterCounter = /*#__PURE__*/forwardRef(function (props, ref) {
|
|
|
6156
6269
|
inputLength: inputLength,
|
|
6157
6270
|
maxCount: maxCharacters,
|
|
6158
6271
|
maxLength: maxCharacters
|
|
6159
|
-
}, characterTitle(
|
|
6272
|
+
}, characterTitle), isMacOS && screenReaderMessage && createElement(HiddenLabelText, {
|
|
6273
|
+
"aria-live": "assertive",
|
|
6274
|
+
"data-testid": "screenReaderMessage"
|
|
6275
|
+
}, screenReaderMessage)));
|
|
6160
6276
|
});
|
|
6161
6277
|
|
|
6162
6278
|
var _excluded$x = ["actionable", "children", "containerStyle", "errorMessage", "fieldId", "hasCharacterCounter", "helperMessage", "iconPosition", "inputSize", "inputLength", "isInverse", "isLabelVisuallyHidden", "labelPosition", "labelStyle", "labelText", "labelWidth", "maxCount", "maxLength", "messageStyle", "testId"];
|
|
@@ -6707,25 +6823,32 @@ function usePagination(props) {
|
|
|
6707
6823
|
}, other);
|
|
6708
6824
|
}
|
|
6709
6825
|
|
|
6710
|
-
var _excluded$B = ["dropdownDropDirection", "testId", "defaultPage", "defaultRowsPerPage", "itemCount", "onPageChange", "onRowsPerPageChange", "page", "rowsPerPage", "rowsPerPageValues", "hasSquareCorners"];
|
|
6826
|
+
var _excluded$B = ["dropdownDropDirection", "testId", "defaultPage", "defaultRowsPerPage", "itemCount", "onPageChange", "onRowsPerPageChange", "page", "rowsPerPage", "rowsPerPageValues", "hasOutsideBorder", "hasSquareCorners"];
|
|
6827
|
+
function getBorder(hasOutsideBorder, isInverse) {
|
|
6828
|
+
return hasOutsideBorder ? "1px solid " + (isInverse ? curriedTransparentize(0.6, magma.colors.neutral100) : magma.colors.neutral300) : 'none';
|
|
6829
|
+
}
|
|
6711
6830
|
var StyledContainer$2 = /*#__PURE__*/_styled("div", {
|
|
6712
6831
|
target: "e1cgxi452",
|
|
6713
6832
|
label: "StyledContainer"
|
|
6714
6833
|
})("align-items:center;background:", function (props) {
|
|
6715
6834
|
return props.isInverse ? curriedTransparentize(0.9, props.theme.colors.neutral100) : props.theme.colors.neutral200;
|
|
6716
|
-
}, ";border-top:1px solid ", function (props) {
|
|
6717
|
-
return props.isInverse ? curriedTransparentize(0.6, props.theme.colors.neutral100) : props.theme.colors.neutral300;
|
|
6718
6835
|
}, ";display:flex;justify-content:flex-end;padding:", function (props) {
|
|
6719
6836
|
return props.theme.spaceScale.spacing02;
|
|
6837
|
+
}, ";border-left:", function (props) {
|
|
6838
|
+
return getBorder(props.hasOutsideBorder, props.isInverse);
|
|
6839
|
+
}, ";border-right:", function (props) {
|
|
6840
|
+
return getBorder(props.hasOutsideBorder, props.isInverse);
|
|
6841
|
+
}, ";border-bottom:", function (props) {
|
|
6842
|
+
return getBorder(props.hasOutsideBorder, props.isInverse);
|
|
6720
6843
|
}, ";border-radius:", function (props) {
|
|
6721
6844
|
return props.hasSquareCorners ? '0' : "0 0 " + props.theme.borderRadius + " " + props.theme.borderRadius;
|
|
6722
|
-
}, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
6845
|
+
}, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["TablePagination.tsx"],"names":[],"mappings":"AAsBmC","file":"TablePagination.tsx","sourcesContent":["import * as React from 'react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport { EastIcon, WestIcon } from 'react-magma-icons';\r\nimport { useControlled } from '../../hooks/useControlled';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { magma } from '../../theme/magma';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { ButtonColor, ButtonVariant } from '../Button';\r\nimport { ButtonGroup, ButtonGroupAlignment } from '../ButtonGroup';\r\nimport { IconButton } from '../IconButton';\r\nimport { Label } from '../Label';\r\nimport { NativeSelect } from '../NativeSelect';\r\nimport { usePagination } from '../Pagination/usePagination';\r\nfunction getBorder(hasOutsideBorder, isInverse) {\r\n    return hasOutsideBorder\r\n        ? `1px solid ${isInverse\r\n            ? transparentize(0.6, magma.colors.neutral100)\r\n            : magma.colors.neutral300}`\r\n        : 'none';\r\n}\r\nconst StyledContainer = styled.div `\n  align-items: center;\n  background: ${props => props.isInverse\r\n    ? transparentize(0.9, props.theme.colors.neutral100)\r\n    : props.theme.colors.neutral200};\n  display: flex;\n  justify-content: flex-end;\n  padding: ${props => props.theme.spaceScale.spacing02};\n  border-left: ${props => getBorder(props.hasOutsideBorder, props.isInverse)};\n  border-right: ${props => getBorder(props.hasOutsideBorder, props.isInverse)};\n  border-bottom: ${props => getBorder(props.hasOutsideBorder, props.isInverse)};\n  border-radius: ${props => props.hasSquareCorners\r\n    ? '0'\r\n    : `0 0 ${props.theme.borderRadius} ${props.theme.borderRadius}`};\n`;\r\nconst PageCount = styled(Label) `\n  margin: 0 ${props => props.theme.spaceScale.spacing08};\n`;\r\nconst RowsPerPageLabel = styled.span `\n  font-weight: 600;\n  font-family: ${props => props.theme.bodyFont};\n  line-height: 20px;\n  margin: 0 16px 0 0;\n  text-align: left;\n  color: ${props => (props.isInverse ? props.theme.colors.neutral100 : '')};\n`;\r\nconst RowsPerPageController = (props) => {\r\n    const { handleRowsPerPageChange, rowsPerPageValues, isInverse, rowsPerPage } = props;\r\n    const theme = React.useContext(ThemeContext);\r\n    const i18n = React.useContext(I18nContext);\r\n    const rowsPerPageItems = rowsPerPageValues.map(value => ({\r\n        label: value.toString(),\r\n        value,\r\n    }));\r\n    return (React.createElement(React.Fragment, null,\r\n        React.createElement(RowsPerPageLabel, { isInverse: isInverse, theme: theme },\r\n            i18n.table.pagination.rowsPerPageLabel,\r\n            \":\"),\r\n        React.createElement(NativeSelect, { onChange: event => handleRowsPerPageChange(event.target.value), \"aria-label\": i18n.table.pagination.rowsPerPageLabel, style: { minWidth: 80 }, testId: \"rowPerPageSelect\", fieldId: '', value: rowsPerPage }, rowsPerPageItems.map((row, index) => (React.createElement(\"option\", { key: index, value: row.value }, row.label))))));\r\n};\r\nexport const TablePagination = React.forwardRef((props, ref) => {\r\n    const { dropdownDropDirection, testId, defaultPage, defaultRowsPerPage = 10, itemCount, onPageChange, onRowsPerPageChange = null, page: pageProp, rowsPerPage: rowsPerPageProp, rowsPerPageValues = [10, 20, 50, 100], hasOutsideBorder, hasSquareCorners = true, ...other } = props;\r\n    const theme = React.useContext(ThemeContext);\r\n    const i18n = React.useContext(I18nContext);\r\n    const hasRowPerPageChangeFunction = onRowsPerPageChange && typeof onRowsPerPageChange === 'function';\r\n    const isInverse = useIsInverse(props.isInverse);\r\n    const [rowsPerPage, setRowsPerPageState] = useControlled({\r\n        controlled: rowsPerPageProp,\r\n        default: defaultRowsPerPage,\r\n    });\r\n    React.useEffect(() => {\r\n        const checkedRowsPerPage = rowsPerPageProp\r\n            ? rowsPerPageProp\r\n            : defaultRowsPerPage;\r\n        if (!rowsPerPageValues.includes(checkedRowsPerPage)) {\r\n            setRowsPerPageState(rowsPerPageValues[0]);\r\n            handleRowsPerPageChange(rowsPerPageValues[0]);\r\n        }\r\n    }, []);\r\n    const { page, pageButtons, setPageState } = usePagination({\r\n        count: itemCount / rowsPerPage,\r\n        defaultPage,\r\n        numberOfEdgePages: 0,\r\n        numberOfAdjacentPages: 0,\r\n        onPageChange,\r\n        page: pageProp,\r\n    });\r\n    const isLastPage = page * rowsPerPage >= itemCount;\r\n    const displayPageStart = (page - 1) * rowsPerPage + 1;\r\n    const displayPageEnd = isLastPage ? itemCount : page * rowsPerPage;\r\n    function handleRowsPerPageChange(value) {\r\n        if (!pageProp) {\r\n            setPageState(1);\r\n            onPageChange &&\r\n                typeof onPageChange === 'function' &&\r\n                onPageChange({}, 1);\r\n        }\r\n        if (!rowsPerPageProp) {\r\n            setRowsPerPageState(value);\r\n        }\r\n        hasRowPerPageChangeFunction && onRowsPerPageChange(value);\r\n    }\r\n    const previousButton = pageButtons[0];\r\n    const nextButton = pageButtons[pageButtons.length - 1];\r\n    return (React.createElement(StyledContainer, Object.assign({}, other, { \"data-testid\": testId, isInverse: isInverse, hasOutsideBorder: hasOutsideBorder, hasSquareCorners: hasSquareCorners, ref: ref, theme: theme }),\r\n        hasRowPerPageChangeFunction && (React.createElement(RowsPerPageController, { isInverse: isInverse, handleRowsPerPageChange: handleRowsPerPageChange, rowsPerPageValues: rowsPerPageValues, rowsPerPage: rowsPerPage })),\r\n        React.createElement(PageCount, { isInverse: isInverse, theme: theme }, `${displayPageStart}-${displayPageEnd} ${i18n.table.pagination.ofLabel} ${itemCount}`),\r\n        React.createElement(ButtonGroup, { alignment: ButtonGroupAlignment.center },\r\n            React.createElement(IconButton, { \"aria-label\": i18n.table.pagination.previousAriaLabel, color: ButtonColor.secondary, disabled: previousButton.disabled, icon: React.createElement(WestIcon, null), isInverse: isInverse, onClick: previousButton.onClick, testId: \"previousBtn\", variant: ButtonVariant.link }),\r\n            React.createElement(IconButton, { \"aria-label\": i18n.table.pagination.nextAriaLabel, color: ButtonColor.secondary, disabled: nextButton.disabled, icon: React.createElement(EastIcon, null), isInverse: isInverse, onClick: nextButton.onClick, testId: \"nextBtn\", variant: ButtonVariant.link }))));\r\n});\r\n//# sourceMappingURL=TablePagination.js.map"]} */"));
|
|
6723
6846
|
var PageCount = /*#__PURE__*/_styled(Label, {
|
|
6724
6847
|
target: "e1cgxi451",
|
|
6725
6848
|
label: "PageCount"
|
|
6726
6849
|
})("margin:0 ", function (props) {
|
|
6727
6850
|
return props.theme.spaceScale.spacing08;
|
|
6728
|
-
}, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
6851
|
+
}, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["TablePagination.tsx"],"names":[],"mappings":"AAqCgC","file":"TablePagination.tsx","sourcesContent":["import * as React from 'react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport { EastIcon, WestIcon } from 'react-magma-icons';\r\nimport { useControlled } from '../../hooks/useControlled';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { magma } from '../../theme/magma';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { ButtonColor, ButtonVariant } from '../Button';\r\nimport { ButtonGroup, ButtonGroupAlignment } from '../ButtonGroup';\r\nimport { IconButton } from '../IconButton';\r\nimport { Label } from '../Label';\r\nimport { NativeSelect } from '../NativeSelect';\r\nimport { usePagination } from '../Pagination/usePagination';\r\nfunction getBorder(hasOutsideBorder, isInverse) {\r\n    return hasOutsideBorder\r\n        ? `1px solid ${isInverse\r\n            ? transparentize(0.6, magma.colors.neutral100)\r\n            : magma.colors.neutral300}`\r\n        : 'none';\r\n}\r\nconst StyledContainer = styled.div `\n  align-items: center;\n  background: ${props => props.isInverse\r\n    ? transparentize(0.9, props.theme.colors.neutral100)\r\n    : props.theme.colors.neutral200};\n  display: flex;\n  justify-content: flex-end;\n  padding: ${props => props.theme.spaceScale.spacing02};\n  border-left: ${props => getBorder(props.hasOutsideBorder, props.isInverse)};\n  border-right: ${props => getBorder(props.hasOutsideBorder, props.isInverse)};\n  border-bottom: ${props => getBorder(props.hasOutsideBorder, props.isInverse)};\n  border-radius: ${props => props.hasSquareCorners\r\n    ? '0'\r\n    : `0 0 ${props.theme.borderRadius} ${props.theme.borderRadius}`};\n`;\r\nconst PageCount = styled(Label) `\n  margin: 0 ${props => props.theme.spaceScale.spacing08};\n`;\r\nconst RowsPerPageLabel = styled.span `\n  font-weight: 600;\n  font-family: ${props => props.theme.bodyFont};\n  line-height: 20px;\n  margin: 0 16px 0 0;\n  text-align: left;\n  color: ${props => (props.isInverse ? props.theme.colors.neutral100 : '')};\n`;\r\nconst RowsPerPageController = (props) => {\r\n    const { handleRowsPerPageChange, rowsPerPageValues, isInverse, rowsPerPage } = props;\r\n    const theme = React.useContext(ThemeContext);\r\n    const i18n = React.useContext(I18nContext);\r\n    const rowsPerPageItems = rowsPerPageValues.map(value => ({\r\n        label: value.toString(),\r\n        value,\r\n    }));\r\n    return (React.createElement(React.Fragment, null,\r\n        React.createElement(RowsPerPageLabel, { isInverse: isInverse, theme: theme },\r\n            i18n.table.pagination.rowsPerPageLabel,\r\n            \":\"),\r\n        React.createElement(NativeSelect, { onChange: event => handleRowsPerPageChange(event.target.value), \"aria-label\": i18n.table.pagination.rowsPerPageLabel, style: { minWidth: 80 }, testId: \"rowPerPageSelect\", fieldId: '', value: rowsPerPage }, rowsPerPageItems.map((row, index) => (React.createElement(\"option\", { key: index, value: row.value }, row.label))))));\r\n};\r\nexport const TablePagination = React.forwardRef((props, ref) => {\r\n    const { dropdownDropDirection, testId, defaultPage, defaultRowsPerPage = 10, itemCount, onPageChange, onRowsPerPageChange = null, page: pageProp, rowsPerPage: rowsPerPageProp, rowsPerPageValues = [10, 20, 50, 100], hasOutsideBorder, hasSquareCorners = true, ...other } = props;\r\n    const theme = React.useContext(ThemeContext);\r\n    const i18n = React.useContext(I18nContext);\r\n    const hasRowPerPageChangeFunction = onRowsPerPageChange && typeof onRowsPerPageChange === 'function';\r\n    const isInverse = useIsInverse(props.isInverse);\r\n    const [rowsPerPage, setRowsPerPageState] = useControlled({\r\n        controlled: rowsPerPageProp,\r\n        default: defaultRowsPerPage,\r\n    });\r\n    React.useEffect(() => {\r\n        const checkedRowsPerPage = rowsPerPageProp\r\n            ? rowsPerPageProp\r\n            : defaultRowsPerPage;\r\n        if (!rowsPerPageValues.includes(checkedRowsPerPage)) {\r\n            setRowsPerPageState(rowsPerPageValues[0]);\r\n            handleRowsPerPageChange(rowsPerPageValues[0]);\r\n        }\r\n    }, []);\r\n    const { page, pageButtons, setPageState } = usePagination({\r\n        count: itemCount / rowsPerPage,\r\n        defaultPage,\r\n        numberOfEdgePages: 0,\r\n        numberOfAdjacentPages: 0,\r\n        onPageChange,\r\n        page: pageProp,\r\n    });\r\n    const isLastPage = page * rowsPerPage >= itemCount;\r\n    const displayPageStart = (page - 1) * rowsPerPage + 1;\r\n    const displayPageEnd = isLastPage ? itemCount : page * rowsPerPage;\r\n    function handleRowsPerPageChange(value) {\r\n        if (!pageProp) {\r\n            setPageState(1);\r\n            onPageChange &&\r\n                typeof onPageChange === 'function' &&\r\n                onPageChange({}, 1);\r\n        }\r\n        if (!rowsPerPageProp) {\r\n            setRowsPerPageState(value);\r\n        }\r\n        hasRowPerPageChangeFunction && onRowsPerPageChange(value);\r\n    }\r\n    const previousButton = pageButtons[0];\r\n    const nextButton = pageButtons[pageButtons.length - 1];\r\n    return (React.createElement(StyledContainer, Object.assign({}, other, { \"data-testid\": testId, isInverse: isInverse, hasOutsideBorder: hasOutsideBorder, hasSquareCorners: hasSquareCorners, ref: ref, theme: theme }),\r\n        hasRowPerPageChangeFunction && (React.createElement(RowsPerPageController, { isInverse: isInverse, handleRowsPerPageChange: handleRowsPerPageChange, rowsPerPageValues: rowsPerPageValues, rowsPerPage: rowsPerPage })),\r\n        React.createElement(PageCount, { isInverse: isInverse, theme: theme }, `${displayPageStart}-${displayPageEnd} ${i18n.table.pagination.ofLabel} ${itemCount}`),\r\n        React.createElement(ButtonGroup, { alignment: ButtonGroupAlignment.center },\r\n            React.createElement(IconButton, { \"aria-label\": i18n.table.pagination.previousAriaLabel, color: ButtonColor.secondary, disabled: previousButton.disabled, icon: React.createElement(WestIcon, null), isInverse: isInverse, onClick: previousButton.onClick, testId: \"previousBtn\", variant: ButtonVariant.link }),\r\n            React.createElement(IconButton, { \"aria-label\": i18n.table.pagination.nextAriaLabel, color: ButtonColor.secondary, disabled: nextButton.disabled, icon: React.createElement(EastIcon, null), isInverse: isInverse, onClick: nextButton.onClick, testId: \"nextBtn\", variant: ButtonVariant.link }))));\r\n});\r\n//# sourceMappingURL=TablePagination.js.map"]} */"));
|
|
6729
6852
|
var RowsPerPageLabel = /*#__PURE__*/_styled("span", {
|
|
6730
6853
|
target: "e1cgxi450",
|
|
6731
6854
|
label: "RowsPerPageLabel"
|
|
@@ -6733,7 +6856,7 @@ var RowsPerPageLabel = /*#__PURE__*/_styled("span", {
|
|
|
6733
6856
|
return props.theme.bodyFont;
|
|
6734
6857
|
}, ";line-height:20px;margin:0 16px 0 0;text-align:left;color:", function (props) {
|
|
6735
6858
|
return props.isInverse ? props.theme.colors.neutral100 : '';
|
|
6736
|
-
}, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
6859
|
+
}, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["TablePagination.tsx"],"names":[],"mappings":"AAwCqC","file":"TablePagination.tsx","sourcesContent":["import * as React from 'react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport { EastIcon, WestIcon } from 'react-magma-icons';\r\nimport { useControlled } from '../../hooks/useControlled';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { magma } from '../../theme/magma';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { ButtonColor, ButtonVariant } from '../Button';\r\nimport { ButtonGroup, ButtonGroupAlignment } from '../ButtonGroup';\r\nimport { IconButton } from '../IconButton';\r\nimport { Label } from '../Label';\r\nimport { NativeSelect } from '../NativeSelect';\r\nimport { usePagination } from '../Pagination/usePagination';\r\nfunction getBorder(hasOutsideBorder, isInverse) {\r\n    return hasOutsideBorder\r\n        ? `1px solid ${isInverse\r\n            ? transparentize(0.6, magma.colors.neutral100)\r\n            : magma.colors.neutral300}`\r\n        : 'none';\r\n}\r\nconst StyledContainer = styled.div `\n  align-items: center;\n  background: ${props => props.isInverse\r\n    ? transparentize(0.9, props.theme.colors.neutral100)\r\n    : props.theme.colors.neutral200};\n  display: flex;\n  justify-content: flex-end;\n  padding: ${props => props.theme.spaceScale.spacing02};\n  border-left: ${props => getBorder(props.hasOutsideBorder, props.isInverse)};\n  border-right: ${props => getBorder(props.hasOutsideBorder, props.isInverse)};\n  border-bottom: ${props => getBorder(props.hasOutsideBorder, props.isInverse)};\n  border-radius: ${props => props.hasSquareCorners\r\n    ? '0'\r\n    : `0 0 ${props.theme.borderRadius} ${props.theme.borderRadius}`};\n`;\r\nconst PageCount = styled(Label) `\n  margin: 0 ${props => props.theme.spaceScale.spacing08};\n`;\r\nconst RowsPerPageLabel = styled.span `\n  font-weight: 600;\n  font-family: ${props => props.theme.bodyFont};\n  line-height: 20px;\n  margin: 0 16px 0 0;\n  text-align: left;\n  color: ${props => (props.isInverse ? props.theme.colors.neutral100 : '')};\n`;\r\nconst RowsPerPageController = (props) => {\r\n    const { handleRowsPerPageChange, rowsPerPageValues, isInverse, rowsPerPage } = props;\r\n    const theme = React.useContext(ThemeContext);\r\n    const i18n = React.useContext(I18nContext);\r\n    const rowsPerPageItems = rowsPerPageValues.map(value => ({\r\n        label: value.toString(),\r\n        value,\r\n    }));\r\n    return (React.createElement(React.Fragment, null,\r\n        React.createElement(RowsPerPageLabel, { isInverse: isInverse, theme: theme },\r\n            i18n.table.pagination.rowsPerPageLabel,\r\n            \":\"),\r\n        React.createElement(NativeSelect, { onChange: event => handleRowsPerPageChange(event.target.value), \"aria-label\": i18n.table.pagination.rowsPerPageLabel, style: { minWidth: 80 }, testId: \"rowPerPageSelect\", fieldId: '', value: rowsPerPage }, rowsPerPageItems.map((row, index) => (React.createElement(\"option\", { key: index, value: row.value }, row.label))))));\r\n};\r\nexport const TablePagination = React.forwardRef((props, ref) => {\r\n    const { dropdownDropDirection, testId, defaultPage, defaultRowsPerPage = 10, itemCount, onPageChange, onRowsPerPageChange = null, page: pageProp, rowsPerPage: rowsPerPageProp, rowsPerPageValues = [10, 20, 50, 100], hasOutsideBorder, hasSquareCorners = true, ...other } = props;\r\n    const theme = React.useContext(ThemeContext);\r\n    const i18n = React.useContext(I18nContext);\r\n    const hasRowPerPageChangeFunction = onRowsPerPageChange && typeof onRowsPerPageChange === 'function';\r\n    const isInverse = useIsInverse(props.isInverse);\r\n    const [rowsPerPage, setRowsPerPageState] = useControlled({\r\n        controlled: rowsPerPageProp,\r\n        default: defaultRowsPerPage,\r\n    });\r\n    React.useEffect(() => {\r\n        const checkedRowsPerPage = rowsPerPageProp\r\n            ? rowsPerPageProp\r\n            : defaultRowsPerPage;\r\n        if (!rowsPerPageValues.includes(checkedRowsPerPage)) {\r\n            setRowsPerPageState(rowsPerPageValues[0]);\r\n            handleRowsPerPageChange(rowsPerPageValues[0]);\r\n        }\r\n    }, []);\r\n    const { page, pageButtons, setPageState } = usePagination({\r\n        count: itemCount / rowsPerPage,\r\n        defaultPage,\r\n        numberOfEdgePages: 0,\r\n        numberOfAdjacentPages: 0,\r\n        onPageChange,\r\n        page: pageProp,\r\n    });\r\n    const isLastPage = page * rowsPerPage >= itemCount;\r\n    const displayPageStart = (page - 1) * rowsPerPage + 1;\r\n    const displayPageEnd = isLastPage ? itemCount : page * rowsPerPage;\r\n    function handleRowsPerPageChange(value) {\r\n        if (!pageProp) {\r\n            setPageState(1);\r\n            onPageChange &&\r\n                typeof onPageChange === 'function' &&\r\n                onPageChange({}, 1);\r\n        }\r\n        if (!rowsPerPageProp) {\r\n            setRowsPerPageState(value);\r\n        }\r\n        hasRowPerPageChangeFunction && onRowsPerPageChange(value);\r\n    }\r\n    const previousButton = pageButtons[0];\r\n    const nextButton = pageButtons[pageButtons.length - 1];\r\n    return (React.createElement(StyledContainer, Object.assign({}, other, { \"data-testid\": testId, isInverse: isInverse, hasOutsideBorder: hasOutsideBorder, hasSquareCorners: hasSquareCorners, ref: ref, theme: theme }),\r\n        hasRowPerPageChangeFunction && (React.createElement(RowsPerPageController, { isInverse: isInverse, handleRowsPerPageChange: handleRowsPerPageChange, rowsPerPageValues: rowsPerPageValues, rowsPerPage: rowsPerPage })),\r\n        React.createElement(PageCount, { isInverse: isInverse, theme: theme }, `${displayPageStart}-${displayPageEnd} ${i18n.table.pagination.ofLabel} ${itemCount}`),\r\n        React.createElement(ButtonGroup, { alignment: ButtonGroupAlignment.center },\r\n            React.createElement(IconButton, { \"aria-label\": i18n.table.pagination.previousAriaLabel, color: ButtonColor.secondary, disabled: previousButton.disabled, icon: React.createElement(WestIcon, null), isInverse: isInverse, onClick: previousButton.onClick, testId: \"previousBtn\", variant: ButtonVariant.link }),\r\n            React.createElement(IconButton, { \"aria-label\": i18n.table.pagination.nextAriaLabel, color: ButtonColor.secondary, disabled: nextButton.disabled, icon: React.createElement(EastIcon, null), isInverse: isInverse, onClick: nextButton.onClick, testId: \"nextBtn\", variant: ButtonVariant.link }))));\r\n});\r\n//# sourceMappingURL=TablePagination.js.map"]} */"));
|
|
6737
6860
|
var RowsPerPageController = function RowsPerPageController(props) {
|
|
6738
6861
|
var handleRowsPerPageChange = props.handleRowsPerPageChange,
|
|
6739
6862
|
rowsPerPageValues = props.rowsPerPageValues,
|
|
@@ -6781,6 +6904,7 @@ var TablePagination = /*#__PURE__*/forwardRef(function (props, ref) {
|
|
|
6781
6904
|
rowsPerPageProp = props.rowsPerPage,
|
|
6782
6905
|
_props$rowsPerPageVal = props.rowsPerPageValues,
|
|
6783
6906
|
rowsPerPageValues = _props$rowsPerPageVal === void 0 ? [10, 20, 50, 100] : _props$rowsPerPageVal,
|
|
6907
|
+
hasOutsideBorder = props.hasOutsideBorder,
|
|
6784
6908
|
_props$hasSquareCorne = props.hasSquareCorners,
|
|
6785
6909
|
hasSquareCorners = _props$hasSquareCorne === void 0 ? true : _props$hasSquareCorne,
|
|
6786
6910
|
other = _objectWithoutPropertiesLoose(props, _excluded$B);
|
|
@@ -6830,6 +6954,7 @@ var TablePagination = /*#__PURE__*/forwardRef(function (props, ref) {
|
|
|
6830
6954
|
return createElement(StyledContainer$2, Object.assign({}, other, {
|
|
6831
6955
|
"data-testid": testId,
|
|
6832
6956
|
isInverse: isInverse,
|
|
6957
|
+
hasOutsideBorder: hasOutsideBorder,
|
|
6833
6958
|
hasSquareCorners: hasSquareCorners,
|
|
6834
6959
|
ref: ref,
|
|
6835
6960
|
theme: theme
|
|
@@ -6902,22 +7027,29 @@ function buildTableRowColor(props) {
|
|
|
6902
7027
|
}
|
|
6903
7028
|
return 'inherit';
|
|
6904
7029
|
}
|
|
7030
|
+
function getBorderBottom(isInverse) {
|
|
7031
|
+
return "1px solid " + (isInverse ? curriedTransparentize(0.6, magma.colors.neutral100) : magma.colors.neutral300);
|
|
7032
|
+
}
|
|
6905
7033
|
var StyledTableRow = /*#__PURE__*/_styled("tr", {
|
|
6906
7034
|
target: "e1b4326l2",
|
|
6907
7035
|
label: "StyledTableRow"
|
|
6908
|
-
})("border-bottom:
|
|
6909
|
-
return props.isInverse
|
|
6910
|
-
}, ";color:inherit;display:table-row;outline:0;vertical-align:top
|
|
6911
|
-
return props.
|
|
7036
|
+
})("border-bottom:", function (props) {
|
|
7037
|
+
return getBorderBottom(props.isInverse);
|
|
7038
|
+
}, ";color:inherit;display:table-row;outline:0;vertical-align:top;td{border-bottom:", function (props) {
|
|
7039
|
+
return getBorderBottom(props.isInverse);
|
|
7040
|
+
}, ";}&:last-child{border-bottom:", function (props) {
|
|
7041
|
+
return props.color || props.hasZebraStripes && !props.hasTablePagination ? 0 : "" + getBorderBottom(props.isInverse);
|
|
7042
|
+
}, ";td{border-bottom:0;}td:first-child{border-radius:", function (props) {
|
|
7043
|
+
return props.hasSquareCorners || props.hasTablePagination ? '0' : "0 0 0 " + props.theme.borderRadius;
|
|
6912
7044
|
}, ";}td:last-child{border-radius:", function (props) {
|
|
6913
|
-
return props.hasSquareCorners ? '0' : "0 0 " + props.theme.borderRadius + " 0";
|
|
7045
|
+
return props.hasSquareCorners || props.hasTablePagination ? '0' : "0 0 " + props.theme.borderRadius + " 0";
|
|
6914
7046
|
}, ";}}", function (props) {
|
|
6915
|
-
return !props.color && /*#__PURE__*/css("&:nth-of-type(even){background:", props.hasZebraStripes ? props.isInverse ? curriedTransparentize(0.93, props.theme.colors.neutral100) : props.theme.colors.neutral200 : 'none', ";};label:StyledTableRow;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["TableRow.tsx"],"names":[],"mappings":"AAoEQ","file":"TableRow.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport { NorthIcon, SortDoubleArrowIcon, SouthIcon } from 'react-magma-icons';\r\nimport { I18nContext } from '../../i18n';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { Checkbox } from '../Checkbox';\r\nimport { IndeterminateCheckbox, IndeterminateCheckboxStatus, } from '../IndeterminateCheckbox';\r\nimport { TableContext, TableRowColor, TableCell, TableHeaderCell, TableCellAlign, TableSortDirection, } from './';\r\nfunction buildTableRowBackground(props) {\r\n    if (props.isInverse) {\r\n        switch (props.color) {\r\n            case 'success':\r\n                return props.theme.colors.success200;\r\n            case 'warning':\r\n                return props.theme.colors.warning200;\r\n            case 'danger':\r\n                return props.theme.colors.danger200;\r\n            case 'info':\r\n                return props.theme.colors.info200;\r\n            default:\r\n                return 'inherit';\r\n        }\r\n    }\r\n    switch (props.color) {\r\n        case 'success':\r\n            return props.theme.colors.success;\r\n        case 'warning':\r\n            return props.theme.colors.warning;\r\n        case 'danger':\r\n            return props.theme.colors.danger;\r\n        case 'info':\r\n            return props.theme.colors.info;\r\n        default:\r\n            return 'inherit';\r\n    }\r\n}\r\nfunction buildTableRowColor(props) {\r\n    if (props.color && props.isInverse) {\r\n        return props.theme.colors.neutral700;\r\n    }\r\n    if (props.color && !props.isInverse) {\r\n        return props.theme.colors.neutral100;\r\n    }\r\n    return 'inherit';\r\n}\r\nconst StyledTableRow = styled.tr `\n  border-bottom: 1px solid\n    ${props => props.isInverse\r\n    ? transparentize(0.6, props.theme.colors.neutral100)\r\n    : props.theme.colors.neutral300};\n  color: inherit;\n  display: table-row;\n  outline: 0;\n  vertical-align: top;\n\n  &:last-child {\n    border-bottom: 0;\n    td:first-child {\n      border-radius: ${props => props.hasSquareCorners ? '0' : `0 0 0 ${props.theme.borderRadius}`};\n    }\n    td:last-child {\n      border-radius: ${props => props.hasSquareCorners ? '0' : `0 0 ${props.theme.borderRadius} 0`};\n    }\n  }\n\n  ${props => !props.color &&\r\n    css `\n      &:nth-of-type(even) {\n        background: ${props.hasZebraStripes\r\n        ? props.isInverse\r\n            ? transparentize(0.93, props.theme.colors.neutral100)\r\n            : props.theme.colors.neutral200\r\n        : 'none'};\n      }\n    `};\n\n  ${props => props.hasHoverStyles &&\r\n    !props.color &&\r\n    css `\n    &:hover {\n      background: ${props.isInverse\r\n        ? transparentize(0.85, props.theme.colors.neutral100)\r\n        : transparentize(0.93, props.theme.colors.neutral900)};\n    `}\n\n  ${props => props.color &&\r\n    css `\n      background: ${buildTableRowBackground(props)};\n      color: ${buildTableRowColor(props)};\n    `};\n`;\r\nconst SortButton = styled.button `\n  align-items: flex-end;\n  background: none;\n  border: 0;\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  margin: 0;\n  text-align: left;\n  width: 100%;\n  flex: 1 1 auto;\n\n  &:focus {\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n    outline-offset: -2px;\n  }\n\n  &:hover,\n  &:focus {\n    cursor: pointer;\n    svg {\n      fill: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n    }\n  }\n`;\r\nconst SortIconWrapper = styled.span `\n  position: relative;\n  top: ${props => props.theme.spaceScale.spacing01};\n`;\r\nexport const TableRow = React.forwardRef((props, ref) => {\r\n    const { children, headerRowStatus, isSelected, isSelectableDisabled, sortDirection, onHeaderRowSelect, onTableRowSelect, rowIndex, rowName, onSort, testId, ...other } = props;\r\n    const theme = React.useContext(ThemeContext);\r\n    const tableContext = React.useContext(TableContext);\r\n    const i18n = React.useContext(I18nContext);\r\n    let isHeaderRow = false;\r\n    React.Children.forEach(children, (child) => {\r\n        if (child.type.displayName === 'TableHeaderCell') {\r\n            isHeaderRow = true;\r\n            return;\r\n        }\r\n    });\r\n    function getIsCheckboxInverse() {\r\n        if (props.color && props.color === TableRowColor.warning) {\r\n            return false;\r\n        }\r\n        if (props.color && props.color !== TableRowColor.warning) {\r\n            return true;\r\n        }\r\n        return tableContext.isInverse;\r\n    }\r\n    const [isHovering, setIsHovering] = React.useState(false);\r\n    const handleMouseEnter = () => {\r\n        if (tableContext.isSortableBySelected)\r\n            setIsHovering(true);\r\n    };\r\n    const handleMouseLeave = () => {\r\n        if (tableContext.isSortableBySelected)\r\n            setIsHovering(false);\r\n    };\r\n    function handleSort() {\r\n        onSort && typeof onSort === 'function' && onSort();\r\n    }\r\n    const SortIcon = sortDirection === TableSortDirection.ascending ? (React.createElement(NorthIcon, { color: tableContext.isInverse\r\n            ? theme.colors.neutral100\r\n            : theme.colors.neutral700, size: theme.iconSizes.small, testId: \"sort-ascending\" })) : sortDirection === TableSortDirection.descending ? (React.createElement(SouthIcon, { color: tableContext.isInverse\r\n            ? theme.colors.neutral100\r\n            : theme.colors.neutral700, size: theme.iconSizes.small, testId: \"sort-descending\" })) : (React.createElement(SortDoubleArrowIcon, { color: tableContext.isInverse\r\n            ? transparentize(0.3, theme.colors.neutral100)\r\n            : theme.colors.neutral500, size: theme.iconSizes.small, testId: \"sort-none\" }));\r\n    return (React.createElement(StyledTableRow, Object.assign({}, other, { \"data-testid\": testId, hasSquareCorners: tableContext.hasSquareCorners, hasHoverStyles: tableContext.hasHoverStyles && !isHeaderRow, hasZebraStripes: tableContext.hasZebraStripes, isInverse: tableContext.isInverse, ref: ref, theme: theme }),\r\n        tableContext.isSelectable && isHeaderRow && (React.createElement(TableHeaderCell, { width: theme.spaceScale.spacing05, style: {\r\n                background: isHovering\r\n                    ? transparentize(0.93, theme.colors.neutral900)\r\n                    : '',\r\n            } },\r\n            React.createElement(\"span\", { style: { display: 'flex', flexDirection: 'row' } },\r\n                React.createElement(IndeterminateCheckbox, { status: headerRowStatus, isInverse: getIsCheckboxInverse(), labelStyle: { padding: 0 }, labelText: headerRowStatus === IndeterminateCheckboxStatus.unchecked\r\n                        ? i18n.table.selectable.selectAllRowsAriaLabel\r\n                        : i18n.table.selectable.deselectAllRowsAriaLabel, isTextVisuallyHidden: true, onChange: onHeaderRowSelect }),\r\n                tableContext.isSortableBySelected && (React.createElement(SortButton, { density: tableContext.density, isInverse: tableContext.isInverse, onClick: handleSort, textAlign: TableCellAlign.left, theme: theme, onMouseEnter: handleMouseEnter, onMouseLeave: handleMouseLeave, \"data-testid\": `${testId || ''}-sort-button`, \"aria-label\": i18n.table.selectable.sortButtonAriaLabel },\r\n                    React.createElement(SortIconWrapper, { theme: theme }, SortIcon)))))),\r\n        tableContext.isSelectable && !isHeaderRow && (React.createElement(TableCell, { width: theme.spaceScale.spacing05, style: { verticalAlign: 'middle' } },\r\n            React.createElement(Checkbox, { checked: isSelected, disabled: isSelectableDisabled, labelStyle: { padding: 0 }, labelText: isSelected\r\n                    ? `${i18n.table.selectable.deselectRowAriaLabel} ${rowName || ''}`\r\n                    : `${i18n.table.selectable.selectRowAriaLabel} ${rowName || ''}`, isTextVisuallyHidden: true, isInverse: getIsCheckboxInverse(), onChange: onTableRowSelect }))),\r\n        children));\r\n});\r\n//# sourceMappingURL=TableRow.js.map"]} */"));
|
|
7047
|
+
return !props.color && /*#__PURE__*/css("&:nth-of-type(even){background:", props.hasZebraStripes ? props.isInverse ? curriedTransparentize(0.93, props.theme.colors.neutral100) : props.theme.colors.neutral200 : 'none', ";};label:StyledTableRow;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["TableRow.tsx"],"names":[],"mappings":"AAuFQ","file":"TableRow.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport { NorthIcon, SortDoubleArrowIcon, SouthIcon } from 'react-magma-icons';\r\nimport { I18nContext } from '../../i18n';\r\nimport { magma } from '../../theme/magma';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { Checkbox } from '../Checkbox';\r\nimport { IndeterminateCheckbox, IndeterminateCheckboxStatus, } from '../IndeterminateCheckbox';\r\nimport { TableContext, TableRowColor, TableCell, TableHeaderCell, TableCellAlign, TableSortDirection, } from './';\r\nfunction buildTableRowBackground(props) {\r\n    if (props.isInverse) {\r\n        switch (props.color) {\r\n            case 'success':\r\n                return props.theme.colors.success200;\r\n            case 'warning':\r\n                return props.theme.colors.warning200;\r\n            case 'danger':\r\n                return props.theme.colors.danger200;\r\n            case 'info':\r\n                return props.theme.colors.info200;\r\n            default:\r\n                return 'inherit';\r\n        }\r\n    }\r\n    switch (props.color) {\r\n        case 'success':\r\n            return props.theme.colors.success;\r\n        case 'warning':\r\n            return props.theme.colors.warning;\r\n        case 'danger':\r\n            return props.theme.colors.danger;\r\n        case 'info':\r\n            return props.theme.colors.info;\r\n        default:\r\n            return 'inherit';\r\n    }\r\n}\r\nfunction buildTableRowColor(props) {\r\n    if (props.color && props.isInverse) {\r\n        return props.theme.colors.neutral700;\r\n    }\r\n    if (props.color && !props.isInverse) {\r\n        return props.theme.colors.neutral100;\r\n    }\r\n    return 'inherit';\r\n}\r\nfunction getBorderBottom(isInverse) {\r\n    return `1px solid ${isInverse\r\n        ? transparentize(0.6, magma.colors.neutral100)\r\n        : magma.colors.neutral300}`;\r\n}\r\nconst StyledTableRow = styled.tr `\n  border-bottom: ${props => getBorderBottom(props.isInverse)};\n  color: inherit;\n  display: table-row;\n  outline: 0;\n  vertical-align: top;\n\n  // Compensates border bottom for all rows (except last one) when table has outside border\n  td {\n    border-bottom: ${props => getBorderBottom(props.isInverse)};\n  }\n\n  &:last-child {\n    // Removes border bottom for last row if it's colored\n    border-bottom: ${props => props.color || (props.hasZebraStripes && !props.hasTablePagination)\r\n    ? 0\r\n    : `${getBorderBottom(props.isInverse)}`};\n\n    td {\n      border-bottom: 0;\n    }\n    td:first-child {\n      border-radius: ${props => props.hasSquareCorners || props.hasTablePagination\r\n    ? '0'\r\n    : `0 0 0 ${props.theme.borderRadius}`};\n    }\n    td:last-child {\n      border-radius: ${props => props.hasSquareCorners || props.hasTablePagination\r\n    ? '0'\r\n    : `0 0 ${props.theme.borderRadius} 0`};\n    }\n  }\n\n  ${props => !props.color &&\r\n    css `\n      &:nth-of-type(even) {\n        background: ${props.hasZebraStripes\r\n        ? props.isInverse\r\n            ? transparentize(0.93, props.theme.colors.neutral100)\r\n            : props.theme.colors.neutral200\r\n        : 'none'};\n      }\n    `};\n\n  ${props => props.hasHoverStyles &&\r\n    !props.color &&\r\n    css `\n    &:hover {\n      background: ${props.isInverse\r\n        ? transparentize(0.85, props.theme.colors.neutral100)\r\n        : transparentize(0.93, props.theme.colors.neutral900)};\n    `}\n\n  ${props => props.color &&\r\n    css `\n      background: ${buildTableRowBackground(props)};\n      color: ${buildTableRowColor(props)};\n    `};\n`;\r\nconst SortButton = styled.button `\n  align-items: flex-end;\n  background: none;\n  border: 0;\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  margin: 0;\n  text-align: left;\n  width: 100%;\n  flex: 1 1 auto;\n\n  &:focus {\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n    outline-offset: -2px;\n  }\n\n  &:hover,\n  &:focus {\n    cursor: pointer;\n    svg {\n      fill: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n    }\n  }\n`;\r\nconst SortIconWrapper = styled.span `\n  position: relative;\n  top: ${props => props.theme.spaceScale.spacing01};\n`;\r\nexport const TableRow = React.forwardRef((props, ref) => {\r\n    const { children, headerRowStatus, isSelected, isSelectableDisabled, sortDirection, onHeaderRowSelect, onTableRowSelect, rowIndex, rowName, onSort, testId, ...other } = props;\r\n    const theme = React.useContext(ThemeContext);\r\n    const tableContext = React.useContext(TableContext);\r\n    const i18n = React.useContext(I18nContext);\r\n    let isHeaderRow = false;\r\n    React.Children.forEach(children, (child) => {\r\n        if (child.type.displayName === 'TableHeaderCell') {\r\n            isHeaderRow = true;\r\n            return;\r\n        }\r\n    });\r\n    function getIsCheckboxInverse() {\r\n        if (props.color && props.color === TableRowColor.warning) {\r\n            return false;\r\n        }\r\n        if (props.color && props.color !== TableRowColor.warning) {\r\n            return true;\r\n        }\r\n        return tableContext.isInverse;\r\n    }\r\n    const [isHovering, setIsHovering] = React.useState(false);\r\n    const handleMouseEnter = () => {\r\n        if (tableContext.isSortableBySelected)\r\n            setIsHovering(true);\r\n    };\r\n    const handleMouseLeave = () => {\r\n        if (tableContext.isSortableBySelected)\r\n            setIsHovering(false);\r\n    };\r\n    function handleSort() {\r\n        onSort && typeof onSort === 'function' && onSort();\r\n    }\r\n    const SortIcon = sortDirection === TableSortDirection.ascending ? (React.createElement(NorthIcon, { color: tableContext.isInverse\r\n            ? theme.colors.neutral100\r\n            : theme.colors.neutral700, size: theme.iconSizes.small, testId: \"sort-ascending\" })) : sortDirection === TableSortDirection.descending ? (React.createElement(SouthIcon, { color: tableContext.isInverse\r\n            ? theme.colors.neutral100\r\n            : theme.colors.neutral700, size: theme.iconSizes.small, testId: \"sort-descending\" })) : (React.createElement(SortDoubleArrowIcon, { color: tableContext.isInverse\r\n            ? transparentize(0.3, theme.colors.neutral100)\r\n            : theme.colors.neutral500, size: theme.iconSizes.small, testId: \"sort-none\" }));\r\n    return (React.createElement(StyledTableRow, Object.assign({}, other, { \"data-testid\": testId, hasHoverStyles: tableContext.hasHoverStyles && !isHeaderRow, hasSquareCorners: tableContext.hasSquareCorners, hasTablePagination: tableContext.hasTablePagination, hasZebraStripes: tableContext.hasZebraStripes, isInverse: tableContext.isInverse, ref: ref, theme: theme }),\r\n        tableContext.isSelectable && isHeaderRow && (React.createElement(TableHeaderCell, { width: theme.spaceScale.spacing05, style: {\r\n                background: isHovering\r\n                    ? transparentize(0.93, theme.colors.neutral900)\r\n                    : '',\r\n            } },\r\n            React.createElement(\"span\", { style: { display: 'flex', flexDirection: 'row' } },\r\n                React.createElement(IndeterminateCheckbox, { status: headerRowStatus, isInverse: getIsCheckboxInverse(), labelStyle: { padding: 0 }, labelText: headerRowStatus === IndeterminateCheckboxStatus.unchecked\r\n                        ? i18n.table.selectable.selectAllRowsAriaLabel\r\n                        : i18n.table.selectable.deselectAllRowsAriaLabel, isTextVisuallyHidden: true, onChange: onHeaderRowSelect }),\r\n                tableContext.isSortableBySelected && (React.createElement(SortButton, { density: tableContext.density, isInverse: tableContext.isInverse, onClick: handleSort, textAlign: TableCellAlign.left, theme: theme, onMouseEnter: handleMouseEnter, onMouseLeave: handleMouseLeave, \"data-testid\": `${testId || ''}-sort-button`, \"aria-label\": i18n.table.selectable.sortButtonAriaLabel },\r\n                    React.createElement(SortIconWrapper, { theme: theme }, SortIcon)))))),\r\n        tableContext.isSelectable && !isHeaderRow && (React.createElement(TableCell, { width: theme.spaceScale.spacing05, style: { verticalAlign: 'middle' } },\r\n            React.createElement(Checkbox, { checked: isSelected, disabled: isSelectableDisabled, labelStyle: { padding: 0 }, labelText: isSelected\r\n                    ? `${i18n.table.selectable.deselectRowAriaLabel} ${rowName || ''}`\r\n                    : `${i18n.table.selectable.selectRowAriaLabel} ${rowName || ''}`, isTextVisuallyHidden: true, isInverse: getIsCheckboxInverse(), onChange: onTableRowSelect }))),\r\n        children));\r\n});\r\n//# sourceMappingURL=TableRow.js.map"]} */"));
|
|
6916
7048
|
}, ";", function (props) {
|
|
6917
|
-
return props.hasHoverStyles && !props.color && /*#__PURE__*/css("&:hover{background:", props.isInverse ? curriedTransparentize(0.85, props.theme.colors.neutral100) : curriedTransparentize(0.93, props.theme.colors.neutral900), ";};label:StyledTableRow;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["TableRow.tsx"],"names":[],"mappings":"AAgFQ","file":"TableRow.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport { NorthIcon, SortDoubleArrowIcon, SouthIcon } from 'react-magma-icons';\r\nimport { I18nContext } from '../../i18n';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { Checkbox } from '../Checkbox';\r\nimport { IndeterminateCheckbox, IndeterminateCheckboxStatus, } from '../IndeterminateCheckbox';\r\nimport { TableContext, TableRowColor, TableCell, TableHeaderCell, TableCellAlign, TableSortDirection, } from './';\r\nfunction buildTableRowBackground(props) {\r\n    if (props.isInverse) {\r\n        switch (props.color) {\r\n            case 'success':\r\n                return props.theme.colors.success200;\r\n            case 'warning':\r\n                return props.theme.colors.warning200;\r\n            case 'danger':\r\n                return props.theme.colors.danger200;\r\n            case 'info':\r\n                return props.theme.colors.info200;\r\n            default:\r\n                return 'inherit';\r\n        }\r\n    }\r\n    switch (props.color) {\r\n        case 'success':\r\n            return props.theme.colors.success;\r\n        case 'warning':\r\n            return props.theme.colors.warning;\r\n        case 'danger':\r\n            return props.theme.colors.danger;\r\n        case 'info':\r\n            return props.theme.colors.info;\r\n        default:\r\n            return 'inherit';\r\n    }\r\n}\r\nfunction buildTableRowColor(props) {\r\n    if (props.color && props.isInverse) {\r\n        return props.theme.colors.neutral700;\r\n    }\r\n    if (props.color && !props.isInverse) {\r\n        return props.theme.colors.neutral100;\r\n    }\r\n    return 'inherit';\r\n}\r\nconst StyledTableRow = styled.tr `\n  border-bottom: 1px solid\n    ${props => props.isInverse\r\n    ? transparentize(0.6, props.theme.colors.neutral100)\r\n    : props.theme.colors.neutral300};\n  color: inherit;\n  display: table-row;\n  outline: 0;\n  vertical-align: top;\n\n  &:last-child {\n    border-bottom: 0;\n    td:first-child {\n      border-radius: ${props => props.hasSquareCorners ? '0' : `0 0 0 ${props.theme.borderRadius}`};\n    }\n    td:last-child {\n      border-radius: ${props => props.hasSquareCorners ? '0' : `0 0 ${props.theme.borderRadius} 0`};\n    }\n  }\n\n  ${props => !props.color &&\r\n    css `\n      &:nth-of-type(even) {\n        background: ${props.hasZebraStripes\r\n        ? props.isInverse\r\n            ? transparentize(0.93, props.theme.colors.neutral100)\r\n            : props.theme.colors.neutral200\r\n        : 'none'};\n      }\n    `};\n\n  ${props => props.hasHoverStyles &&\r\n    !props.color &&\r\n    css `\n    &:hover {\n      background: ${props.isInverse\r\n        ? transparentize(0.85, props.theme.colors.neutral100)\r\n        : transparentize(0.93, props.theme.colors.neutral900)};\n    `}\n\n  ${props => props.color &&\r\n    css `\n      background: ${buildTableRowBackground(props)};\n      color: ${buildTableRowColor(props)};\n    `};\n`;\r\nconst SortButton = styled.button `\n  align-items: flex-end;\n  background: none;\n  border: 0;\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  margin: 0;\n  text-align: left;\n  width: 100%;\n  flex: 1 1 auto;\n\n  &:focus {\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n    outline-offset: -2px;\n  }\n\n  &:hover,\n  &:focus {\n    cursor: pointer;\n    svg {\n      fill: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n    }\n  }\n`;\r\nconst SortIconWrapper = styled.span `\n  position: relative;\n  top: ${props => props.theme.spaceScale.spacing01};\n`;\r\nexport const TableRow = React.forwardRef((props, ref) => {\r\n    const { children, headerRowStatus, isSelected, isSelectableDisabled, sortDirection, onHeaderRowSelect, onTableRowSelect, rowIndex, rowName, onSort, testId, ...other } = props;\r\n    const theme = React.useContext(ThemeContext);\r\n    const tableContext = React.useContext(TableContext);\r\n    const i18n = React.useContext(I18nContext);\r\n    let isHeaderRow = false;\r\n    React.Children.forEach(children, (child) => {\r\n        if (child.type.displayName === 'TableHeaderCell') {\r\n            isHeaderRow = true;\r\n            return;\r\n        }\r\n    });\r\n    function getIsCheckboxInverse() {\r\n        if (props.color && props.color === TableRowColor.warning) {\r\n            return false;\r\n        }\r\n        if (props.color && props.color !== TableRowColor.warning) {\r\n            return true;\r\n        }\r\n        return tableContext.isInverse;\r\n    }\r\n    const [isHovering, setIsHovering] = React.useState(false);\r\n    const handleMouseEnter = () => {\r\n        if (tableContext.isSortableBySelected)\r\n            setIsHovering(true);\r\n    };\r\n    const handleMouseLeave = () => {\r\n        if (tableContext.isSortableBySelected)\r\n            setIsHovering(false);\r\n    };\r\n    function handleSort() {\r\n        onSort && typeof onSort === 'function' && onSort();\r\n    }\r\n    const SortIcon = sortDirection === TableSortDirection.ascending ? (React.createElement(NorthIcon, { color: tableContext.isInverse\r\n            ? theme.colors.neutral100\r\n            : theme.colors.neutral700, size: theme.iconSizes.small, testId: \"sort-ascending\" })) : sortDirection === TableSortDirection.descending ? (React.createElement(SouthIcon, { color: tableContext.isInverse\r\n            ? theme.colors.neutral100\r\n            : theme.colors.neutral700, size: theme.iconSizes.small, testId: \"sort-descending\" })) : (React.createElement(SortDoubleArrowIcon, { color: tableContext.isInverse\r\n            ? transparentize(0.3, theme.colors.neutral100)\r\n            : theme.colors.neutral500, size: theme.iconSizes.small, testId: \"sort-none\" }));\r\n    return (React.createElement(StyledTableRow, Object.assign({}, other, { \"data-testid\": testId, hasSquareCorners: tableContext.hasSquareCorners, hasHoverStyles: tableContext.hasHoverStyles && !isHeaderRow, hasZebraStripes: tableContext.hasZebraStripes, isInverse: tableContext.isInverse, ref: ref, theme: theme }),\r\n        tableContext.isSelectable && isHeaderRow && (React.createElement(TableHeaderCell, { width: theme.spaceScale.spacing05, style: {\r\n                background: isHovering\r\n                    ? transparentize(0.93, theme.colors.neutral900)\r\n                    : '',\r\n            } },\r\n            React.createElement(\"span\", { style: { display: 'flex', flexDirection: 'row' } },\r\n                React.createElement(IndeterminateCheckbox, { status: headerRowStatus, isInverse: getIsCheckboxInverse(), labelStyle: { padding: 0 }, labelText: headerRowStatus === IndeterminateCheckboxStatus.unchecked\r\n                        ? i18n.table.selectable.selectAllRowsAriaLabel\r\n                        : i18n.table.selectable.deselectAllRowsAriaLabel, isTextVisuallyHidden: true, onChange: onHeaderRowSelect }),\r\n                tableContext.isSortableBySelected && (React.createElement(SortButton, { density: tableContext.density, isInverse: tableContext.isInverse, onClick: handleSort, textAlign: TableCellAlign.left, theme: theme, onMouseEnter: handleMouseEnter, onMouseLeave: handleMouseLeave, \"data-testid\": `${testId || ''}-sort-button`, \"aria-label\": i18n.table.selectable.sortButtonAriaLabel },\r\n                    React.createElement(SortIconWrapper, { theme: theme }, SortIcon)))))),\r\n        tableContext.isSelectable && !isHeaderRow && (React.createElement(TableCell, { width: theme.spaceScale.spacing05, style: { verticalAlign: 'middle' } },\r\n            React.createElement(Checkbox, { checked: isSelected, disabled: isSelectableDisabled, labelStyle: { padding: 0 }, labelText: isSelected\r\n                    ? `${i18n.table.selectable.deselectRowAriaLabel} ${rowName || ''}`\r\n                    : `${i18n.table.selectable.selectRowAriaLabel} ${rowName || ''}`, isTextVisuallyHidden: true, isInverse: getIsCheckboxInverse(), onChange: onTableRowSelect }))),\r\n        children));\r\n});\r\n//# sourceMappingURL=TableRow.js.map"]} */"));
|
|
7049
|
+
return props.hasHoverStyles && !props.color && /*#__PURE__*/css("&:hover{background:", props.isInverse ? curriedTransparentize(0.85, props.theme.colors.neutral100) : curriedTransparentize(0.93, props.theme.colors.neutral900), ";};label:StyledTableRow;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["TableRow.tsx"],"names":[],"mappings":"AAmGQ","file":"TableRow.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport { NorthIcon, SortDoubleArrowIcon, SouthIcon } from 'react-magma-icons';\r\nimport { I18nContext } from '../../i18n';\r\nimport { magma } from '../../theme/magma';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { Checkbox } from '../Checkbox';\r\nimport { IndeterminateCheckbox, IndeterminateCheckboxStatus, } from '../IndeterminateCheckbox';\r\nimport { TableContext, TableRowColor, TableCell, TableHeaderCell, TableCellAlign, TableSortDirection, } from './';\r\nfunction buildTableRowBackground(props) {\r\n    if (props.isInverse) {\r\n        switch (props.color) {\r\n            case 'success':\r\n                return props.theme.colors.success200;\r\n            case 'warning':\r\n                return props.theme.colors.warning200;\r\n            case 'danger':\r\n                return props.theme.colors.danger200;\r\n            case 'info':\r\n                return props.theme.colors.info200;\r\n            default:\r\n                return 'inherit';\r\n        }\r\n    }\r\n    switch (props.color) {\r\n        case 'success':\r\n            return props.theme.colors.success;\r\n        case 'warning':\r\n            return props.theme.colors.warning;\r\n        case 'danger':\r\n            return props.theme.colors.danger;\r\n        case 'info':\r\n            return props.theme.colors.info;\r\n        default:\r\n            return 'inherit';\r\n    }\r\n}\r\nfunction buildTableRowColor(props) {\r\n    if (props.color && props.isInverse) {\r\n        return props.theme.colors.neutral700;\r\n    }\r\n    if (props.color && !props.isInverse) {\r\n        return props.theme.colors.neutral100;\r\n    }\r\n    return 'inherit';\r\n}\r\nfunction getBorderBottom(isInverse) {\r\n    return `1px solid ${isInverse\r\n        ? transparentize(0.6, magma.colors.neutral100)\r\n        : magma.colors.neutral300}`;\r\n}\r\nconst StyledTableRow = styled.tr `\n  border-bottom: ${props => getBorderBottom(props.isInverse)};\n  color: inherit;\n  display: table-row;\n  outline: 0;\n  vertical-align: top;\n\n  // Compensates border bottom for all rows (except last one) when table has outside border\n  td {\n    border-bottom: ${props => getBorderBottom(props.isInverse)};\n  }\n\n  &:last-child {\n    // Removes border bottom for last row if it's colored\n    border-bottom: ${props => props.color || (props.hasZebraStripes && !props.hasTablePagination)\r\n    ? 0\r\n    : `${getBorderBottom(props.isInverse)}`};\n\n    td {\n      border-bottom: 0;\n    }\n    td:first-child {\n      border-radius: ${props => props.hasSquareCorners || props.hasTablePagination\r\n    ? '0'\r\n    : `0 0 0 ${props.theme.borderRadius}`};\n    }\n    td:last-child {\n      border-radius: ${props => props.hasSquareCorners || props.hasTablePagination\r\n    ? '0'\r\n    : `0 0 ${props.theme.borderRadius} 0`};\n    }\n  }\n\n  ${props => !props.color &&\r\n    css `\n      &:nth-of-type(even) {\n        background: ${props.hasZebraStripes\r\n        ? props.isInverse\r\n            ? transparentize(0.93, props.theme.colors.neutral100)\r\n            : props.theme.colors.neutral200\r\n        : 'none'};\n      }\n    `};\n\n  ${props => props.hasHoverStyles &&\r\n    !props.color &&\r\n    css `\n    &:hover {\n      background: ${props.isInverse\r\n        ? transparentize(0.85, props.theme.colors.neutral100)\r\n        : transparentize(0.93, props.theme.colors.neutral900)};\n    `}\n\n  ${props => props.color &&\r\n    css `\n      background: ${buildTableRowBackground(props)};\n      color: ${buildTableRowColor(props)};\n    `};\n`;\r\nconst SortButton = styled.button `\n  align-items: flex-end;\n  background: none;\n  border: 0;\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  margin: 0;\n  text-align: left;\n  width: 100%;\n  flex: 1 1 auto;\n\n  &:focus {\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n    outline-offset: -2px;\n  }\n\n  &:hover,\n  &:focus {\n    cursor: pointer;\n    svg {\n      fill: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n    }\n  }\n`;\r\nconst SortIconWrapper = styled.span `\n  position: relative;\n  top: ${props => props.theme.spaceScale.spacing01};\n`;\r\nexport const TableRow = React.forwardRef((props, ref) => {\r\n    const { children, headerRowStatus, isSelected, isSelectableDisabled, sortDirection, onHeaderRowSelect, onTableRowSelect, rowIndex, rowName, onSort, testId, ...other } = props;\r\n    const theme = React.useContext(ThemeContext);\r\n    const tableContext = React.useContext(TableContext);\r\n    const i18n = React.useContext(I18nContext);\r\n    let isHeaderRow = false;\r\n    React.Children.forEach(children, (child) => {\r\n        if (child.type.displayName === 'TableHeaderCell') {\r\n            isHeaderRow = true;\r\n            return;\r\n        }\r\n    });\r\n    function getIsCheckboxInverse() {\r\n        if (props.color && props.color === TableRowColor.warning) {\r\n            return false;\r\n        }\r\n        if (props.color && props.color !== TableRowColor.warning) {\r\n            return true;\r\n        }\r\n        return tableContext.isInverse;\r\n    }\r\n    const [isHovering, setIsHovering] = React.useState(false);\r\n    const handleMouseEnter = () => {\r\n        if (tableContext.isSortableBySelected)\r\n            setIsHovering(true);\r\n    };\r\n    const handleMouseLeave = () => {\r\n        if (tableContext.isSortableBySelected)\r\n            setIsHovering(false);\r\n    };\r\n    function handleSort() {\r\n        onSort && typeof onSort === 'function' && onSort();\r\n    }\r\n    const SortIcon = sortDirection === TableSortDirection.ascending ? (React.createElement(NorthIcon, { color: tableContext.isInverse\r\n            ? theme.colors.neutral100\r\n            : theme.colors.neutral700, size: theme.iconSizes.small, testId: \"sort-ascending\" })) : sortDirection === TableSortDirection.descending ? (React.createElement(SouthIcon, { color: tableContext.isInverse\r\n            ? theme.colors.neutral100\r\n            : theme.colors.neutral700, size: theme.iconSizes.small, testId: \"sort-descending\" })) : (React.createElement(SortDoubleArrowIcon, { color: tableContext.isInverse\r\n            ? transparentize(0.3, theme.colors.neutral100)\r\n            : theme.colors.neutral500, size: theme.iconSizes.small, testId: \"sort-none\" }));\r\n    return (React.createElement(StyledTableRow, Object.assign({}, other, { \"data-testid\": testId, hasHoverStyles: tableContext.hasHoverStyles && !isHeaderRow, hasSquareCorners: tableContext.hasSquareCorners, hasTablePagination: tableContext.hasTablePagination, hasZebraStripes: tableContext.hasZebraStripes, isInverse: tableContext.isInverse, ref: ref, theme: theme }),\r\n        tableContext.isSelectable && isHeaderRow && (React.createElement(TableHeaderCell, { width: theme.spaceScale.spacing05, style: {\r\n                background: isHovering\r\n                    ? transparentize(0.93, theme.colors.neutral900)\r\n                    : '',\r\n            } },\r\n            React.createElement(\"span\", { style: { display: 'flex', flexDirection: 'row' } },\r\n                React.createElement(IndeterminateCheckbox, { status: headerRowStatus, isInverse: getIsCheckboxInverse(), labelStyle: { padding: 0 }, labelText: headerRowStatus === IndeterminateCheckboxStatus.unchecked\r\n                        ? i18n.table.selectable.selectAllRowsAriaLabel\r\n                        : i18n.table.selectable.deselectAllRowsAriaLabel, isTextVisuallyHidden: true, onChange: onHeaderRowSelect }),\r\n                tableContext.isSortableBySelected && (React.createElement(SortButton, { density: tableContext.density, isInverse: tableContext.isInverse, onClick: handleSort, textAlign: TableCellAlign.left, theme: theme, onMouseEnter: handleMouseEnter, onMouseLeave: handleMouseLeave, \"data-testid\": `${testId || ''}-sort-button`, \"aria-label\": i18n.table.selectable.sortButtonAriaLabel },\r\n                    React.createElement(SortIconWrapper, { theme: theme }, SortIcon)))))),\r\n        tableContext.isSelectable && !isHeaderRow && (React.createElement(TableCell, { width: theme.spaceScale.spacing05, style: { verticalAlign: 'middle' } },\r\n            React.createElement(Checkbox, { checked: isSelected, disabled: isSelectableDisabled, labelStyle: { padding: 0 }, labelText: isSelected\r\n                    ? `${i18n.table.selectable.deselectRowAriaLabel} ${rowName || ''}`\r\n                    : `${i18n.table.selectable.selectRowAriaLabel} ${rowName || ''}`, isTextVisuallyHidden: true, isInverse: getIsCheckboxInverse(), onChange: onTableRowSelect }))),\r\n        children));\r\n});\r\n//# sourceMappingURL=TableRow.js.map"]} */"));
|
|
6918
7050
|
}, " ", function (props) {
|
|
6919
|
-
return props.color && /*#__PURE__*/css("background:", buildTableRowBackground(props), ";color:", buildTableRowColor(props), ";;label:StyledTableRow;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["TableRow.tsx"],"names":[],"mappings":"AAwFQ","file":"TableRow.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport { NorthIcon, SortDoubleArrowIcon, SouthIcon } from 'react-magma-icons';\r\nimport { I18nContext } from '../../i18n';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { Checkbox } from '../Checkbox';\r\nimport { IndeterminateCheckbox, IndeterminateCheckboxStatus, } from '../IndeterminateCheckbox';\r\nimport { TableContext, TableRowColor, TableCell, TableHeaderCell, TableCellAlign, TableSortDirection, } from './';\r\nfunction buildTableRowBackground(props) {\r\n    if (props.isInverse) {\r\n        switch (props.color) {\r\n            case 'success':\r\n                return props.theme.colors.success200;\r\n            case 'warning':\r\n                return props.theme.colors.warning200;\r\n            case 'danger':\r\n                return props.theme.colors.danger200;\r\n            case 'info':\r\n                return props.theme.colors.info200;\r\n            default:\r\n                return 'inherit';\r\n        }\r\n    }\r\n    switch (props.color) {\r\n        case 'success':\r\n            return props.theme.colors.success;\r\n        case 'warning':\r\n            return props.theme.colors.warning;\r\n        case 'danger':\r\n            return props.theme.colors.danger;\r\n        case 'info':\r\n            return props.theme.colors.info;\r\n        default:\r\n            return 'inherit';\r\n    }\r\n}\r\nfunction buildTableRowColor(props) {\r\n    if (props.color && props.isInverse) {\r\n        return props.theme.colors.neutral700;\r\n    }\r\n    if (props.color && !props.isInverse) {\r\n        return props.theme.colors.neutral100;\r\n    }\r\n    return 'inherit';\r\n}\r\nconst StyledTableRow = styled.tr `\n  border-bottom: 1px solid\n    ${props => props.isInverse\r\n    ? transparentize(0.6, props.theme.colors.neutral100)\r\n    : props.theme.colors.neutral300};\n  color: inherit;\n  display: table-row;\n  outline: 0;\n  vertical-align: top;\n\n  &:last-child {\n    border-bottom: 0;\n    td:first-child {\n      border-radius: ${props => props.hasSquareCorners ? '0' : `0 0 0 ${props.theme.borderRadius}`};\n    }\n    td:last-child {\n      border-radius: ${props => props.hasSquareCorners ? '0' : `0 0 ${props.theme.borderRadius} 0`};\n    }\n  }\n\n  ${props => !props.color &&\r\n    css `\n      &:nth-of-type(even) {\n        background: ${props.hasZebraStripes\r\n        ? props.isInverse\r\n            ? transparentize(0.93, props.theme.colors.neutral100)\r\n            : props.theme.colors.neutral200\r\n        : 'none'};\n      }\n    `};\n\n  ${props => props.hasHoverStyles &&\r\n    !props.color &&\r\n    css `\n    &:hover {\n      background: ${props.isInverse\r\n        ? transparentize(0.85, props.theme.colors.neutral100)\r\n        : transparentize(0.93, props.theme.colors.neutral900)};\n    `}\n\n  ${props => props.color &&\r\n    css `\n      background: ${buildTableRowBackground(props)};\n      color: ${buildTableRowColor(props)};\n    `};\n`;\r\nconst SortButton = styled.button `\n  align-items: flex-end;\n  background: none;\n  border: 0;\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  margin: 0;\n  text-align: left;\n  width: 100%;\n  flex: 1 1 auto;\n\n  &:focus {\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n    outline-offset: -2px;\n  }\n\n  &:hover,\n  &:focus {\n    cursor: pointer;\n    svg {\n      fill: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n    }\n  }\n`;\r\nconst SortIconWrapper = styled.span `\n  position: relative;\n  top: ${props => props.theme.spaceScale.spacing01};\n`;\r\nexport const TableRow = React.forwardRef((props, ref) => {\r\n    const { children, headerRowStatus, isSelected, isSelectableDisabled, sortDirection, onHeaderRowSelect, onTableRowSelect, rowIndex, rowName, onSort, testId, ...other } = props;\r\n    const theme = React.useContext(ThemeContext);\r\n    const tableContext = React.useContext(TableContext);\r\n    const i18n = React.useContext(I18nContext);\r\n    let isHeaderRow = false;\r\n    React.Children.forEach(children, (child) => {\r\n        if (child.type.displayName === 'TableHeaderCell') {\r\n            isHeaderRow = true;\r\n            return;\r\n        }\r\n    });\r\n    function getIsCheckboxInverse() {\r\n        if (props.color && props.color === TableRowColor.warning) {\r\n            return false;\r\n        }\r\n        if (props.color && props.color !== TableRowColor.warning) {\r\n            return true;\r\n        }\r\n        return tableContext.isInverse;\r\n    }\r\n    const [isHovering, setIsHovering] = React.useState(false);\r\n    const handleMouseEnter = () => {\r\n        if (tableContext.isSortableBySelected)\r\n            setIsHovering(true);\r\n    };\r\n    const handleMouseLeave = () => {\r\n        if (tableContext.isSortableBySelected)\r\n            setIsHovering(false);\r\n    };\r\n    function handleSort() {\r\n        onSort && typeof onSort === 'function' && onSort();\r\n    }\r\n    const SortIcon = sortDirection === TableSortDirection.ascending ? (React.createElement(NorthIcon, { color: tableContext.isInverse\r\n            ? theme.colors.neutral100\r\n            : theme.colors.neutral700, size: theme.iconSizes.small, testId: \"sort-ascending\" })) : sortDirection === TableSortDirection.descending ? (React.createElement(SouthIcon, { color: tableContext.isInverse\r\n            ? theme.colors.neutral100\r\n            : theme.colors.neutral700, size: theme.iconSizes.small, testId: \"sort-descending\" })) : (React.createElement(SortDoubleArrowIcon, { color: tableContext.isInverse\r\n            ? transparentize(0.3, theme.colors.neutral100)\r\n            : theme.colors.neutral500, size: theme.iconSizes.small, testId: \"sort-none\" }));\r\n    return (React.createElement(StyledTableRow, Object.assign({}, other, { \"data-testid\": testId, hasSquareCorners: tableContext.hasSquareCorners, hasHoverStyles: tableContext.hasHoverStyles && !isHeaderRow, hasZebraStripes: tableContext.hasZebraStripes, isInverse: tableContext.isInverse, ref: ref, theme: theme }),\r\n        tableContext.isSelectable && isHeaderRow && (React.createElement(TableHeaderCell, { width: theme.spaceScale.spacing05, style: {\r\n                background: isHovering\r\n                    ? transparentize(0.93, theme.colors.neutral900)\r\n                    : '',\r\n            } },\r\n            React.createElement(\"span\", { style: { display: 'flex', flexDirection: 'row' } },\r\n                React.createElement(IndeterminateCheckbox, { status: headerRowStatus, isInverse: getIsCheckboxInverse(), labelStyle: { padding: 0 }, labelText: headerRowStatus === IndeterminateCheckboxStatus.unchecked\r\n                        ? i18n.table.selectable.selectAllRowsAriaLabel\r\n                        : i18n.table.selectable.deselectAllRowsAriaLabel, isTextVisuallyHidden: true, onChange: onHeaderRowSelect }),\r\n                tableContext.isSortableBySelected && (React.createElement(SortButton, { density: tableContext.density, isInverse: tableContext.isInverse, onClick: handleSort, textAlign: TableCellAlign.left, theme: theme, onMouseEnter: handleMouseEnter, onMouseLeave: handleMouseLeave, \"data-testid\": `${testId || ''}-sort-button`, \"aria-label\": i18n.table.selectable.sortButtonAriaLabel },\r\n                    React.createElement(SortIconWrapper, { theme: theme }, SortIcon)))))),\r\n        tableContext.isSelectable && !isHeaderRow && (React.createElement(TableCell, { width: theme.spaceScale.spacing05, style: { verticalAlign: 'middle' } },\r\n            React.createElement(Checkbox, { checked: isSelected, disabled: isSelectableDisabled, labelStyle: { padding: 0 }, labelText: isSelected\r\n                    ? `${i18n.table.selectable.deselectRowAriaLabel} ${rowName || ''}`\r\n                    : `${i18n.table.selectable.selectRowAriaLabel} ${rowName || ''}`, isTextVisuallyHidden: true, isInverse: getIsCheckboxInverse(), onChange: onTableRowSelect }))),\r\n        children));\r\n});\r\n//# sourceMappingURL=TableRow.js.map"]} */"));
|
|
6920
|
-
}, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["TableRow.tsx"],"names":[],"mappings":"AA+CiC","file":"TableRow.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport { NorthIcon, SortDoubleArrowIcon, SouthIcon } from 'react-magma-icons';\r\nimport { I18nContext } from '../../i18n';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { Checkbox } from '../Checkbox';\r\nimport { IndeterminateCheckbox, IndeterminateCheckboxStatus, } from '../IndeterminateCheckbox';\r\nimport { TableContext, TableRowColor, TableCell, TableHeaderCell, TableCellAlign, TableSortDirection, } from './';\r\nfunction buildTableRowBackground(props) {\r\n    if (props.isInverse) {\r\n        switch (props.color) {\r\n            case 'success':\r\n                return props.theme.colors.success200;\r\n            case 'warning':\r\n                return props.theme.colors.warning200;\r\n            case 'danger':\r\n                return props.theme.colors.danger200;\r\n            case 'info':\r\n                return props.theme.colors.info200;\r\n            default:\r\n                return 'inherit';\r\n        }\r\n    }\r\n    switch (props.color) {\r\n        case 'success':\r\n            return props.theme.colors.success;\r\n        case 'warning':\r\n            return props.theme.colors.warning;\r\n        case 'danger':\r\n            return props.theme.colors.danger;\r\n        case 'info':\r\n            return props.theme.colors.info;\r\n        default:\r\n            return 'inherit';\r\n    }\r\n}\r\nfunction buildTableRowColor(props) {\r\n    if (props.color && props.isInverse) {\r\n        return props.theme.colors.neutral700;\r\n    }\r\n    if (props.color && !props.isInverse) {\r\n        return props.theme.colors.neutral100;\r\n    }\r\n    return 'inherit';\r\n}\r\nconst StyledTableRow = styled.tr `\n  border-bottom: 1px solid\n    ${props => props.isInverse\r\n    ? transparentize(0.6, props.theme.colors.neutral100)\r\n    : props.theme.colors.neutral300};\n  color: inherit;\n  display: table-row;\n  outline: 0;\n  vertical-align: top;\n\n  &:last-child {\n    border-bottom: 0;\n    td:first-child {\n      border-radius: ${props => props.hasSquareCorners ? '0' : `0 0 0 ${props.theme.borderRadius}`};\n    }\n    td:last-child {\n      border-radius: ${props => props.hasSquareCorners ? '0' : `0 0 ${props.theme.borderRadius} 0`};\n    }\n  }\n\n  ${props => !props.color &&\r\n    css `\n      &:nth-of-type(even) {\n        background: ${props.hasZebraStripes\r\n        ? props.isInverse\r\n            ? transparentize(0.93, props.theme.colors.neutral100)\r\n            : props.theme.colors.neutral200\r\n        : 'none'};\n      }\n    `};\n\n  ${props => props.hasHoverStyles &&\r\n    !props.color &&\r\n    css `\n    &:hover {\n      background: ${props.isInverse\r\n        ? transparentize(0.85, props.theme.colors.neutral100)\r\n        : transparentize(0.93, props.theme.colors.neutral900)};\n    `}\n\n  ${props => props.color &&\r\n    css `\n      background: ${buildTableRowBackground(props)};\n      color: ${buildTableRowColor(props)};\n    `};\n`;\r\nconst SortButton = styled.button `\n  align-items: flex-end;\n  background: none;\n  border: 0;\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  margin: 0;\n  text-align: left;\n  width: 100%;\n  flex: 1 1 auto;\n\n  &:focus {\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n    outline-offset: -2px;\n  }\n\n  &:hover,\n  &:focus {\n    cursor: pointer;\n    svg {\n      fill: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n    }\n  }\n`;\r\nconst SortIconWrapper = styled.span `\n  position: relative;\n  top: ${props => props.theme.spaceScale.spacing01};\n`;\r\nexport const TableRow = React.forwardRef((props, ref) => {\r\n    const { children, headerRowStatus, isSelected, isSelectableDisabled, sortDirection, onHeaderRowSelect, onTableRowSelect, rowIndex, rowName, onSort, testId, ...other } = props;\r\n    const theme = React.useContext(ThemeContext);\r\n    const tableContext = React.useContext(TableContext);\r\n    const i18n = React.useContext(I18nContext);\r\n    let isHeaderRow = false;\r\n    React.Children.forEach(children, (child) => {\r\n        if (child.type.displayName === 'TableHeaderCell') {\r\n            isHeaderRow = true;\r\n            return;\r\n        }\r\n    });\r\n    function getIsCheckboxInverse() {\r\n        if (props.color && props.color === TableRowColor.warning) {\r\n            return false;\r\n        }\r\n        if (props.color && props.color !== TableRowColor.warning) {\r\n            return true;\r\n        }\r\n        return tableContext.isInverse;\r\n    }\r\n    const [isHovering, setIsHovering] = React.useState(false);\r\n    const handleMouseEnter = () => {\r\n        if (tableContext.isSortableBySelected)\r\n            setIsHovering(true);\r\n    };\r\n    const handleMouseLeave = () => {\r\n        if (tableContext.isSortableBySelected)\r\n            setIsHovering(false);\r\n    };\r\n    function handleSort() {\r\n        onSort && typeof onSort === 'function' && onSort();\r\n    }\r\n    const SortIcon = sortDirection === TableSortDirection.ascending ? (React.createElement(NorthIcon, { color: tableContext.isInverse\r\n            ? theme.colors.neutral100\r\n            : theme.colors.neutral700, size: theme.iconSizes.small, testId: \"sort-ascending\" })) : sortDirection === TableSortDirection.descending ? (React.createElement(SouthIcon, { color: tableContext.isInverse\r\n            ? theme.colors.neutral100\r\n            : theme.colors.neutral700, size: theme.iconSizes.small, testId: \"sort-descending\" })) : (React.createElement(SortDoubleArrowIcon, { color: tableContext.isInverse\r\n            ? transparentize(0.3, theme.colors.neutral100)\r\n            : theme.colors.neutral500, size: theme.iconSizes.small, testId: \"sort-none\" }));\r\n    return (React.createElement(StyledTableRow, Object.assign({}, other, { \"data-testid\": testId, hasSquareCorners: tableContext.hasSquareCorners, hasHoverStyles: tableContext.hasHoverStyles && !isHeaderRow, hasZebraStripes: tableContext.hasZebraStripes, isInverse: tableContext.isInverse, ref: ref, theme: theme }),\r\n        tableContext.isSelectable && isHeaderRow && (React.createElement(TableHeaderCell, { width: theme.spaceScale.spacing05, style: {\r\n                background: isHovering\r\n                    ? transparentize(0.93, theme.colors.neutral900)\r\n                    : '',\r\n            } },\r\n            React.createElement(\"span\", { style: { display: 'flex', flexDirection: 'row' } },\r\n                React.createElement(IndeterminateCheckbox, { status: headerRowStatus, isInverse: getIsCheckboxInverse(), labelStyle: { padding: 0 }, labelText: headerRowStatus === IndeterminateCheckboxStatus.unchecked\r\n                        ? i18n.table.selectable.selectAllRowsAriaLabel\r\n                        : i18n.table.selectable.deselectAllRowsAriaLabel, isTextVisuallyHidden: true, onChange: onHeaderRowSelect }),\r\n                tableContext.isSortableBySelected && (React.createElement(SortButton, { density: tableContext.density, isInverse: tableContext.isInverse, onClick: handleSort, textAlign: TableCellAlign.left, theme: theme, onMouseEnter: handleMouseEnter, onMouseLeave: handleMouseLeave, \"data-testid\": `${testId || ''}-sort-button`, \"aria-label\": i18n.table.selectable.sortButtonAriaLabel },\r\n                    React.createElement(SortIconWrapper, { theme: theme }, SortIcon)))))),\r\n        tableContext.isSelectable && !isHeaderRow && (React.createElement(TableCell, { width: theme.spaceScale.spacing05, style: { verticalAlign: 'middle' } },\r\n            React.createElement(Checkbox, { checked: isSelected, disabled: isSelectableDisabled, labelStyle: { padding: 0 }, labelText: isSelected\r\n                    ? `${i18n.table.selectable.deselectRowAriaLabel} ${rowName || ''}`\r\n                    : `${i18n.table.selectable.selectRowAriaLabel} ${rowName || ''}`, isTextVisuallyHidden: true, isInverse: getIsCheckboxInverse(), onChange: onTableRowSelect }))),\r\n        children));\r\n});\r\n//# sourceMappingURL=TableRow.js.map"]} */"));
|
|
7051
|
+
return props.color && /*#__PURE__*/css("background:", buildTableRowBackground(props), ";color:", buildTableRowColor(props), ";;label:StyledTableRow;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["TableRow.tsx"],"names":[],"mappings":"AA2GQ","file":"TableRow.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport { NorthIcon, SortDoubleArrowIcon, SouthIcon } from 'react-magma-icons';\r\nimport { I18nContext } from '../../i18n';\r\nimport { magma } from '../../theme/magma';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { Checkbox } from '../Checkbox';\r\nimport { IndeterminateCheckbox, IndeterminateCheckboxStatus, } from '../IndeterminateCheckbox';\r\nimport { TableContext, TableRowColor, TableCell, TableHeaderCell, TableCellAlign, TableSortDirection, } from './';\r\nfunction buildTableRowBackground(props) {\r\n    if (props.isInverse) {\r\n        switch (props.color) {\r\n            case 'success':\r\n                return props.theme.colors.success200;\r\n            case 'warning':\r\n                return props.theme.colors.warning200;\r\n            case 'danger':\r\n                return props.theme.colors.danger200;\r\n            case 'info':\r\n                return props.theme.colors.info200;\r\n            default:\r\n                return 'inherit';\r\n        }\r\n    }\r\n    switch (props.color) {\r\n        case 'success':\r\n            return props.theme.colors.success;\r\n        case 'warning':\r\n            return props.theme.colors.warning;\r\n        case 'danger':\r\n            return props.theme.colors.danger;\r\n        case 'info':\r\n            return props.theme.colors.info;\r\n        default:\r\n            return 'inherit';\r\n    }\r\n}\r\nfunction buildTableRowColor(props) {\r\n    if (props.color && props.isInverse) {\r\n        return props.theme.colors.neutral700;\r\n    }\r\n    if (props.color && !props.isInverse) {\r\n        return props.theme.colors.neutral100;\r\n    }\r\n    return 'inherit';\r\n}\r\nfunction getBorderBottom(isInverse) {\r\n    return `1px solid ${isInverse\r\n        ? transparentize(0.6, magma.colors.neutral100)\r\n        : magma.colors.neutral300}`;\r\n}\r\nconst StyledTableRow = styled.tr `\n  border-bottom: ${props => getBorderBottom(props.isInverse)};\n  color: inherit;\n  display: table-row;\n  outline: 0;\n  vertical-align: top;\n\n  // Compensates border bottom for all rows (except last one) when table has outside border\n  td {\n    border-bottom: ${props => getBorderBottom(props.isInverse)};\n  }\n\n  &:last-child {\n    // Removes border bottom for last row if it's colored\n    border-bottom: ${props => props.color || (props.hasZebraStripes && !props.hasTablePagination)\r\n    ? 0\r\n    : `${getBorderBottom(props.isInverse)}`};\n\n    td {\n      border-bottom: 0;\n    }\n    td:first-child {\n      border-radius: ${props => props.hasSquareCorners || props.hasTablePagination\r\n    ? '0'\r\n    : `0 0 0 ${props.theme.borderRadius}`};\n    }\n    td:last-child {\n      border-radius: ${props => props.hasSquareCorners || props.hasTablePagination\r\n    ? '0'\r\n    : `0 0 ${props.theme.borderRadius} 0`};\n    }\n  }\n\n  ${props => !props.color &&\r\n    css `\n      &:nth-of-type(even) {\n        background: ${props.hasZebraStripes\r\n        ? props.isInverse\r\n            ? transparentize(0.93, props.theme.colors.neutral100)\r\n            : props.theme.colors.neutral200\r\n        : 'none'};\n      }\n    `};\n\n  ${props => props.hasHoverStyles &&\r\n    !props.color &&\r\n    css `\n    &:hover {\n      background: ${props.isInverse\r\n        ? transparentize(0.85, props.theme.colors.neutral100)\r\n        : transparentize(0.93, props.theme.colors.neutral900)};\n    `}\n\n  ${props => props.color &&\r\n    css `\n      background: ${buildTableRowBackground(props)};\n      color: ${buildTableRowColor(props)};\n    `};\n`;\r\nconst SortButton = styled.button `\n  align-items: flex-end;\n  background: none;\n  border: 0;\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  margin: 0;\n  text-align: left;\n  width: 100%;\n  flex: 1 1 auto;\n\n  &:focus {\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n    outline-offset: -2px;\n  }\n\n  &:hover,\n  &:focus {\n    cursor: pointer;\n    svg {\n      fill: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n    }\n  }\n`;\r\nconst SortIconWrapper = styled.span `\n  position: relative;\n  top: ${props => props.theme.spaceScale.spacing01};\n`;\r\nexport const TableRow = React.forwardRef((props, ref) => {\r\n    const { children, headerRowStatus, isSelected, isSelectableDisabled, sortDirection, onHeaderRowSelect, onTableRowSelect, rowIndex, rowName, onSort, testId, ...other } = props;\r\n    const theme = React.useContext(ThemeContext);\r\n    const tableContext = React.useContext(TableContext);\r\n    const i18n = React.useContext(I18nContext);\r\n    let isHeaderRow = false;\r\n    React.Children.forEach(children, (child) => {\r\n        if (child.type.displayName === 'TableHeaderCell') {\r\n            isHeaderRow = true;\r\n            return;\r\n        }\r\n    });\r\n    function getIsCheckboxInverse() {\r\n        if (props.color && props.color === TableRowColor.warning) {\r\n            return false;\r\n        }\r\n        if (props.color && props.color !== TableRowColor.warning) {\r\n            return true;\r\n        }\r\n        return tableContext.isInverse;\r\n    }\r\n    const [isHovering, setIsHovering] = React.useState(false);\r\n    const handleMouseEnter = () => {\r\n        if (tableContext.isSortableBySelected)\r\n            setIsHovering(true);\r\n    };\r\n    const handleMouseLeave = () => {\r\n        if (tableContext.isSortableBySelected)\r\n            setIsHovering(false);\r\n    };\r\n    function handleSort() {\r\n        onSort && typeof onSort === 'function' && onSort();\r\n    }\r\n    const SortIcon = sortDirection === TableSortDirection.ascending ? (React.createElement(NorthIcon, { color: tableContext.isInverse\r\n            ? theme.colors.neutral100\r\n            : theme.colors.neutral700, size: theme.iconSizes.small, testId: \"sort-ascending\" })) : sortDirection === TableSortDirection.descending ? (React.createElement(SouthIcon, { color: tableContext.isInverse\r\n            ? theme.colors.neutral100\r\n            : theme.colors.neutral700, size: theme.iconSizes.small, testId: \"sort-descending\" })) : (React.createElement(SortDoubleArrowIcon, { color: tableContext.isInverse\r\n            ? transparentize(0.3, theme.colors.neutral100)\r\n            : theme.colors.neutral500, size: theme.iconSizes.small, testId: \"sort-none\" }));\r\n    return (React.createElement(StyledTableRow, Object.assign({}, other, { \"data-testid\": testId, hasHoverStyles: tableContext.hasHoverStyles && !isHeaderRow, hasSquareCorners: tableContext.hasSquareCorners, hasTablePagination: tableContext.hasTablePagination, hasZebraStripes: tableContext.hasZebraStripes, isInverse: tableContext.isInverse, ref: ref, theme: theme }),\r\n        tableContext.isSelectable && isHeaderRow && (React.createElement(TableHeaderCell, { width: theme.spaceScale.spacing05, style: {\r\n                background: isHovering\r\n                    ? transparentize(0.93, theme.colors.neutral900)\r\n                    : '',\r\n            } },\r\n            React.createElement(\"span\", { style: { display: 'flex', flexDirection: 'row' } },\r\n                React.createElement(IndeterminateCheckbox, { status: headerRowStatus, isInverse: getIsCheckboxInverse(), labelStyle: { padding: 0 }, labelText: headerRowStatus === IndeterminateCheckboxStatus.unchecked\r\n                        ? i18n.table.selectable.selectAllRowsAriaLabel\r\n                        : i18n.table.selectable.deselectAllRowsAriaLabel, isTextVisuallyHidden: true, onChange: onHeaderRowSelect }),\r\n                tableContext.isSortableBySelected && (React.createElement(SortButton, { density: tableContext.density, isInverse: tableContext.isInverse, onClick: handleSort, textAlign: TableCellAlign.left, theme: theme, onMouseEnter: handleMouseEnter, onMouseLeave: handleMouseLeave, \"data-testid\": `${testId || ''}-sort-button`, \"aria-label\": i18n.table.selectable.sortButtonAriaLabel },\r\n                    React.createElement(SortIconWrapper, { theme: theme }, SortIcon)))))),\r\n        tableContext.isSelectable && !isHeaderRow && (React.createElement(TableCell, { width: theme.spaceScale.spacing05, style: { verticalAlign: 'middle' } },\r\n            React.createElement(Checkbox, { checked: isSelected, disabled: isSelectableDisabled, labelStyle: { padding: 0 }, labelText: isSelected\r\n                    ? `${i18n.table.selectable.deselectRowAriaLabel} ${rowName || ''}`\r\n                    : `${i18n.table.selectable.selectRowAriaLabel} ${rowName || ''}`, isTextVisuallyHidden: true, isInverse: getIsCheckboxInverse(), onChange: onTableRowSelect }))),\r\n        children));\r\n});\r\n//# sourceMappingURL=TableRow.js.map"]} */"));
|
|
7052
|
+
}, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["TableRow.tsx"],"names":[],"mappings":"AAqDiC","file":"TableRow.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport { NorthIcon, SortDoubleArrowIcon, SouthIcon } from 'react-magma-icons';\r\nimport { I18nContext } from '../../i18n';\r\nimport { magma } from '../../theme/magma';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { Checkbox } from '../Checkbox';\r\nimport { IndeterminateCheckbox, IndeterminateCheckboxStatus, } from '../IndeterminateCheckbox';\r\nimport { TableContext, TableRowColor, TableCell, TableHeaderCell, TableCellAlign, TableSortDirection, } from './';\r\nfunction buildTableRowBackground(props) {\r\n    if (props.isInverse) {\r\n        switch (props.color) {\r\n            case 'success':\r\n                return props.theme.colors.success200;\r\n            case 'warning':\r\n                return props.theme.colors.warning200;\r\n            case 'danger':\r\n                return props.theme.colors.danger200;\r\n            case 'info':\r\n                return props.theme.colors.info200;\r\n            default:\r\n                return 'inherit';\r\n        }\r\n    }\r\n    switch (props.color) {\r\n        case 'success':\r\n            return props.theme.colors.success;\r\n        case 'warning':\r\n            return props.theme.colors.warning;\r\n        case 'danger':\r\n            return props.theme.colors.danger;\r\n        case 'info':\r\n            return props.theme.colors.info;\r\n        default:\r\n            return 'inherit';\r\n    }\r\n}\r\nfunction buildTableRowColor(props) {\r\n    if (props.color && props.isInverse) {\r\n        return props.theme.colors.neutral700;\r\n    }\r\n    if (props.color && !props.isInverse) {\r\n        return props.theme.colors.neutral100;\r\n    }\r\n    return 'inherit';\r\n}\r\nfunction getBorderBottom(isInverse) {\r\n    return `1px solid ${isInverse\r\n        ? transparentize(0.6, magma.colors.neutral100)\r\n        : magma.colors.neutral300}`;\r\n}\r\nconst StyledTableRow = styled.tr `\n  border-bottom: ${props => getBorderBottom(props.isInverse)};\n  color: inherit;\n  display: table-row;\n  outline: 0;\n  vertical-align: top;\n\n  // Compensates border bottom for all rows (except last one) when table has outside border\n  td {\n    border-bottom: ${props => getBorderBottom(props.isInverse)};\n  }\n\n  &:last-child {\n    // Removes border bottom for last row if it's colored\n    border-bottom: ${props => props.color || (props.hasZebraStripes && !props.hasTablePagination)\r\n    ? 0\r\n    : `${getBorderBottom(props.isInverse)}`};\n\n    td {\n      border-bottom: 0;\n    }\n    td:first-child {\n      border-radius: ${props => props.hasSquareCorners || props.hasTablePagination\r\n    ? '0'\r\n    : `0 0 0 ${props.theme.borderRadius}`};\n    }\n    td:last-child {\n      border-radius: ${props => props.hasSquareCorners || props.hasTablePagination\r\n    ? '0'\r\n    : `0 0 ${props.theme.borderRadius} 0`};\n    }\n  }\n\n  ${props => !props.color &&\r\n    css `\n      &:nth-of-type(even) {\n        background: ${props.hasZebraStripes\r\n        ? props.isInverse\r\n            ? transparentize(0.93, props.theme.colors.neutral100)\r\n            : props.theme.colors.neutral200\r\n        : 'none'};\n      }\n    `};\n\n  ${props => props.hasHoverStyles &&\r\n    !props.color &&\r\n    css `\n    &:hover {\n      background: ${props.isInverse\r\n        ? transparentize(0.85, props.theme.colors.neutral100)\r\n        : transparentize(0.93, props.theme.colors.neutral900)};\n    `}\n\n  ${props => props.color &&\r\n    css `\n      background: ${buildTableRowBackground(props)};\n      color: ${buildTableRowColor(props)};\n    `};\n`;\r\nconst SortButton = styled.button `\n  align-items: flex-end;\n  background: none;\n  border: 0;\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  margin: 0;\n  text-align: left;\n  width: 100%;\n  flex: 1 1 auto;\n\n  &:focus {\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n    outline-offset: -2px;\n  }\n\n  &:hover,\n  &:focus {\n    cursor: pointer;\n    svg {\n      fill: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n    }\n  }\n`;\r\nconst SortIconWrapper = styled.span `\n  position: relative;\n  top: ${props => props.theme.spaceScale.spacing01};\n`;\r\nexport const TableRow = React.forwardRef((props, ref) => {\r\n    const { children, headerRowStatus, isSelected, isSelectableDisabled, sortDirection, onHeaderRowSelect, onTableRowSelect, rowIndex, rowName, onSort, testId, ...other } = props;\r\n    const theme = React.useContext(ThemeContext);\r\n    const tableContext = React.useContext(TableContext);\r\n    const i18n = React.useContext(I18nContext);\r\n    let isHeaderRow = false;\r\n    React.Children.forEach(children, (child) => {\r\n        if (child.type.displayName === 'TableHeaderCell') {\r\n            isHeaderRow = true;\r\n            return;\r\n        }\r\n    });\r\n    function getIsCheckboxInverse() {\r\n        if (props.color && props.color === TableRowColor.warning) {\r\n            return false;\r\n        }\r\n        if (props.color && props.color !== TableRowColor.warning) {\r\n            return true;\r\n        }\r\n        return tableContext.isInverse;\r\n    }\r\n    const [isHovering, setIsHovering] = React.useState(false);\r\n    const handleMouseEnter = () => {\r\n        if (tableContext.isSortableBySelected)\r\n            setIsHovering(true);\r\n    };\r\n    const handleMouseLeave = () => {\r\n        if (tableContext.isSortableBySelected)\r\n            setIsHovering(false);\r\n    };\r\n    function handleSort() {\r\n        onSort && typeof onSort === 'function' && onSort();\r\n    }\r\n    const SortIcon = sortDirection === TableSortDirection.ascending ? (React.createElement(NorthIcon, { color: tableContext.isInverse\r\n            ? theme.colors.neutral100\r\n            : theme.colors.neutral700, size: theme.iconSizes.small, testId: \"sort-ascending\" })) : sortDirection === TableSortDirection.descending ? (React.createElement(SouthIcon, { color: tableContext.isInverse\r\n            ? theme.colors.neutral100\r\n            : theme.colors.neutral700, size: theme.iconSizes.small, testId: \"sort-descending\" })) : (React.createElement(SortDoubleArrowIcon, { color: tableContext.isInverse\r\n            ? transparentize(0.3, theme.colors.neutral100)\r\n            : theme.colors.neutral500, size: theme.iconSizes.small, testId: \"sort-none\" }));\r\n    return (React.createElement(StyledTableRow, Object.assign({}, other, { \"data-testid\": testId, hasHoverStyles: tableContext.hasHoverStyles && !isHeaderRow, hasSquareCorners: tableContext.hasSquareCorners, hasTablePagination: tableContext.hasTablePagination, hasZebraStripes: tableContext.hasZebraStripes, isInverse: tableContext.isInverse, ref: ref, theme: theme }),\r\n        tableContext.isSelectable && isHeaderRow && (React.createElement(TableHeaderCell, { width: theme.spaceScale.spacing05, style: {\r\n                background: isHovering\r\n                    ? transparentize(0.93, theme.colors.neutral900)\r\n                    : '',\r\n            } },\r\n            React.createElement(\"span\", { style: { display: 'flex', flexDirection: 'row' } },\r\n                React.createElement(IndeterminateCheckbox, { status: headerRowStatus, isInverse: getIsCheckboxInverse(), labelStyle: { padding: 0 }, labelText: headerRowStatus === IndeterminateCheckboxStatus.unchecked\r\n                        ? i18n.table.selectable.selectAllRowsAriaLabel\r\n                        : i18n.table.selectable.deselectAllRowsAriaLabel, isTextVisuallyHidden: true, onChange: onHeaderRowSelect }),\r\n                tableContext.isSortableBySelected && (React.createElement(SortButton, { density: tableContext.density, isInverse: tableContext.isInverse, onClick: handleSort, textAlign: TableCellAlign.left, theme: theme, onMouseEnter: handleMouseEnter, onMouseLeave: handleMouseLeave, \"data-testid\": `${testId || ''}-sort-button`, \"aria-label\": i18n.table.selectable.sortButtonAriaLabel },\r\n                    React.createElement(SortIconWrapper, { theme: theme }, SortIcon)))))),\r\n        tableContext.isSelectable && !isHeaderRow && (React.createElement(TableCell, { width: theme.spaceScale.spacing05, style: { verticalAlign: 'middle' } },\r\n            React.createElement(Checkbox, { checked: isSelected, disabled: isSelectableDisabled, labelStyle: { padding: 0 }, labelText: isSelected\r\n                    ? `${i18n.table.selectable.deselectRowAriaLabel} ${rowName || ''}`\r\n                    : `${i18n.table.selectable.selectRowAriaLabel} ${rowName || ''}`, isTextVisuallyHidden: true, isInverse: getIsCheckboxInverse(), onChange: onTableRowSelect }))),\r\n        children));\r\n});\r\n//# sourceMappingURL=TableRow.js.map"]} */"));
|
|
6921
7053
|
var SortButton$1 = /*#__PURE__*/_styled("button", {
|
|
6922
7054
|
target: "e1b4326l1",
|
|
6923
7055
|
label: "SortButton"
|
|
@@ -6927,13 +7059,13 @@ var SortButton$1 = /*#__PURE__*/_styled("button", {
|
|
|
6927
7059
|
return props.isInverse ? props.theme.colors.focusInverse : props.theme.colors.focus;
|
|
6928
7060
|
}, ";outline-offset:-2px;}&:hover,&:focus{cursor:pointer;svg{fill:", function (props) {
|
|
6929
7061
|
return props.isInverse ? props.theme.colors.neutral100 : props.theme.colors.neutral700;
|
|
6930
|
-
}, ";}}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["TableRow.tsx"],"names":[],"mappings":"AA6FiC","file":"TableRow.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport { NorthIcon, SortDoubleArrowIcon, SouthIcon } from 'react-magma-icons';\r\nimport { I18nContext } from '../../i18n';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { Checkbox } from '../Checkbox';\r\nimport { IndeterminateCheckbox, IndeterminateCheckboxStatus, } from '../IndeterminateCheckbox';\r\nimport { TableContext, TableRowColor, TableCell, TableHeaderCell, TableCellAlign, TableSortDirection, } from './';\r\nfunction buildTableRowBackground(props) {\r\n    if (props.isInverse) {\r\n        switch (props.color) {\r\n            case 'success':\r\n                return props.theme.colors.success200;\r\n            case 'warning':\r\n                return props.theme.colors.warning200;\r\n            case 'danger':\r\n                return props.theme.colors.danger200;\r\n            case 'info':\r\n                return props.theme.colors.info200;\r\n            default:\r\n                return 'inherit';\r\n        }\r\n    }\r\n    switch (props.color) {\r\n        case 'success':\r\n            return props.theme.colors.success;\r\n        case 'warning':\r\n            return props.theme.colors.warning;\r\n        case 'danger':\r\n            return props.theme.colors.danger;\r\n        case 'info':\r\n            return props.theme.colors.info;\r\n        default:\r\n            return 'inherit';\r\n    }\r\n}\r\nfunction buildTableRowColor(props) {\r\n    if (props.color && props.isInverse) {\r\n        return props.theme.colors.neutral700;\r\n    }\r\n    if (props.color && !props.isInverse) {\r\n        return props.theme.colors.neutral100;\r\n    }\r\n    return 'inherit';\r\n}\r\nconst StyledTableRow = styled.tr `\n  border-bottom: 1px solid\n    ${props => props.isInverse\r\n    ? transparentize(0.6, props.theme.colors.neutral100)\r\n    : props.theme.colors.neutral300};\n  color: inherit;\n  display: table-row;\n  outline: 0;\n  vertical-align: top;\n\n  &:last-child {\n    border-bottom: 0;\n    td:first-child {\n      border-radius: ${props => props.hasSquareCorners ? '0' : `0 0 0 ${props.theme.borderRadius}`};\n    }\n    td:last-child {\n      border-radius: ${props => props.hasSquareCorners ? '0' : `0 0 ${props.theme.borderRadius} 0`};\n    }\n  }\n\n  ${props => !props.color &&\r\n    css `\n      &:nth-of-type(even) {\n        background: ${props.hasZebraStripes\r\n        ? props.isInverse\r\n            ? transparentize(0.93, props.theme.colors.neutral100)\r\n            : props.theme.colors.neutral200\r\n        : 'none'};\n      }\n    `};\n\n  ${props => props.hasHoverStyles &&\r\n    !props.color &&\r\n    css `\n    &:hover {\n      background: ${props.isInverse\r\n        ? transparentize(0.85, props.theme.colors.neutral100)\r\n        : transparentize(0.93, props.theme.colors.neutral900)};\n    `}\n\n  ${props => props.color &&\r\n    css `\n      background: ${buildTableRowBackground(props)};\n      color: ${buildTableRowColor(props)};\n    `};\n`;\r\nconst SortButton = styled.button `\n  align-items: flex-end;\n  background: none;\n  border: 0;\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  margin: 0;\n  text-align: left;\n  width: 100%;\n  flex: 1 1 auto;\n\n  &:focus {\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n    outline-offset: -2px;\n  }\n\n  &:hover,\n  &:focus {\n    cursor: pointer;\n    svg {\n      fill: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n    }\n  }\n`;\r\nconst SortIconWrapper = styled.span `\n  position: relative;\n  top: ${props => props.theme.spaceScale.spacing01};\n`;\r\nexport const TableRow = React.forwardRef((props, ref) => {\r\n    const { children, headerRowStatus, isSelected, isSelectableDisabled, sortDirection, onHeaderRowSelect, onTableRowSelect, rowIndex, rowName, onSort, testId, ...other } = props;\r\n    const theme = React.useContext(ThemeContext);\r\n    const tableContext = React.useContext(TableContext);\r\n    const i18n = React.useContext(I18nContext);\r\n    let isHeaderRow = false;\r\n    React.Children.forEach(children, (child) => {\r\n        if (child.type.displayName === 'TableHeaderCell') {\r\n            isHeaderRow = true;\r\n            return;\r\n        }\r\n    });\r\n    function getIsCheckboxInverse() {\r\n        if (props.color && props.color === TableRowColor.warning) {\r\n            return false;\r\n        }\r\n        if (props.color && props.color !== TableRowColor.warning) {\r\n            return true;\r\n        }\r\n        return tableContext.isInverse;\r\n    }\r\n    const [isHovering, setIsHovering] = React.useState(false);\r\n    const handleMouseEnter = () => {\r\n        if (tableContext.isSortableBySelected)\r\n            setIsHovering(true);\r\n    };\r\n    const handleMouseLeave = () => {\r\n        if (tableContext.isSortableBySelected)\r\n            setIsHovering(false);\r\n    };\r\n    function handleSort() {\r\n        onSort && typeof onSort === 'function' && onSort();\r\n    }\r\n    const SortIcon = sortDirection === TableSortDirection.ascending ? (React.createElement(NorthIcon, { color: tableContext.isInverse\r\n            ? theme.colors.neutral100\r\n            : theme.colors.neutral700, size: theme.iconSizes.small, testId: \"sort-ascending\" })) : sortDirection === TableSortDirection.descending ? (React.createElement(SouthIcon, { color: tableContext.isInverse\r\n            ? theme.colors.neutral100\r\n            : theme.colors.neutral700, size: theme.iconSizes.small, testId: \"sort-descending\" })) : (React.createElement(SortDoubleArrowIcon, { color: tableContext.isInverse\r\n            ? transparentize(0.3, theme.colors.neutral100)\r\n            : theme.colors.neutral500, size: theme.iconSizes.small, testId: \"sort-none\" }));\r\n    return (React.createElement(StyledTableRow, Object.assign({}, other, { \"data-testid\": testId, hasSquareCorners: tableContext.hasSquareCorners, hasHoverStyles: tableContext.hasHoverStyles && !isHeaderRow, hasZebraStripes: tableContext.hasZebraStripes, isInverse: tableContext.isInverse, ref: ref, theme: theme }),\r\n        tableContext.isSelectable && isHeaderRow && (React.createElement(TableHeaderCell, { width: theme.spaceScale.spacing05, style: {\r\n                background: isHovering\r\n                    ? transparentize(0.93, theme.colors.neutral900)\r\n                    : '',\r\n            } },\r\n            React.createElement(\"span\", { style: { display: 'flex', flexDirection: 'row' } },\r\n                React.createElement(IndeterminateCheckbox, { status: headerRowStatus, isInverse: getIsCheckboxInverse(), labelStyle: { padding: 0 }, labelText: headerRowStatus === IndeterminateCheckboxStatus.unchecked\r\n                        ? i18n.table.selectable.selectAllRowsAriaLabel\r\n                        : i18n.table.selectable.deselectAllRowsAriaLabel, isTextVisuallyHidden: true, onChange: onHeaderRowSelect }),\r\n                tableContext.isSortableBySelected && (React.createElement(SortButton, { density: tableContext.density, isInverse: tableContext.isInverse, onClick: handleSort, textAlign: TableCellAlign.left, theme: theme, onMouseEnter: handleMouseEnter, onMouseLeave: handleMouseLeave, \"data-testid\": `${testId || ''}-sort-button`, \"aria-label\": i18n.table.selectable.sortButtonAriaLabel },\r\n                    React.createElement(SortIconWrapper, { theme: theme }, SortIcon)))))),\r\n        tableContext.isSelectable && !isHeaderRow && (React.createElement(TableCell, { width: theme.spaceScale.spacing05, style: { verticalAlign: 'middle' } },\r\n            React.createElement(Checkbox, { checked: isSelected, disabled: isSelectableDisabled, labelStyle: { padding: 0 }, labelText: isSelected\r\n                    ? `${i18n.table.selectable.deselectRowAriaLabel} ${rowName || ''}`\r\n                    : `${i18n.table.selectable.selectRowAriaLabel} ${rowName || ''}`, isTextVisuallyHidden: true, isInverse: getIsCheckboxInverse(), onChange: onTableRowSelect }))),\r\n        children));\r\n});\r\n//# sourceMappingURL=TableRow.js.map"]} */"));
|
|
7062
|
+
}, ";}}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["TableRow.tsx"],"names":[],"mappings":"AAgHiC","file":"TableRow.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport { NorthIcon, SortDoubleArrowIcon, SouthIcon } from 'react-magma-icons';\r\nimport { I18nContext } from '../../i18n';\r\nimport { magma } from '../../theme/magma';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { Checkbox } from '../Checkbox';\r\nimport { IndeterminateCheckbox, IndeterminateCheckboxStatus, } from '../IndeterminateCheckbox';\r\nimport { TableContext, TableRowColor, TableCell, TableHeaderCell, TableCellAlign, TableSortDirection, } from './';\r\nfunction buildTableRowBackground(props) {\r\n    if (props.isInverse) {\r\n        switch (props.color) {\r\n            case 'success':\r\n                return props.theme.colors.success200;\r\n            case 'warning':\r\n                return props.theme.colors.warning200;\r\n            case 'danger':\r\n                return props.theme.colors.danger200;\r\n            case 'info':\r\n                return props.theme.colors.info200;\r\n            default:\r\n                return 'inherit';\r\n        }\r\n    }\r\n    switch (props.color) {\r\n        case 'success':\r\n            return props.theme.colors.success;\r\n        case 'warning':\r\n            return props.theme.colors.warning;\r\n        case 'danger':\r\n            return props.theme.colors.danger;\r\n        case 'info':\r\n            return props.theme.colors.info;\r\n        default:\r\n            return 'inherit';\r\n    }\r\n}\r\nfunction buildTableRowColor(props) {\r\n    if (props.color && props.isInverse) {\r\n        return props.theme.colors.neutral700;\r\n    }\r\n    if (props.color && !props.isInverse) {\r\n        return props.theme.colors.neutral100;\r\n    }\r\n    return 'inherit';\r\n}\r\nfunction getBorderBottom(isInverse) {\r\n    return `1px solid ${isInverse\r\n        ? transparentize(0.6, magma.colors.neutral100)\r\n        : magma.colors.neutral300}`;\r\n}\r\nconst StyledTableRow = styled.tr `\n  border-bottom: ${props => getBorderBottom(props.isInverse)};\n  color: inherit;\n  display: table-row;\n  outline: 0;\n  vertical-align: top;\n\n  // Compensates border bottom for all rows (except last one) when table has outside border\n  td {\n    border-bottom: ${props => getBorderBottom(props.isInverse)};\n  }\n\n  &:last-child {\n    // Removes border bottom for last row if it's colored\n    border-bottom: ${props => props.color || (props.hasZebraStripes && !props.hasTablePagination)\r\n    ? 0\r\n    : `${getBorderBottom(props.isInverse)}`};\n\n    td {\n      border-bottom: 0;\n    }\n    td:first-child {\n      border-radius: ${props => props.hasSquareCorners || props.hasTablePagination\r\n    ? '0'\r\n    : `0 0 0 ${props.theme.borderRadius}`};\n    }\n    td:last-child {\n      border-radius: ${props => props.hasSquareCorners || props.hasTablePagination\r\n    ? '0'\r\n    : `0 0 ${props.theme.borderRadius} 0`};\n    }\n  }\n\n  ${props => !props.color &&\r\n    css `\n      &:nth-of-type(even) {\n        background: ${props.hasZebraStripes\r\n        ? props.isInverse\r\n            ? transparentize(0.93, props.theme.colors.neutral100)\r\n            : props.theme.colors.neutral200\r\n        : 'none'};\n      }\n    `};\n\n  ${props => props.hasHoverStyles &&\r\n    !props.color &&\r\n    css `\n    &:hover {\n      background: ${props.isInverse\r\n        ? transparentize(0.85, props.theme.colors.neutral100)\r\n        : transparentize(0.93, props.theme.colors.neutral900)};\n    `}\n\n  ${props => props.color &&\r\n    css `\n      background: ${buildTableRowBackground(props)};\n      color: ${buildTableRowColor(props)};\n    `};\n`;\r\nconst SortButton = styled.button `\n  align-items: flex-end;\n  background: none;\n  border: 0;\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  margin: 0;\n  text-align: left;\n  width: 100%;\n  flex: 1 1 auto;\n\n  &:focus {\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n    outline-offset: -2px;\n  }\n\n  &:hover,\n  &:focus {\n    cursor: pointer;\n    svg {\n      fill: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n    }\n  }\n`;\r\nconst SortIconWrapper = styled.span `\n  position: relative;\n  top: ${props => props.theme.spaceScale.spacing01};\n`;\r\nexport const TableRow = React.forwardRef((props, ref) => {\r\n    const { children, headerRowStatus, isSelected, isSelectableDisabled, sortDirection, onHeaderRowSelect, onTableRowSelect, rowIndex, rowName, onSort, testId, ...other } = props;\r\n    const theme = React.useContext(ThemeContext);\r\n    const tableContext = React.useContext(TableContext);\r\n    const i18n = React.useContext(I18nContext);\r\n    let isHeaderRow = false;\r\n    React.Children.forEach(children, (child) => {\r\n        if (child.type.displayName === 'TableHeaderCell') {\r\n            isHeaderRow = true;\r\n            return;\r\n        }\r\n    });\r\n    function getIsCheckboxInverse() {\r\n        if (props.color && props.color === TableRowColor.warning) {\r\n            return false;\r\n        }\r\n        if (props.color && props.color !== TableRowColor.warning) {\r\n            return true;\r\n        }\r\n        return tableContext.isInverse;\r\n    }\r\n    const [isHovering, setIsHovering] = React.useState(false);\r\n    const handleMouseEnter = () => {\r\n        if (tableContext.isSortableBySelected)\r\n            setIsHovering(true);\r\n    };\r\n    const handleMouseLeave = () => {\r\n        if (tableContext.isSortableBySelected)\r\n            setIsHovering(false);\r\n    };\r\n    function handleSort() {\r\n        onSort && typeof onSort === 'function' && onSort();\r\n    }\r\n    const SortIcon = sortDirection === TableSortDirection.ascending ? (React.createElement(NorthIcon, { color: tableContext.isInverse\r\n            ? theme.colors.neutral100\r\n            : theme.colors.neutral700, size: theme.iconSizes.small, testId: \"sort-ascending\" })) : sortDirection === TableSortDirection.descending ? (React.createElement(SouthIcon, { color: tableContext.isInverse\r\n            ? theme.colors.neutral100\r\n            : theme.colors.neutral700, size: theme.iconSizes.small, testId: \"sort-descending\" })) : (React.createElement(SortDoubleArrowIcon, { color: tableContext.isInverse\r\n            ? transparentize(0.3, theme.colors.neutral100)\r\n            : theme.colors.neutral500, size: theme.iconSizes.small, testId: \"sort-none\" }));\r\n    return (React.createElement(StyledTableRow, Object.assign({}, other, { \"data-testid\": testId, hasHoverStyles: tableContext.hasHoverStyles && !isHeaderRow, hasSquareCorners: tableContext.hasSquareCorners, hasTablePagination: tableContext.hasTablePagination, hasZebraStripes: tableContext.hasZebraStripes, isInverse: tableContext.isInverse, ref: ref, theme: theme }),\r\n        tableContext.isSelectable && isHeaderRow && (React.createElement(TableHeaderCell, { width: theme.spaceScale.spacing05, style: {\r\n                background: isHovering\r\n                    ? transparentize(0.93, theme.colors.neutral900)\r\n                    : '',\r\n            } },\r\n            React.createElement(\"span\", { style: { display: 'flex', flexDirection: 'row' } },\r\n                React.createElement(IndeterminateCheckbox, { status: headerRowStatus, isInverse: getIsCheckboxInverse(), labelStyle: { padding: 0 }, labelText: headerRowStatus === IndeterminateCheckboxStatus.unchecked\r\n                        ? i18n.table.selectable.selectAllRowsAriaLabel\r\n                        : i18n.table.selectable.deselectAllRowsAriaLabel, isTextVisuallyHidden: true, onChange: onHeaderRowSelect }),\r\n                tableContext.isSortableBySelected && (React.createElement(SortButton, { density: tableContext.density, isInverse: tableContext.isInverse, onClick: handleSort, textAlign: TableCellAlign.left, theme: theme, onMouseEnter: handleMouseEnter, onMouseLeave: handleMouseLeave, \"data-testid\": `${testId || ''}-sort-button`, \"aria-label\": i18n.table.selectable.sortButtonAriaLabel },\r\n                    React.createElement(SortIconWrapper, { theme: theme }, SortIcon)))))),\r\n        tableContext.isSelectable && !isHeaderRow && (React.createElement(TableCell, { width: theme.spaceScale.spacing05, style: { verticalAlign: 'middle' } },\r\n            React.createElement(Checkbox, { checked: isSelected, disabled: isSelectableDisabled, labelStyle: { padding: 0 }, labelText: isSelected\r\n                    ? `${i18n.table.selectable.deselectRowAriaLabel} ${rowName || ''}`\r\n                    : `${i18n.table.selectable.selectRowAriaLabel} ${rowName || ''}`, isTextVisuallyHidden: true, isInverse: getIsCheckboxInverse(), onChange: onTableRowSelect }))),\r\n        children));\r\n});\r\n//# sourceMappingURL=TableRow.js.map"]} */"));
|
|
6931
7063
|
var SortIconWrapper = /*#__PURE__*/_styled("span", {
|
|
6932
7064
|
target: "e1b4326l0",
|
|
6933
7065
|
label: "SortIconWrapper"
|
|
6934
7066
|
})("position:relative;top:", function (props) {
|
|
6935
7067
|
return props.theme.spaceScale.spacing01;
|
|
6936
|
-
}, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["TableRow.tsx"],"names":[],"mappings":"AA2HoC","file":"TableRow.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport { NorthIcon, SortDoubleArrowIcon, SouthIcon } from 'react-magma-icons';\r\nimport { I18nContext } from '../../i18n';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { Checkbox } from '../Checkbox';\r\nimport { IndeterminateCheckbox, IndeterminateCheckboxStatus, } from '../IndeterminateCheckbox';\r\nimport { TableContext, TableRowColor, TableCell, TableHeaderCell, TableCellAlign, TableSortDirection, } from './';\r\nfunction buildTableRowBackground(props) {\r\n    if (props.isInverse) {\r\n        switch (props.color) {\r\n            case 'success':\r\n                return props.theme.colors.success200;\r\n            case 'warning':\r\n                return props.theme.colors.warning200;\r\n            case 'danger':\r\n                return props.theme.colors.danger200;\r\n            case 'info':\r\n                return props.theme.colors.info200;\r\n            default:\r\n                return 'inherit';\r\n        }\r\n    }\r\n    switch (props.color) {\r\n        case 'success':\r\n            return props.theme.colors.success;\r\n        case 'warning':\r\n            return props.theme.colors.warning;\r\n        case 'danger':\r\n            return props.theme.colors.danger;\r\n        case 'info':\r\n            return props.theme.colors.info;\r\n        default:\r\n            return 'inherit';\r\n    }\r\n}\r\nfunction buildTableRowColor(props) {\r\n    if (props.color && props.isInverse) {\r\n        return props.theme.colors.neutral700;\r\n    }\r\n    if (props.color && !props.isInverse) {\r\n        return props.theme.colors.neutral100;\r\n    }\r\n    return 'inherit';\r\n}\r\nconst StyledTableRow = styled.tr `\n  border-bottom: 1px solid\n    ${props => props.isInverse\r\n    ? transparentize(0.6, props.theme.colors.neutral100)\r\n    : props.theme.colors.neutral300};\n  color: inherit;\n  display: table-row;\n  outline: 0;\n  vertical-align: top;\n\n  &:last-child {\n    border-bottom: 0;\n    td:first-child {\n      border-radius: ${props => props.hasSquareCorners ? '0' : `0 0 0 ${props.theme.borderRadius}`};\n    }\n    td:last-child {\n      border-radius: ${props => props.hasSquareCorners ? '0' : `0 0 ${props.theme.borderRadius} 0`};\n    }\n  }\n\n  ${props => !props.color &&\r\n    css `\n      &:nth-of-type(even) {\n        background: ${props.hasZebraStripes\r\n        ? props.isInverse\r\n            ? transparentize(0.93, props.theme.colors.neutral100)\r\n            : props.theme.colors.neutral200\r\n        : 'none'};\n      }\n    `};\n\n  ${props => props.hasHoverStyles &&\r\n    !props.color &&\r\n    css `\n    &:hover {\n      background: ${props.isInverse\r\n        ? transparentize(0.85, props.theme.colors.neutral100)\r\n        : transparentize(0.93, props.theme.colors.neutral900)};\n    `}\n\n  ${props => props.color &&\r\n    css `\n      background: ${buildTableRowBackground(props)};\n      color: ${buildTableRowColor(props)};\n    `};\n`;\r\nconst SortButton = styled.button `\n  align-items: flex-end;\n  background: none;\n  border: 0;\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  margin: 0;\n  text-align: left;\n  width: 100%;\n  flex: 1 1 auto;\n\n  &:focus {\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n    outline-offset: -2px;\n  }\n\n  &:hover,\n  &:focus {\n    cursor: pointer;\n    svg {\n      fill: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n    }\n  }\n`;\r\nconst SortIconWrapper = styled.span `\n  position: relative;\n  top: ${props => props.theme.spaceScale.spacing01};\n`;\r\nexport const TableRow = React.forwardRef((props, ref) => {\r\n    const { children, headerRowStatus, isSelected, isSelectableDisabled, sortDirection, onHeaderRowSelect, onTableRowSelect, rowIndex, rowName, onSort, testId, ...other } = props;\r\n    const theme = React.useContext(ThemeContext);\r\n    const tableContext = React.useContext(TableContext);\r\n    const i18n = React.useContext(I18nContext);\r\n    let isHeaderRow = false;\r\n    React.Children.forEach(children, (child) => {\r\n        if (child.type.displayName === 'TableHeaderCell') {\r\n            isHeaderRow = true;\r\n            return;\r\n        }\r\n    });\r\n    function getIsCheckboxInverse() {\r\n        if (props.color && props.color === TableRowColor.warning) {\r\n            return false;\r\n        }\r\n        if (props.color && props.color !== TableRowColor.warning) {\r\n            return true;\r\n        }\r\n        return tableContext.isInverse;\r\n    }\r\n    const [isHovering, setIsHovering] = React.useState(false);\r\n    const handleMouseEnter = () => {\r\n        if (tableContext.isSortableBySelected)\r\n            setIsHovering(true);\r\n    };\r\n    const handleMouseLeave = () => {\r\n        if (tableContext.isSortableBySelected)\r\n            setIsHovering(false);\r\n    };\r\n    function handleSort() {\r\n        onSort && typeof onSort === 'function' && onSort();\r\n    }\r\n    const SortIcon = sortDirection === TableSortDirection.ascending ? (React.createElement(NorthIcon, { color: tableContext.isInverse\r\n            ? theme.colors.neutral100\r\n            : theme.colors.neutral700, size: theme.iconSizes.small, testId: \"sort-ascending\" })) : sortDirection === TableSortDirection.descending ? (React.createElement(SouthIcon, { color: tableContext.isInverse\r\n            ? theme.colors.neutral100\r\n            : theme.colors.neutral700, size: theme.iconSizes.small, testId: \"sort-descending\" })) : (React.createElement(SortDoubleArrowIcon, { color: tableContext.isInverse\r\n            ? transparentize(0.3, theme.colors.neutral100)\r\n            : theme.colors.neutral500, size: theme.iconSizes.small, testId: \"sort-none\" }));\r\n    return (React.createElement(StyledTableRow, Object.assign({}, other, { \"data-testid\": testId, hasSquareCorners: tableContext.hasSquareCorners, hasHoverStyles: tableContext.hasHoverStyles && !isHeaderRow, hasZebraStripes: tableContext.hasZebraStripes, isInverse: tableContext.isInverse, ref: ref, theme: theme }),\r\n        tableContext.isSelectable && isHeaderRow && (React.createElement(TableHeaderCell, { width: theme.spaceScale.spacing05, style: {\r\n                background: isHovering\r\n                    ? transparentize(0.93, theme.colors.neutral900)\r\n                    : '',\r\n            } },\r\n            React.createElement(\"span\", { style: { display: 'flex', flexDirection: 'row' } },\r\n                React.createElement(IndeterminateCheckbox, { status: headerRowStatus, isInverse: getIsCheckboxInverse(), labelStyle: { padding: 0 }, labelText: headerRowStatus === IndeterminateCheckboxStatus.unchecked\r\n                        ? i18n.table.selectable.selectAllRowsAriaLabel\r\n                        : i18n.table.selectable.deselectAllRowsAriaLabel, isTextVisuallyHidden: true, onChange: onHeaderRowSelect }),\r\n                tableContext.isSortableBySelected && (React.createElement(SortButton, { density: tableContext.density, isInverse: tableContext.isInverse, onClick: handleSort, textAlign: TableCellAlign.left, theme: theme, onMouseEnter: handleMouseEnter, onMouseLeave: handleMouseLeave, \"data-testid\": `${testId || ''}-sort-button`, \"aria-label\": i18n.table.selectable.sortButtonAriaLabel },\r\n                    React.createElement(SortIconWrapper, { theme: theme }, SortIcon)))))),\r\n        tableContext.isSelectable && !isHeaderRow && (React.createElement(TableCell, { width: theme.spaceScale.spacing05, style: { verticalAlign: 'middle' } },\r\n            React.createElement(Checkbox, { checked: isSelected, disabled: isSelectableDisabled, labelStyle: { padding: 0 }, labelText: isSelected\r\n                    ? `${i18n.table.selectable.deselectRowAriaLabel} ${rowName || ''}`\r\n                    : `${i18n.table.selectable.selectRowAriaLabel} ${rowName || ''}`, isTextVisuallyHidden: true, isInverse: getIsCheckboxInverse(), onChange: onTableRowSelect }))),\r\n        children));\r\n});\r\n//# sourceMappingURL=TableRow.js.map"]} */"));
|
|
7068
|
+
}, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["TableRow.tsx"],"names":[],"mappings":"AA8IoC","file":"TableRow.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport { NorthIcon, SortDoubleArrowIcon, SouthIcon } from 'react-magma-icons';\r\nimport { I18nContext } from '../../i18n';\r\nimport { magma } from '../../theme/magma';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { Checkbox } from '../Checkbox';\r\nimport { IndeterminateCheckbox, IndeterminateCheckboxStatus, } from '../IndeterminateCheckbox';\r\nimport { TableContext, TableRowColor, TableCell, TableHeaderCell, TableCellAlign, TableSortDirection, } from './';\r\nfunction buildTableRowBackground(props) {\r\n    if (props.isInverse) {\r\n        switch (props.color) {\r\n            case 'success':\r\n                return props.theme.colors.success200;\r\n            case 'warning':\r\n                return props.theme.colors.warning200;\r\n            case 'danger':\r\n                return props.theme.colors.danger200;\r\n            case 'info':\r\n                return props.theme.colors.info200;\r\n            default:\r\n                return 'inherit';\r\n        }\r\n    }\r\n    switch (props.color) {\r\n        case 'success':\r\n            return props.theme.colors.success;\r\n        case 'warning':\r\n            return props.theme.colors.warning;\r\n        case 'danger':\r\n            return props.theme.colors.danger;\r\n        case 'info':\r\n            return props.theme.colors.info;\r\n        default:\r\n            return 'inherit';\r\n    }\r\n}\r\nfunction buildTableRowColor(props) {\r\n    if (props.color && props.isInverse) {\r\n        return props.theme.colors.neutral700;\r\n    }\r\n    if (props.color && !props.isInverse) {\r\n        return props.theme.colors.neutral100;\r\n    }\r\n    return 'inherit';\r\n}\r\nfunction getBorderBottom(isInverse) {\r\n    return `1px solid ${isInverse\r\n        ? transparentize(0.6, magma.colors.neutral100)\r\n        : magma.colors.neutral300}`;\r\n}\r\nconst StyledTableRow = styled.tr `\n  border-bottom: ${props => getBorderBottom(props.isInverse)};\n  color: inherit;\n  display: table-row;\n  outline: 0;\n  vertical-align: top;\n\n  // Compensates border bottom for all rows (except last one) when table has outside border\n  td {\n    border-bottom: ${props => getBorderBottom(props.isInverse)};\n  }\n\n  &:last-child {\n    // Removes border bottom for last row if it's colored\n    border-bottom: ${props => props.color || (props.hasZebraStripes && !props.hasTablePagination)\r\n    ? 0\r\n    : `${getBorderBottom(props.isInverse)}`};\n\n    td {\n      border-bottom: 0;\n    }\n    td:first-child {\n      border-radius: ${props => props.hasSquareCorners || props.hasTablePagination\r\n    ? '0'\r\n    : `0 0 0 ${props.theme.borderRadius}`};\n    }\n    td:last-child {\n      border-radius: ${props => props.hasSquareCorners || props.hasTablePagination\r\n    ? '0'\r\n    : `0 0 ${props.theme.borderRadius} 0`};\n    }\n  }\n\n  ${props => !props.color &&\r\n    css `\n      &:nth-of-type(even) {\n        background: ${props.hasZebraStripes\r\n        ? props.isInverse\r\n            ? transparentize(0.93, props.theme.colors.neutral100)\r\n            : props.theme.colors.neutral200\r\n        : 'none'};\n      }\n    `};\n\n  ${props => props.hasHoverStyles &&\r\n    !props.color &&\r\n    css `\n    &:hover {\n      background: ${props.isInverse\r\n        ? transparentize(0.85, props.theme.colors.neutral100)\r\n        : transparentize(0.93, props.theme.colors.neutral900)};\n    `}\n\n  ${props => props.color &&\r\n    css `\n      background: ${buildTableRowBackground(props)};\n      color: ${buildTableRowColor(props)};\n    `};\n`;\r\nconst SortButton = styled.button `\n  align-items: flex-end;\n  background: none;\n  border: 0;\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  margin: 0;\n  text-align: left;\n  width: 100%;\n  flex: 1 1 auto;\n\n  &:focus {\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n    outline-offset: -2px;\n  }\n\n  &:hover,\n  &:focus {\n    cursor: pointer;\n    svg {\n      fill: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n    }\n  }\n`;\r\nconst SortIconWrapper = styled.span `\n  position: relative;\n  top: ${props => props.theme.spaceScale.spacing01};\n`;\r\nexport const TableRow = React.forwardRef((props, ref) => {\r\n    const { children, headerRowStatus, isSelected, isSelectableDisabled, sortDirection, onHeaderRowSelect, onTableRowSelect, rowIndex, rowName, onSort, testId, ...other } = props;\r\n    const theme = React.useContext(ThemeContext);\r\n    const tableContext = React.useContext(TableContext);\r\n    const i18n = React.useContext(I18nContext);\r\n    let isHeaderRow = false;\r\n    React.Children.forEach(children, (child) => {\r\n        if (child.type.displayName === 'TableHeaderCell') {\r\n            isHeaderRow = true;\r\n            return;\r\n        }\r\n    });\r\n    function getIsCheckboxInverse() {\r\n        if (props.color && props.color === TableRowColor.warning) {\r\n            return false;\r\n        }\r\n        if (props.color && props.color !== TableRowColor.warning) {\r\n            return true;\r\n        }\r\n        return tableContext.isInverse;\r\n    }\r\n    const [isHovering, setIsHovering] = React.useState(false);\r\n    const handleMouseEnter = () => {\r\n        if (tableContext.isSortableBySelected)\r\n            setIsHovering(true);\r\n    };\r\n    const handleMouseLeave = () => {\r\n        if (tableContext.isSortableBySelected)\r\n            setIsHovering(false);\r\n    };\r\n    function handleSort() {\r\n        onSort && typeof onSort === 'function' && onSort();\r\n    }\r\n    const SortIcon = sortDirection === TableSortDirection.ascending ? (React.createElement(NorthIcon, { color: tableContext.isInverse\r\n            ? theme.colors.neutral100\r\n            : theme.colors.neutral700, size: theme.iconSizes.small, testId: \"sort-ascending\" })) : sortDirection === TableSortDirection.descending ? (React.createElement(SouthIcon, { color: tableContext.isInverse\r\n            ? theme.colors.neutral100\r\n            : theme.colors.neutral700, size: theme.iconSizes.small, testId: \"sort-descending\" })) : (React.createElement(SortDoubleArrowIcon, { color: tableContext.isInverse\r\n            ? transparentize(0.3, theme.colors.neutral100)\r\n            : theme.colors.neutral500, size: theme.iconSizes.small, testId: \"sort-none\" }));\r\n    return (React.createElement(StyledTableRow, Object.assign({}, other, { \"data-testid\": testId, hasHoverStyles: tableContext.hasHoverStyles && !isHeaderRow, hasSquareCorners: tableContext.hasSquareCorners, hasTablePagination: tableContext.hasTablePagination, hasZebraStripes: tableContext.hasZebraStripes, isInverse: tableContext.isInverse, ref: ref, theme: theme }),\r\n        tableContext.isSelectable && isHeaderRow && (React.createElement(TableHeaderCell, { width: theme.spaceScale.spacing05, style: {\r\n                background: isHovering\r\n                    ? transparentize(0.93, theme.colors.neutral900)\r\n                    : '',\r\n            } },\r\n            React.createElement(\"span\", { style: { display: 'flex', flexDirection: 'row' } },\r\n                React.createElement(IndeterminateCheckbox, { status: headerRowStatus, isInverse: getIsCheckboxInverse(), labelStyle: { padding: 0 }, labelText: headerRowStatus === IndeterminateCheckboxStatus.unchecked\r\n                        ? i18n.table.selectable.selectAllRowsAriaLabel\r\n                        : i18n.table.selectable.deselectAllRowsAriaLabel, isTextVisuallyHidden: true, onChange: onHeaderRowSelect }),\r\n                tableContext.isSortableBySelected && (React.createElement(SortButton, { density: tableContext.density, isInverse: tableContext.isInverse, onClick: handleSort, textAlign: TableCellAlign.left, theme: theme, onMouseEnter: handleMouseEnter, onMouseLeave: handleMouseLeave, \"data-testid\": `${testId || ''}-sort-button`, \"aria-label\": i18n.table.selectable.sortButtonAriaLabel },\r\n                    React.createElement(SortIconWrapper, { theme: theme }, SortIcon)))))),\r\n        tableContext.isSelectable && !isHeaderRow && (React.createElement(TableCell, { width: theme.spaceScale.spacing05, style: { verticalAlign: 'middle' } },\r\n            React.createElement(Checkbox, { checked: isSelected, disabled: isSelectableDisabled, labelStyle: { padding: 0 }, labelText: isSelected\r\n                    ? `${i18n.table.selectable.deselectRowAriaLabel} ${rowName || ''}`\r\n                    : `${i18n.table.selectable.selectRowAriaLabel} ${rowName || ''}`, isTextVisuallyHidden: true, isInverse: getIsCheckboxInverse(), onChange: onTableRowSelect }))),\r\n        children));\r\n});\r\n//# sourceMappingURL=TableRow.js.map"]} */"));
|
|
6937
7069
|
var TableRow = /*#__PURE__*/forwardRef(function (props, ref) {
|
|
6938
7070
|
var children = props.children,
|
|
6939
7071
|
headerRowStatus = props.headerRowStatus,
|
|
@@ -6992,8 +7124,9 @@ var TableRow = /*#__PURE__*/forwardRef(function (props, ref) {
|
|
|
6992
7124
|
});
|
|
6993
7125
|
return createElement(StyledTableRow, Object.assign({}, other, {
|
|
6994
7126
|
"data-testid": testId,
|
|
6995
|
-
hasSquareCorners: tableContext.hasSquareCorners,
|
|
6996
7127
|
hasHoverStyles: tableContext.hasHoverStyles && !isHeaderRow,
|
|
7128
|
+
hasSquareCorners: tableContext.hasSquareCorners,
|
|
7129
|
+
hasTablePagination: tableContext.hasTablePagination,
|
|
6997
7130
|
hasZebraStripes: tableContext.hasZebraStripes,
|
|
6998
7131
|
isInverse: tableContext.isInverse,
|
|
6999
7132
|
ref: ref,
|
|
@@ -7056,7 +7189,7 @@ function defaultComponents$1(components) {
|
|
|
7056
7189
|
}, components);
|
|
7057
7190
|
}
|
|
7058
7191
|
|
|
7059
|
-
var _excluded$D = ["columns", "components", "componentsProps", "defaultSelectedRows", "onHeaderSelect", "onRowSelect", "onSelectedRowsChange", "paginationProps", "rows", "selectedRows", "hasPagination", "onSortBySelected", "sortDirection"],
|
|
7192
|
+
var _excluded$D = ["columns", "components", "componentsProps", "defaultSelectedRows", "onHeaderSelect", "onRowSelect", "onSelectedRowsChange", "paginationProps", "rows", "selectedRows", "hasSquareCorners", "hasOutsideBorder", "hasPagination", "onSortBySelected", "sortDirection"],
|
|
7060
7193
|
_excluded2$1 = ["defaultPage"],
|
|
7061
7194
|
_excluded3 = ["field", "header"],
|
|
7062
7195
|
_excluded4 = ["id", "color", "isSelectableDisabled"];
|
|
@@ -7074,6 +7207,8 @@ var Datagrid = /*#__PURE__*/forwardRef(function (props, ref) {
|
|
|
7074
7207
|
paginationProps = _props$paginationProp === void 0 ? {} : _props$paginationProp,
|
|
7075
7208
|
rows = props.rows,
|
|
7076
7209
|
selectedRowsProp = props.selectedRows,
|
|
7210
|
+
hasSquareCorners = props.hasSquareCorners,
|
|
7211
|
+
hasOutsideBorder = props.hasOutsideBorder,
|
|
7077
7212
|
_props$hasPagination = props.hasPagination,
|
|
7078
7213
|
hasPagination = _props$hasPagination === void 0 ? true : _props$hasPagination,
|
|
7079
7214
|
onSortBySelected = props.onSortBySelected,
|
|
@@ -7088,7 +7223,7 @@ var Datagrid = /*#__PURE__*/forwardRef(function (props, ref) {
|
|
|
7088
7223
|
}),
|
|
7089
7224
|
selectedRows = _useControlled[0],
|
|
7090
7225
|
updatedSelectedRows = _useControlled[1];
|
|
7091
|
-
var isControlled = selectedRowsProp
|
|
7226
|
+
var isControlled = !!selectedRowsProp;
|
|
7092
7227
|
var _useDataPagination = useDataPagination({
|
|
7093
7228
|
defaultItemsPerPage: paginationProps.defaultRowsPerPage,
|
|
7094
7229
|
items: rows,
|
|
@@ -7154,7 +7289,11 @@ var Datagrid = /*#__PURE__*/forwardRef(function (props, ref) {
|
|
|
7154
7289
|
function handleRowSort() {
|
|
7155
7290
|
onSortBySelected && typeof onSortBySelected === 'function' && onSortBySelected();
|
|
7156
7291
|
}
|
|
7157
|
-
return createElement(Fragment, null, createElement(Table, Object.assign({
|
|
7292
|
+
return createElement(Fragment, null, createElement(Table, Object.assign({
|
|
7293
|
+
hasOutsideBorder: hasOutsideBorder,
|
|
7294
|
+
hasSquareCorners: hasSquareCorners,
|
|
7295
|
+
hasTablePagination: hasPagination
|
|
7296
|
+
}, other, {
|
|
7158
7297
|
ref: ref,
|
|
7159
7298
|
"aria-live": "polite"
|
|
7160
7299
|
}), createElement(TableHead, null, createElement(TableRow, {
|
|
@@ -7196,7 +7335,9 @@ var Datagrid = /*#__PURE__*/forwardRef(function (props, ref) {
|
|
|
7196
7335
|
}));
|
|
7197
7336
|
}))), hasPagination && createElement(Pagination, Object.assign({
|
|
7198
7337
|
isInverse: props.isInverse,
|
|
7199
|
-
itemCount: rows.length
|
|
7338
|
+
itemCount: rows.length,
|
|
7339
|
+
hasOutsideBorder: hasOutsideBorder,
|
|
7340
|
+
hasSquareCorners: hasSquareCorners
|
|
7200
7341
|
}, passedOnPaginationProps, componentsProps.pagination)));
|
|
7201
7342
|
});
|
|
7202
7343
|
|
|
@@ -9723,7 +9864,7 @@ var TooltipContainer = /*#__PURE__*/_styled("div", {
|
|
|
9723
9864
|
styles: "display:inline;pointer-events:auto"
|
|
9724
9865
|
} : {
|
|
9725
9866
|
name: "18dvl03",
|
|
9726
|
-
styles: "display:inline;pointer-events:auto/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImluZGV4LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFjb0MiLCJmaWxlIjoiaW5kZXgudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0ICogYXMgUmVhY3QgZnJvbSAncmVhY3QnO1xyXG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XHJcbmltcG9ydCB7IG9mZnNldCwgZmxpcCwgYXV0b1VwZGF0ZSwgYXJyb3csIHNoaWZ0LCB1c2VGbG9hdGluZywgRmxvYXRpbmdBcnJvdywgfSBmcm9tICdAZmxvYXRpbmctdWkvcmVhY3QnO1xyXG5pbXBvcnQgeyB1c2VJc0ludmVyc2UgfSBmcm9tICcuLi8uLi9pbnZlcnNlJztcclxuaW1wb3J0IHsgVGhlbWVDb250ZXh0IH0gZnJvbSAnLi4vLi4vdGhlbWUvVGhlbWVDb250ZXh0JztcclxuaW1wb3J0IHsgdXNlRm9ya2VkUmVmLCB1c2VHZW5lcmF0ZUlkLCByZW1vdmVQeFN0eWxlU3RyaW5ncyB9IGZyb20gJy4uLy4uL3V0aWxzJztcclxuZXhwb3J0IHZhciBUb29sdGlwUG9zaXRpb247XHJcbihmdW5jdGlvbiAoVG9vbHRpcFBvc2l0aW9uKSB7XHJcbiAgICBUb29sdGlwUG9zaXRpb25bXCJib3R0b21cIl0gPSBcImJvdHRvbVwiO1xyXG4gICAgVG9vbHRpcFBvc2l0aW9uW1wibGVmdFwiXSA9IFwibGVmdFwiO1xyXG4gICAgVG9vbHRpcFBvc2l0aW9uW1wicmlnaHRcIl0gPSBcInJpZ2h0XCI7XHJcbiAgICBUb29sdGlwUG9zaXRpb25bXCJ0b3BcIl0gPSBcInRvcFwiO1xyXG59KShUb29sdGlwUG9zaXRpb24gfHwgKFRvb2x0aXBQb3NpdGlvbiA9IHt9KSk7XHJcbmV4cG9ydCBjb25zdCBFbnVtVG9vbHRpcFBvc2l0aW9uID0gVG9vbHRpcFBvc2l0aW9uO1xyXG5jb25zdCBUb29sdGlwQ29udGFpbmVyID0gc3R5bGVkLmRpdiBgXG4gIGRpc3BsYXk6IGlubGluZTtcbiAgcG9pbnRlci1ldmVudHM6IGF1dG87XG5gO1xyXG5leHBvcnQgY29uc3QgVG9vbHRpcEFycm93ID0gc3R5bGVkLnNwYW4gYFxuICAmJixcbiAgJiY6YmVmb3JlIHtcbiAgICBkaXNwbGF5OiBibG9jaztcbiAgICBoZWlnaHQ6ICR7cHJvcHMgPT4gcHJvcHMudGhlbWUudG9vbHRpcC5hcnJvd1NpemVEb3VibGVkfTtcbiAgICBwb3NpdGlvbjogYWJzb2x1dGU7XG4gICAgd2lkdGg6ICR7cHJvcHMgPT4gcHJvcHMudGhlbWUudG9vbHRpcC5hcnJvd1NpemVEb3VibGVkfTtcbiAgICB6LWluZGV4OiAtMTtcbiAgfVxuXG4gICYmOjpiZWZvcmUge1xuICAgIGNvbnRlbnQ6ICcnO1xuICAgIHRyYW5zZm9ybTogcm90YXRlKDQ1ZGVnKTtcbiAgICBiYWNrZ3JvdW5kOiAke3Byb3BzID0+IHByb3BzLmlzSW52ZXJzZVxyXG4gICAgPyBwcm9wcy50aGVtZS50b29sdGlwLmludmVyc2UuYmFja2dyb3VuZENvbG9yXHJcbiAgICA6IHByb3BzLnRoZW1lLnRvb2x0aXAuYmFja2dyb3VuZENvbG9yfTtcbiAgfVxuYDtcclxuZXhwb3J0IGNvbnN0IFN0eWxlZFRvb2x0aXAgPSBzdHlsZWQuZGl2IGBcbiAgYmFja2dyb3VuZDogJHtwcm9wcyA9PiBwcm9wcy5pc0ludmVyc2VcclxuICAgID8gcHJvcHMudGhlbWUudG9vbHRpcC5pbnZlcnNlLmJhY2tncm91bmRDb2xvclxyXG4gICAgOiBwcm9wcy50aGVtZS50b29sdGlwLmJhY2tncm91bmRDb2xvcn07XG4gIGJvcmRlci1yYWRpdXM6ICR7cHJvcHMgPT4gcHJvcHMudGhlbWUuYm9yZGVyUmFkaXVzfTtcbiAgY29sb3I6ICR7cHJvcHMgPT4gcHJvcHMuaXNJbnZlcnNlXHJcbiAgICA/IHByb3BzLnRoZW1lLnRvb2x0aXAuaW52ZXJzZS50ZXh0Q29sb3JcclxuICAgIDogcHJvcHMudGhlbWUudG9vbHRpcC50ZXh0Q29sb3J9O1xuICBmb250LXNpemU6ICR7cHJvcHMgPT4gcHJvcHMudGhlbWUudG9vbHRpcC50eXBlU2NhbGUuZm9udFNpemV9O1xuICBmb250LWZhbWlseTogJHtwcm9wcyA9PiBwcm9wcy50aGVtZS5ib2R5Rm9udH07XG4gIGxldHRlci1zcGFjaW5nOiAke3Byb3BzID0+IHByb3BzLnRoZW1lLnRvb2x0aXAudHlwZVNjYWxlLmxldHRlclNwYWNpbmd9O1xuICBsaW5lLWhlaWdodDogJHtwcm9wcyA9PiBwcm9wcy50aGVtZS50b29sdGlwLnR5cGVTY2FsZS5saW5lSGVpZ2h0fTtcbiAgZm9udC13ZWlnaHQ6ICR7cHJvcHMgPT4gcHJvcHMudGhlbWUudG9vbHRpcC5mb250V2VpZ2h0fTtcbiAgbWF4LXdpZHRoOiAke3Byb3BzID0+IHByb3BzLnRoZW1lLnRvb2x0aXAubWF4V2lkdGh9O1xuICBtaW4taGVpZ2h0OiAyLjVlbTtcbiAgcGFkZGluZzogJHtwcm9wcyA9PiBwcm9wcy50aGVtZS5zcGFjZVNjYWxlLnNwYWNpbmcwM31cbiAgICAke3Byb3BzID0+IHByb3BzLnRoZW1lLnNwYWNlU2NhbGUuc3BhY2luZzA0fTtcbiAgei1pbmRleDogJHtwcm9wcyA9PiBwcm9wcy50aGVtZS50b29sdGlwLnpJbmRleH07XG5gO1xyXG4vLyBVc2luZyBhbnkgZm9yIHRoZSByZWYgYmVjYXVzZSBpdCBpcyBwdXQgb24gdGhlIHBhc3NlZCBpbiBjaGlsZHJlbiB3aGljaCBkb2VzIG5vdCBoYXZlIGEgc3BlY2lmaWMgdHlwZVxyXG5leHBvcnQgY29uc3QgVG9vbHRpcCA9IFJlYWN0LmZvcndhcmRSZWYoKHByb3BzLCByZWYpID0+IHtcclxuICAgIGNvbnN0IFtpc1Zpc2libGUsIHNldElzVmlzaWJsZV0gPSBSZWFjdC51c2VTdGF0ZShwcm9wcy5vcGVuKTtcclxuICAgIGNvbnN0IGFycm93RWxlbWVudCA9IFJlYWN0LnVzZVJlZihudWxsKTtcclxuICAgIGNvbnN0IHsgYXJyb3dTdHlsZSwgY2hpbGRyZW4sIGNvbnRlbnQsIGNvbnRhaW5lclN0eWxlLCBpZDogZGVmYXVsdElkLCBwb3NpdGlvbiwgdGVzdElkLCB0b29sdGlwU3R5bGUsIC4uLm90aGVyIH0gPSBwcm9wcztcclxuICAgIGNvbnN0IGlzQXJyb3dWaXNpYmxlID0gUmVhY3QudXNlTWVtbygoKSA9PiB7XHJcbiAgICAgICAgaWYgKGFycm93RWxlbWVudC5jdXJyZW50KSB7XHJcbiAgICAgICAgICAgIGNvbnN0IGNvbXB1dGVkU3R5bGUgPSB3aW5kb3cuZ2V0Q29tcHV0ZWRTdHlsZShhcnJvd0VsZW1lbnQuY3VycmVudCk7XHJcbiAgICAgICAgICAgIGNvbnN0IGlzSGlkZGVuID0gY29tcHV0ZWRTdHlsZS5kaXNwbGF5ID09PSAnbm9uZScgfHxcclxuICAgICAgICAgICAgICAgIGNvbXB1dGVkU3R5bGUudmlzaWJpbGl0eSA9PT0gJ2hpZGRlbicgfHxcclxuICAgICAgICAgICAgICAgIHBhcnNlRmxvYXQoY29tcHV0ZWRTdHlsZS5vcGFjaXR5KSA9PT0gMDtcclxuICAgICAgICAgICAgcmV0dXJuICFpc0hpZGRlbjtcclxuICAgICAgICB9XHJcbiAgICB9LCBbYXJyb3dTdHlsZSwgYXJyb3dFbGVtZW50LCBhcnJvd0VsZW1lbnQuY3VycmVudF0pO1xyXG4gICAgY29uc3QgeyByZWZzLCBmbG9hdGluZ1N0eWxlcywgcGxhY2VtZW50LCBjb250ZXh0LCBlbGVtZW50cywgdXBkYXRlIH0gPSB1c2VGbG9hdGluZyh7XHJcbiAgICAgICAgLy9mbGlwKCkgLSBDaGFuZ2VzIHRoZSBwbGFjZW1lbnQgb2YgdGhlIGZsb2F0aW5nIGVsZW1lbnQgdG8ga2VlcCBpdCBpbiB2aWV3LlxyXG4gICAgICAgIC8vb2Zmc2V0KCkgLSBUcmFuc2xhdGVzIHRoZSBmbG9hdGluZyBlbGVtZW50IGFsb25nIHRoZSBzcGVjaWZpZWQgYXhlcy4gKFNwYWNlIGJldHdlZW4gdGhlIFRyaWdnZXIgYW5kIHRoZSBDb250ZW50KS5cclxuICAgICAgICAvL3NoaWZ0KCkgLSBTaGlmdHMgdGhlIGZsb2F0aW5nIGVsZW1lbnQgYWxvbmcgdGhlIHNwZWNpZmllZCBheGVzIHRvIGtlZXAgaXQgaW4gdmlldyB3aXRoaW4gdGhlIGNsaXBwaW5nIGNvbnRleHQgb3Igdmlld3BvcnQuXHJcbiAgICAgICAgLy9hcnJvdygpIC0gUG9zaXRpb25zIGFuIGFycm93IGVsZW1lbnQgcG9pbnRpbmcgYXQgdGhlIHJlZmVyZW5jZSBlbGVtZW50LCBlbnN1cmluZyBwcm9wZXIgYWxpZ25tZW50LlxyXG4gICAgICAgIG1pZGRsZXdhcmU6IFtcclxuICAgICAgICAgICAgZmxpcCgpLFxyXG4gICAgICAgICAgICBzaGlmdCgpLFxyXG4gICAgICAgICAgICBvZmZzZXQoaXNBcnJvd1Zpc2libGUgPyAxNCA6IDApLFxyXG4gICAgICAgICAgICAuLi4oaXNBcnJvd1Zpc2libGUgPyBbYXJyb3coeyBlbGVtZW50OiBhcnJvd0VsZW1lbnQgfSldIDogW10pLFxyXG4gICAgICAgIF0sXHJcbiAgICAgICAgcGxhY2VtZW50OiBwcm9wcy5wb3NpdGlvbiB8fCBUb29sdGlwUG9zaXRpb24udG9wLFxyXG4gICAgICAgIHdoaWxlRWxlbWVudHNNb3VudGVkOiBhdXRvVXBkYXRlLFxyXG4gICAgfSk7XHJcbiAgICBSZWFjdC51c2VFZmZlY3QoKCkgPT4ge1xyXG4gICAgICAgIGNvbnN0IHJlZmVyZW5jZUVsZW1lbnQgPSBlbGVtZW50cy5yZWZlcmVuY2U7XHJcbiAgICAgICAgY29uc3QgZmxvYXRpbmdUb29sdGlwQ29udGVudCA9IGVsZW1lbnRzLmZsb2F0aW5nO1xyXG4gICAgICAgIGlmIChpc1Zpc2libGUgJiYgcmVmZXJlbmNlRWxlbWVudCAmJiBmbG9hdGluZ1Rvb2x0aXBDb250ZW50KSB7XHJcbiAgICAgICAgICAgIHJldHVybiBhdXRvVXBkYXRlKHJlZmVyZW5jZUVsZW1lbnQsIGZsb2F0aW5nVG9vbHRpcENvbnRlbnQsIHVwZGF0ZSk7XHJcbiAgICAgICAgfVxyXG4gICAgfSwgW2lzVmlzaWJsZSwgZWxlbWVudHMsIHVwZGF0ZV0pO1xyXG4gICAgY29uc3QgY29tYmluZWRSZWYgPSB1c2VGb3JrZWRSZWYocmVmLCByZWZzLnNldFJlZmVyZW5jZSk7XHJcbiAgICBSZWFjdC51c2VFZmZlY3QoKCkgPT4ge1xyXG4gICAgICAgIGNvbnN0IGhhbmRsZUVzYyA9IGV2ZW50ID0+
|
|
9867
|
+
styles: "display:inline;pointer-events:auto/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAcoC","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport styled from '@emotion/styled';\r\nimport { offset, flip, autoUpdate, arrow, shift, useFloating, FloatingArrow, } from '@floating-ui/react';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { useForkedRef, useGenerateId, removePxStyleStrings } from '../../utils';\r\nexport var TooltipPosition;\r\n(function (TooltipPosition) {\r\n    TooltipPosition[\"bottom\"] = \"bottom\";\r\n    TooltipPosition[\"left\"] = \"left\";\r\n    TooltipPosition[\"right\"] = \"right\";\r\n    TooltipPosition[\"top\"] = \"top\";\r\n})(TooltipPosition || (TooltipPosition = {}));\r\nexport const EnumTooltipPosition = TooltipPosition;\r\nconst TooltipContainer = styled.div `\n  display: inline;\n  pointer-events: auto;\n`;\r\nexport const TooltipArrow = styled.span `\n  &&,\n  &&:before {\n    display: block;\n    height: ${props => props.theme.tooltip.arrowSizeDoubled};\n    position: absolute;\n    width: ${props => props.theme.tooltip.arrowSizeDoubled};\n    z-index: -1;\n  }\n\n  &&::before {\n    content: '';\n    transform: rotate(45deg);\n    background: ${props => props.isInverse\r\n    ? props.theme.tooltip.inverse.backgroundColor\r\n    : props.theme.tooltip.backgroundColor};\n  }\n`;\r\nexport const StyledTooltip = styled.div `\n  background: ${props => props.isInverse\r\n    ? props.theme.tooltip.inverse.backgroundColor\r\n    : props.theme.tooltip.backgroundColor};\n  border-radius: ${props => props.theme.borderRadius};\n  color: ${props => props.isInverse\r\n    ? props.theme.tooltip.inverse.textColor\r\n    : props.theme.tooltip.textColor};\n  font-size: ${props => props.theme.tooltip.typeScale.fontSize};\n  font-family: ${props => props.theme.bodyFont};\n  letter-spacing: ${props => props.theme.tooltip.typeScale.letterSpacing};\n  line-height: ${props => props.theme.tooltip.typeScale.lineHeight};\n  font-weight: ${props => props.theme.tooltip.fontWeight};\n  max-width: ${props => props.theme.tooltip.maxWidth};\n  min-height: 2.5em;\n  padding: ${props => props.theme.spaceScale.spacing03}\n    ${props => props.theme.spaceScale.spacing04};\n  z-index: ${props => props.theme.tooltip.zIndex};\n`;\r\n// Using any for the ref because it is put on the passed in children which does not have a specific type\r\nexport const Tooltip = React.forwardRef((props, ref) => {\r\n    const [isVisible, setIsVisible] = React.useState(props.open);\r\n    const arrowElement = React.useRef(null);\r\n    const { arrowStyle, children, content, containerStyle, id: defaultId, position, testId, tooltipStyle, ...other } = props;\r\n    const isArrowVisible = React.useMemo(() => {\r\n        if (arrowElement.current) {\r\n            const computedStyle = window.getComputedStyle(arrowElement.current);\r\n            const isHidden = computedStyle.display === 'none' ||\r\n                computedStyle.visibility === 'hidden' ||\r\n                parseFloat(computedStyle.opacity) === 0;\r\n            return !isHidden;\r\n        }\r\n    }, [arrowStyle, arrowElement, arrowElement.current]);\r\n    const { refs, floatingStyles, placement, context, elements, update } = useFloating({\r\n        //flip() - Changes the placement of the floating element to keep it in view.\r\n        //offset() - Translates the floating element along the specified axes. (Space between the Trigger and the Content).\r\n        //shift() - Shifts the floating element along the specified axes to keep it in view within the clipping context or viewport.\r\n        //arrow() - Positions an arrow element pointing at the reference element, ensuring proper alignment.\r\n        middleware: [\r\n            flip(),\r\n            shift(),\r\n            offset(isArrowVisible ? 14 : 0),\r\n            ...(isArrowVisible ? [arrow({ element: arrowElement })] : []),\r\n        ],\r\n        placement: props.position || TooltipPosition.top,\r\n        whileElementsMounted: autoUpdate,\r\n    });\r\n    React.useEffect(() => {\r\n        const referenceElement = elements.reference;\r\n        const floatingTooltipContent = elements.floating;\r\n        if (isVisible && referenceElement && floatingTooltipContent) {\r\n            return autoUpdate(referenceElement, floatingTooltipContent, update);\r\n        }\r\n    }, [isVisible, elements, update]);\r\n    const combinedRef = useForkedRef(ref, refs.setReference);\r\n    React.useEffect(() => {\r\n        const handleEsc = event => {\r\n            if (event.key === 'Escape') {\r\n                hideTooltip();\r\n            }\r\n        };\r\n        window.addEventListener('keydown', handleEsc);\r\n        return () => {\r\n            window.removeEventListener('keydown', handleEsc);\r\n        };\r\n    }, []);\r\n    function handleKeyDown(event) {\r\n        if (event.key === 'Escape') {\r\n            if (isVisible) {\r\n                event.stopPropagation();\r\n            }\r\n            hideTooltip();\r\n        }\r\n    }\r\n    function showTooltip() {\r\n        setIsVisible(true);\r\n    }\r\n    function hideTooltip() {\r\n        setIsVisible(props.open);\r\n    }\r\n    const id = useGenerateId(defaultId);\r\n    const theme = React.useContext(ThemeContext);\r\n    if (Array.isArray(children)) {\r\n        throw new Error('Tooltip children can only be one element.');\r\n    }\r\n    const tooltipTrigger = React.cloneElement(children, {\r\n        'aria-describedby': isVisible ? id : null,\r\n        onBlur: hideTooltip,\r\n        onFocus: showTooltip,\r\n        ref: combinedRef,\r\n    });\r\n    const combinedTooltipStyles = {\r\n        zIndex: theme.tooltip.zIndex,\r\n        ...floatingStyles,\r\n        ...tooltipStyle,\r\n    };\r\n    const isInverse = useIsInverse(props.isInverse);\r\n    return (React.createElement(TooltipContainer, Object.assign({}, other, { \"data-testid\": testId || 'tooltip', onKeyDown: handleKeyDown, onMouseLeave: hideTooltip, onMouseEnter: showTooltip, style: containerStyle }),\r\n        tooltipTrigger,\r\n        isVisible && (React.createElement(\"div\", { ref: refs.setFloating, style: combinedTooltipStyles },\r\n            React.createElement(FloatingArrow, { ref: arrowElement, \"data-testid\": testId ? `${testId}-arrow` : 'tooltip-arrow', context: context, style: { ...arrowStyle, zIndex: 2 }, width: removePxStyleStrings([theme.tooltip.arrowSizeDoubled]), height: removePxStyleStrings([theme.tooltip.arrowSizeDoubled]) / 2, fill: isInverse\r\n                    ? theme.tooltip.inverse.backgroundColor\r\n                    : theme.tooltip.backgroundColor }),\r\n            React.createElement(StyledTooltip, { id: id, isInverse: isInverse, position: placement ? placement : TooltipPosition.top, theme: theme, role: \"tooltip\", \"data-tooltip-placement\": placement ? placement : TooltipPosition.top }, content)))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */",
|
|
9727
9868
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$e
|
|
9728
9869
|
});
|
|
9729
9870
|
var TooltipArrow = /*#__PURE__*/_styled("span", {
|
|
@@ -9735,7 +9876,7 @@ var TooltipArrow = /*#__PURE__*/_styled("span", {
|
|
|
9735
9876
|
return props.theme.tooltip.arrowSizeDoubled;
|
|
9736
9877
|
}, ";z-index:-1;}&&::before{content:'';transform:rotate(45deg);background:", function (props) {
|
|
9737
9878
|
return props.isInverse ? props.theme.tooltip.inverse.backgroundColor : props.theme.tooltip.backgroundColor;
|
|
9738
|
-
}, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImluZGV4LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFrQndDIiwiZmlsZSI6ImluZGV4LnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCAqIGFzIFJlYWN0IGZyb20gJ3JlYWN0JztcclxuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xyXG5pbXBvcnQgeyBvZmZzZXQsIGZsaXAsIGF1dG9VcGRhdGUsIGFycm93LCBzaGlmdCwgdXNlRmxvYXRpbmcsIEZsb2F0aW5nQXJyb3csIH0gZnJvbSAnQGZsb2F0aW5nLXVpL3JlYWN0JztcclxuaW1wb3J0IHsgdXNlSXNJbnZlcnNlIH0gZnJvbSAnLi4vLi4vaW52ZXJzZSc7XHJcbmltcG9ydCB7IFRoZW1lQ29udGV4dCB9IGZyb20gJy4uLy4uL3RoZW1lL1RoZW1lQ29udGV4dCc7XHJcbmltcG9ydCB7IHVzZUZvcmtlZFJlZiwgdXNlR2VuZXJhdGVJZCwgcmVtb3ZlUHhTdHlsZVN0cmluZ3MgfSBmcm9tICcuLi8uLi91dGlscyc7XHJcbmV4cG9ydCB2YXIgVG9vbHRpcFBvc2l0aW9uO1xyXG4oZnVuY3Rpb24gKFRvb2x0aXBQb3NpdGlvbikge1xyXG4gICAgVG9vbHRpcFBvc2l0aW9uW1wiYm90dG9tXCJdID0gXCJib3R0b21cIjtcclxuICAgIFRvb2x0aXBQb3NpdGlvbltcImxlZnRcIl0gPSBcImxlZnRcIjtcclxuICAgIFRvb2x0aXBQb3NpdGlvbltcInJpZ2h0XCJdID0gXCJyaWdodFwiO1xyXG4gICAgVG9vbHRpcFBvc2l0aW9uW1widG9wXCJdID0gXCJ0b3BcIjtcclxufSkoVG9vbHRpcFBvc2l0aW9uIHx8IChUb29sdGlwUG9zaXRpb24gPSB7fSkpO1xyXG5leHBvcnQgY29uc3QgRW51bVRvb2x0aXBQb3NpdGlvbiA9IFRvb2x0aXBQb3NpdGlvbjtcclxuY29uc3QgVG9vbHRpcENvbnRhaW5lciA9IHN0eWxlZC5kaXYgYFxuICBkaXNwbGF5OiBpbmxpbmU7XG4gIHBvaW50ZXItZXZlbnRzOiBhdXRvO1xuYDtcclxuZXhwb3J0IGNvbnN0IFRvb2x0aXBBcnJvdyA9IHN0eWxlZC5zcGFuIGBcbiAgJiYsXG4gICYmOmJlZm9yZSB7XG4gICAgZGlzcGxheTogYmxvY2s7XG4gICAgaGVpZ2h0OiAke3Byb3BzID0+IHByb3BzLnRoZW1lLnRvb2x0aXAuYXJyb3dTaXplRG91YmxlZH07XG4gICAgcG9zaXRpb246IGFic29sdXRlO1xuICAgIHdpZHRoOiAke3Byb3BzID0+IHByb3BzLnRoZW1lLnRvb2x0aXAuYXJyb3dTaXplRG91YmxlZH07XG4gICAgei1pbmRleDogLTE7XG4gIH1cblxuICAmJjo6YmVmb3JlIHtcbiAgICBjb250ZW50OiAnJztcbiAgICB0cmFuc2Zvcm06IHJvdGF0ZSg0NWRlZyk7XG4gICAgYmFja2dyb3VuZDogJHtwcm9wcyA9PiBwcm9wcy5pc0ludmVyc2VcclxuICAgID8gcHJvcHMudGhlbWUudG9vbHRpcC5pbnZlcnNlLmJhY2tncm91bmRDb2xvclxyXG4gICAgOiBwcm9wcy50aGVtZS50b29sdGlwLmJhY2tncm91bmRDb2xvcn07XG4gIH1cbmA7XHJcbmV4cG9ydCBjb25zdCBTdHlsZWRUb29sdGlwID0gc3R5bGVkLmRpdiBgXG4gIGJhY2tncm91bmQ6ICR7cHJvcHMgPT4gcHJvcHMuaXNJbnZlcnNlXHJcbiAgICA/IHByb3BzLnRoZW1lLnRvb2x0aXAuaW52ZXJzZS5iYWNrZ3JvdW5kQ29sb3JcclxuICAgIDogcHJvcHMudGhlbWUudG9vbHRpcC5iYWNrZ3JvdW5kQ29sb3J9O1xuICBib3JkZXItcmFkaXVzOiAke3Byb3BzID0+IHByb3BzLnRoZW1lLmJvcmRlclJhZGl1c307XG4gIGNvbG9yOiAke3Byb3BzID0+IHByb3BzLmlzSW52ZXJzZVxyXG4gICAgPyBwcm9wcy50aGVtZS50b29sdGlwLmludmVyc2UudGV4dENvbG9yXHJcbiAgICA6IHByb3BzLnRoZW1lLnRvb2x0aXAudGV4dENvbG9yfTtcbiAgZm9udC1zaXplOiAke3Byb3BzID0+IHByb3BzLnRoZW1lLnRvb2x0aXAudHlwZVNjYWxlLmZvbnRTaXplfTtcbiAgZm9udC1mYW1pbHk6ICR7cHJvcHMgPT4gcHJvcHMudGhlbWUuYm9keUZvbnR9O1xuICBsZXR0ZXItc3BhY2luZzogJHtwcm9wcyA9PiBwcm9wcy50aGVtZS50b29sdGlwLnR5cGVTY2FsZS5sZXR0ZXJTcGFjaW5nfTtcbiAgbGluZS1oZWlnaHQ6ICR7cHJvcHMgPT4gcHJvcHMudGhlbWUudG9vbHRpcC50eXBlU2NhbGUubGluZUhlaWdodH07XG4gIGZvbnQtd2VpZ2h0OiAke3Byb3BzID0+IHByb3BzLnRoZW1lLnRvb2x0aXAuZm9udFdlaWdodH07XG4gIG1heC13aWR0aDogJHtwcm9wcyA9PiBwcm9wcy50aGVtZS50b29sdGlwLm1heFdpZHRofTtcbiAgbWluLWhlaWdodDogMi41ZW07XG4gIHBhZGRpbmc6ICR7cHJvcHMgPT4gcHJvcHMudGhlbWUuc3BhY2VTY2FsZS5zcGFjaW5nMDN9XG4gICAgJHtwcm9wcyA9PiBwcm9wcy50aGVtZS5zcGFjZVNjYWxlLnNwYWNpbmcwNH07XG4gIHotaW5kZXg6ICR7cHJvcHMgPT4gcHJvcHMudGhlbWUudG9vbHRpcC56SW5kZXh9O1xuYDtcclxuLy8gVXNpbmcgYW55IGZvciB0aGUgcmVmIGJlY2F1c2UgaXQgaXMgcHV0IG9uIHRoZSBwYXNzZWQgaW4gY2hpbGRyZW4gd2hpY2ggZG9lcyBub3QgaGF2ZSBhIHNwZWNpZmljIHR5cGVcclxuZXhwb3J0IGNvbnN0IFRvb2x0aXAgPSBSZWFjdC5mb3J3YXJkUmVmKChwcm9wcywgcmVmKSA9PiB7XHJcbiAgICBjb25zdCBbaXNWaXNpYmxlLCBzZXRJc1Zpc2libGVdID0gUmVhY3QudXNlU3RhdGUocHJvcHMub3Blbik7XHJcbiAgICBjb25zdCBhcnJvd0VsZW1lbnQgPSBSZWFjdC51c2VSZWYobnVsbCk7XHJcbiAgICBjb25zdCB7IGFycm93U3R5bGUsIGNoaWxkcmVuLCBjb250ZW50LCBjb250YWluZXJTdHlsZSwgaWQ6IGRlZmF1bHRJZCwgcG9zaXRpb24sIHRlc3RJZCwgdG9vbHRpcFN0eWxlLCAuLi5vdGhlciB9ID0gcHJvcHM7XHJcbiAgICBjb25zdCBpc0Fycm93VmlzaWJsZSA9IFJlYWN0LnVzZU1lbW8oKCkgPT4ge1xyXG4gICAgICAgIGlmIChhcnJvd0VsZW1lbnQuY3VycmVudCkge1xyXG4gICAgICAgICAgICBjb25zdCBjb21wdXRlZFN0eWxlID0gd2luZG93LmdldENvbXB1dGVkU3R5bGUoYXJyb3dFbGVtZW50LmN1cnJlbnQpO1xyXG4gICAgICAgICAgICBjb25zdCBpc0hpZGRlbiA9IGNvbXB1dGVkU3R5bGUuZGlzcGxheSA9PT0gJ25vbmUnIHx8XHJcbiAgICAgICAgICAgICAgICBjb21wdXRlZFN0eWxlLnZpc2liaWxpdHkgPT09ICdoaWRkZW4nIHx8XHJcbiAgICAgICAgICAgICAgICBwYXJzZUZsb2F0KGNvbXB1dGVkU3R5bGUub3BhY2l0eSkgPT09IDA7XHJcbiAgICAgICAgICAgIHJldHVybiAhaXNIaWRkZW47XHJcbiAgICAgICAgfVxyXG4gICAgfSwgW2Fycm93U3R5bGUsIGFycm93RWxlbWVudCwgYXJyb3dFbGVtZW50LmN1cnJlbnRdKTtcclxuICAgIGNvbnN0IHsgcmVmcywgZmxvYXRpbmdTdHlsZXMsIHBsYWNlbWVudCwgY29udGV4dCwgZWxlbWVudHMsIHVwZGF0ZSB9ID0gdXNlRmxvYXRpbmcoe1xyXG4gICAgICAgIC8vZmxpcCgpIC0gQ2hhbmdlcyB0aGUgcGxhY2VtZW50IG9mIHRoZSBmbG9hdGluZyBlbGVtZW50IHRvIGtlZXAgaXQgaW4gdmlldy5cclxuICAgICAgICAvL29mZnNldCgpIC0gVHJhbnNsYXRlcyB0aGUgZmxvYXRpbmcgZWxlbWVudCBhbG9uZyB0aGUgc3BlY2lmaWVkIGF4ZXMuIChTcGFjZSBiZXR3ZWVuIHRoZSBUcmlnZ2VyIGFuZCB0aGUgQ29udGVudCkuXHJcbiAgICAgICAgLy9zaGlmdCgpIC0gU2hpZnRzIHRoZSBmbG9hdGluZyBlbGVtZW50IGFsb25nIHRoZSBzcGVjaWZpZWQgYXhlcyB0byBrZWVwIGl0IGluIHZpZXcgd2l0aGluIHRoZSBjbGlwcGluZyBjb250ZXh0IG9yIHZpZXdwb3J0LlxyXG4gICAgICAgIC8vYXJyb3coKSAtIFBvc2l0aW9ucyBhbiBhcnJvdyBlbGVtZW50IHBvaW50aW5nIGF0IHRoZSByZWZlcmVuY2UgZWxlbWVudCwgZW5zdXJpbmcgcHJvcGVyIGFsaWdubWVudC5cclxuICAgICAgICBtaWRkbGV3YXJlOiBbXHJcbiAgICAgICAgICAgIGZsaXAoKSxcclxuICAgICAgICAgICAgc2hpZnQoKSxcclxuICAgICAgICAgICAgb2Zmc2V0KGlzQXJyb3dWaXNpYmxlID8gMTQgOiAwKSxcclxuICAgICAgICAgICAgLi4uKGlzQXJyb3dWaXNpYmxlID8gW2Fycm93KHsgZWxlbWVudDogYXJyb3dFbGVtZW50IH0pXSA6IFtdKSxcclxuICAgICAgICBdLFxyXG4gICAgICAgIHBsYWNlbWVudDogcHJvcHMucG9zaXRpb24gfHwgVG9vbHRpcFBvc2l0aW9uLnRvcCxcclxuICAgICAgICB3aGlsZUVsZW1lbnRzTW91bnRlZDogYXV0b1VwZGF0ZSxcclxuICAgIH0pO1xyXG4gICAgUmVhY3QudXNlRWZmZWN0KCgpID0+IHtcclxuICAgICAgICBjb25zdCByZWZlcmVuY2VFbGVtZW50ID0gZWxlbWVudHMucmVmZXJlbmNlO1xyXG4gICAgICAgIGNvbnN0IGZsb2F0aW5nVG9vbHRpcENvbnRlbnQgPSBlbGVtZW50cy5mbG9hdGluZztcclxuICAgICAgICBpZiAoaXNWaXNpYmxlICYmIHJlZmVyZW5jZUVsZW1lbnQgJiYgZmxvYXRpbmdUb29sdGlwQ29udGVudCkge1xyXG4gICAgICAgICAgICByZXR1cm4gYXV0b1VwZGF0ZShyZWZlcmVuY2VFbGVtZW50LCBmbG9hdGluZ1Rvb2x0aXBDb250ZW50LCB1cGRhdGUpO1xyXG4gICAgICAgIH1cclxuICAgIH0sIFtpc1Zpc2libGUsIGVsZW1lbnRzLCB1cGRhdGVdKTtcclxuICAgIGNvbnN0IGNvbWJpbmVkUmVmID0gdXNlRm9ya2VkUmVmKHJlZiwgcmVmcy5zZXRSZWZlcmVuY2UpO1xyXG4gICAgUmVhY3QudXNlRWZmZWN0KCgpID0+IHtcclxuICAgICAgICBjb25zdCBoYW5kbGVFc2MgPSBldmVudCA9PiB7XHJcbiAgICAgICAgICAgIGlmIChldmVudC5rZXkgPT09ICdFc2NhcGUnKSB7XHJcbiAgICAgICAgICAgICAgICBoaWRlVG9vbHRpcCgpO1xyXG4gICAgICAgICAgICB9XHJcbiAgICAgICAgfTtcclxuICAgICAgICB3aW5kb3cuYWRkRXZlbnRMaXN0ZW5lcigna2V5ZG93bicsIGhhbmRsZUVzYyk7XHJcbiAgICAgICAgcmV0dXJuICgpID0+
|
|
9879
|
+
}, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAkBwC","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport styled from '@emotion/styled';\r\nimport { offset, flip, autoUpdate, arrow, shift, useFloating, FloatingArrow, } from '@floating-ui/react';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { useForkedRef, useGenerateId, removePxStyleStrings } from '../../utils';\r\nexport var TooltipPosition;\r\n(function (TooltipPosition) {\r\n    TooltipPosition[\"bottom\"] = \"bottom\";\r\n    TooltipPosition[\"left\"] = \"left\";\r\n    TooltipPosition[\"right\"] = \"right\";\r\n    TooltipPosition[\"top\"] = \"top\";\r\n})(TooltipPosition || (TooltipPosition = {}));\r\nexport const EnumTooltipPosition = TooltipPosition;\r\nconst TooltipContainer = styled.div `\n  display: inline;\n  pointer-events: auto;\n`;\r\nexport const TooltipArrow = styled.span `\n  &&,\n  &&:before {\n    display: block;\n    height: ${props => props.theme.tooltip.arrowSizeDoubled};\n    position: absolute;\n    width: ${props => props.theme.tooltip.arrowSizeDoubled};\n    z-index: -1;\n  }\n\n  &&::before {\n    content: '';\n    transform: rotate(45deg);\n    background: ${props => props.isInverse\r\n    ? props.theme.tooltip.inverse.backgroundColor\r\n    : props.theme.tooltip.backgroundColor};\n  }\n`;\r\nexport const StyledTooltip = styled.div `\n  background: ${props => props.isInverse\r\n    ? props.theme.tooltip.inverse.backgroundColor\r\n    : props.theme.tooltip.backgroundColor};\n  border-radius: ${props => props.theme.borderRadius};\n  color: ${props => props.isInverse\r\n    ? props.theme.tooltip.inverse.textColor\r\n    : props.theme.tooltip.textColor};\n  font-size: ${props => props.theme.tooltip.typeScale.fontSize};\n  font-family: ${props => props.theme.bodyFont};\n  letter-spacing: ${props => props.theme.tooltip.typeScale.letterSpacing};\n  line-height: ${props => props.theme.tooltip.typeScale.lineHeight};\n  font-weight: ${props => props.theme.tooltip.fontWeight};\n  max-width: ${props => props.theme.tooltip.maxWidth};\n  min-height: 2.5em;\n  padding: ${props => props.theme.spaceScale.spacing03}\n    ${props => props.theme.spaceScale.spacing04};\n  z-index: ${props => props.theme.tooltip.zIndex};\n`;\r\n// Using any for the ref because it is put on the passed in children which does not have a specific type\r\nexport const Tooltip = React.forwardRef((props, ref) => {\r\n    const [isVisible, setIsVisible] = React.useState(props.open);\r\n    const arrowElement = React.useRef(null);\r\n    const { arrowStyle, children, content, containerStyle, id: defaultId, position, testId, tooltipStyle, ...other } = props;\r\n    const isArrowVisible = React.useMemo(() => {\r\n        if (arrowElement.current) {\r\n            const computedStyle = window.getComputedStyle(arrowElement.current);\r\n            const isHidden = computedStyle.display === 'none' ||\r\n                computedStyle.visibility === 'hidden' ||\r\n                parseFloat(computedStyle.opacity) === 0;\r\n            return !isHidden;\r\n        }\r\n    }, [arrowStyle, arrowElement, arrowElement.current]);\r\n    const { refs, floatingStyles, placement, context, elements, update } = useFloating({\r\n        //flip() - Changes the placement of the floating element to keep it in view.\r\n        //offset() - Translates the floating element along the specified axes. (Space between the Trigger and the Content).\r\n        //shift() - Shifts the floating element along the specified axes to keep it in view within the clipping context or viewport.\r\n        //arrow() - Positions an arrow element pointing at the reference element, ensuring proper alignment.\r\n        middleware: [\r\n            flip(),\r\n            shift(),\r\n            offset(isArrowVisible ? 14 : 0),\r\n            ...(isArrowVisible ? [arrow({ element: arrowElement })] : []),\r\n        ],\r\n        placement: props.position || TooltipPosition.top,\r\n        whileElementsMounted: autoUpdate,\r\n    });\r\n    React.useEffect(() => {\r\n        const referenceElement = elements.reference;\r\n        const floatingTooltipContent = elements.floating;\r\n        if (isVisible && referenceElement && floatingTooltipContent) {\r\n            return autoUpdate(referenceElement, floatingTooltipContent, update);\r\n        }\r\n    }, [isVisible, elements, update]);\r\n    const combinedRef = useForkedRef(ref, refs.setReference);\r\n    React.useEffect(() => {\r\n        const handleEsc = event => {\r\n            if (event.key === 'Escape') {\r\n                hideTooltip();\r\n            }\r\n        };\r\n        window.addEventListener('keydown', handleEsc);\r\n        return () => {\r\n            window.removeEventListener('keydown', handleEsc);\r\n        };\r\n    }, []);\r\n    function handleKeyDown(event) {\r\n        if (event.key === 'Escape') {\r\n            if (isVisible) {\r\n                event.stopPropagation();\r\n            }\r\n            hideTooltip();\r\n        }\r\n    }\r\n    function showTooltip() {\r\n        setIsVisible(true);\r\n    }\r\n    function hideTooltip() {\r\n        setIsVisible(props.open);\r\n    }\r\n    const id = useGenerateId(defaultId);\r\n    const theme = React.useContext(ThemeContext);\r\n    if (Array.isArray(children)) {\r\n        throw new Error('Tooltip children can only be one element.');\r\n    }\r\n    const tooltipTrigger = React.cloneElement(children, {\r\n        'aria-describedby': isVisible ? id : null,\r\n        onBlur: hideTooltip,\r\n        onFocus: showTooltip,\r\n        ref: combinedRef,\r\n    });\r\n    const combinedTooltipStyles = {\r\n        zIndex: theme.tooltip.zIndex,\r\n        ...floatingStyles,\r\n        ...tooltipStyle,\r\n    };\r\n    const isInverse = useIsInverse(props.isInverse);\r\n    return (React.createElement(TooltipContainer, Object.assign({}, other, { \"data-testid\": testId || 'tooltip', onKeyDown: handleKeyDown, onMouseLeave: hideTooltip, onMouseEnter: showTooltip, style: containerStyle }),\r\n        tooltipTrigger,\r\n        isVisible && (React.createElement(\"div\", { ref: refs.setFloating, style: combinedTooltipStyles },\r\n            React.createElement(FloatingArrow, { ref: arrowElement, \"data-testid\": testId ? `${testId}-arrow` : 'tooltip-arrow', context: context, style: { ...arrowStyle, zIndex: 2 }, width: removePxStyleStrings([theme.tooltip.arrowSizeDoubled]), height: removePxStyleStrings([theme.tooltip.arrowSizeDoubled]) / 2, fill: isInverse\r\n                    ? theme.tooltip.inverse.backgroundColor\r\n                    : theme.tooltip.backgroundColor }),\r\n            React.createElement(StyledTooltip, { id: id, isInverse: isInverse, position: placement ? placement : TooltipPosition.top, theme: theme, role: \"tooltip\", \"data-tooltip-placement\": placement ? placement : TooltipPosition.top }, content)))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */"));
|
|
9739
9880
|
var StyledTooltip = /*#__PURE__*/_styled("div", {
|
|
9740
9881
|
target: "elrt5sw0",
|
|
9741
9882
|
label: "StyledTooltip"
|
|
@@ -9763,7 +9904,7 @@ var StyledTooltip = /*#__PURE__*/_styled("div", {
|
|
|
9763
9904
|
return props.theme.spaceScale.spacing04;
|
|
9764
9905
|
}, ";z-index:", function (props) {
|
|
9765
9906
|
return props.theme.tooltip.zIndex;
|
|
9766
|
-
}, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImluZGV4LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFvQ3dDIiwiZmlsZSI6ImluZGV4LnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCAqIGFzIFJlYWN0IGZyb20gJ3JlYWN0JztcclxuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xyXG5pbXBvcnQgeyBvZmZzZXQsIGZsaXAsIGF1dG9VcGRhdGUsIGFycm93LCBzaGlmdCwgdXNlRmxvYXRpbmcsIEZsb2F0aW5nQXJyb3csIH0gZnJvbSAnQGZsb2F0aW5nLXVpL3JlYWN0JztcclxuaW1wb3J0IHsgdXNlSXNJbnZlcnNlIH0gZnJvbSAnLi4vLi4vaW52ZXJzZSc7XHJcbmltcG9ydCB7IFRoZW1lQ29udGV4dCB9IGZyb20gJy4uLy4uL3RoZW1lL1RoZW1lQ29udGV4dCc7XHJcbmltcG9ydCB7IHVzZUZvcmtlZFJlZiwgdXNlR2VuZXJhdGVJZCwgcmVtb3ZlUHhTdHlsZVN0cmluZ3MgfSBmcm9tICcuLi8uLi91dGlscyc7XHJcbmV4cG9ydCB2YXIgVG9vbHRpcFBvc2l0aW9uO1xyXG4oZnVuY3Rpb24gKFRvb2x0aXBQb3NpdGlvbikge1xyXG4gICAgVG9vbHRpcFBvc2l0aW9uW1wiYm90dG9tXCJdID0gXCJib3R0b21cIjtcclxuICAgIFRvb2x0aXBQb3NpdGlvbltcImxlZnRcIl0gPSBcImxlZnRcIjtcclxuICAgIFRvb2x0aXBQb3NpdGlvbltcInJpZ2h0XCJdID0gXCJyaWdodFwiO1xyXG4gICAgVG9vbHRpcFBvc2l0aW9uW1widG9wXCJdID0gXCJ0b3BcIjtcclxufSkoVG9vbHRpcFBvc2l0aW9uIHx8IChUb29sdGlwUG9zaXRpb24gPSB7fSkpO1xyXG5leHBvcnQgY29uc3QgRW51bVRvb2x0aXBQb3NpdGlvbiA9IFRvb2x0aXBQb3NpdGlvbjtcclxuY29uc3QgVG9vbHRpcENvbnRhaW5lciA9IHN0eWxlZC5kaXYgYFxuICBkaXNwbGF5OiBpbmxpbmU7XG4gIHBvaW50ZXItZXZlbnRzOiBhdXRvO1xuYDtcclxuZXhwb3J0IGNvbnN0IFRvb2x0aXBBcnJvdyA9IHN0eWxlZC5zcGFuIGBcbiAgJiYsXG4gICYmOmJlZm9yZSB7XG4gICAgZGlzcGxheTogYmxvY2s7XG4gICAgaGVpZ2h0OiAke3Byb3BzID0+IHByb3BzLnRoZW1lLnRvb2x0aXAuYXJyb3dTaXplRG91YmxlZH07XG4gICAgcG9zaXRpb246IGFic29sdXRlO1xuICAgIHdpZHRoOiAke3Byb3BzID0+IHByb3BzLnRoZW1lLnRvb2x0aXAuYXJyb3dTaXplRG91YmxlZH07XG4gICAgei1pbmRleDogLTE7XG4gIH1cblxuICAmJjo6YmVmb3JlIHtcbiAgICBjb250ZW50OiAnJztcbiAgICB0cmFuc2Zvcm06IHJvdGF0ZSg0NWRlZyk7XG4gICAgYmFja2dyb3VuZDogJHtwcm9wcyA9PiBwcm9wcy5pc0ludmVyc2VcclxuICAgID8gcHJvcHMudGhlbWUudG9vbHRpcC5pbnZlcnNlLmJhY2tncm91bmRDb2xvclxyXG4gICAgOiBwcm9wcy50aGVtZS50b29sdGlwLmJhY2tncm91bmRDb2xvcn07XG4gIH1cbmA7XHJcbmV4cG9ydCBjb25zdCBTdHlsZWRUb29sdGlwID0gc3R5bGVkLmRpdiBgXG4gIGJhY2tncm91bmQ6ICR7cHJvcHMgPT4gcHJvcHMuaXNJbnZlcnNlXHJcbiAgICA/IHByb3BzLnRoZW1lLnRvb2x0aXAuaW52ZXJzZS5iYWNrZ3JvdW5kQ29sb3JcclxuICAgIDogcHJvcHMudGhlbWUudG9vbHRpcC5iYWNrZ3JvdW5kQ29sb3J9O1xuICBib3JkZXItcmFkaXVzOiAke3Byb3BzID0+IHByb3BzLnRoZW1lLmJvcmRlclJhZGl1c307XG4gIGNvbG9yOiAke3Byb3BzID0+IHByb3BzLmlzSW52ZXJzZVxyXG4gICAgPyBwcm9wcy50aGVtZS50b29sdGlwLmludmVyc2UudGV4dENvbG9yXHJcbiAgICA6IHByb3BzLnRoZW1lLnRvb2x0aXAudGV4dENvbG9yfTtcbiAgZm9udC1zaXplOiAke3Byb3BzID0+IHByb3BzLnRoZW1lLnRvb2x0aXAudHlwZVNjYWxlLmZvbnRTaXplfTtcbiAgZm9udC1mYW1pbHk6ICR7cHJvcHMgPT4gcHJvcHMudGhlbWUuYm9keUZvbnR9O1xuICBsZXR0ZXItc3BhY2luZzogJHtwcm9wcyA9PiBwcm9wcy50aGVtZS50b29sdGlwLnR5cGVTY2FsZS5sZXR0ZXJTcGFjaW5nfTtcbiAgbGluZS1oZWlnaHQ6ICR7cHJvcHMgPT4gcHJvcHMudGhlbWUudG9vbHRpcC50eXBlU2NhbGUubGluZUhlaWdodH07XG4gIGZvbnQtd2VpZ2h0OiAke3Byb3BzID0+IHByb3BzLnRoZW1lLnRvb2x0aXAuZm9udFdlaWdodH07XG4gIG1heC13aWR0aDogJHtwcm9wcyA9PiBwcm9wcy50aGVtZS50b29sdGlwLm1heFdpZHRofTtcbiAgbWluLWhlaWdodDogMi41ZW07XG4gIHBhZGRpbmc6ICR7cHJvcHMgPT4gcHJvcHMudGhlbWUuc3BhY2VTY2FsZS5zcGFjaW5nMDN9XG4gICAgJHtwcm9wcyA9PiBwcm9wcy50aGVtZS5zcGFjZVNjYWxlLnNwYWNpbmcwNH07XG4gIHotaW5kZXg6ICR7cHJvcHMgPT4gcHJvcHMudGhlbWUudG9vbHRpcC56SW5kZXh9O1xuYDtcclxuLy8gVXNpbmcgYW55IGZvciB0aGUgcmVmIGJlY2F1c2UgaXQgaXMgcHV0IG9uIHRoZSBwYXNzZWQgaW4gY2hpbGRyZW4gd2hpY2ggZG9lcyBub3QgaGF2ZSBhIHNwZWNpZmljIHR5cGVcclxuZXhwb3J0IGNvbnN0IFRvb2x0aXAgPSBSZWFjdC5mb3J3YXJkUmVmKChwcm9wcywgcmVmKSA9PiB7XHJcbiAgICBjb25zdCBbaXNWaXNpYmxlLCBzZXRJc1Zpc2libGVdID0gUmVhY3QudXNlU3RhdGUocHJvcHMub3Blbik7XHJcbiAgICBjb25zdCBhcnJvd0VsZW1lbnQgPSBSZWFjdC51c2VSZWYobnVsbCk7XHJcbiAgICBjb25zdCB7IGFycm93U3R5bGUsIGNoaWxkcmVuLCBjb250ZW50LCBjb250YWluZXJTdHlsZSwgaWQ6IGRlZmF1bHRJZCwgcG9zaXRpb24sIHRlc3RJZCwgdG9vbHRpcFN0eWxlLCAuLi5vdGhlciB9ID0gcHJvcHM7XHJcbiAgICBjb25zdCBpc0Fycm93VmlzaWJsZSA9IFJlYWN0LnVzZU1lbW8oKCkgPT4ge1xyXG4gICAgICAgIGlmIChhcnJvd0VsZW1lbnQuY3VycmVudCkge1xyXG4gICAgICAgICAgICBjb25zdCBjb21wdXRlZFN0eWxlID0gd2luZG93LmdldENvbXB1dGVkU3R5bGUoYXJyb3dFbGVtZW50LmN1cnJlbnQpO1xyXG4gICAgICAgICAgICBjb25zdCBpc0hpZGRlbiA9IGNvbXB1dGVkU3R5bGUuZGlzcGxheSA9PT0gJ25vbmUnIHx8XHJcbiAgICAgICAgICAgICAgICBjb21wdXRlZFN0eWxlLnZpc2liaWxpdHkgPT09ICdoaWRkZW4nIHx8XHJcbiAgICAgICAgICAgICAgICBwYXJzZUZsb2F0KGNvbXB1dGVkU3R5bGUub3BhY2l0eSkgPT09IDA7XHJcbiAgICAgICAgICAgIHJldHVybiAhaXNIaWRkZW47XHJcbiAgICAgICAgfVxyXG4gICAgfSwgW2Fycm93U3R5bGUsIGFycm93RWxlbWVudCwgYXJyb3dFbGVtZW50LmN1cnJlbnRdKTtcclxuICAgIGNvbnN0IHsgcmVmcywgZmxvYXRpbmdTdHlsZXMsIHBsYWNlbWVudCwgY29udGV4dCwgZWxlbWVudHMsIHVwZGF0ZSB9ID0gdXNlRmxvYXRpbmcoe1xyXG4gICAgICAgIC8vZmxpcCgpIC0gQ2hhbmdlcyB0aGUgcGxhY2VtZW50IG9mIHRoZSBmbG9hdGluZyBlbGVtZW50IHRvIGtlZXAgaXQgaW4gdmlldy5cclxuICAgICAgICAvL29mZnNldCgpIC0gVHJhbnNsYXRlcyB0aGUgZmxvYXRpbmcgZWxlbWVudCBhbG9uZyB0aGUgc3BlY2lmaWVkIGF4ZXMuIChTcGFjZSBiZXR3ZWVuIHRoZSBUcmlnZ2VyIGFuZCB0aGUgQ29udGVudCkuXHJcbiAgICAgICAgLy9zaGlmdCgpIC0gU2hpZnRzIHRoZSBmbG9hdGluZyBlbGVtZW50IGFsb25nIHRoZSBzcGVjaWZpZWQgYXhlcyB0byBrZWVwIGl0IGluIHZpZXcgd2l0aGluIHRoZSBjbGlwcGluZyBjb250ZXh0IG9yIHZpZXdwb3J0LlxyXG4gICAgICAgIC8vYXJyb3coKSAtIFBvc2l0aW9ucyBhbiBhcnJvdyBlbGVtZW50IHBvaW50aW5nIGF0IHRoZSByZWZlcmVuY2UgZWxlbWVudCwgZW5zdXJpbmcgcHJvcGVyIGFsaWdubWVudC5cclxuICAgICAgICBtaWRkbGV3YXJlOiBbXHJcbiAgICAgICAgICAgIGZsaXAoKSxcclxuICAgICAgICAgICAgc2hpZnQoKSxcclxuICAgICAgICAgICAgb2Zmc2V0KGlzQXJyb3dWaXNpYmxlID8gMTQgOiAwKSxcclxuICAgICAgICAgICAgLi4uKGlzQXJyb3dWaXNpYmxlID8gW2Fycm93KHsgZWxlbWVudDogYXJyb3dFbGVtZW50IH0pXSA6IFtdKSxcclxuICAgICAgICBdLFxyXG4gICAgICAgIHBsYWNlbWVudDogcHJvcHMucG9zaXRpb24gfHwgVG9vbHRpcFBvc2l0aW9uLnRvcCxcclxuICAgICAgICB3aGlsZUVsZW1lbnRzTW91bnRlZDogYXV0b1VwZGF0ZSxcclxuICAgIH0pO1xyXG4gICAgUmVhY3QudXNlRWZmZWN0KCgpID0+IHtcclxuICAgICAgICBjb25zdCByZWZlcmVuY2VFbGVtZW50ID0gZWxlbWVudHMucmVmZXJlbmNlO1xyXG4gICAgICAgIGNvbnN0IGZsb2F0aW5nVG9vbHRpcENvbnRlbnQgPSBlbGVtZW50cy5mbG9hdGluZztcclxuICAgICAgICBpZiAoaXNWaXNpYmxlICYmIHJlZmVyZW5jZUVsZW1lbnQgJiYgZmxvYXRpbmdUb29sdGlwQ29udGVudCkge1xyXG4gICAgICAgICAgICByZXR1cm4gYXV0b1VwZGF0ZShyZWZlcmVuY2VFbGVtZW50LCBmbG9hdGluZ1Rvb2x0aXBDb250ZW50LCB1cGRhdGUpO1xyXG4gICAgICAgIH1cclxuICAgIH0sIFtpc1Zpc2libGUsIGVsZW1lbnRzLCB1cGRhdGVdKTtcclxuICAgIGNvbnN0IGNvbWJpbmVkUmVmID0gdXNlRm9ya2VkUmVmKHJlZiwgcmVmcy5zZXRSZWZlcmVuY2UpO1xyXG4gICAgUmVhY3QudXNlRWZmZWN0KCgpID0+IHtcclxuICAgICAgICBjb25zdCBoYW5kbGVFc2MgPSBldmVudCA9PiB7XHJcbiAgICAgICAgICAgIGlmIChldmVudC5rZXkgPT09ICdFc2NhcGUnKSB7XHJcbiAgICAgICAgICAgICAgICBoaWRlVG9vbHRpcCgpO1xyXG4gICAgICAgICAgICB9XHJcbiAgICAgICAgfTtcclxuICAgICAgICB3aW5kb3cuYWRkRXZlbnRMaXN0ZW5lcigna2V5ZG93bicsIGhhbmRsZUVzYyk7XHJcbiAgICAgICAgcmV0dXJuICgpID0+
|
|
9907
|
+
}, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAoCwC","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport styled from '@emotion/styled';\r\nimport { offset, flip, autoUpdate, arrow, shift, useFloating, FloatingArrow, } from '@floating-ui/react';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { useForkedRef, useGenerateId, removePxStyleStrings } from '../../utils';\r\nexport var TooltipPosition;\r\n(function (TooltipPosition) {\r\n    TooltipPosition[\"bottom\"] = \"bottom\";\r\n    TooltipPosition[\"left\"] = \"left\";\r\n    TooltipPosition[\"right\"] = \"right\";\r\n    TooltipPosition[\"top\"] = \"top\";\r\n})(TooltipPosition || (TooltipPosition = {}));\r\nexport const EnumTooltipPosition = TooltipPosition;\r\nconst TooltipContainer = styled.div `\n  display: inline;\n  pointer-events: auto;\n`;\r\nexport const TooltipArrow = styled.span `\n  &&,\n  &&:before {\n    display: block;\n    height: ${props => props.theme.tooltip.arrowSizeDoubled};\n    position: absolute;\n    width: ${props => props.theme.tooltip.arrowSizeDoubled};\n    z-index: -1;\n  }\n\n  &&::before {\n    content: '';\n    transform: rotate(45deg);\n    background: ${props => props.isInverse\r\n    ? props.theme.tooltip.inverse.backgroundColor\r\n    : props.theme.tooltip.backgroundColor};\n  }\n`;\r\nexport const StyledTooltip = styled.div `\n  background: ${props => props.isInverse\r\n    ? props.theme.tooltip.inverse.backgroundColor\r\n    : props.theme.tooltip.backgroundColor};\n  border-radius: ${props => props.theme.borderRadius};\n  color: ${props => props.isInverse\r\n    ? props.theme.tooltip.inverse.textColor\r\n    : props.theme.tooltip.textColor};\n  font-size: ${props => props.theme.tooltip.typeScale.fontSize};\n  font-family: ${props => props.theme.bodyFont};\n  letter-spacing: ${props => props.theme.tooltip.typeScale.letterSpacing};\n  line-height: ${props => props.theme.tooltip.typeScale.lineHeight};\n  font-weight: ${props => props.theme.tooltip.fontWeight};\n  max-width: ${props => props.theme.tooltip.maxWidth};\n  min-height: 2.5em;\n  padding: ${props => props.theme.spaceScale.spacing03}\n    ${props => props.theme.spaceScale.spacing04};\n  z-index: ${props => props.theme.tooltip.zIndex};\n`;\r\n// Using any for the ref because it is put on the passed in children which does not have a specific type\r\nexport const Tooltip = React.forwardRef((props, ref) => {\r\n    const [isVisible, setIsVisible] = React.useState(props.open);\r\n    const arrowElement = React.useRef(null);\r\n    const { arrowStyle, children, content, containerStyle, id: defaultId, position, testId, tooltipStyle, ...other } = props;\r\n    const isArrowVisible = React.useMemo(() => {\r\n        if (arrowElement.current) {\r\n            const computedStyle = window.getComputedStyle(arrowElement.current);\r\n            const isHidden = computedStyle.display === 'none' ||\r\n                computedStyle.visibility === 'hidden' ||\r\n                parseFloat(computedStyle.opacity) === 0;\r\n            return !isHidden;\r\n        }\r\n    }, [arrowStyle, arrowElement, arrowElement.current]);\r\n    const { refs, floatingStyles, placement, context, elements, update } = useFloating({\r\n        //flip() - Changes the placement of the floating element to keep it in view.\r\n        //offset() - Translates the floating element along the specified axes. (Space between the Trigger and the Content).\r\n        //shift() - Shifts the floating element along the specified axes to keep it in view within the clipping context or viewport.\r\n        //arrow() - Positions an arrow element pointing at the reference element, ensuring proper alignment.\r\n        middleware: [\r\n            flip(),\r\n            shift(),\r\n            offset(isArrowVisible ? 14 : 0),\r\n            ...(isArrowVisible ? [arrow({ element: arrowElement })] : []),\r\n        ],\r\n        placement: props.position || TooltipPosition.top,\r\n        whileElementsMounted: autoUpdate,\r\n    });\r\n    React.useEffect(() => {\r\n        const referenceElement = elements.reference;\r\n        const floatingTooltipContent = elements.floating;\r\n        if (isVisible && referenceElement && floatingTooltipContent) {\r\n            return autoUpdate(referenceElement, floatingTooltipContent, update);\r\n        }\r\n    }, [isVisible, elements, update]);\r\n    const combinedRef = useForkedRef(ref, refs.setReference);\r\n    React.useEffect(() => {\r\n        const handleEsc = event => {\r\n            if (event.key === 'Escape') {\r\n                hideTooltip();\r\n            }\r\n        };\r\n        window.addEventListener('keydown', handleEsc);\r\n        return () => {\r\n            window.removeEventListener('keydown', handleEsc);\r\n        };\r\n    }, []);\r\n    function handleKeyDown(event) {\r\n        if (event.key === 'Escape') {\r\n            if (isVisible) {\r\n                event.stopPropagation();\r\n            }\r\n            hideTooltip();\r\n        }\r\n    }\r\n    function showTooltip() {\r\n        setIsVisible(true);\r\n    }\r\n    function hideTooltip() {\r\n        setIsVisible(props.open);\r\n    }\r\n    const id = useGenerateId(defaultId);\r\n    const theme = React.useContext(ThemeContext);\r\n    if (Array.isArray(children)) {\r\n        throw new Error('Tooltip children can only be one element.');\r\n    }\r\n    const tooltipTrigger = React.cloneElement(children, {\r\n        'aria-describedby': isVisible ? id : null,\r\n        onBlur: hideTooltip,\r\n        onFocus: showTooltip,\r\n        ref: combinedRef,\r\n    });\r\n    const combinedTooltipStyles = {\r\n        zIndex: theme.tooltip.zIndex,\r\n        ...floatingStyles,\r\n        ...tooltipStyle,\r\n    };\r\n    const isInverse = useIsInverse(props.isInverse);\r\n    return (React.createElement(TooltipContainer, Object.assign({}, other, { \"data-testid\": testId || 'tooltip', onKeyDown: handleKeyDown, onMouseLeave: hideTooltip, onMouseEnter: showTooltip, style: containerStyle }),\r\n        tooltipTrigger,\r\n        isVisible && (React.createElement(\"div\", { ref: refs.setFloating, style: combinedTooltipStyles },\r\n            React.createElement(FloatingArrow, { ref: arrowElement, \"data-testid\": testId ? `${testId}-arrow` : 'tooltip-arrow', context: context, style: { ...arrowStyle, zIndex: 2 }, width: removePxStyleStrings([theme.tooltip.arrowSizeDoubled]), height: removePxStyleStrings([theme.tooltip.arrowSizeDoubled]) / 2, fill: isInverse\r\n                    ? theme.tooltip.inverse.backgroundColor\r\n                    : theme.tooltip.backgroundColor }),\r\n            React.createElement(StyledTooltip, { id: id, isInverse: isInverse, position: placement ? placement : TooltipPosition.top, theme: theme, role: \"tooltip\", \"data-tooltip-placement\": placement ? placement : TooltipPosition.top }, content)))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */"));
|
|
9767
9908
|
// Using any for the ref because it is put on the passed in children which does not have a specific type
|
|
9768
9909
|
var Tooltip = /*#__PURE__*/forwardRef(function (props, ref) {
|
|
9769
9910
|
var _React$useState = useState(props.open),
|
|
@@ -9823,6 +9964,9 @@ var Tooltip = /*#__PURE__*/forwardRef(function (props, ref) {
|
|
|
9823
9964
|
}, []);
|
|
9824
9965
|
function handleKeyDown(event) {
|
|
9825
9966
|
if (event.key === 'Escape') {
|
|
9967
|
+
if (isVisible) {
|
|
9968
|
+
event.stopPropagation();
|
|
9969
|
+
}
|
|
9826
9970
|
hideTooltip();
|
|
9827
9971
|
}
|
|
9828
9972
|
}
|
|
@@ -11630,54 +11774,6 @@ var DropdownMenuItem = /*#__PURE__*/forwardRef(function (props, forwardedRef) {
|
|
|
11630
11774
|
});
|
|
11631
11775
|
DropdownMenuItem.displayName = 'DropdownMenuItem';
|
|
11632
11776
|
|
|
11633
|
-
var useDeviceDetect = function useDeviceDetect() {
|
|
11634
|
-
var userAgent = useMemo(function () {
|
|
11635
|
-
return navigator.userAgent.toLowerCase();
|
|
11636
|
-
}, []);
|
|
11637
|
-
var isSafari = useMemo(function () {
|
|
11638
|
-
return /^((?!chrome|android).)*safari/i.test(userAgent);
|
|
11639
|
-
}, [userAgent]);
|
|
11640
|
-
var isChrome = useMemo(function () {
|
|
11641
|
-
return /chrome|crios/i.test(userAgent) && !/edge|edg/i.test(userAgent);
|
|
11642
|
-
}, [userAgent]);
|
|
11643
|
-
var isFirefox = useMemo(function () {
|
|
11644
|
-
return /firefox|fxios/i.test(userAgent);
|
|
11645
|
-
}, [userAgent]);
|
|
11646
|
-
var isEdge = useMemo(function () {
|
|
11647
|
-
return /edge|edg/i.test(userAgent);
|
|
11648
|
-
}, [userAgent]);
|
|
11649
|
-
var isMobile = useMemo(function () {
|
|
11650
|
-
return /mobi|android|touch|mini/i.test(userAgent);
|
|
11651
|
-
}, [userAgent]);
|
|
11652
|
-
var isWindows = useMemo(function () {
|
|
11653
|
-
return /windows nt/.test(userAgent);
|
|
11654
|
-
}, [userAgent]);
|
|
11655
|
-
var isMacOS = useMemo(function () {
|
|
11656
|
-
return /macintosh/.test(userAgent);
|
|
11657
|
-
}, [userAgent]);
|
|
11658
|
-
var isAndroid = useMemo(function () {
|
|
11659
|
-
return /android/.test(userAgent);
|
|
11660
|
-
}, [userAgent]);
|
|
11661
|
-
var isIOS = useMemo(function () {
|
|
11662
|
-
return /iphone|ipad|ipod/.test(userAgent);
|
|
11663
|
-
}, [userAgent]);
|
|
11664
|
-
var isLinux = useMemo(function () {
|
|
11665
|
-
return /linux/.test(userAgent) && !isAndroid;
|
|
11666
|
-
}, [userAgent, isAndroid]);
|
|
11667
|
-
return {
|
|
11668
|
-
isSafari: isSafari,
|
|
11669
|
-
isChrome: isChrome,
|
|
11670
|
-
isFirefox: isFirefox,
|
|
11671
|
-
isEdge: isEdge,
|
|
11672
|
-
isMobile: isMobile,
|
|
11673
|
-
isWindows: isWindows,
|
|
11674
|
-
isMacOS: isMacOS,
|
|
11675
|
-
isLinux: isLinux,
|
|
11676
|
-
isAndroid: isAndroid,
|
|
11677
|
-
isIOS: isIOS
|
|
11678
|
-
};
|
|
11679
|
-
};
|
|
11680
|
-
|
|
11681
11777
|
var _excluded$O = ["children", "icon", "to"];
|
|
11682
11778
|
var StyledItem$3 = /*#__PURE__*/_styled("a", {
|
|
11683
11779
|
target: "e1b21r9q0",
|
|
@@ -12086,6 +12182,142 @@ function useAccordionButton(props, forwardedRef) {
|
|
|
12086
12182
|
};
|
|
12087
12183
|
}
|
|
12088
12184
|
|
|
12185
|
+
var drawerTransitions = {
|
|
12186
|
+
fade: {
|
|
12187
|
+
motion: {
|
|
12188
|
+
exit: {
|
|
12189
|
+
opacity: 0,
|
|
12190
|
+
transition: {
|
|
12191
|
+
opacity: {
|
|
12192
|
+
duration: 0.25,
|
|
12193
|
+
ease: 'easeOut'
|
|
12194
|
+
}
|
|
12195
|
+
}
|
|
12196
|
+
},
|
|
12197
|
+
enter: {
|
|
12198
|
+
opacity: 1,
|
|
12199
|
+
transition: {
|
|
12200
|
+
duration: 0.25,
|
|
12201
|
+
ease: 'easeIn'
|
|
12202
|
+
}
|
|
12203
|
+
}
|
|
12204
|
+
},
|
|
12205
|
+
baseStyle: {}
|
|
12206
|
+
},
|
|
12207
|
+
slideTop: {
|
|
12208
|
+
motion: {
|
|
12209
|
+
exit: {
|
|
12210
|
+
y: '-100%',
|
|
12211
|
+
transition: {
|
|
12212
|
+
y: {
|
|
12213
|
+
duration: 0.25,
|
|
12214
|
+
ease: [0.4, 0, 0.2, 1]
|
|
12215
|
+
}
|
|
12216
|
+
}
|
|
12217
|
+
},
|
|
12218
|
+
enter: {
|
|
12219
|
+
y: '0',
|
|
12220
|
+
transition: {
|
|
12221
|
+
y: {
|
|
12222
|
+
duration: 0.25,
|
|
12223
|
+
ease: [0.4, 0, 0.2, 1]
|
|
12224
|
+
}
|
|
12225
|
+
}
|
|
12226
|
+
}
|
|
12227
|
+
},
|
|
12228
|
+
baseStyle: {
|
|
12229
|
+
position: 'fixed',
|
|
12230
|
+
top: 0,
|
|
12231
|
+
right: 0,
|
|
12232
|
+
left: 0
|
|
12233
|
+
}
|
|
12234
|
+
},
|
|
12235
|
+
slideBottom: {
|
|
12236
|
+
motion: {
|
|
12237
|
+
exit: {
|
|
12238
|
+
y: '100%',
|
|
12239
|
+
transition: {
|
|
12240
|
+
y: {
|
|
12241
|
+
duration: 0.25,
|
|
12242
|
+
ease: [0.4, 0, 0.2, 1]
|
|
12243
|
+
}
|
|
12244
|
+
}
|
|
12245
|
+
},
|
|
12246
|
+
enter: {
|
|
12247
|
+
y: '0',
|
|
12248
|
+
transition: {
|
|
12249
|
+
y: {
|
|
12250
|
+
duration: 0.25,
|
|
12251
|
+
ease: [0.4, 0, 0.2, 1]
|
|
12252
|
+
}
|
|
12253
|
+
}
|
|
12254
|
+
}
|
|
12255
|
+
},
|
|
12256
|
+
baseStyle: {
|
|
12257
|
+
position: 'fixed',
|
|
12258
|
+
bottom: 0,
|
|
12259
|
+
right: 0,
|
|
12260
|
+
left: 0
|
|
12261
|
+
}
|
|
12262
|
+
},
|
|
12263
|
+
slideRight: {
|
|
12264
|
+
motion: {
|
|
12265
|
+
exit: {
|
|
12266
|
+
x: '100%',
|
|
12267
|
+
transition: {
|
|
12268
|
+
x: {
|
|
12269
|
+
duration: 0.25,
|
|
12270
|
+
ease: [0.4, 0, 0.2, 1]
|
|
12271
|
+
}
|
|
12272
|
+
}
|
|
12273
|
+
},
|
|
12274
|
+
enter: {
|
|
12275
|
+
x: '0',
|
|
12276
|
+
transition: {
|
|
12277
|
+
x: {
|
|
12278
|
+
duration: 0.25,
|
|
12279
|
+
ease: [0.4, 0, 0.2, 1]
|
|
12280
|
+
}
|
|
12281
|
+
}
|
|
12282
|
+
}
|
|
12283
|
+
},
|
|
12284
|
+
baseStyle: {
|
|
12285
|
+
position: 'fixed',
|
|
12286
|
+
top: 0,
|
|
12287
|
+
right: 0,
|
|
12288
|
+
bottom: 0
|
|
12289
|
+
}
|
|
12290
|
+
},
|
|
12291
|
+
slideLeft: {
|
|
12292
|
+
motion: {
|
|
12293
|
+
exit: {
|
|
12294
|
+
x: '-100%',
|
|
12295
|
+
transition: {
|
|
12296
|
+
x: {
|
|
12297
|
+
duration: 0.25,
|
|
12298
|
+
ease: [0.4, 0, 0.2, 1]
|
|
12299
|
+
}
|
|
12300
|
+
}
|
|
12301
|
+
},
|
|
12302
|
+
enter: {
|
|
12303
|
+
x: '0',
|
|
12304
|
+
transition: {
|
|
12305
|
+
x: {
|
|
12306
|
+
duration: 0.25,
|
|
12307
|
+
ease: [0.4, 0, 0.2, 1]
|
|
12308
|
+
}
|
|
12309
|
+
}
|
|
12310
|
+
}
|
|
12311
|
+
},
|
|
12312
|
+
baseStyle: {
|
|
12313
|
+
position: 'fixed',
|
|
12314
|
+
top: 0,
|
|
12315
|
+
bottom: 0,
|
|
12316
|
+
left: 0
|
|
12317
|
+
}
|
|
12318
|
+
}
|
|
12319
|
+
};
|
|
12320
|
+
|
|
12089
12321
|
var reducedMotionTransitions = {
|
|
12090
12322
|
fade: {
|
|
12091
12323
|
motion: {
|
|
@@ -12429,11 +12661,12 @@ var reducedMotionTransitions = {
|
|
|
12429
12661
|
}
|
|
12430
12662
|
};
|
|
12431
12663
|
|
|
12432
|
-
var _excluded$T = ["style", "unmountOnExit", "isOpen", "testId", "initial", "exit", "customTransition"];
|
|
12664
|
+
var _excluded$T = ["style", "unmountOnExit", "hasDrawerAnimation", "isOpen", "testId", "initial", "exit", "customTransition"];
|
|
12433
12665
|
var Transition = /*#__PURE__*/forwardRef(function (props, ref) {
|
|
12434
12666
|
var theme = useContext(ThemeContext);
|
|
12435
12667
|
var style = props.style,
|
|
12436
12668
|
unmountOnExit = props.unmountOnExit,
|
|
12669
|
+
hasDrawerAnimation = props.hasDrawerAnimation,
|
|
12437
12670
|
isOpen = props.isOpen,
|
|
12438
12671
|
testId = props.testId,
|
|
12439
12672
|
_props$initial = props.initial,
|
|
@@ -12452,7 +12685,7 @@ var Transition = /*#__PURE__*/forwardRef(function (props, ref) {
|
|
|
12452
12685
|
rest = _objectWithoutPropertiesLoose(props, _excluded$T);
|
|
12453
12686
|
var shouldExpand = unmountOnExit ? isOpen && unmountOnExit : true;
|
|
12454
12687
|
var shouldReduceMotion = useReducedMotion();
|
|
12455
|
-
var transitionsArr = shouldReduceMotion ? reducedMotionTransitions : theme.transitions;
|
|
12688
|
+
var transitionsArr = shouldReduceMotion ? reducedMotionTransitions : hasDrawerAnimation ? drawerTransitions : theme.transitions;
|
|
12456
12689
|
var variants = Object.keys(rest).reduce(function (acc, key) {
|
|
12457
12690
|
if (rest[key] && transitionsArr[key]) {
|
|
12458
12691
|
var themeVariant = transitionsArr[key];
|
|
@@ -14981,7 +15214,7 @@ var Radio = /*#__PURE__*/forwardRef(function (props, ref) {
|
|
|
14981
15214
|
})), isTextVisuallyHidden ? createElement(HiddenLabelText$1, null, labelText) : textPosition !== RadioTextPosition.left && labelText && labelText));
|
|
14982
15215
|
});
|
|
14983
15216
|
|
|
14984
|
-
var _excluded$1i = ["ariaLabel", "children", "closeAriaLabel", "closeButtonSize", "containerStyle", "containerTransition", "isBackgroundClickDisabled", "isEscKeyDownDisabled", "header", "isCloseButtonHidden", "isOpen", "unmountOnExit", "testId", "isModalClosingControlledManually", "headerRef", "onClose", "showBackgroundOverlay"];
|
|
15217
|
+
var _excluded$1i = ["ariaLabel", "children", "closeAriaLabel", "closeButtonSize", "containerStyle", "containerTransition", "isBackgroundClickDisabled", "isEscKeyDownDisabled", "header", "isCloseButtonHidden", "isOpen", "unmountOnExit", "testId", "isModalClosingControlledManually", "headerRef", "onClose", "hasDrawerAnimation", "showBackgroundOverlay"];
|
|
14985
15218
|
var ModalSize;
|
|
14986
15219
|
(function (ModalSize) {
|
|
14987
15220
|
ModalSize["large"] = "large";
|
|
@@ -14991,17 +15224,17 @@ var ModalSize;
|
|
|
14991
15224
|
var ModalContainer = /*#__PURE__*/_styled(Transition, {
|
|
14992
15225
|
target: "e1pxemtw6",
|
|
14993
15226
|
label: "ModalContainer"
|
|
14994
|
-
})("bottom:0;left:0;overflow-y:auto;padding:", function (props) {
|
|
15227
|
+
})("position:fixed;bottom:0;left:0;overflow-y:auto;padding:", function (props) {
|
|
14995
15228
|
return props.theme.spaceScale.spacing03;
|
|
14996
15229
|
}, ";right:0;top:0;z-index:", function (props) {
|
|
14997
15230
|
return props.modalCount >= 2 ? '999' : '998';
|
|
14998
|
-
}, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Modal.tsx"],"names":[],"mappings":"AAuB0C","file":"Modal.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css, Global } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport ReactDOM from 'react-dom';\r\nimport { CloseIcon } from 'react-magma-icons';\r\nimport { useFocusLock } from '../../hooks/useFocusLock';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { magma } from '../../theme/magma';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { omit, useGenerateId, usePrevious } from '../../utils';\r\nimport { ButtonColor, ButtonVariant } from '../Button';\r\nimport { Heading } from '../Heading';\r\nimport { IconButton } from '../IconButton';\r\nimport { Transition } from '../Transition';\r\nimport { TypographyVisualStyle } from '../Typography';\r\nexport var ModalSize;\r\n(function (ModalSize) {\r\n    ModalSize[\"large\"] = \"large\";\r\n    ModalSize[\"medium\"] = \"medium\";\r\n    ModalSize[\"small\"] = \"small\";\r\n})(ModalSize || (ModalSize = {}));\r\nconst ModalContainer = styled(Transition) `\n  bottom: 0;\n  left: 0;\n  overflow-y: auto;\n  padding: ${props => props.theme.spaceScale.spacing03};\n  right: 0;\n  top: 0;\n  z-index: ${props => (props.modalCount >= 2 ? '999' : '998')};\n`;\r\nconst ModalBackdrop = styled(Transition) `\n  backdrop-filter: blur(3px);\n  background: ${props => transparentize(0.4, props.theme.colors.neutral900)};\n  bottom: 0;\n  left: 0;\n  right: 0;\n  top: 0;\n  z-index: 997;\n  position: fixed;\n`;\r\nconst ModalContent = styled.div `\n  background: ${props => props.isInverse\r\n    ? props.theme.colors.primary600\r\n    : props.theme.colors.neutral100};\n  border: ${props => {\r\n    if (!props.showBackgroundOverlay && props.isInverse) {\r\n        return `1px solid ${transparentize(0.5, props.theme.colors.tertiary)}`;\r\n    }\r\n    return 'none';\r\n}};\n  border-radius: ${props => props.theme.borderRadius};\n  box-shadow: ${props => {\r\n    const amount = props.isInverse ? 0.82 : 0.6;\r\n    return `0 2px 6px ${transparentize(amount, props.theme.colors.neutral900)}`;\r\n}};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  margin: 0 auto;\n  position: relative;\n  z-index: 1000;\n\n  max-width: ${props => {\r\n    switch (props.size) {\r\n        case 'large':\r\n            return props.theme.modal.width.large;\r\n        case 'small':\r\n            return props.theme.modal.width.small;\r\n        default:\r\n            return props.theme.modal.width.medium;\r\n    }\r\n}};\n\n  @media (min-width: ${props => props.theme.breakpoints.small}px) {\n    margin: ${props => props.theme.spaceScale.spacing08} auto;\n  }\n`;\r\nconst ModalHeader = styled.div `\n  padding: ${props => props.theme.spaceScale.spacing05}\n    ${props => props.theme.spaceScale.spacing05} 0\n    ${props => props.theme.spaceScale.spacing05};\n  @media (min-width: ${props => props.theme.breakpoints.small}px) {\n    padding: ${props => props.theme.spaceScale.spacing06}\n      ${props => props.theme.spaceScale.spacing06} 0\n      ${props => props.theme.spaceScale.spacing06};\n  }\n`;\r\nconst ModalWrapper = styled.div `\n  padding: ${props => props.theme.spaceScale.spacing05};\n  @media (min-width: ${props => props.theme.breakpoints.small}px) {\n    padding: ${props => props.theme.spaceScale.spacing06};\n  }\n`;\r\nconst H1 = styled(Heading) `\n  font-size: ${props => props.theme.typographyVisualStyles.headingSmall.desktop.fontSize};\n  line-height: ${props => props.theme.typographyVisualStyles.headingSmall.desktop.lineHeight};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  margin: 0;\n  padding-right: ${props => props.theme.spaceScale.spacing10};\n  font-weight: 600;\n`;\r\nconst CloseBtn = styled.span `\n  position: absolute;\n  top: 0;\n  right: 0;\n  margin: ${props => props.theme.spaceScale.spacing02};\n`;\r\nexport const Modal = React.forwardRef((props, ref) => {\r\n    const { ariaLabel, children, closeAriaLabel, closeButtonSize, containerStyle, containerTransition = { slideTop: true }, isBackgroundClickDisabled, isEscKeyDownDisabled, header, isCloseButtonHidden, isOpen, unmountOnExit = true, testId, isModalClosingControlledManually, headerRef, onClose, showBackgroundOverlay = true, ...rest } = props;\r\n    const lastFocus = React.useRef();\r\n    const headingRef = React.useRef();\r\n    const bodyRef = React.useRef();\r\n    const id = useGenerateId(props.id);\r\n    const headingId = `${id}_heading`;\r\n    const contentId = `${id}_content`;\r\n    const [isModalOpen, setIsModalOpen] = React.useState(isOpen);\r\n    const [currentTarget, setCurrentTarget] = React.useState(null);\r\n    const [modalCount, setModalCount] = React.useState(0);\r\n    const focusTrapElement = useFocusLock(isModalOpen, headingRef, bodyRef);\r\n    const prevOpen = usePrevious(isOpen);\r\n    React.useEffect(() => {\r\n        if (isModalClosingControlledManually &&\r\n            prevOpen &&\r\n            !isOpen &&\r\n            isModalOpen) {\r\n            setIsModalOpen(false);\r\n        }\r\n        else if (!prevOpen && isOpen) {\r\n            setIsModalOpen(true);\r\n            if (headerRef && typeof headerRef === 'function') {\r\n                headerRef(headingRef);\r\n            }\r\n        }\r\n        else if (prevOpen && !isOpen && isModalOpen) {\r\n            handleClose();\r\n        }\r\n    }, [isOpen]);\r\n    React.useEffect(() => {\r\n        if (isModalOpen) {\r\n            lastFocus.current = document.activeElement;\r\n            const count = document.querySelectorAll('[aria-modal=\"true\"]').length;\r\n            setModalCount(count);\r\n            if (!isEscKeyDownDisabled) {\r\n                document.body.addEventListener('keydown', handleEscapeKeyDown, false);\r\n            }\r\n        }\r\n        return () => {\r\n            document.body.removeEventListener('keydown', handleEscapeKeyDown, false);\r\n        };\r\n    }, [isModalOpen]);\r\n    function handleModalClick(event) {\r\n        if (!document.getElementById(contentId).contains(event.target) &&\r\n            event.target === currentTarget) {\r\n            handleClose(event);\r\n        }\r\n    }\r\n    function handleModalOnMouseDown(event) {\r\n        setCurrentTarget(event.target);\r\n    }\r\n    function handleEscapeKeyDown(event) {\r\n        if (event.key === 'Escape') {\r\n            event.preventDefault();\r\n            event.stopPropagation();\r\n            props.onEscKeyDown &&\r\n                typeof props.onEscKeyDown === 'function' &&\r\n                props.onEscKeyDown(event);\r\n            //Supports nested modals\r\n            const modalsInDom = document.querySelectorAll('[aria-modal=\"true\"]').length;\r\n            if (modalCount <= 1 && modalsInDom !== 1) {\r\n                if (document.getElementById(id).contains(event.target)) {\r\n                    handleClose(event);\r\n                }\r\n                else {\r\n                    headingRef.current.focus();\r\n                }\r\n            }\r\n            else {\r\n                handleClose(event);\r\n            }\r\n        }\r\n    }\r\n    function handleClose(event) {\r\n        event?.stopPropagation();\r\n        setTimeout(() => {\r\n            if (!props.isModalClosingControlledManually) {\r\n                setIsModalOpen(false);\r\n            }\r\n            lastFocus.current?.focus();\r\n            onClose && typeof onClose === 'function' && onClose();\r\n        }, 0);\r\n    }\r\n    const isInverse = useIsInverse(props.isInverse);\r\n    const other = omit(['onEscKeyDown'], rest);\r\n    const theme = React.useContext(ThemeContext);\r\n    const i18n = React.useContext(I18nContext);\r\n    const CloseIconButton = (React.createElement(CloseIcon, { size: magma.iconSizes[closeButtonSize]\r\n            ? magma.iconSizes[closeButtonSize]\r\n            : magma.iconSizes.medium }));\r\n    return isModalOpen\r\n        ? ReactDOM.createPortal(React.createElement(\"div\", { ref: focusTrapElement },\r\n            React.createElement(Global, { styles: css `\n                html {\n                  overflow: ${isOpen ? 'hidden' : 'auto'};\n                }\n              ` }),\r\n            React.createElement(ModalContainer, Object.assign({ \"aria-labelledby\": header ? headingId : null, \"aria-label\": !header ? ariaLabel : null, \"aria-modal\": true, \"data-testid\": testId, id: id, modalCount: modalCount, onClick: isBackgroundClickDisabled ? null : handleModalClick, onMouseDown: isBackgroundClickDisabled ? null : handleModalOnMouseDown, role: \"dialog\", style: containerStyle, theme: theme, isOpen: isModalOpen }, containerTransition, { unmountOnExit: unmountOnExit }),\r\n                React.createElement(ModalContent, Object.assign({}, other, { \"data-testid\": \"modal-content\", id: contentId, ref: ref, showBackgroundOverlay: showBackgroundOverlay, theme: theme }),\r\n                    header && (React.createElement(ModalHeader, { theme: theme }, header && (React.createElement(H1, { id: headingId, isInverse: isInverse, level: 1, ref: headingRef, visualStyle: TypographyVisualStyle.headingSmall, tabIndex: -1, theme: theme }, header)))),\r\n                    React.createElement(ModalWrapper, { ref: bodyRef, theme: theme }, children),\r\n                    !isCloseButtonHidden && (React.createElement(CloseBtn, { theme: theme },\r\n                        React.createElement(IconButton, { \"aria-label\": closeAriaLabel\r\n                                ? closeAriaLabel\r\n                                : i18n.modal.closeAriaLabel, color: ButtonColor.primary, icon: CloseIconButton, isInverse: isInverse, onClick: handleClose, testId: \"modal-closebtn\", variant: ButtonVariant.link }))))),\r\n            showBackgroundOverlay && (React.createElement(ModalBackdrop, { \"data-testid\": \"modal-backdrop\", onMouseDown: isBackgroundClickDisabled\r\n                    ? event => event.preventDefault()\r\n                    : null, fade: true, isOpen: isModalOpen, style: modalCount >= 2 && { zIndex: '998' }, unmountOnExit: true, theme: theme }))), document.getElementsByTagName('body')[0])\r\n        : null;\r\n});\r\n//# sourceMappingURL=Modal.js.map"]} */"));
|
|
15231
|
+
}, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Modal.tsx"],"names":[],"mappings":"AAuB0C","file":"Modal.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css, Global } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport ReactDOM from 'react-dom';\r\nimport { CloseIcon } from 'react-magma-icons';\r\nimport { useFocusLock } from '../../hooks/useFocusLock';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { magma } from '../../theme/magma';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { omit, useGenerateId, usePrevious } from '../../utils';\r\nimport { ButtonColor, ButtonVariant } from '../Button';\r\nimport { Heading } from '../Heading';\r\nimport { IconButton } from '../IconButton';\r\nimport { Transition } from '../Transition';\r\nimport { TypographyVisualStyle } from '../Typography';\r\nexport var ModalSize;\r\n(function (ModalSize) {\r\n    ModalSize[\"large\"] = \"large\";\r\n    ModalSize[\"medium\"] = \"medium\";\r\n    ModalSize[\"small\"] = \"small\";\r\n})(ModalSize || (ModalSize = {}));\r\nconst ModalContainer = styled(Transition) `\n  position: fixed;\n  bottom: 0;\n  left: 0;\n  overflow-y: auto;\n  padding: ${props => props.theme.spaceScale.spacing03};\n  right: 0;\n  top: 0;\n  z-index: ${props => (props.modalCount >= 2 ? '999' : '998')};\n`;\r\nconst ModalBackdrop = styled(Transition) `\n  backdrop-filter: blur(3px);\n  background: ${props => transparentize(0.4, props.theme.colors.neutral900)};\n  bottom: 0;\n  left: 0;\n  right: 0;\n  top: 0;\n  z-index: 997;\n  position: fixed;\n`;\r\nconst ModalContent = styled.div `\n  background: ${props => props.isInverse\r\n    ? props.theme.colors.primary600\r\n    : props.theme.colors.neutral100};\n  border: ${props => {\r\n    if (!props.showBackgroundOverlay && props.isInverse) {\r\n        return `1px solid ${transparentize(0.5, props.theme.colors.tertiary)}`;\r\n    }\r\n    return 'none';\r\n}};\n  border-radius: ${props => props.theme.borderRadius};\n  box-shadow: ${props => {\r\n    const amount = props.isInverse ? 0.82 : 0.6;\r\n    return `0 2px 6px ${transparentize(amount, props.theme.colors.neutral900)}`;\r\n}};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  margin: 0 auto;\n  position: relative;\n  z-index: 1000;\n\n  max-width: ${props => {\r\n    switch (props.size) {\r\n        case 'large':\r\n            return props.theme.modal.width.large;\r\n        case 'small':\r\n            return props.theme.modal.width.small;\r\n        default:\r\n            return props.theme.modal.width.medium;\r\n    }\r\n}};\n\n  @media (min-width: ${props => props.theme.breakpoints.small}px) {\n    margin: ${props => props.theme.spaceScale.spacing08} auto;\n  }\n`;\r\nconst ModalHeader = styled.div `\n  padding: ${props => props.theme.spaceScale.spacing05}\n    ${props => props.theme.spaceScale.spacing05} 0\n    ${props => props.theme.spaceScale.spacing05};\n  @media (min-width: ${props => props.theme.breakpoints.small}px) {\n    padding: ${props => props.theme.spaceScale.spacing06}\n      ${props => props.theme.spaceScale.spacing06} 0\n      ${props => props.theme.spaceScale.spacing06};\n  }\n`;\r\nconst ModalWrapper = styled.div `\n  padding: ${props => props.theme.spaceScale.spacing05};\n  @media (min-width: ${props => props.theme.breakpoints.small}px) {\n    padding: ${props => props.theme.spaceScale.spacing06};\n  }\n`;\r\nconst H1 = styled(Heading) `\n  font-size: ${props => props.theme.typographyVisualStyles.headingSmall.desktop.fontSize};\n  line-height: ${props => props.theme.typographyVisualStyles.headingSmall.desktop.lineHeight};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  margin: 0;\n  padding-right: ${props => props.theme.spaceScale.spacing10};\n  font-weight: 600;\n`;\r\nconst CloseBtn = styled.span `\n  position: absolute;\n  top: 0;\n  right: 0;\n  margin: ${props => props.theme.spaceScale.spacing02};\n`;\r\nexport const Modal = React.forwardRef((props, ref) => {\r\n    const { ariaLabel, children, closeAriaLabel, closeButtonSize, containerStyle, containerTransition, isBackgroundClickDisabled, isEscKeyDownDisabled, header, isCloseButtonHidden, isOpen, unmountOnExit = true, testId, isModalClosingControlledManually, headerRef, onClose, hasDrawerAnimation, showBackgroundOverlay = true, ...rest } = props;\r\n    const lastFocus = React.useRef();\r\n    const headingRef = React.useRef();\r\n    const bodyRef = React.useRef();\r\n    const id = useGenerateId(props.id);\r\n    const headingId = `${id}_heading`;\r\n    const contentId = `${id}_content`;\r\n    const [isModalOpen, setIsModalOpen] = React.useState(isOpen);\r\n    const [currentTarget, setCurrentTarget] = React.useState(null);\r\n    const [modalCount, setModalCount] = React.useState(0);\r\n    const focusTrapElement = useFocusLock(isModalOpen, headingRef, bodyRef);\r\n    const prevOpen = usePrevious(isOpen);\r\n    React.useEffect(() => {\r\n        if (isModalClosingControlledManually &&\r\n            prevOpen &&\r\n            !isOpen &&\r\n            isModalOpen) {\r\n            setIsModalOpen(false);\r\n        }\r\n        else if (!prevOpen && isOpen) {\r\n            setIsModalOpen(true);\r\n            if (headerRef && typeof headerRef === 'function') {\r\n                headerRef(headingRef);\r\n            }\r\n        }\r\n        else if (prevOpen && !isOpen && isModalOpen) {\r\n            handleClose();\r\n        }\r\n    }, [isOpen]);\r\n    React.useEffect(() => {\r\n        if (isModalOpen) {\r\n            lastFocus.current = document.activeElement;\r\n            const count = document.querySelectorAll('[aria-modal=\"true\"]').length;\r\n            setModalCount(count);\r\n            if (!isEscKeyDownDisabled) {\r\n                document.body.addEventListener('keydown', handleEscapeKeyDown, false);\r\n            }\r\n        }\r\n        return () => {\r\n            document.body.removeEventListener('keydown', handleEscapeKeyDown, false);\r\n        };\r\n    }, [isModalOpen]);\r\n    function handleModalClick(event) {\r\n        if (!document.getElementById(contentId).contains(event.target) &&\r\n            event.target === currentTarget) {\r\n            handleClose(event);\r\n        }\r\n    }\r\n    function handleModalOnMouseDown(event) {\r\n        setCurrentTarget(event.target);\r\n    }\r\n    function handleEscapeKeyDown(event) {\r\n        if (event.key === 'Escape') {\r\n            event.preventDefault();\r\n            event.stopPropagation();\r\n            props.onEscKeyDown &&\r\n                typeof props.onEscKeyDown === 'function' &&\r\n                props.onEscKeyDown(event);\r\n            //Supports nested modals\r\n            const modalsInDom = document.querySelectorAll('[aria-modal=\"true\"]').length;\r\n            if (modalCount <= 1 && modalsInDom !== 1) {\r\n                if (document.getElementById(id).contains(event.target)) {\r\n                    handleClose(event);\r\n                }\r\n                else {\r\n                    headingRef.current.focus();\r\n                }\r\n            }\r\n            else {\r\n                handleClose(event);\r\n            }\r\n        }\r\n    }\r\n    function handleClose(event) {\r\n        event?.stopPropagation();\r\n        setTimeout(() => {\r\n            if (!props.isModalClosingControlledManually) {\r\n                setIsModalOpen(false);\r\n            }\r\n            lastFocus.current?.focus();\r\n            onClose && typeof onClose === 'function' && onClose();\r\n        }, 0);\r\n    }\r\n    const isInverse = useIsInverse(props.isInverse);\r\n    const other = omit(['onEscKeyDown'], rest);\r\n    const theme = React.useContext(ThemeContext);\r\n    const i18n = React.useContext(I18nContext);\r\n    const CloseIconButton = (React.createElement(CloseIcon, { size: magma.iconSizes[closeButtonSize]\r\n            ? magma.iconSizes[closeButtonSize]\r\n            : magma.iconSizes.medium }));\r\n    // Fix for server-side rendering\r\n    if (typeof document === 'undefined') {\r\n        return null;\r\n    }\r\n    return ReactDOM.createPortal(React.createElement(\"div\", { ref: focusTrapElement },\r\n        React.createElement(Global, { styles: css `\n            html {\n              overflow: ${isOpen ? 'hidden' : 'auto'};\n            }\n          ` }),\r\n        React.createElement(ModalContainer, Object.assign({ \"aria-labelledby\": header ? headingId : null, \"aria-label\": !header ? ariaLabel : null, \"aria-modal\": true, \"data-testid\": testId, id: id, modalCount: modalCount, onClick: isBackgroundClickDisabled ? null : handleModalClick, onMouseDown: isBackgroundClickDisabled ? null : handleModalOnMouseDown, role: \"dialog\", style: containerStyle, theme: theme, isOpen: isModalOpen }, containerTransition, { unmountOnExit: unmountOnExit, hasDrawerAnimation: hasDrawerAnimation }),\r\n            React.createElement(ModalContent, Object.assign({}, other, { \"data-testid\": \"modal-content\", id: contentId, ref: ref, showBackgroundOverlay: showBackgroundOverlay, theme: theme }),\r\n                header && (React.createElement(ModalHeader, { theme: theme }, header && (React.createElement(H1, { id: headingId, isInverse: isInverse, level: 1, ref: headingRef, visualStyle: TypographyVisualStyle.headingSmall, tabIndex: -1, theme: theme }, header)))),\r\n                React.createElement(ModalWrapper, { ref: bodyRef, theme: theme }, children),\r\n                !isCloseButtonHidden && (React.createElement(CloseBtn, { theme: theme },\r\n                    React.createElement(IconButton, { \"aria-label\": closeAriaLabel ? closeAriaLabel : i18n.modal.closeAriaLabel, color: ButtonColor.primary, icon: CloseIconButton, isInverse: isInverse, onClick: handleClose, testId: \"modal-closebtn\", variant: ButtonVariant.link }))))),\r\n        showBackgroundOverlay && (React.createElement(ModalBackdrop, { \"data-testid\": \"modal-backdrop\", onMouseDown: isBackgroundClickDisabled ? undefined : handleClose, fade: hasDrawerAnimation, isOpen: isModalOpen, style: modalCount >= 2 && { zIndex: '998' }, unmountOnExit: true, theme: theme }))), document.getElementsByTagName('body')[0]);\r\n});\r\n//# sourceMappingURL=Modal.js.map"]} */"));
|
|
14999
15232
|
var ModalBackdrop = /*#__PURE__*/_styled(Transition, {
|
|
15000
15233
|
target: "e1pxemtw5",
|
|
15001
15234
|
label: "ModalBackdrop"
|
|
15002
15235
|
})("backdrop-filter:blur(3px);background:", function (props) {
|
|
15003
15236
|
return curriedTransparentize(0.4, props.theme.colors.neutral900);
|
|
15004
|
-
}, ";bottom:0;left:0;right:0;top:0;z-index:997;position:fixed;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Modal.tsx"],"names":[],"mappings":"AAgCyC","file":"Modal.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css, Global } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport ReactDOM from 'react-dom';\r\nimport { CloseIcon } from 'react-magma-icons';\r\nimport { useFocusLock } from '../../hooks/useFocusLock';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { magma } from '../../theme/magma';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { omit, useGenerateId, usePrevious } from '../../utils';\r\nimport { ButtonColor, ButtonVariant } from '../Button';\r\nimport { Heading } from '../Heading';\r\nimport { IconButton } from '../IconButton';\r\nimport { Transition } from '../Transition';\r\nimport { TypographyVisualStyle } from '../Typography';\r\nexport var ModalSize;\r\n(function (ModalSize) {\r\n    ModalSize[\"large\"] = \"large\";\r\n    ModalSize[\"medium\"] = \"medium\";\r\n    ModalSize[\"small\"] = \"small\";\r\n})(ModalSize || (ModalSize = {}));\r\nconst ModalContainer = styled(Transition) `\n  bottom: 0;\n  left: 0;\n  overflow-y: auto;\n  padding: ${props => props.theme.spaceScale.spacing03};\n  right: 0;\n  top: 0;\n  z-index: ${props => (props.modalCount >= 2 ? '999' : '998')};\n`;\r\nconst ModalBackdrop = styled(Transition) `\n  backdrop-filter: blur(3px);\n  background: ${props => transparentize(0.4, props.theme.colors.neutral900)};\n  bottom: 0;\n  left: 0;\n  right: 0;\n  top: 0;\n  z-index: 997;\n  position: fixed;\n`;\r\nconst ModalContent = styled.div `\n  background: ${props => props.isInverse\r\n    ? props.theme.colors.primary600\r\n    : props.theme.colors.neutral100};\n  border: ${props => {\r\n    if (!props.showBackgroundOverlay && props.isInverse) {\r\n        return `1px solid ${transparentize(0.5, props.theme.colors.tertiary)}`;\r\n    }\r\n    return 'none';\r\n}};\n  border-radius: ${props => props.theme.borderRadius};\n  box-shadow: ${props => {\r\n    const amount = props.isInverse ? 0.82 : 0.6;\r\n    return `0 2px 6px ${transparentize(amount, props.theme.colors.neutral900)}`;\r\n}};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  margin: 0 auto;\n  position: relative;\n  z-index: 1000;\n\n  max-width: ${props => {\r\n    switch (props.size) {\r\n        case 'large':\r\n            return props.theme.modal.width.large;\r\n        case 'small':\r\n            return props.theme.modal.width.small;\r\n        default:\r\n            return props.theme.modal.width.medium;\r\n    }\r\n}};\n\n  @media (min-width: ${props => props.theme.breakpoints.small}px) {\n    margin: ${props => props.theme.spaceScale.spacing08} auto;\n  }\n`;\r\nconst ModalHeader = styled.div `\n  padding: ${props => props.theme.spaceScale.spacing05}\n    ${props => props.theme.spaceScale.spacing05} 0\n    ${props => props.theme.spaceScale.spacing05};\n  @media (min-width: ${props => props.theme.breakpoints.small}px) {\n    padding: ${props => props.theme.spaceScale.spacing06}\n      ${props => props.theme.spaceScale.spacing06} 0\n      ${props => props.theme.spaceScale.spacing06};\n  }\n`;\r\nconst ModalWrapper = styled.div `\n  padding: ${props => props.theme.spaceScale.spacing05};\n  @media (min-width: ${props => props.theme.breakpoints.small}px) {\n    padding: ${props => props.theme.spaceScale.spacing06};\n  }\n`;\r\nconst H1 = styled(Heading) `\n  font-size: ${props => props.theme.typographyVisualStyles.headingSmall.desktop.fontSize};\n  line-height: ${props => props.theme.typographyVisualStyles.headingSmall.desktop.lineHeight};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  margin: 0;\n  padding-right: ${props => props.theme.spaceScale.spacing10};\n  font-weight: 600;\n`;\r\nconst CloseBtn = styled.span `\n  position: absolute;\n  top: 0;\n  right: 0;\n  margin: ${props => props.theme.spaceScale.spacing02};\n`;\r\nexport const Modal = React.forwardRef((props, ref) => {\r\n    const { ariaLabel, children, closeAriaLabel, closeButtonSize, containerStyle, containerTransition = { slideTop: true }, isBackgroundClickDisabled, isEscKeyDownDisabled, header, isCloseButtonHidden, isOpen, unmountOnExit = true, testId, isModalClosingControlledManually, headerRef, onClose, showBackgroundOverlay = true, ...rest } = props;\r\n    const lastFocus = React.useRef();\r\n    const headingRef = React.useRef();\r\n    const bodyRef = React.useRef();\r\n    const id = useGenerateId(props.id);\r\n    const headingId = `${id}_heading`;\r\n    const contentId = `${id}_content`;\r\n    const [isModalOpen, setIsModalOpen] = React.useState(isOpen);\r\n    const [currentTarget, setCurrentTarget] = React.useState(null);\r\n    const [modalCount, setModalCount] = React.useState(0);\r\n    const focusTrapElement = useFocusLock(isModalOpen, headingRef, bodyRef);\r\n    const prevOpen = usePrevious(isOpen);\r\n    React.useEffect(() => {\r\n        if (isModalClosingControlledManually &&\r\n            prevOpen &&\r\n            !isOpen &&\r\n            isModalOpen) {\r\n            setIsModalOpen(false);\r\n        }\r\n        else if (!prevOpen && isOpen) {\r\n            setIsModalOpen(true);\r\n            if (headerRef && typeof headerRef === 'function') {\r\n                headerRef(headingRef);\r\n            }\r\n        }\r\n        else if (prevOpen && !isOpen && isModalOpen) {\r\n            handleClose();\r\n        }\r\n    }, [isOpen]);\r\n    React.useEffect(() => {\r\n        if (isModalOpen) {\r\n            lastFocus.current = document.activeElement;\r\n            const count = document.querySelectorAll('[aria-modal=\"true\"]').length;\r\n            setModalCount(count);\r\n            if (!isEscKeyDownDisabled) {\r\n                document.body.addEventListener('keydown', handleEscapeKeyDown, false);\r\n            }\r\n        }\r\n        return () => {\r\n            document.body.removeEventListener('keydown', handleEscapeKeyDown, false);\r\n        };\r\n    }, [isModalOpen]);\r\n    function handleModalClick(event) {\r\n        if (!document.getElementById(contentId).contains(event.target) &&\r\n            event.target === currentTarget) {\r\n            handleClose(event);\r\n        }\r\n    }\r\n    function handleModalOnMouseDown(event) {\r\n        setCurrentTarget(event.target);\r\n    }\r\n    function handleEscapeKeyDown(event) {\r\n        if (event.key === 'Escape') {\r\n            event.preventDefault();\r\n            event.stopPropagation();\r\n            props.onEscKeyDown &&\r\n                typeof props.onEscKeyDown === 'function' &&\r\n                props.onEscKeyDown(event);\r\n            //Supports nested modals\r\n            const modalsInDom = document.querySelectorAll('[aria-modal=\"true\"]').length;\r\n            if (modalCount <= 1 && modalsInDom !== 1) {\r\n                if (document.getElementById(id).contains(event.target)) {\r\n                    handleClose(event);\r\n                }\r\n                else {\r\n                    headingRef.current.focus();\r\n                }\r\n            }\r\n            else {\r\n                handleClose(event);\r\n            }\r\n        }\r\n    }\r\n    function handleClose(event) {\r\n        event?.stopPropagation();\r\n        setTimeout(() => {\r\n            if (!props.isModalClosingControlledManually) {\r\n                setIsModalOpen(false);\r\n            }\r\n            lastFocus.current?.focus();\r\n            onClose && typeof onClose === 'function' && onClose();\r\n        }, 0);\r\n    }\r\n    const isInverse = useIsInverse(props.isInverse);\r\n    const other = omit(['onEscKeyDown'], rest);\r\n    const theme = React.useContext(ThemeContext);\r\n    const i18n = React.useContext(I18nContext);\r\n    const CloseIconButton = (React.createElement(CloseIcon, { size: magma.iconSizes[closeButtonSize]\r\n            ? magma.iconSizes[closeButtonSize]\r\n            : magma.iconSizes.medium }));\r\n    return isModalOpen\r\n        ? ReactDOM.createPortal(React.createElement(\"div\", { ref: focusTrapElement },\r\n            React.createElement(Global, { styles: css `\n                html {\n                  overflow: ${isOpen ? 'hidden' : 'auto'};\n                }\n              ` }),\r\n            React.createElement(ModalContainer, Object.assign({ \"aria-labelledby\": header ? headingId : null, \"aria-label\": !header ? ariaLabel : null, \"aria-modal\": true, \"data-testid\": testId, id: id, modalCount: modalCount, onClick: isBackgroundClickDisabled ? null : handleModalClick, onMouseDown: isBackgroundClickDisabled ? null : handleModalOnMouseDown, role: \"dialog\", style: containerStyle, theme: theme, isOpen: isModalOpen }, containerTransition, { unmountOnExit: unmountOnExit }),\r\n                React.createElement(ModalContent, Object.assign({}, other, { \"data-testid\": \"modal-content\", id: contentId, ref: ref, showBackgroundOverlay: showBackgroundOverlay, theme: theme }),\r\n                    header && (React.createElement(ModalHeader, { theme: theme }, header && (React.createElement(H1, { id: headingId, isInverse: isInverse, level: 1, ref: headingRef, visualStyle: TypographyVisualStyle.headingSmall, tabIndex: -1, theme: theme }, header)))),\r\n                    React.createElement(ModalWrapper, { ref: bodyRef, theme: theme }, children),\r\n                    !isCloseButtonHidden && (React.createElement(CloseBtn, { theme: theme },\r\n                        React.createElement(IconButton, { \"aria-label\": closeAriaLabel\r\n                                ? closeAriaLabel\r\n                                : i18n.modal.closeAriaLabel, color: ButtonColor.primary, icon: CloseIconButton, isInverse: isInverse, onClick: handleClose, testId: \"modal-closebtn\", variant: ButtonVariant.link }))))),\r\n            showBackgroundOverlay && (React.createElement(ModalBackdrop, { \"data-testid\": \"modal-backdrop\", onMouseDown: isBackgroundClickDisabled\r\n                    ? event => event.preventDefault()\r\n                    : null, fade: true, isOpen: isModalOpen, style: modalCount >= 2 && { zIndex: '998' }, unmountOnExit: true, theme: theme }))), document.getElementsByTagName('body')[0])\r\n        : null;\r\n});\r\n//# sourceMappingURL=Modal.js.map"]} */"));
|
|
15237
|
+
}, ";bottom:0;left:0;right:0;top:0;z-index:997;position:fixed;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Modal.tsx"],"names":[],"mappings":"AAiCyC","file":"Modal.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css, Global } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport ReactDOM from 'react-dom';\r\nimport { CloseIcon } from 'react-magma-icons';\r\nimport { useFocusLock } from '../../hooks/useFocusLock';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { magma } from '../../theme/magma';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { omit, useGenerateId, usePrevious } from '../../utils';\r\nimport { ButtonColor, ButtonVariant } from '../Button';\r\nimport { Heading } from '../Heading';\r\nimport { IconButton } from '../IconButton';\r\nimport { Transition } from '../Transition';\r\nimport { TypographyVisualStyle } from '../Typography';\r\nexport var ModalSize;\r\n(function (ModalSize) {\r\n    ModalSize[\"large\"] = \"large\";\r\n    ModalSize[\"medium\"] = \"medium\";\r\n    ModalSize[\"small\"] = \"small\";\r\n})(ModalSize || (ModalSize = {}));\r\nconst ModalContainer = styled(Transition) `\n  position: fixed;\n  bottom: 0;\n  left: 0;\n  overflow-y: auto;\n  padding: ${props => props.theme.spaceScale.spacing03};\n  right: 0;\n  top: 0;\n  z-index: ${props => (props.modalCount >= 2 ? '999' : '998')};\n`;\r\nconst ModalBackdrop = styled(Transition) `\n  backdrop-filter: blur(3px);\n  background: ${props => transparentize(0.4, props.theme.colors.neutral900)};\n  bottom: 0;\n  left: 0;\n  right: 0;\n  top: 0;\n  z-index: 997;\n  position: fixed;\n`;\r\nconst ModalContent = styled.div `\n  background: ${props => props.isInverse\r\n    ? props.theme.colors.primary600\r\n    : props.theme.colors.neutral100};\n  border: ${props => {\r\n    if (!props.showBackgroundOverlay && props.isInverse) {\r\n        return `1px solid ${transparentize(0.5, props.theme.colors.tertiary)}`;\r\n    }\r\n    return 'none';\r\n}};\n  border-radius: ${props => props.theme.borderRadius};\n  box-shadow: ${props => {\r\n    const amount = props.isInverse ? 0.82 : 0.6;\r\n    return `0 2px 6px ${transparentize(amount, props.theme.colors.neutral900)}`;\r\n}};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  margin: 0 auto;\n  position: relative;\n  z-index: 1000;\n\n  max-width: ${props => {\r\n    switch (props.size) {\r\n        case 'large':\r\n            return props.theme.modal.width.large;\r\n        case 'small':\r\n            return props.theme.modal.width.small;\r\n        default:\r\n            return props.theme.modal.width.medium;\r\n    }\r\n}};\n\n  @media (min-width: ${props => props.theme.breakpoints.small}px) {\n    margin: ${props => props.theme.spaceScale.spacing08} auto;\n  }\n`;\r\nconst ModalHeader = styled.div `\n  padding: ${props => props.theme.spaceScale.spacing05}\n    ${props => props.theme.spaceScale.spacing05} 0\n    ${props => props.theme.spaceScale.spacing05};\n  @media (min-width: ${props => props.theme.breakpoints.small}px) {\n    padding: ${props => props.theme.spaceScale.spacing06}\n      ${props => props.theme.spaceScale.spacing06} 0\n      ${props => props.theme.spaceScale.spacing06};\n  }\n`;\r\nconst ModalWrapper = styled.div `\n  padding: ${props => props.theme.spaceScale.spacing05};\n  @media (min-width: ${props => props.theme.breakpoints.small}px) {\n    padding: ${props => props.theme.spaceScale.spacing06};\n  }\n`;\r\nconst H1 = styled(Heading) `\n  font-size: ${props => props.theme.typographyVisualStyles.headingSmall.desktop.fontSize};\n  line-height: ${props => props.theme.typographyVisualStyles.headingSmall.desktop.lineHeight};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  margin: 0;\n  padding-right: ${props => props.theme.spaceScale.spacing10};\n  font-weight: 600;\n`;\r\nconst CloseBtn = styled.span `\n  position: absolute;\n  top: 0;\n  right: 0;\n  margin: ${props => props.theme.spaceScale.spacing02};\n`;\r\nexport const Modal = React.forwardRef((props, ref) => {\r\n    const { ariaLabel, children, closeAriaLabel, closeButtonSize, containerStyle, containerTransition, isBackgroundClickDisabled, isEscKeyDownDisabled, header, isCloseButtonHidden, isOpen, unmountOnExit = true, testId, isModalClosingControlledManually, headerRef, onClose, hasDrawerAnimation, showBackgroundOverlay = true, ...rest } = props;\r\n    const lastFocus = React.useRef();\r\n    const headingRef = React.useRef();\r\n    const bodyRef = React.useRef();\r\n    const id = useGenerateId(props.id);\r\n    const headingId = `${id}_heading`;\r\n    const contentId = `${id}_content`;\r\n    const [isModalOpen, setIsModalOpen] = React.useState(isOpen);\r\n    const [currentTarget, setCurrentTarget] = React.useState(null);\r\n    const [modalCount, setModalCount] = React.useState(0);\r\n    const focusTrapElement = useFocusLock(isModalOpen, headingRef, bodyRef);\r\n    const prevOpen = usePrevious(isOpen);\r\n    React.useEffect(() => {\r\n        if (isModalClosingControlledManually &&\r\n            prevOpen &&\r\n            !isOpen &&\r\n            isModalOpen) {\r\n            setIsModalOpen(false);\r\n        }\r\n        else if (!prevOpen && isOpen) {\r\n            setIsModalOpen(true);\r\n            if (headerRef && typeof headerRef === 'function') {\r\n                headerRef(headingRef);\r\n            }\r\n        }\r\n        else if (prevOpen && !isOpen && isModalOpen) {\r\n            handleClose();\r\n        }\r\n    }, [isOpen]);\r\n    React.useEffect(() => {\r\n        if (isModalOpen) {\r\n            lastFocus.current = document.activeElement;\r\n            const count = document.querySelectorAll('[aria-modal=\"true\"]').length;\r\n            setModalCount(count);\r\n            if (!isEscKeyDownDisabled) {\r\n                document.body.addEventListener('keydown', handleEscapeKeyDown, false);\r\n            }\r\n        }\r\n        return () => {\r\n            document.body.removeEventListener('keydown', handleEscapeKeyDown, false);\r\n        };\r\n    }, [isModalOpen]);\r\n    function handleModalClick(event) {\r\n        if (!document.getElementById(contentId).contains(event.target) &&\r\n            event.target === currentTarget) {\r\n            handleClose(event);\r\n        }\r\n    }\r\n    function handleModalOnMouseDown(event) {\r\n        setCurrentTarget(event.target);\r\n    }\r\n    function handleEscapeKeyDown(event) {\r\n        if (event.key === 'Escape') {\r\n            event.preventDefault();\r\n            event.stopPropagation();\r\n            props.onEscKeyDown &&\r\n                typeof props.onEscKeyDown === 'function' &&\r\n                props.onEscKeyDown(event);\r\n            //Supports nested modals\r\n            const modalsInDom = document.querySelectorAll('[aria-modal=\"true\"]').length;\r\n            if (modalCount <= 1 && modalsInDom !== 1) {\r\n                if (document.getElementById(id).contains(event.target)) {\r\n                    handleClose(event);\r\n                }\r\n                else {\r\n                    headingRef.current.focus();\r\n                }\r\n            }\r\n            else {\r\n                handleClose(event);\r\n            }\r\n        }\r\n    }\r\n    function handleClose(event) {\r\n        event?.stopPropagation();\r\n        setTimeout(() => {\r\n            if (!props.isModalClosingControlledManually) {\r\n                setIsModalOpen(false);\r\n            }\r\n            lastFocus.current?.focus();\r\n            onClose && typeof onClose === 'function' && onClose();\r\n        }, 0);\r\n    }\r\n    const isInverse = useIsInverse(props.isInverse);\r\n    const other = omit(['onEscKeyDown'], rest);\r\n    const theme = React.useContext(ThemeContext);\r\n    const i18n = React.useContext(I18nContext);\r\n    const CloseIconButton = (React.createElement(CloseIcon, { size: magma.iconSizes[closeButtonSize]\r\n            ? magma.iconSizes[closeButtonSize]\r\n            : magma.iconSizes.medium }));\r\n    // Fix for server-side rendering\r\n    if (typeof document === 'undefined') {\r\n        return null;\r\n    }\r\n    return ReactDOM.createPortal(React.createElement(\"div\", { ref: focusTrapElement },\r\n        React.createElement(Global, { styles: css `\n            html {\n              overflow: ${isOpen ? 'hidden' : 'auto'};\n            }\n          ` }),\r\n        React.createElement(ModalContainer, Object.assign({ \"aria-labelledby\": header ? headingId : null, \"aria-label\": !header ? ariaLabel : null, \"aria-modal\": true, \"data-testid\": testId, id: id, modalCount: modalCount, onClick: isBackgroundClickDisabled ? null : handleModalClick, onMouseDown: isBackgroundClickDisabled ? null : handleModalOnMouseDown, role: \"dialog\", style: containerStyle, theme: theme, isOpen: isModalOpen }, containerTransition, { unmountOnExit: unmountOnExit, hasDrawerAnimation: hasDrawerAnimation }),\r\n            React.createElement(ModalContent, Object.assign({}, other, { \"data-testid\": \"modal-content\", id: contentId, ref: ref, showBackgroundOverlay: showBackgroundOverlay, theme: theme }),\r\n                header && (React.createElement(ModalHeader, { theme: theme }, header && (React.createElement(H1, { id: headingId, isInverse: isInverse, level: 1, ref: headingRef, visualStyle: TypographyVisualStyle.headingSmall, tabIndex: -1, theme: theme }, header)))),\r\n                React.createElement(ModalWrapper, { ref: bodyRef, theme: theme }, children),\r\n                !isCloseButtonHidden && (React.createElement(CloseBtn, { theme: theme },\r\n                    React.createElement(IconButton, { \"aria-label\": closeAriaLabel ? closeAriaLabel : i18n.modal.closeAriaLabel, color: ButtonColor.primary, icon: CloseIconButton, isInverse: isInverse, onClick: handleClose, testId: \"modal-closebtn\", variant: ButtonVariant.link }))))),\r\n        showBackgroundOverlay && (React.createElement(ModalBackdrop, { \"data-testid\": \"modal-backdrop\", onMouseDown: isBackgroundClickDisabled ? undefined : handleClose, fade: hasDrawerAnimation, isOpen: isModalOpen, style: modalCount >= 2 && { zIndex: '998' }, unmountOnExit: true, theme: theme }))), document.getElementsByTagName('body')[0]);\r\n});\r\n//# sourceMappingURL=Modal.js.map"]} */"));
|
|
15005
15238
|
var ModalContent = /*#__PURE__*/_styled("div", {
|
|
15006
15239
|
target: "e1pxemtw4",
|
|
15007
15240
|
label: "ModalContent"
|
|
@@ -15032,7 +15265,7 @@ var ModalContent = /*#__PURE__*/_styled("div", {
|
|
|
15032
15265
|
return props.theme.breakpoints.small;
|
|
15033
15266
|
}, "px){margin:", function (props) {
|
|
15034
15267
|
return props.theme.spaceScale.spacing08;
|
|
15035
|
-
}, " auto;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Modal.tsx"],"names":[],"mappings":"AA0CgC","file":"Modal.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css, Global } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport ReactDOM from 'react-dom';\r\nimport { CloseIcon } from 'react-magma-icons';\r\nimport { useFocusLock } from '../../hooks/useFocusLock';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { magma } from '../../theme/magma';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { omit, useGenerateId, usePrevious } from '../../utils';\r\nimport { ButtonColor, ButtonVariant } from '../Button';\r\nimport { Heading } from '../Heading';\r\nimport { IconButton } from '../IconButton';\r\nimport { Transition } from '../Transition';\r\nimport { TypographyVisualStyle } from '../Typography';\r\nexport var ModalSize;\r\n(function (ModalSize) {\r\n    ModalSize[\"large\"] = \"large\";\r\n    ModalSize[\"medium\"] = \"medium\";\r\n    ModalSize[\"small\"] = \"small\";\r\n})(ModalSize || (ModalSize = {}));\r\nconst ModalContainer = styled(Transition) `\n  bottom: 0;\n  left: 0;\n  overflow-y: auto;\n  padding: ${props => props.theme.spaceScale.spacing03};\n  right: 0;\n  top: 0;\n  z-index: ${props => (props.modalCount >= 2 ? '999' : '998')};\n`;\r\nconst ModalBackdrop = styled(Transition) `\n  backdrop-filter: blur(3px);\n  background: ${props => transparentize(0.4, props.theme.colors.neutral900)};\n  bottom: 0;\n  left: 0;\n  right: 0;\n  top: 0;\n  z-index: 997;\n  position: fixed;\n`;\r\nconst ModalContent = styled.div `\n  background: ${props => props.isInverse\r\n    ? props.theme.colors.primary600\r\n    : props.theme.colors.neutral100};\n  border: ${props => {\r\n    if (!props.showBackgroundOverlay && props.isInverse) {\r\n        return `1px solid ${transparentize(0.5, props.theme.colors.tertiary)}`;\r\n    }\r\n    return 'none';\r\n}};\n  border-radius: ${props => props.theme.borderRadius};\n  box-shadow: ${props => {\r\n    const amount = props.isInverse ? 0.82 : 0.6;\r\n    return `0 2px 6px ${transparentize(amount, props.theme.colors.neutral900)}`;\r\n}};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  margin: 0 auto;\n  position: relative;\n  z-index: 1000;\n\n  max-width: ${props => {\r\n    switch (props.size) {\r\n        case 'large':\r\n            return props.theme.modal.width.large;\r\n        case 'small':\r\n            return props.theme.modal.width.small;\r\n        default:\r\n            return props.theme.modal.width.medium;\r\n    }\r\n}};\n\n  @media (min-width: ${props => props.theme.breakpoints.small}px) {\n    margin: ${props => props.theme.spaceScale.spacing08} auto;\n  }\n`;\r\nconst ModalHeader = styled.div `\n  padding: ${props => props.theme.spaceScale.spacing05}\n    ${props => props.theme.spaceScale.spacing05} 0\n    ${props => props.theme.spaceScale.spacing05};\n  @media (min-width: ${props => props.theme.breakpoints.small}px) {\n    padding: ${props => props.theme.spaceScale.spacing06}\n      ${props => props.theme.spaceScale.spacing06} 0\n      ${props => props.theme.spaceScale.spacing06};\n  }\n`;\r\nconst ModalWrapper = styled.div `\n  padding: ${props => props.theme.spaceScale.spacing05};\n  @media (min-width: ${props => props.theme.breakpoints.small}px) {\n    padding: ${props => props.theme.spaceScale.spacing06};\n  }\n`;\r\nconst H1 = styled(Heading) `\n  font-size: ${props => props.theme.typographyVisualStyles.headingSmall.desktop.fontSize};\n  line-height: ${props => props.theme.typographyVisualStyles.headingSmall.desktop.lineHeight};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  margin: 0;\n  padding-right: ${props => props.theme.spaceScale.spacing10};\n  font-weight: 600;\n`;\r\nconst CloseBtn = styled.span `\n  position: absolute;\n  top: 0;\n  right: 0;\n  margin: ${props => props.theme.spaceScale.spacing02};\n`;\r\nexport const Modal = React.forwardRef((props, ref) => {\r\n    const { ariaLabel, children, closeAriaLabel, closeButtonSize, containerStyle, containerTransition = { slideTop: true }, isBackgroundClickDisabled, isEscKeyDownDisabled, header, isCloseButtonHidden, isOpen, unmountOnExit = true, testId, isModalClosingControlledManually, headerRef, onClose, showBackgroundOverlay = true, ...rest } = props;\r\n    const lastFocus = React.useRef();\r\n    const headingRef = React.useRef();\r\n    const bodyRef = React.useRef();\r\n    const id = useGenerateId(props.id);\r\n    const headingId = `${id}_heading`;\r\n    const contentId = `${id}_content`;\r\n    const [isModalOpen, setIsModalOpen] = React.useState(isOpen);\r\n    const [currentTarget, setCurrentTarget] = React.useState(null);\r\n    const [modalCount, setModalCount] = React.useState(0);\r\n    const focusTrapElement = useFocusLock(isModalOpen, headingRef, bodyRef);\r\n    const prevOpen = usePrevious(isOpen);\r\n    React.useEffect(() => {\r\n        if (isModalClosingControlledManually &&\r\n            prevOpen &&\r\n            !isOpen &&\r\n            isModalOpen) {\r\n            setIsModalOpen(false);\r\n        }\r\n        else if (!prevOpen && isOpen) {\r\n            setIsModalOpen(true);\r\n            if (headerRef && typeof headerRef === 'function') {\r\n                headerRef(headingRef);\r\n            }\r\n        }\r\n        else if (prevOpen && !isOpen && isModalOpen) {\r\n            handleClose();\r\n        }\r\n    }, [isOpen]);\r\n    React.useEffect(() => {\r\n        if (isModalOpen) {\r\n            lastFocus.current = document.activeElement;\r\n            const count = document.querySelectorAll('[aria-modal=\"true\"]').length;\r\n            setModalCount(count);\r\n            if (!isEscKeyDownDisabled) {\r\n                document.body.addEventListener('keydown', handleEscapeKeyDown, false);\r\n            }\r\n        }\r\n        return () => {\r\n            document.body.removeEventListener('keydown', handleEscapeKeyDown, false);\r\n        };\r\n    }, [isModalOpen]);\r\n    function handleModalClick(event) {\r\n        if (!document.getElementById(contentId).contains(event.target) &&\r\n            event.target === currentTarget) {\r\n            handleClose(event);\r\n        }\r\n    }\r\n    function handleModalOnMouseDown(event) {\r\n        setCurrentTarget(event.target);\r\n    }\r\n    function handleEscapeKeyDown(event) {\r\n        if (event.key === 'Escape') {\r\n            event.preventDefault();\r\n            event.stopPropagation();\r\n            props.onEscKeyDown &&\r\n                typeof props.onEscKeyDown === 'function' &&\r\n                props.onEscKeyDown(event);\r\n            //Supports nested modals\r\n            const modalsInDom = document.querySelectorAll('[aria-modal=\"true\"]').length;\r\n            if (modalCount <= 1 && modalsInDom !== 1) {\r\n                if (document.getElementById(id).contains(event.target)) {\r\n                    handleClose(event);\r\n                }\r\n                else {\r\n                    headingRef.current.focus();\r\n                }\r\n            }\r\n            else {\r\n                handleClose(event);\r\n            }\r\n        }\r\n    }\r\n    function handleClose(event) {\r\n        event?.stopPropagation();\r\n        setTimeout(() => {\r\n            if (!props.isModalClosingControlledManually) {\r\n                setIsModalOpen(false);\r\n            }\r\n            lastFocus.current?.focus();\r\n            onClose && typeof onClose === 'function' && onClose();\r\n        }, 0);\r\n    }\r\n    const isInverse = useIsInverse(props.isInverse);\r\n    const other = omit(['onEscKeyDown'], rest);\r\n    const theme = React.useContext(ThemeContext);\r\n    const i18n = React.useContext(I18nContext);\r\n    const CloseIconButton = (React.createElement(CloseIcon, { size: magma.iconSizes[closeButtonSize]\r\n            ? magma.iconSizes[closeButtonSize]\r\n            : magma.iconSizes.medium }));\r\n    return isModalOpen\r\n        ? ReactDOM.createPortal(React.createElement(\"div\", { ref: focusTrapElement },\r\n            React.createElement(Global, { styles: css `\n                html {\n                  overflow: ${isOpen ? 'hidden' : 'auto'};\n                }\n              ` }),\r\n            React.createElement(ModalContainer, Object.assign({ \"aria-labelledby\": header ? headingId : null, \"aria-label\": !header ? ariaLabel : null, \"aria-modal\": true, \"data-testid\": testId, id: id, modalCount: modalCount, onClick: isBackgroundClickDisabled ? null : handleModalClick, onMouseDown: isBackgroundClickDisabled ? null : handleModalOnMouseDown, role: \"dialog\", style: containerStyle, theme: theme, isOpen: isModalOpen }, containerTransition, { unmountOnExit: unmountOnExit }),\r\n                React.createElement(ModalContent, Object.assign({}, other, { \"data-testid\": \"modal-content\", id: contentId, ref: ref, showBackgroundOverlay: showBackgroundOverlay, theme: theme }),\r\n                    header && (React.createElement(ModalHeader, { theme: theme }, header && (React.createElement(H1, { id: headingId, isInverse: isInverse, level: 1, ref: headingRef, visualStyle: TypographyVisualStyle.headingSmall, tabIndex: -1, theme: theme }, header)))),\r\n                    React.createElement(ModalWrapper, { ref: bodyRef, theme: theme }, children),\r\n                    !isCloseButtonHidden && (React.createElement(CloseBtn, { theme: theme },\r\n                        React.createElement(IconButton, { \"aria-label\": closeAriaLabel\r\n                                ? closeAriaLabel\r\n                                : i18n.modal.closeAriaLabel, color: ButtonColor.primary, icon: CloseIconButton, isInverse: isInverse, onClick: handleClose, testId: \"modal-closebtn\", variant: ButtonVariant.link }))))),\r\n            showBackgroundOverlay && (React.createElement(ModalBackdrop, { \"data-testid\": \"modal-backdrop\", onMouseDown: isBackgroundClickDisabled\r\n                    ? event => event.preventDefault()\r\n                    : null, fade: true, isOpen: isModalOpen, style: modalCount >= 2 && { zIndex: '998' }, unmountOnExit: true, theme: theme }))), document.getElementsByTagName('body')[0])\r\n        : null;\r\n});\r\n//# sourceMappingURL=Modal.js.map"]} */"));
|
|
15268
|
+
}, " auto;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Modal.tsx"],"names":[],"mappings":"AA2CgC","file":"Modal.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css, Global } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport ReactDOM from 'react-dom';\r\nimport { CloseIcon } from 'react-magma-icons';\r\nimport { useFocusLock } from '../../hooks/useFocusLock';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { magma } from '../../theme/magma';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { omit, useGenerateId, usePrevious } from '../../utils';\r\nimport { ButtonColor, ButtonVariant } from '../Button';\r\nimport { Heading } from '../Heading';\r\nimport { IconButton } from '../IconButton';\r\nimport { Transition } from '../Transition';\r\nimport { TypographyVisualStyle } from '../Typography';\r\nexport var ModalSize;\r\n(function (ModalSize) {\r\n    ModalSize[\"large\"] = \"large\";\r\n    ModalSize[\"medium\"] = \"medium\";\r\n    ModalSize[\"small\"] = \"small\";\r\n})(ModalSize || (ModalSize = {}));\r\nconst ModalContainer = styled(Transition) `\n  position: fixed;\n  bottom: 0;\n  left: 0;\n  overflow-y: auto;\n  padding: ${props => props.theme.spaceScale.spacing03};\n  right: 0;\n  top: 0;\n  z-index: ${props => (props.modalCount >= 2 ? '999' : '998')};\n`;\r\nconst ModalBackdrop = styled(Transition) `\n  backdrop-filter: blur(3px);\n  background: ${props => transparentize(0.4, props.theme.colors.neutral900)};\n  bottom: 0;\n  left: 0;\n  right: 0;\n  top: 0;\n  z-index: 997;\n  position: fixed;\n`;\r\nconst ModalContent = styled.div `\n  background: ${props => props.isInverse\r\n    ? props.theme.colors.primary600\r\n    : props.theme.colors.neutral100};\n  border: ${props => {\r\n    if (!props.showBackgroundOverlay && props.isInverse) {\r\n        return `1px solid ${transparentize(0.5, props.theme.colors.tertiary)}`;\r\n    }\r\n    return 'none';\r\n}};\n  border-radius: ${props => props.theme.borderRadius};\n  box-shadow: ${props => {\r\n    const amount = props.isInverse ? 0.82 : 0.6;\r\n    return `0 2px 6px ${transparentize(amount, props.theme.colors.neutral900)}`;\r\n}};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  margin: 0 auto;\n  position: relative;\n  z-index: 1000;\n\n  max-width: ${props => {\r\n    switch (props.size) {\r\n        case 'large':\r\n            return props.theme.modal.width.large;\r\n        case 'small':\r\n            return props.theme.modal.width.small;\r\n        default:\r\n            return props.theme.modal.width.medium;\r\n    }\r\n}};\n\n  @media (min-width: ${props => props.theme.breakpoints.small}px) {\n    margin: ${props => props.theme.spaceScale.spacing08} auto;\n  }\n`;\r\nconst ModalHeader = styled.div `\n  padding: ${props => props.theme.spaceScale.spacing05}\n    ${props => props.theme.spaceScale.spacing05} 0\n    ${props => props.theme.spaceScale.spacing05};\n  @media (min-width: ${props => props.theme.breakpoints.small}px) {\n    padding: ${props => props.theme.spaceScale.spacing06}\n      ${props => props.theme.spaceScale.spacing06} 0\n      ${props => props.theme.spaceScale.spacing06};\n  }\n`;\r\nconst ModalWrapper = styled.div `\n  padding: ${props => props.theme.spaceScale.spacing05};\n  @media (min-width: ${props => props.theme.breakpoints.small}px) {\n    padding: ${props => props.theme.spaceScale.spacing06};\n  }\n`;\r\nconst H1 = styled(Heading) `\n  font-size: ${props => props.theme.typographyVisualStyles.headingSmall.desktop.fontSize};\n  line-height: ${props => props.theme.typographyVisualStyles.headingSmall.desktop.lineHeight};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  margin: 0;\n  padding-right: ${props => props.theme.spaceScale.spacing10};\n  font-weight: 600;\n`;\r\nconst CloseBtn = styled.span `\n  position: absolute;\n  top: 0;\n  right: 0;\n  margin: ${props => props.theme.spaceScale.spacing02};\n`;\r\nexport const Modal = React.forwardRef((props, ref) => {\r\n    const { ariaLabel, children, closeAriaLabel, closeButtonSize, containerStyle, containerTransition, isBackgroundClickDisabled, isEscKeyDownDisabled, header, isCloseButtonHidden, isOpen, unmountOnExit = true, testId, isModalClosingControlledManually, headerRef, onClose, hasDrawerAnimation, showBackgroundOverlay = true, ...rest } = props;\r\n    const lastFocus = React.useRef();\r\n    const headingRef = React.useRef();\r\n    const bodyRef = React.useRef();\r\n    const id = useGenerateId(props.id);\r\n    const headingId = `${id}_heading`;\r\n    const contentId = `${id}_content`;\r\n    const [isModalOpen, setIsModalOpen] = React.useState(isOpen);\r\n    const [currentTarget, setCurrentTarget] = React.useState(null);\r\n    const [modalCount, setModalCount] = React.useState(0);\r\n    const focusTrapElement = useFocusLock(isModalOpen, headingRef, bodyRef);\r\n    const prevOpen = usePrevious(isOpen);\r\n    React.useEffect(() => {\r\n        if (isModalClosingControlledManually &&\r\n            prevOpen &&\r\n            !isOpen &&\r\n            isModalOpen) {\r\n            setIsModalOpen(false);\r\n        }\r\n        else if (!prevOpen && isOpen) {\r\n            setIsModalOpen(true);\r\n            if (headerRef && typeof headerRef === 'function') {\r\n                headerRef(headingRef);\r\n            }\r\n        }\r\n        else if (prevOpen && !isOpen && isModalOpen) {\r\n            handleClose();\r\n        }\r\n    }, [isOpen]);\r\n    React.useEffect(() => {\r\n        if (isModalOpen) {\r\n            lastFocus.current = document.activeElement;\r\n            const count = document.querySelectorAll('[aria-modal=\"true\"]').length;\r\n            setModalCount(count);\r\n            if (!isEscKeyDownDisabled) {\r\n                document.body.addEventListener('keydown', handleEscapeKeyDown, false);\r\n            }\r\n        }\r\n        return () => {\r\n            document.body.removeEventListener('keydown', handleEscapeKeyDown, false);\r\n        };\r\n    }, [isModalOpen]);\r\n    function handleModalClick(event) {\r\n        if (!document.getElementById(contentId).contains(event.target) &&\r\n            event.target === currentTarget) {\r\n            handleClose(event);\r\n        }\r\n    }\r\n    function handleModalOnMouseDown(event) {\r\n        setCurrentTarget(event.target);\r\n    }\r\n    function handleEscapeKeyDown(event) {\r\n        if (event.key === 'Escape') {\r\n            event.preventDefault();\r\n            event.stopPropagation();\r\n            props.onEscKeyDown &&\r\n                typeof props.onEscKeyDown === 'function' &&\r\n                props.onEscKeyDown(event);\r\n            //Supports nested modals\r\n            const modalsInDom = document.querySelectorAll('[aria-modal=\"true\"]').length;\r\n            if (modalCount <= 1 && modalsInDom !== 1) {\r\n                if (document.getElementById(id).contains(event.target)) {\r\n                    handleClose(event);\r\n                }\r\n                else {\r\n                    headingRef.current.focus();\r\n                }\r\n            }\r\n            else {\r\n                handleClose(event);\r\n            }\r\n        }\r\n    }\r\n    function handleClose(event) {\r\n        event?.stopPropagation();\r\n        setTimeout(() => {\r\n            if (!props.isModalClosingControlledManually) {\r\n                setIsModalOpen(false);\r\n            }\r\n            lastFocus.current?.focus();\r\n            onClose && typeof onClose === 'function' && onClose();\r\n        }, 0);\r\n    }\r\n    const isInverse = useIsInverse(props.isInverse);\r\n    const other = omit(['onEscKeyDown'], rest);\r\n    const theme = React.useContext(ThemeContext);\r\n    const i18n = React.useContext(I18nContext);\r\n    const CloseIconButton = (React.createElement(CloseIcon, { size: magma.iconSizes[closeButtonSize]\r\n            ? magma.iconSizes[closeButtonSize]\r\n            : magma.iconSizes.medium }));\r\n    // Fix for server-side rendering\r\n    if (typeof document === 'undefined') {\r\n        return null;\r\n    }\r\n    return ReactDOM.createPortal(React.createElement(\"div\", { ref: focusTrapElement },\r\n        React.createElement(Global, { styles: css `\n            html {\n              overflow: ${isOpen ? 'hidden' : 'auto'};\n            }\n          ` }),\r\n        React.createElement(ModalContainer, Object.assign({ \"aria-labelledby\": header ? headingId : null, \"aria-label\": !header ? ariaLabel : null, \"aria-modal\": true, \"data-testid\": testId, id: id, modalCount: modalCount, onClick: isBackgroundClickDisabled ? null : handleModalClick, onMouseDown: isBackgroundClickDisabled ? null : handleModalOnMouseDown, role: \"dialog\", style: containerStyle, theme: theme, isOpen: isModalOpen }, containerTransition, { unmountOnExit: unmountOnExit, hasDrawerAnimation: hasDrawerAnimation }),\r\n            React.createElement(ModalContent, Object.assign({}, other, { \"data-testid\": \"modal-content\", id: contentId, ref: ref, showBackgroundOverlay: showBackgroundOverlay, theme: theme }),\r\n                header && (React.createElement(ModalHeader, { theme: theme }, header && (React.createElement(H1, { id: headingId, isInverse: isInverse, level: 1, ref: headingRef, visualStyle: TypographyVisualStyle.headingSmall, tabIndex: -1, theme: theme }, header)))),\r\n                React.createElement(ModalWrapper, { ref: bodyRef, theme: theme }, children),\r\n                !isCloseButtonHidden && (React.createElement(CloseBtn, { theme: theme },\r\n                    React.createElement(IconButton, { \"aria-label\": closeAriaLabel ? closeAriaLabel : i18n.modal.closeAriaLabel, color: ButtonColor.primary, icon: CloseIconButton, isInverse: isInverse, onClick: handleClose, testId: \"modal-closebtn\", variant: ButtonVariant.link }))))),\r\n        showBackgroundOverlay && (React.createElement(ModalBackdrop, { \"data-testid\": \"modal-backdrop\", onMouseDown: isBackgroundClickDisabled ? undefined : handleClose, fade: hasDrawerAnimation, isOpen: isModalOpen, style: modalCount >= 2 && { zIndex: '998' }, unmountOnExit: true, theme: theme }))), document.getElementsByTagName('body')[0]);\r\n});\r\n//# sourceMappingURL=Modal.js.map"]} */"));
|
|
15036
15269
|
var ModalHeader = /*#__PURE__*/_styled("div", {
|
|
15037
15270
|
target: "e1pxemtw3",
|
|
15038
15271
|
label: "ModalHeader"
|
|
@@ -15050,7 +15283,7 @@ var ModalHeader = /*#__PURE__*/_styled("div", {
|
|
|
15050
15283
|
return props.theme.spaceScale.spacing06;
|
|
15051
15284
|
}, " 0 ", function (props) {
|
|
15052
15285
|
return props.theme.spaceScale.spacing06;
|
|
15053
|
-
}, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Modal.tsx"],"names":[],"mappings":"AA+E+B","file":"Modal.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css, Global } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport ReactDOM from 'react-dom';\r\nimport { CloseIcon } from 'react-magma-icons';\r\nimport { useFocusLock } from '../../hooks/useFocusLock';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { magma } from '../../theme/magma';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { omit, useGenerateId, usePrevious } from '../../utils';\r\nimport { ButtonColor, ButtonVariant } from '../Button';\r\nimport { Heading } from '../Heading';\r\nimport { IconButton } from '../IconButton';\r\nimport { Transition } from '../Transition';\r\nimport { TypographyVisualStyle } from '../Typography';\r\nexport var ModalSize;\r\n(function (ModalSize) {\r\n    ModalSize[\"large\"] = \"large\";\r\n    ModalSize[\"medium\"] = \"medium\";\r\n    ModalSize[\"small\"] = \"small\";\r\n})(ModalSize || (ModalSize = {}));\r\nconst ModalContainer = styled(Transition) `\n  bottom: 0;\n  left: 0;\n  overflow-y: auto;\n  padding: ${props => props.theme.spaceScale.spacing03};\n  right: 0;\n  top: 0;\n  z-index: ${props => (props.modalCount >= 2 ? '999' : '998')};\n`;\r\nconst ModalBackdrop = styled(Transition) `\n  backdrop-filter: blur(3px);\n  background: ${props => transparentize(0.4, props.theme.colors.neutral900)};\n  bottom: 0;\n  left: 0;\n  right: 0;\n  top: 0;\n  z-index: 997;\n  position: fixed;\n`;\r\nconst ModalContent = styled.div `\n  background: ${props => props.isInverse\r\n    ? props.theme.colors.primary600\r\n    : props.theme.colors.neutral100};\n  border: ${props => {\r\n    if (!props.showBackgroundOverlay && props.isInverse) {\r\n        return `1px solid ${transparentize(0.5, props.theme.colors.tertiary)}`;\r\n    }\r\n    return 'none';\r\n}};\n  border-radius: ${props => props.theme.borderRadius};\n  box-shadow: ${props => {\r\n    const amount = props.isInverse ? 0.82 : 0.6;\r\n    return `0 2px 6px ${transparentize(amount, props.theme.colors.neutral900)}`;\r\n}};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  margin: 0 auto;\n  position: relative;\n  z-index: 1000;\n\n  max-width: ${props => {\r\n    switch (props.size) {\r\n        case 'large':\r\n            return props.theme.modal.width.large;\r\n        case 'small':\r\n            return props.theme.modal.width.small;\r\n        default:\r\n            return props.theme.modal.width.medium;\r\n    }\r\n}};\n\n  @media (min-width: ${props => props.theme.breakpoints.small}px) {\n    margin: ${props => props.theme.spaceScale.spacing08} auto;\n  }\n`;\r\nconst ModalHeader = styled.div `\n  padding: ${props => props.theme.spaceScale.spacing05}\n    ${props => props.theme.spaceScale.spacing05} 0\n    ${props => props.theme.spaceScale.spacing05};\n  @media (min-width: ${props => props.theme.breakpoints.small}px) {\n    padding: ${props => props.theme.spaceScale.spacing06}\n      ${props => props.theme.spaceScale.spacing06} 0\n      ${props => props.theme.spaceScale.spacing06};\n  }\n`;\r\nconst ModalWrapper = styled.div `\n  padding: ${props => props.theme.spaceScale.spacing05};\n  @media (min-width: ${props => props.theme.breakpoints.small}px) {\n    padding: ${props => props.theme.spaceScale.spacing06};\n  }\n`;\r\nconst H1 = styled(Heading) `\n  font-size: ${props => props.theme.typographyVisualStyles.headingSmall.desktop.fontSize};\n  line-height: ${props => props.theme.typographyVisualStyles.headingSmall.desktop.lineHeight};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  margin: 0;\n  padding-right: ${props => props.theme.spaceScale.spacing10};\n  font-weight: 600;\n`;\r\nconst CloseBtn = styled.span `\n  position: absolute;\n  top: 0;\n  right: 0;\n  margin: ${props => props.theme.spaceScale.spacing02};\n`;\r\nexport const Modal = React.forwardRef((props, ref) => {\r\n    const { ariaLabel, children, closeAriaLabel, closeButtonSize, containerStyle, containerTransition = { slideTop: true }, isBackgroundClickDisabled, isEscKeyDownDisabled, header, isCloseButtonHidden, isOpen, unmountOnExit = true, testId, isModalClosingControlledManually, headerRef, onClose, showBackgroundOverlay = true, ...rest } = props;\r\n    const lastFocus = React.useRef();\r\n    const headingRef = React.useRef();\r\n    const bodyRef = React.useRef();\r\n    const id = useGenerateId(props.id);\r\n    const headingId = `${id}_heading`;\r\n    const contentId = `${id}_content`;\r\n    const [isModalOpen, setIsModalOpen] = React.useState(isOpen);\r\n    const [currentTarget, setCurrentTarget] = React.useState(null);\r\n    const [modalCount, setModalCount] = React.useState(0);\r\n    const focusTrapElement = useFocusLock(isModalOpen, headingRef, bodyRef);\r\n    const prevOpen = usePrevious(isOpen);\r\n    React.useEffect(() => {\r\n        if (isModalClosingControlledManually &&\r\n            prevOpen &&\r\n            !isOpen &&\r\n            isModalOpen) {\r\n            setIsModalOpen(false);\r\n        }\r\n        else if (!prevOpen && isOpen) {\r\n            setIsModalOpen(true);\r\n            if (headerRef && typeof headerRef === 'function') {\r\n                headerRef(headingRef);\r\n            }\r\n        }\r\n        else if (prevOpen && !isOpen && isModalOpen) {\r\n            handleClose();\r\n        }\r\n    }, [isOpen]);\r\n    React.useEffect(() => {\r\n        if (isModalOpen) {\r\n            lastFocus.current = document.activeElement;\r\n            const count = document.querySelectorAll('[aria-modal=\"true\"]').length;\r\n            setModalCount(count);\r\n            if (!isEscKeyDownDisabled) {\r\n                document.body.addEventListener('keydown', handleEscapeKeyDown, false);\r\n            }\r\n        }\r\n        return () => {\r\n            document.body.removeEventListener('keydown', handleEscapeKeyDown, false);\r\n        };\r\n    }, [isModalOpen]);\r\n    function handleModalClick(event) {\r\n        if (!document.getElementById(contentId).contains(event.target) &&\r\n            event.target === currentTarget) {\r\n            handleClose(event);\r\n        }\r\n    }\r\n    function handleModalOnMouseDown(event) {\r\n        setCurrentTarget(event.target);\r\n    }\r\n    function handleEscapeKeyDown(event) {\r\n        if (event.key === 'Escape') {\r\n            event.preventDefault();\r\n            event.stopPropagation();\r\n            props.onEscKeyDown &&\r\n                typeof props.onEscKeyDown === 'function' &&\r\n                props.onEscKeyDown(event);\r\n            //Supports nested modals\r\n            const modalsInDom = document.querySelectorAll('[aria-modal=\"true\"]').length;\r\n            if (modalCount <= 1 && modalsInDom !== 1) {\r\n                if (document.getElementById(id).contains(event.target)) {\r\n                    handleClose(event);\r\n                }\r\n                else {\r\n                    headingRef.current.focus();\r\n                }\r\n            }\r\n            else {\r\n                handleClose(event);\r\n            }\r\n        }\r\n    }\r\n    function handleClose(event) {\r\n        event?.stopPropagation();\r\n        setTimeout(() => {\r\n            if (!props.isModalClosingControlledManually) {\r\n                setIsModalOpen(false);\r\n            }\r\n            lastFocus.current?.focus();\r\n            onClose && typeof onClose === 'function' && onClose();\r\n        }, 0);\r\n    }\r\n    const isInverse = useIsInverse(props.isInverse);\r\n    const other = omit(['onEscKeyDown'], rest);\r\n    const theme = React.useContext(ThemeContext);\r\n    const i18n = React.useContext(I18nContext);\r\n    const CloseIconButton = (React.createElement(CloseIcon, { size: magma.iconSizes[closeButtonSize]\r\n            ? magma.iconSizes[closeButtonSize]\r\n            : magma.iconSizes.medium }));\r\n    return isModalOpen\r\n        ? ReactDOM.createPortal(React.createElement(\"div\", { ref: focusTrapElement },\r\n            React.createElement(Global, { styles: css `\n                html {\n                  overflow: ${isOpen ? 'hidden' : 'auto'};\n                }\n              ` }),\r\n            React.createElement(ModalContainer, Object.assign({ \"aria-labelledby\": header ? headingId : null, \"aria-label\": !header ? ariaLabel : null, \"aria-modal\": true, \"data-testid\": testId, id: id, modalCount: modalCount, onClick: isBackgroundClickDisabled ? null : handleModalClick, onMouseDown: isBackgroundClickDisabled ? null : handleModalOnMouseDown, role: \"dialog\", style: containerStyle, theme: theme, isOpen: isModalOpen }, containerTransition, { unmountOnExit: unmountOnExit }),\r\n                React.createElement(ModalContent, Object.assign({}, other, { \"data-testid\": \"modal-content\", id: contentId, ref: ref, showBackgroundOverlay: showBackgroundOverlay, theme: theme }),\r\n                    header && (React.createElement(ModalHeader, { theme: theme }, header && (React.createElement(H1, { id: headingId, isInverse: isInverse, level: 1, ref: headingRef, visualStyle: TypographyVisualStyle.headingSmall, tabIndex: -1, theme: theme }, header)))),\r\n                    React.createElement(ModalWrapper, { ref: bodyRef, theme: theme }, children),\r\n                    !isCloseButtonHidden && (React.createElement(CloseBtn, { theme: theme },\r\n                        React.createElement(IconButton, { \"aria-label\": closeAriaLabel\r\n                                ? closeAriaLabel\r\n                                : i18n.modal.closeAriaLabel, color: ButtonColor.primary, icon: CloseIconButton, isInverse: isInverse, onClick: handleClose, testId: \"modal-closebtn\", variant: ButtonVariant.link }))))),\r\n            showBackgroundOverlay && (React.createElement(ModalBackdrop, { \"data-testid\": \"modal-backdrop\", onMouseDown: isBackgroundClickDisabled\r\n                    ? event => event.preventDefault()\r\n                    : null, fade: true, isOpen: isModalOpen, style: modalCount >= 2 && { zIndex: '998' }, unmountOnExit: true, theme: theme }))), document.getElementsByTagName('body')[0])\r\n        : null;\r\n});\r\n//# sourceMappingURL=Modal.js.map"]} */"));
|
|
15286
|
+
}, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Modal.tsx"],"names":[],"mappings":"AAgF+B","file":"Modal.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css, Global } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport ReactDOM from 'react-dom';\r\nimport { CloseIcon } from 'react-magma-icons';\r\nimport { useFocusLock } from '../../hooks/useFocusLock';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { magma } from '../../theme/magma';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { omit, useGenerateId, usePrevious } from '../../utils';\r\nimport { ButtonColor, ButtonVariant } from '../Button';\r\nimport { Heading } from '../Heading';\r\nimport { IconButton } from '../IconButton';\r\nimport { Transition } from '../Transition';\r\nimport { TypographyVisualStyle } from '../Typography';\r\nexport var ModalSize;\r\n(function (ModalSize) {\r\n    ModalSize[\"large\"] = \"large\";\r\n    ModalSize[\"medium\"] = \"medium\";\r\n    ModalSize[\"small\"] = \"small\";\r\n})(ModalSize || (ModalSize = {}));\r\nconst ModalContainer = styled(Transition) `\n  position: fixed;\n  bottom: 0;\n  left: 0;\n  overflow-y: auto;\n  padding: ${props => props.theme.spaceScale.spacing03};\n  right: 0;\n  top: 0;\n  z-index: ${props => (props.modalCount >= 2 ? '999' : '998')};\n`;\r\nconst ModalBackdrop = styled(Transition) `\n  backdrop-filter: blur(3px);\n  background: ${props => transparentize(0.4, props.theme.colors.neutral900)};\n  bottom: 0;\n  left: 0;\n  right: 0;\n  top: 0;\n  z-index: 997;\n  position: fixed;\n`;\r\nconst ModalContent = styled.div `\n  background: ${props => props.isInverse\r\n    ? props.theme.colors.primary600\r\n    : props.theme.colors.neutral100};\n  border: ${props => {\r\n    if (!props.showBackgroundOverlay && props.isInverse) {\r\n        return `1px solid ${transparentize(0.5, props.theme.colors.tertiary)}`;\r\n    }\r\n    return 'none';\r\n}};\n  border-radius: ${props => props.theme.borderRadius};\n  box-shadow: ${props => {\r\n    const amount = props.isInverse ? 0.82 : 0.6;\r\n    return `0 2px 6px ${transparentize(amount, props.theme.colors.neutral900)}`;\r\n}};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  margin: 0 auto;\n  position: relative;\n  z-index: 1000;\n\n  max-width: ${props => {\r\n    switch (props.size) {\r\n        case 'large':\r\n            return props.theme.modal.width.large;\r\n        case 'small':\r\n            return props.theme.modal.width.small;\r\n        default:\r\n            return props.theme.modal.width.medium;\r\n    }\r\n}};\n\n  @media (min-width: ${props => props.theme.breakpoints.small}px) {\n    margin: ${props => props.theme.spaceScale.spacing08} auto;\n  }\n`;\r\nconst ModalHeader = styled.div `\n  padding: ${props => props.theme.spaceScale.spacing05}\n    ${props => props.theme.spaceScale.spacing05} 0\n    ${props => props.theme.spaceScale.spacing05};\n  @media (min-width: ${props => props.theme.breakpoints.small}px) {\n    padding: ${props => props.theme.spaceScale.spacing06}\n      ${props => props.theme.spaceScale.spacing06} 0\n      ${props => props.theme.spaceScale.spacing06};\n  }\n`;\r\nconst ModalWrapper = styled.div `\n  padding: ${props => props.theme.spaceScale.spacing05};\n  @media (min-width: ${props => props.theme.breakpoints.small}px) {\n    padding: ${props => props.theme.spaceScale.spacing06};\n  }\n`;\r\nconst H1 = styled(Heading) `\n  font-size: ${props => props.theme.typographyVisualStyles.headingSmall.desktop.fontSize};\n  line-height: ${props => props.theme.typographyVisualStyles.headingSmall.desktop.lineHeight};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  margin: 0;\n  padding-right: ${props => props.theme.spaceScale.spacing10};\n  font-weight: 600;\n`;\r\nconst CloseBtn = styled.span `\n  position: absolute;\n  top: 0;\n  right: 0;\n  margin: ${props => props.theme.spaceScale.spacing02};\n`;\r\nexport const Modal = React.forwardRef((props, ref) => {\r\n    const { ariaLabel, children, closeAriaLabel, closeButtonSize, containerStyle, containerTransition, isBackgroundClickDisabled, isEscKeyDownDisabled, header, isCloseButtonHidden, isOpen, unmountOnExit = true, testId, isModalClosingControlledManually, headerRef, onClose, hasDrawerAnimation, showBackgroundOverlay = true, ...rest } = props;\r\n    const lastFocus = React.useRef();\r\n    const headingRef = React.useRef();\r\n    const bodyRef = React.useRef();\r\n    const id = useGenerateId(props.id);\r\n    const headingId = `${id}_heading`;\r\n    const contentId = `${id}_content`;\r\n    const [isModalOpen, setIsModalOpen] = React.useState(isOpen);\r\n    const [currentTarget, setCurrentTarget] = React.useState(null);\r\n    const [modalCount, setModalCount] = React.useState(0);\r\n    const focusTrapElement = useFocusLock(isModalOpen, headingRef, bodyRef);\r\n    const prevOpen = usePrevious(isOpen);\r\n    React.useEffect(() => {\r\n        if (isModalClosingControlledManually &&\r\n            prevOpen &&\r\n            !isOpen &&\r\n            isModalOpen) {\r\n            setIsModalOpen(false);\r\n        }\r\n        else if (!prevOpen && isOpen) {\r\n            setIsModalOpen(true);\r\n            if (headerRef && typeof headerRef === 'function') {\r\n                headerRef(headingRef);\r\n            }\r\n        }\r\n        else if (prevOpen && !isOpen && isModalOpen) {\r\n            handleClose();\r\n        }\r\n    }, [isOpen]);\r\n    React.useEffect(() => {\r\n        if (isModalOpen) {\r\n            lastFocus.current = document.activeElement;\r\n            const count = document.querySelectorAll('[aria-modal=\"true\"]').length;\r\n            setModalCount(count);\r\n            if (!isEscKeyDownDisabled) {\r\n                document.body.addEventListener('keydown', handleEscapeKeyDown, false);\r\n            }\r\n        }\r\n        return () => {\r\n            document.body.removeEventListener('keydown', handleEscapeKeyDown, false);\r\n        };\r\n    }, [isModalOpen]);\r\n    function handleModalClick(event) {\r\n        if (!document.getElementById(contentId).contains(event.target) &&\r\n            event.target === currentTarget) {\r\n            handleClose(event);\r\n        }\r\n    }\r\n    function handleModalOnMouseDown(event) {\r\n        setCurrentTarget(event.target);\r\n    }\r\n    function handleEscapeKeyDown(event) {\r\n        if (event.key === 'Escape') {\r\n            event.preventDefault();\r\n            event.stopPropagation();\r\n            props.onEscKeyDown &&\r\n                typeof props.onEscKeyDown === 'function' &&\r\n                props.onEscKeyDown(event);\r\n            //Supports nested modals\r\n            const modalsInDom = document.querySelectorAll('[aria-modal=\"true\"]').length;\r\n            if (modalCount <= 1 && modalsInDom !== 1) {\r\n                if (document.getElementById(id).contains(event.target)) {\r\n                    handleClose(event);\r\n                }\r\n                else {\r\n                    headingRef.current.focus();\r\n                }\r\n            }\r\n            else {\r\n                handleClose(event);\r\n            }\r\n        }\r\n    }\r\n    function handleClose(event) {\r\n        event?.stopPropagation();\r\n        setTimeout(() => {\r\n            if (!props.isModalClosingControlledManually) {\r\n                setIsModalOpen(false);\r\n            }\r\n            lastFocus.current?.focus();\r\n            onClose && typeof onClose === 'function' && onClose();\r\n        }, 0);\r\n    }\r\n    const isInverse = useIsInverse(props.isInverse);\r\n    const other = omit(['onEscKeyDown'], rest);\r\n    const theme = React.useContext(ThemeContext);\r\n    const i18n = React.useContext(I18nContext);\r\n    const CloseIconButton = (React.createElement(CloseIcon, { size: magma.iconSizes[closeButtonSize]\r\n            ? magma.iconSizes[closeButtonSize]\r\n            : magma.iconSizes.medium }));\r\n    // Fix for server-side rendering\r\n    if (typeof document === 'undefined') {\r\n        return null;\r\n    }\r\n    return ReactDOM.createPortal(React.createElement(\"div\", { ref: focusTrapElement },\r\n        React.createElement(Global, { styles: css `\n            html {\n              overflow: ${isOpen ? 'hidden' : 'auto'};\n            }\n          ` }),\r\n        React.createElement(ModalContainer, Object.assign({ \"aria-labelledby\": header ? headingId : null, \"aria-label\": !header ? ariaLabel : null, \"aria-modal\": true, \"data-testid\": testId, id: id, modalCount: modalCount, onClick: isBackgroundClickDisabled ? null : handleModalClick, onMouseDown: isBackgroundClickDisabled ? null : handleModalOnMouseDown, role: \"dialog\", style: containerStyle, theme: theme, isOpen: isModalOpen }, containerTransition, { unmountOnExit: unmountOnExit, hasDrawerAnimation: hasDrawerAnimation }),\r\n            React.createElement(ModalContent, Object.assign({}, other, { \"data-testid\": \"modal-content\", id: contentId, ref: ref, showBackgroundOverlay: showBackgroundOverlay, theme: theme }),\r\n                header && (React.createElement(ModalHeader, { theme: theme }, header && (React.createElement(H1, { id: headingId, isInverse: isInverse, level: 1, ref: headingRef, visualStyle: TypographyVisualStyle.headingSmall, tabIndex: -1, theme: theme }, header)))),\r\n                React.createElement(ModalWrapper, { ref: bodyRef, theme: theme }, children),\r\n                !isCloseButtonHidden && (React.createElement(CloseBtn, { theme: theme },\r\n                    React.createElement(IconButton, { \"aria-label\": closeAriaLabel ? closeAriaLabel : i18n.modal.closeAriaLabel, color: ButtonColor.primary, icon: CloseIconButton, isInverse: isInverse, onClick: handleClose, testId: \"modal-closebtn\", variant: ButtonVariant.link }))))),\r\n        showBackgroundOverlay && (React.createElement(ModalBackdrop, { \"data-testid\": \"modal-backdrop\", onMouseDown: isBackgroundClickDisabled ? undefined : handleClose, fade: hasDrawerAnimation, isOpen: isModalOpen, style: modalCount >= 2 && { zIndex: '998' }, unmountOnExit: true, theme: theme }))), document.getElementsByTagName('body')[0]);\r\n});\r\n//# sourceMappingURL=Modal.js.map"]} */"));
|
|
15054
15287
|
var ModalWrapper = /*#__PURE__*/_styled("div", {
|
|
15055
15288
|
target: "e1pxemtw2",
|
|
15056
15289
|
label: "ModalWrapper"
|
|
@@ -15060,7 +15293,7 @@ var ModalWrapper = /*#__PURE__*/_styled("div", {
|
|
|
15060
15293
|
return props.theme.breakpoints.small;
|
|
15061
15294
|
}, "px){padding:", function (props) {
|
|
15062
15295
|
return props.theme.spaceScale.spacing06;
|
|
15063
|
-
}, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Modal.tsx"],"names":[],"mappings":"AAyFgC","file":"Modal.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css, Global } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport ReactDOM from 'react-dom';\r\nimport { CloseIcon } from 'react-magma-icons';\r\nimport { useFocusLock } from '../../hooks/useFocusLock';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { magma } from '../../theme/magma';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { omit, useGenerateId, usePrevious } from '../../utils';\r\nimport { ButtonColor, ButtonVariant } from '../Button';\r\nimport { Heading } from '../Heading';\r\nimport { IconButton } from '../IconButton';\r\nimport { Transition } from '../Transition';\r\nimport { TypographyVisualStyle } from '../Typography';\r\nexport var ModalSize;\r\n(function (ModalSize) {\r\n    ModalSize[\"large\"] = \"large\";\r\n    ModalSize[\"medium\"] = \"medium\";\r\n    ModalSize[\"small\"] = \"small\";\r\n})(ModalSize || (ModalSize = {}));\r\nconst ModalContainer = styled(Transition) `\n  bottom: 0;\n  left: 0;\n  overflow-y: auto;\n  padding: ${props => props.theme.spaceScale.spacing03};\n  right: 0;\n  top: 0;\n  z-index: ${props => (props.modalCount >= 2 ? '999' : '998')};\n`;\r\nconst ModalBackdrop = styled(Transition) `\n  backdrop-filter: blur(3px);\n  background: ${props => transparentize(0.4, props.theme.colors.neutral900)};\n  bottom: 0;\n  left: 0;\n  right: 0;\n  top: 0;\n  z-index: 997;\n  position: fixed;\n`;\r\nconst ModalContent = styled.div `\n  background: ${props => props.isInverse\r\n    ? props.theme.colors.primary600\r\n    : props.theme.colors.neutral100};\n  border: ${props => {\r\n    if (!props.showBackgroundOverlay && props.isInverse) {\r\n        return `1px solid ${transparentize(0.5, props.theme.colors.tertiary)}`;\r\n    }\r\n    return 'none';\r\n}};\n  border-radius: ${props => props.theme.borderRadius};\n  box-shadow: ${props => {\r\n    const amount = props.isInverse ? 0.82 : 0.6;\r\n    return `0 2px 6px ${transparentize(amount, props.theme.colors.neutral900)}`;\r\n}};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  margin: 0 auto;\n  position: relative;\n  z-index: 1000;\n\n  max-width: ${props => {\r\n    switch (props.size) {\r\n        case 'large':\r\n            return props.theme.modal.width.large;\r\n        case 'small':\r\n            return props.theme.modal.width.small;\r\n        default:\r\n            return props.theme.modal.width.medium;\r\n    }\r\n}};\n\n  @media (min-width: ${props => props.theme.breakpoints.small}px) {\n    margin: ${props => props.theme.spaceScale.spacing08} auto;\n  }\n`;\r\nconst ModalHeader = styled.div `\n  padding: ${props => props.theme.spaceScale.spacing05}\n    ${props => props.theme.spaceScale.spacing05} 0\n    ${props => props.theme.spaceScale.spacing05};\n  @media (min-width: ${props => props.theme.breakpoints.small}px) {\n    padding: ${props => props.theme.spaceScale.spacing06}\n      ${props => props.theme.spaceScale.spacing06} 0\n      ${props => props.theme.spaceScale.spacing06};\n  }\n`;\r\nconst ModalWrapper = styled.div `\n  padding: ${props => props.theme.spaceScale.spacing05};\n  @media (min-width: ${props => props.theme.breakpoints.small}px) {\n    padding: ${props => props.theme.spaceScale.spacing06};\n  }\n`;\r\nconst H1 = styled(Heading) `\n  font-size: ${props => props.theme.typographyVisualStyles.headingSmall.desktop.fontSize};\n  line-height: ${props => props.theme.typographyVisualStyles.headingSmall.desktop.lineHeight};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  margin: 0;\n  padding-right: ${props => props.theme.spaceScale.spacing10};\n  font-weight: 600;\n`;\r\nconst CloseBtn = styled.span `\n  position: absolute;\n  top: 0;\n  right: 0;\n  margin: ${props => props.theme.spaceScale.spacing02};\n`;\r\nexport const Modal = React.forwardRef((props, ref) => {\r\n    const { ariaLabel, children, closeAriaLabel, closeButtonSize, containerStyle, containerTransition = { slideTop: true }, isBackgroundClickDisabled, isEscKeyDownDisabled, header, isCloseButtonHidden, isOpen, unmountOnExit = true, testId, isModalClosingControlledManually, headerRef, onClose, showBackgroundOverlay = true, ...rest } = props;\r\n    const lastFocus = React.useRef();\r\n    const headingRef = React.useRef();\r\n    const bodyRef = React.useRef();\r\n    const id = useGenerateId(props.id);\r\n    const headingId = `${id}_heading`;\r\n    const contentId = `${id}_content`;\r\n    const [isModalOpen, setIsModalOpen] = React.useState(isOpen);\r\n    const [currentTarget, setCurrentTarget] = React.useState(null);\r\n    const [modalCount, setModalCount] = React.useState(0);\r\n    const focusTrapElement = useFocusLock(isModalOpen, headingRef, bodyRef);\r\n    const prevOpen = usePrevious(isOpen);\r\n    React.useEffect(() => {\r\n        if (isModalClosingControlledManually &&\r\n            prevOpen &&\r\n            !isOpen &&\r\n            isModalOpen) {\r\n            setIsModalOpen(false);\r\n        }\r\n        else if (!prevOpen && isOpen) {\r\n            setIsModalOpen(true);\r\n            if (headerRef && typeof headerRef === 'function') {\r\n                headerRef(headingRef);\r\n            }\r\n        }\r\n        else if (prevOpen && !isOpen && isModalOpen) {\r\n            handleClose();\r\n        }\r\n    }, [isOpen]);\r\n    React.useEffect(() => {\r\n        if (isModalOpen) {\r\n            lastFocus.current = document.activeElement;\r\n            const count = document.querySelectorAll('[aria-modal=\"true\"]').length;\r\n            setModalCount(count);\r\n            if (!isEscKeyDownDisabled) {\r\n                document.body.addEventListener('keydown', handleEscapeKeyDown, false);\r\n            }\r\n        }\r\n        return () => {\r\n            document.body.removeEventListener('keydown', handleEscapeKeyDown, false);\r\n        };\r\n    }, [isModalOpen]);\r\n    function handleModalClick(event) {\r\n        if (!document.getElementById(contentId).contains(event.target) &&\r\n            event.target === currentTarget) {\r\n            handleClose(event);\r\n        }\r\n    }\r\n    function handleModalOnMouseDown(event) {\r\n        setCurrentTarget(event.target);\r\n    }\r\n    function handleEscapeKeyDown(event) {\r\n        if (event.key === 'Escape') {\r\n            event.preventDefault();\r\n            event.stopPropagation();\r\n            props.onEscKeyDown &&\r\n                typeof props.onEscKeyDown === 'function' &&\r\n                props.onEscKeyDown(event);\r\n            //Supports nested modals\r\n            const modalsInDom = document.querySelectorAll('[aria-modal=\"true\"]').length;\r\n            if (modalCount <= 1 && modalsInDom !== 1) {\r\n                if (document.getElementById(id).contains(event.target)) {\r\n                    handleClose(event);\r\n                }\r\n                else {\r\n                    headingRef.current.focus();\r\n                }\r\n            }\r\n            else {\r\n                handleClose(event);\r\n            }\r\n        }\r\n    }\r\n    function handleClose(event) {\r\n        event?.stopPropagation();\r\n        setTimeout(() => {\r\n            if (!props.isModalClosingControlledManually) {\r\n                setIsModalOpen(false);\r\n            }\r\n            lastFocus.current?.focus();\r\n            onClose && typeof onClose === 'function' && onClose();\r\n        }, 0);\r\n    }\r\n    const isInverse = useIsInverse(props.isInverse);\r\n    const other = omit(['onEscKeyDown'], rest);\r\n    const theme = React.useContext(ThemeContext);\r\n    const i18n = React.useContext(I18nContext);\r\n    const CloseIconButton = (React.createElement(CloseIcon, { size: magma.iconSizes[closeButtonSize]\r\n            ? magma.iconSizes[closeButtonSize]\r\n            : magma.iconSizes.medium }));\r\n    return isModalOpen\r\n        ? ReactDOM.createPortal(React.createElement(\"div\", { ref: focusTrapElement },\r\n            React.createElement(Global, { styles: css `\n                html {\n                  overflow: ${isOpen ? 'hidden' : 'auto'};\n                }\n              ` }),\r\n            React.createElement(ModalContainer, Object.assign({ \"aria-labelledby\": header ? headingId : null, \"aria-label\": !header ? ariaLabel : null, \"aria-modal\": true, \"data-testid\": testId, id: id, modalCount: modalCount, onClick: isBackgroundClickDisabled ? null : handleModalClick, onMouseDown: isBackgroundClickDisabled ? null : handleModalOnMouseDown, role: \"dialog\", style: containerStyle, theme: theme, isOpen: isModalOpen }, containerTransition, { unmountOnExit: unmountOnExit }),\r\n                React.createElement(ModalContent, Object.assign({}, other, { \"data-testid\": \"modal-content\", id: contentId, ref: ref, showBackgroundOverlay: showBackgroundOverlay, theme: theme }),\r\n                    header && (React.createElement(ModalHeader, { theme: theme }, header && (React.createElement(H1, { id: headingId, isInverse: isInverse, level: 1, ref: headingRef, visualStyle: TypographyVisualStyle.headingSmall, tabIndex: -1, theme: theme }, header)))),\r\n                    React.createElement(ModalWrapper, { ref: bodyRef, theme: theme }, children),\r\n                    !isCloseButtonHidden && (React.createElement(CloseBtn, { theme: theme },\r\n                        React.createElement(IconButton, { \"aria-label\": closeAriaLabel\r\n                                ? closeAriaLabel\r\n                                : i18n.modal.closeAriaLabel, color: ButtonColor.primary, icon: CloseIconButton, isInverse: isInverse, onClick: handleClose, testId: \"modal-closebtn\", variant: ButtonVariant.link }))))),\r\n            showBackgroundOverlay && (React.createElement(ModalBackdrop, { \"data-testid\": \"modal-backdrop\", onMouseDown: isBackgroundClickDisabled\r\n                    ? event => event.preventDefault()\r\n                    : null, fade: true, isOpen: isModalOpen, style: modalCount >= 2 && { zIndex: '998' }, unmountOnExit: true, theme: theme }))), document.getElementsByTagName('body')[0])\r\n        : null;\r\n});\r\n//# sourceMappingURL=Modal.js.map"]} */"));
|
|
15296
|
+
}, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Modal.tsx"],"names":[],"mappings":"AA0FgC","file":"Modal.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css, Global } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport ReactDOM from 'react-dom';\r\nimport { CloseIcon } from 'react-magma-icons';\r\nimport { useFocusLock } from '../../hooks/useFocusLock';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { magma } from '../../theme/magma';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { omit, useGenerateId, usePrevious } from '../../utils';\r\nimport { ButtonColor, ButtonVariant } from '../Button';\r\nimport { Heading } from '../Heading';\r\nimport { IconButton } from '../IconButton';\r\nimport { Transition } from '../Transition';\r\nimport { TypographyVisualStyle } from '../Typography';\r\nexport var ModalSize;\r\n(function (ModalSize) {\r\n    ModalSize[\"large\"] = \"large\";\r\n    ModalSize[\"medium\"] = \"medium\";\r\n    ModalSize[\"small\"] = \"small\";\r\n})(ModalSize || (ModalSize = {}));\r\nconst ModalContainer = styled(Transition) `\n  position: fixed;\n  bottom: 0;\n  left: 0;\n  overflow-y: auto;\n  padding: ${props => props.theme.spaceScale.spacing03};\n  right: 0;\n  top: 0;\n  z-index: ${props => (props.modalCount >= 2 ? '999' : '998')};\n`;\r\nconst ModalBackdrop = styled(Transition) `\n  backdrop-filter: blur(3px);\n  background: ${props => transparentize(0.4, props.theme.colors.neutral900)};\n  bottom: 0;\n  left: 0;\n  right: 0;\n  top: 0;\n  z-index: 997;\n  position: fixed;\n`;\r\nconst ModalContent = styled.div `\n  background: ${props => props.isInverse\r\n    ? props.theme.colors.primary600\r\n    : props.theme.colors.neutral100};\n  border: ${props => {\r\n    if (!props.showBackgroundOverlay && props.isInverse) {\r\n        return `1px solid ${transparentize(0.5, props.theme.colors.tertiary)}`;\r\n    }\r\n    return 'none';\r\n}};\n  border-radius: ${props => props.theme.borderRadius};\n  box-shadow: ${props => {\r\n    const amount = props.isInverse ? 0.82 : 0.6;\r\n    return `0 2px 6px ${transparentize(amount, props.theme.colors.neutral900)}`;\r\n}};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  margin: 0 auto;\n  position: relative;\n  z-index: 1000;\n\n  max-width: ${props => {\r\n    switch (props.size) {\r\n        case 'large':\r\n            return props.theme.modal.width.large;\r\n        case 'small':\r\n            return props.theme.modal.width.small;\r\n        default:\r\n            return props.theme.modal.width.medium;\r\n    }\r\n}};\n\n  @media (min-width: ${props => props.theme.breakpoints.small}px) {\n    margin: ${props => props.theme.spaceScale.spacing08} auto;\n  }\n`;\r\nconst ModalHeader = styled.div `\n  padding: ${props => props.theme.spaceScale.spacing05}\n    ${props => props.theme.spaceScale.spacing05} 0\n    ${props => props.theme.spaceScale.spacing05};\n  @media (min-width: ${props => props.theme.breakpoints.small}px) {\n    padding: ${props => props.theme.spaceScale.spacing06}\n      ${props => props.theme.spaceScale.spacing06} 0\n      ${props => props.theme.spaceScale.spacing06};\n  }\n`;\r\nconst ModalWrapper = styled.div `\n  padding: ${props => props.theme.spaceScale.spacing05};\n  @media (min-width: ${props => props.theme.breakpoints.small}px) {\n    padding: ${props => props.theme.spaceScale.spacing06};\n  }\n`;\r\nconst H1 = styled(Heading) `\n  font-size: ${props => props.theme.typographyVisualStyles.headingSmall.desktop.fontSize};\n  line-height: ${props => props.theme.typographyVisualStyles.headingSmall.desktop.lineHeight};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  margin: 0;\n  padding-right: ${props => props.theme.spaceScale.spacing10};\n  font-weight: 600;\n`;\r\nconst CloseBtn = styled.span `\n  position: absolute;\n  top: 0;\n  right: 0;\n  margin: ${props => props.theme.spaceScale.spacing02};\n`;\r\nexport const Modal = React.forwardRef((props, ref) => {\r\n    const { ariaLabel, children, closeAriaLabel, closeButtonSize, containerStyle, containerTransition, isBackgroundClickDisabled, isEscKeyDownDisabled, header, isCloseButtonHidden, isOpen, unmountOnExit = true, testId, isModalClosingControlledManually, headerRef, onClose, hasDrawerAnimation, showBackgroundOverlay = true, ...rest } = props;\r\n    const lastFocus = React.useRef();\r\n    const headingRef = React.useRef();\r\n    const bodyRef = React.useRef();\r\n    const id = useGenerateId(props.id);\r\n    const headingId = `${id}_heading`;\r\n    const contentId = `${id}_content`;\r\n    const [isModalOpen, setIsModalOpen] = React.useState(isOpen);\r\n    const [currentTarget, setCurrentTarget] = React.useState(null);\r\n    const [modalCount, setModalCount] = React.useState(0);\r\n    const focusTrapElement = useFocusLock(isModalOpen, headingRef, bodyRef);\r\n    const prevOpen = usePrevious(isOpen);\r\n    React.useEffect(() => {\r\n        if (isModalClosingControlledManually &&\r\n            prevOpen &&\r\n            !isOpen &&\r\n            isModalOpen) {\r\n            setIsModalOpen(false);\r\n        }\r\n        else if (!prevOpen && isOpen) {\r\n            setIsModalOpen(true);\r\n            if (headerRef && typeof headerRef === 'function') {\r\n                headerRef(headingRef);\r\n            }\r\n        }\r\n        else if (prevOpen && !isOpen && isModalOpen) {\r\n            handleClose();\r\n        }\r\n    }, [isOpen]);\r\n    React.useEffect(() => {\r\n        if (isModalOpen) {\r\n            lastFocus.current = document.activeElement;\r\n            const count = document.querySelectorAll('[aria-modal=\"true\"]').length;\r\n            setModalCount(count);\r\n            if (!isEscKeyDownDisabled) {\r\n                document.body.addEventListener('keydown', handleEscapeKeyDown, false);\r\n            }\r\n        }\r\n        return () => {\r\n            document.body.removeEventListener('keydown', handleEscapeKeyDown, false);\r\n        };\r\n    }, [isModalOpen]);\r\n    function handleModalClick(event) {\r\n        if (!document.getElementById(contentId).contains(event.target) &&\r\n            event.target === currentTarget) {\r\n            handleClose(event);\r\n        }\r\n    }\r\n    function handleModalOnMouseDown(event) {\r\n        setCurrentTarget(event.target);\r\n    }\r\n    function handleEscapeKeyDown(event) {\r\n        if (event.key === 'Escape') {\r\n            event.preventDefault();\r\n            event.stopPropagation();\r\n            props.onEscKeyDown &&\r\n                typeof props.onEscKeyDown === 'function' &&\r\n                props.onEscKeyDown(event);\r\n            //Supports nested modals\r\n            const modalsInDom = document.querySelectorAll('[aria-modal=\"true\"]').length;\r\n            if (modalCount <= 1 && modalsInDom !== 1) {\r\n                if (document.getElementById(id).contains(event.target)) {\r\n                    handleClose(event);\r\n                }\r\n                else {\r\n                    headingRef.current.focus();\r\n                }\r\n            }\r\n            else {\r\n                handleClose(event);\r\n            }\r\n        }\r\n    }\r\n    function handleClose(event) {\r\n        event?.stopPropagation();\r\n        setTimeout(() => {\r\n            if (!props.isModalClosingControlledManually) {\r\n                setIsModalOpen(false);\r\n            }\r\n            lastFocus.current?.focus();\r\n            onClose && typeof onClose === 'function' && onClose();\r\n        }, 0);\r\n    }\r\n    const isInverse = useIsInverse(props.isInverse);\r\n    const other = omit(['onEscKeyDown'], rest);\r\n    const theme = React.useContext(ThemeContext);\r\n    const i18n = React.useContext(I18nContext);\r\n    const CloseIconButton = (React.createElement(CloseIcon, { size: magma.iconSizes[closeButtonSize]\r\n            ? magma.iconSizes[closeButtonSize]\r\n            : magma.iconSizes.medium }));\r\n    // Fix for server-side rendering\r\n    if (typeof document === 'undefined') {\r\n        return null;\r\n    }\r\n    return ReactDOM.createPortal(React.createElement(\"div\", { ref: focusTrapElement },\r\n        React.createElement(Global, { styles: css `\n            html {\n              overflow: ${isOpen ? 'hidden' : 'auto'};\n            }\n          ` }),\r\n        React.createElement(ModalContainer, Object.assign({ \"aria-labelledby\": header ? headingId : null, \"aria-label\": !header ? ariaLabel : null, \"aria-modal\": true, \"data-testid\": testId, id: id, modalCount: modalCount, onClick: isBackgroundClickDisabled ? null : handleModalClick, onMouseDown: isBackgroundClickDisabled ? null : handleModalOnMouseDown, role: \"dialog\", style: containerStyle, theme: theme, isOpen: isModalOpen }, containerTransition, { unmountOnExit: unmountOnExit, hasDrawerAnimation: hasDrawerAnimation }),\r\n            React.createElement(ModalContent, Object.assign({}, other, { \"data-testid\": \"modal-content\", id: contentId, ref: ref, showBackgroundOverlay: showBackgroundOverlay, theme: theme }),\r\n                header && (React.createElement(ModalHeader, { theme: theme }, header && (React.createElement(H1, { id: headingId, isInverse: isInverse, level: 1, ref: headingRef, visualStyle: TypographyVisualStyle.headingSmall, tabIndex: -1, theme: theme }, header)))),\r\n                React.createElement(ModalWrapper, { ref: bodyRef, theme: theme }, children),\r\n                !isCloseButtonHidden && (React.createElement(CloseBtn, { theme: theme },\r\n                    React.createElement(IconButton, { \"aria-label\": closeAriaLabel ? closeAriaLabel : i18n.modal.closeAriaLabel, color: ButtonColor.primary, icon: CloseIconButton, isInverse: isInverse, onClick: handleClose, testId: \"modal-closebtn\", variant: ButtonVariant.link }))))),\r\n        showBackgroundOverlay && (React.createElement(ModalBackdrop, { \"data-testid\": \"modal-backdrop\", onMouseDown: isBackgroundClickDisabled ? undefined : handleClose, fade: hasDrawerAnimation, isOpen: isModalOpen, style: modalCount >= 2 && { zIndex: '998' }, unmountOnExit: true, theme: theme }))), document.getElementsByTagName('body')[0]);\r\n});\r\n//# sourceMappingURL=Modal.js.map"]} */"));
|
|
15064
15297
|
var H1 = /*#__PURE__*/_styled(Heading, {
|
|
15065
15298
|
target: "e1pxemtw1",
|
|
15066
15299
|
label: "H1"
|
|
@@ -15072,23 +15305,20 @@ var H1 = /*#__PURE__*/_styled(Heading, {
|
|
|
15072
15305
|
return props.isInverse ? props.theme.colors.neutral100 : props.theme.colors.neutral700;
|
|
15073
15306
|
}, ";margin:0;padding-right:", function (props) {
|
|
15074
15307
|
return props.theme.spaceScale.spacing10;
|
|
15075
|
-
}, ";font-weight:600;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Modal.tsx"],"names":[],"mappings":"AA+F2B","file":"Modal.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css, Global } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport ReactDOM from 'react-dom';\r\nimport { CloseIcon } from 'react-magma-icons';\r\nimport { useFocusLock } from '../../hooks/useFocusLock';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { magma } from '../../theme/magma';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { omit, useGenerateId, usePrevious } from '../../utils';\r\nimport { ButtonColor, ButtonVariant } from '../Button';\r\nimport { Heading } from '../Heading';\r\nimport { IconButton } from '../IconButton';\r\nimport { Transition } from '../Transition';\r\nimport { TypographyVisualStyle } from '../Typography';\r\nexport var ModalSize;\r\n(function (ModalSize) {\r\n    ModalSize[\"large\"] = \"large\";\r\n    ModalSize[\"medium\"] = \"medium\";\r\n    ModalSize[\"small\"] = \"small\";\r\n})(ModalSize || (ModalSize = {}));\r\nconst ModalContainer = styled(Transition) `\n  bottom: 0;\n  left: 0;\n  overflow-y: auto;\n  padding: ${props => props.theme.spaceScale.spacing03};\n  right: 0;\n  top: 0;\n  z-index: ${props => (props.modalCount >= 2 ? '999' : '998')};\n`;\r\nconst ModalBackdrop = styled(Transition) `\n  backdrop-filter: blur(3px);\n  background: ${props => transparentize(0.4, props.theme.colors.neutral900)};\n  bottom: 0;\n  left: 0;\n  right: 0;\n  top: 0;\n  z-index: 997;\n  position: fixed;\n`;\r\nconst ModalContent = styled.div `\n  background: ${props => props.isInverse\r\n    ? props.theme.colors.primary600\r\n    : props.theme.colors.neutral100};\n  border: ${props => {\r\n    if (!props.showBackgroundOverlay && props.isInverse) {\r\n        return `1px solid ${transparentize(0.5, props.theme.colors.tertiary)}`;\r\n    }\r\n    return 'none';\r\n}};\n  border-radius: ${props => props.theme.borderRadius};\n  box-shadow: ${props => {\r\n    const amount = props.isInverse ? 0.82 : 0.6;\r\n    return `0 2px 6px ${transparentize(amount, props.theme.colors.neutral900)}`;\r\n}};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  margin: 0 auto;\n  position: relative;\n  z-index: 1000;\n\n  max-width: ${props => {\r\n    switch (props.size) {\r\n        case 'large':\r\n            return props.theme.modal.width.large;\r\n        case 'small':\r\n            return props.theme.modal.width.small;\r\n        default:\r\n            return props.theme.modal.width.medium;\r\n    }\r\n}};\n\n  @media (min-width: ${props => props.theme.breakpoints.small}px) {\n    margin: ${props => props.theme.spaceScale.spacing08} auto;\n  }\n`;\r\nconst ModalHeader = styled.div `\n  padding: ${props => props.theme.spaceScale.spacing05}\n    ${props => props.theme.spaceScale.spacing05} 0\n    ${props => props.theme.spaceScale.spacing05};\n  @media (min-width: ${props => props.theme.breakpoints.small}px) {\n    padding: ${props => props.theme.spaceScale.spacing06}\n      ${props => props.theme.spaceScale.spacing06} 0\n      ${props => props.theme.spaceScale.spacing06};\n  }\n`;\r\nconst ModalWrapper = styled.div `\n  padding: ${props => props.theme.spaceScale.spacing05};\n  @media (min-width: ${props => props.theme.breakpoints.small}px) {\n    padding: ${props => props.theme.spaceScale.spacing06};\n  }\n`;\r\nconst H1 = styled(Heading) `\n  font-size: ${props => props.theme.typographyVisualStyles.headingSmall.desktop.fontSize};\n  line-height: ${props => props.theme.typographyVisualStyles.headingSmall.desktop.lineHeight};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  margin: 0;\n  padding-right: ${props => props.theme.spaceScale.spacing10};\n  font-weight: 600;\n`;\r\nconst CloseBtn = styled.span `\n  position: absolute;\n  top: 0;\n  right: 0;\n  margin: ${props => props.theme.spaceScale.spacing02};\n`;\r\nexport const Modal = React.forwardRef((props, ref) => {\r\n    const { ariaLabel, children, closeAriaLabel, closeButtonSize, containerStyle, containerTransition = { slideTop: true }, isBackgroundClickDisabled, isEscKeyDownDisabled, header, isCloseButtonHidden, isOpen, unmountOnExit = true, testId, isModalClosingControlledManually, headerRef, onClose, showBackgroundOverlay = true, ...rest } = props;\r\n    const lastFocus = React.useRef();\r\n    const headingRef = React.useRef();\r\n    const bodyRef = React.useRef();\r\n    const id = useGenerateId(props.id);\r\n    const headingId = `${id}_heading`;\r\n    const contentId = `${id}_content`;\r\n    const [isModalOpen, setIsModalOpen] = React.useState(isOpen);\r\n    const [currentTarget, setCurrentTarget] = React.useState(null);\r\n    const [modalCount, setModalCount] = React.useState(0);\r\n    const focusTrapElement = useFocusLock(isModalOpen, headingRef, bodyRef);\r\n    const prevOpen = usePrevious(isOpen);\r\n    React.useEffect(() => {\r\n        if (isModalClosingControlledManually &&\r\n            prevOpen &&\r\n            !isOpen &&\r\n            isModalOpen) {\r\n            setIsModalOpen(false);\r\n        }\r\n        else if (!prevOpen && isOpen) {\r\n            setIsModalOpen(true);\r\n            if (headerRef && typeof headerRef === 'function') {\r\n                headerRef(headingRef);\r\n            }\r\n        }\r\n        else if (prevOpen && !isOpen && isModalOpen) {\r\n            handleClose();\r\n        }\r\n    }, [isOpen]);\r\n    React.useEffect(() => {\r\n        if (isModalOpen) {\r\n            lastFocus.current = document.activeElement;\r\n            const count = document.querySelectorAll('[aria-modal=\"true\"]').length;\r\n            setModalCount(count);\r\n            if (!isEscKeyDownDisabled) {\r\n                document.body.addEventListener('keydown', handleEscapeKeyDown, false);\r\n            }\r\n        }\r\n        return () => {\r\n            document.body.removeEventListener('keydown', handleEscapeKeyDown, false);\r\n        };\r\n    }, [isModalOpen]);\r\n    function handleModalClick(event) {\r\n        if (!document.getElementById(contentId).contains(event.target) &&\r\n            event.target === currentTarget) {\r\n            handleClose(event);\r\n        }\r\n    }\r\n    function handleModalOnMouseDown(event) {\r\n        setCurrentTarget(event.target);\r\n    }\r\n    function handleEscapeKeyDown(event) {\r\n        if (event.key === 'Escape') {\r\n            event.preventDefault();\r\n            event.stopPropagation();\r\n            props.onEscKeyDown &&\r\n                typeof props.onEscKeyDown === 'function' &&\r\n                props.onEscKeyDown(event);\r\n            //Supports nested modals\r\n            const modalsInDom = document.querySelectorAll('[aria-modal=\"true\"]').length;\r\n            if (modalCount <= 1 && modalsInDom !== 1) {\r\n                if (document.getElementById(id).contains(event.target)) {\r\n                    handleClose(event);\r\n                }\r\n                else {\r\n                    headingRef.current.focus();\r\n                }\r\n            }\r\n            else {\r\n                handleClose(event);\r\n            }\r\n        }\r\n    }\r\n    function handleClose(event) {\r\n        event?.stopPropagation();\r\n        setTimeout(() => {\r\n            if (!props.isModalClosingControlledManually) {\r\n                setIsModalOpen(false);\r\n            }\r\n            lastFocus.current?.focus();\r\n            onClose && typeof onClose === 'function' && onClose();\r\n        }, 0);\r\n    }\r\n    const isInverse = useIsInverse(props.isInverse);\r\n    const other = omit(['onEscKeyDown'], rest);\r\n    const theme = React.useContext(ThemeContext);\r\n    const i18n = React.useContext(I18nContext);\r\n    const CloseIconButton = (React.createElement(CloseIcon, { size: magma.iconSizes[closeButtonSize]\r\n            ? magma.iconSizes[closeButtonSize]\r\n            : magma.iconSizes.medium }));\r\n    return isModalOpen\r\n        ? ReactDOM.createPortal(React.createElement(\"div\", { ref: focusTrapElement },\r\n            React.createElement(Global, { styles: css `\n                html {\n                  overflow: ${isOpen ? 'hidden' : 'auto'};\n                }\n              ` }),\r\n            React.createElement(ModalContainer, Object.assign({ \"aria-labelledby\": header ? headingId : null, \"aria-label\": !header ? ariaLabel : null, \"aria-modal\": true, \"data-testid\": testId, id: id, modalCount: modalCount, onClick: isBackgroundClickDisabled ? null : handleModalClick, onMouseDown: isBackgroundClickDisabled ? null : handleModalOnMouseDown, role: \"dialog\", style: containerStyle, theme: theme, isOpen: isModalOpen }, containerTransition, { unmountOnExit: unmountOnExit }),\r\n                React.createElement(ModalContent, Object.assign({}, other, { \"data-testid\": \"modal-content\", id: contentId, ref: ref, showBackgroundOverlay: showBackgroundOverlay, theme: theme }),\r\n                    header && (React.createElement(ModalHeader, { theme: theme }, header && (React.createElement(H1, { id: headingId, isInverse: isInverse, level: 1, ref: headingRef, visualStyle: TypographyVisualStyle.headingSmall, tabIndex: -1, theme: theme }, header)))),\r\n                    React.createElement(ModalWrapper, { ref: bodyRef, theme: theme }, children),\r\n                    !isCloseButtonHidden && (React.createElement(CloseBtn, { theme: theme },\r\n                        React.createElement(IconButton, { \"aria-label\": closeAriaLabel\r\n                                ? closeAriaLabel\r\n                                : i18n.modal.closeAriaLabel, color: ButtonColor.primary, icon: CloseIconButton, isInverse: isInverse, onClick: handleClose, testId: \"modal-closebtn\", variant: ButtonVariant.link }))))),\r\n            showBackgroundOverlay && (React.createElement(ModalBackdrop, { \"data-testid\": \"modal-backdrop\", onMouseDown: isBackgroundClickDisabled\r\n                    ? event => event.preventDefault()\r\n                    : null, fade: true, isOpen: isModalOpen, style: modalCount >= 2 && { zIndex: '998' }, unmountOnExit: true, theme: theme }))), document.getElementsByTagName('body')[0])\r\n        : null;\r\n});\r\n//# sourceMappingURL=Modal.js.map"]} */"));
|
|
15308
|
+
}, ";font-weight:600;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Modal.tsx"],"names":[],"mappings":"AAgG2B","file":"Modal.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css, Global } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport ReactDOM from 'react-dom';\r\nimport { CloseIcon } from 'react-magma-icons';\r\nimport { useFocusLock } from '../../hooks/useFocusLock';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { magma } from '../../theme/magma';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { omit, useGenerateId, usePrevious } from '../../utils';\r\nimport { ButtonColor, ButtonVariant } from '../Button';\r\nimport { Heading } from '../Heading';\r\nimport { IconButton } from '../IconButton';\r\nimport { Transition } from '../Transition';\r\nimport { TypographyVisualStyle } from '../Typography';\r\nexport var ModalSize;\r\n(function (ModalSize) {\r\n    ModalSize[\"large\"] = \"large\";\r\n    ModalSize[\"medium\"] = \"medium\";\r\n    ModalSize[\"small\"] = \"small\";\r\n})(ModalSize || (ModalSize = {}));\r\nconst ModalContainer = styled(Transition) `\n  position: fixed;\n  bottom: 0;\n  left: 0;\n  overflow-y: auto;\n  padding: ${props => props.theme.spaceScale.spacing03};\n  right: 0;\n  top: 0;\n  z-index: ${props => (props.modalCount >= 2 ? '999' : '998')};\n`;\r\nconst ModalBackdrop = styled(Transition) `\n  backdrop-filter: blur(3px);\n  background: ${props => transparentize(0.4, props.theme.colors.neutral900)};\n  bottom: 0;\n  left: 0;\n  right: 0;\n  top: 0;\n  z-index: 997;\n  position: fixed;\n`;\r\nconst ModalContent = styled.div `\n  background: ${props => props.isInverse\r\n    ? props.theme.colors.primary600\r\n    : props.theme.colors.neutral100};\n  border: ${props => {\r\n    if (!props.showBackgroundOverlay && props.isInverse) {\r\n        return `1px solid ${transparentize(0.5, props.theme.colors.tertiary)}`;\r\n    }\r\n    return 'none';\r\n}};\n  border-radius: ${props => props.theme.borderRadius};\n  box-shadow: ${props => {\r\n    const amount = props.isInverse ? 0.82 : 0.6;\r\n    return `0 2px 6px ${transparentize(amount, props.theme.colors.neutral900)}`;\r\n}};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  margin: 0 auto;\n  position: relative;\n  z-index: 1000;\n\n  max-width: ${props => {\r\n    switch (props.size) {\r\n        case 'large':\r\n            return props.theme.modal.width.large;\r\n        case 'small':\r\n            return props.theme.modal.width.small;\r\n        default:\r\n            return props.theme.modal.width.medium;\r\n    }\r\n}};\n\n  @media (min-width: ${props => props.theme.breakpoints.small}px) {\n    margin: ${props => props.theme.spaceScale.spacing08} auto;\n  }\n`;\r\nconst ModalHeader = styled.div `\n  padding: ${props => props.theme.spaceScale.spacing05}\n    ${props => props.theme.spaceScale.spacing05} 0\n    ${props => props.theme.spaceScale.spacing05};\n  @media (min-width: ${props => props.theme.breakpoints.small}px) {\n    padding: ${props => props.theme.spaceScale.spacing06}\n      ${props => props.theme.spaceScale.spacing06} 0\n      ${props => props.theme.spaceScale.spacing06};\n  }\n`;\r\nconst ModalWrapper = styled.div `\n  padding: ${props => props.theme.spaceScale.spacing05};\n  @media (min-width: ${props => props.theme.breakpoints.small}px) {\n    padding: ${props => props.theme.spaceScale.spacing06};\n  }\n`;\r\nconst H1 = styled(Heading) `\n  font-size: ${props => props.theme.typographyVisualStyles.headingSmall.desktop.fontSize};\n  line-height: ${props => props.theme.typographyVisualStyles.headingSmall.desktop.lineHeight};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  margin: 0;\n  padding-right: ${props => props.theme.spaceScale.spacing10};\n  font-weight: 600;\n`;\r\nconst CloseBtn = styled.span `\n  position: absolute;\n  top: 0;\n  right: 0;\n  margin: ${props => props.theme.spaceScale.spacing02};\n`;\r\nexport const Modal = React.forwardRef((props, ref) => {\r\n    const { ariaLabel, children, closeAriaLabel, closeButtonSize, containerStyle, containerTransition, isBackgroundClickDisabled, isEscKeyDownDisabled, header, isCloseButtonHidden, isOpen, unmountOnExit = true, testId, isModalClosingControlledManually, headerRef, onClose, hasDrawerAnimation, showBackgroundOverlay = true, ...rest } = props;\r\n    const lastFocus = React.useRef();\r\n    const headingRef = React.useRef();\r\n    const bodyRef = React.useRef();\r\n    const id = useGenerateId(props.id);\r\n    const headingId = `${id}_heading`;\r\n    const contentId = `${id}_content`;\r\n    const [isModalOpen, setIsModalOpen] = React.useState(isOpen);\r\n    const [currentTarget, setCurrentTarget] = React.useState(null);\r\n    const [modalCount, setModalCount] = React.useState(0);\r\n    const focusTrapElement = useFocusLock(isModalOpen, headingRef, bodyRef);\r\n    const prevOpen = usePrevious(isOpen);\r\n    React.useEffect(() => {\r\n        if (isModalClosingControlledManually &&\r\n            prevOpen &&\r\n            !isOpen &&\r\n            isModalOpen) {\r\n            setIsModalOpen(false);\r\n        }\r\n        else if (!prevOpen && isOpen) {\r\n            setIsModalOpen(true);\r\n            if (headerRef && typeof headerRef === 'function') {\r\n                headerRef(headingRef);\r\n            }\r\n        }\r\n        else if (prevOpen && !isOpen && isModalOpen) {\r\n            handleClose();\r\n        }\r\n    }, [isOpen]);\r\n    React.useEffect(() => {\r\n        if (isModalOpen) {\r\n            lastFocus.current = document.activeElement;\r\n            const count = document.querySelectorAll('[aria-modal=\"true\"]').length;\r\n            setModalCount(count);\r\n            if (!isEscKeyDownDisabled) {\r\n                document.body.addEventListener('keydown', handleEscapeKeyDown, false);\r\n            }\r\n        }\r\n        return () => {\r\n            document.body.removeEventListener('keydown', handleEscapeKeyDown, false);\r\n        };\r\n    }, [isModalOpen]);\r\n    function handleModalClick(event) {\r\n        if (!document.getElementById(contentId).contains(event.target) &&\r\n            event.target === currentTarget) {\r\n            handleClose(event);\r\n        }\r\n    }\r\n    function handleModalOnMouseDown(event) {\r\n        setCurrentTarget(event.target);\r\n    }\r\n    function handleEscapeKeyDown(event) {\r\n        if (event.key === 'Escape') {\r\n            event.preventDefault();\r\n            event.stopPropagation();\r\n            props.onEscKeyDown &&\r\n                typeof props.onEscKeyDown === 'function' &&\r\n                props.onEscKeyDown(event);\r\n            //Supports nested modals\r\n            const modalsInDom = document.querySelectorAll('[aria-modal=\"true\"]').length;\r\n            if (modalCount <= 1 && modalsInDom !== 1) {\r\n                if (document.getElementById(id).contains(event.target)) {\r\n                    handleClose(event);\r\n                }\r\n                else {\r\n                    headingRef.current.focus();\r\n                }\r\n            }\r\n            else {\r\n                handleClose(event);\r\n            }\r\n        }\r\n    }\r\n    function handleClose(event) {\r\n        event?.stopPropagation();\r\n        setTimeout(() => {\r\n            if (!props.isModalClosingControlledManually) {\r\n                setIsModalOpen(false);\r\n            }\r\n            lastFocus.current?.focus();\r\n            onClose && typeof onClose === 'function' && onClose();\r\n        }, 0);\r\n    }\r\n    const isInverse = useIsInverse(props.isInverse);\r\n    const other = omit(['onEscKeyDown'], rest);\r\n    const theme = React.useContext(ThemeContext);\r\n    const i18n = React.useContext(I18nContext);\r\n    const CloseIconButton = (React.createElement(CloseIcon, { size: magma.iconSizes[closeButtonSize]\r\n            ? magma.iconSizes[closeButtonSize]\r\n            : magma.iconSizes.medium }));\r\n    // Fix for server-side rendering\r\n    if (typeof document === 'undefined') {\r\n        return null;\r\n    }\r\n    return ReactDOM.createPortal(React.createElement(\"div\", { ref: focusTrapElement },\r\n        React.createElement(Global, { styles: css `\n            html {\n              overflow: ${isOpen ? 'hidden' : 'auto'};\n            }\n          ` }),\r\n        React.createElement(ModalContainer, Object.assign({ \"aria-labelledby\": header ? headingId : null, \"aria-label\": !header ? ariaLabel : null, \"aria-modal\": true, \"data-testid\": testId, id: id, modalCount: modalCount, onClick: isBackgroundClickDisabled ? null : handleModalClick, onMouseDown: isBackgroundClickDisabled ? null : handleModalOnMouseDown, role: \"dialog\", style: containerStyle, theme: theme, isOpen: isModalOpen }, containerTransition, { unmountOnExit: unmountOnExit, hasDrawerAnimation: hasDrawerAnimation }),\r\n            React.createElement(ModalContent, Object.assign({}, other, { \"data-testid\": \"modal-content\", id: contentId, ref: ref, showBackgroundOverlay: showBackgroundOverlay, theme: theme }),\r\n                header && (React.createElement(ModalHeader, { theme: theme }, header && (React.createElement(H1, { id: headingId, isInverse: isInverse, level: 1, ref: headingRef, visualStyle: TypographyVisualStyle.headingSmall, tabIndex: -1, theme: theme }, header)))),\r\n                React.createElement(ModalWrapper, { ref: bodyRef, theme: theme }, children),\r\n                !isCloseButtonHidden && (React.createElement(CloseBtn, { theme: theme },\r\n                    React.createElement(IconButton, { \"aria-label\": closeAriaLabel ? closeAriaLabel : i18n.modal.closeAriaLabel, color: ButtonColor.primary, icon: CloseIconButton, isInverse: isInverse, onClick: handleClose, testId: \"modal-closebtn\", variant: ButtonVariant.link }))))),\r\n        showBackgroundOverlay && (React.createElement(ModalBackdrop, { \"data-testid\": \"modal-backdrop\", onMouseDown: isBackgroundClickDisabled ? undefined : handleClose, fade: hasDrawerAnimation, isOpen: isModalOpen, style: modalCount >= 2 && { zIndex: '998' }, unmountOnExit: true, theme: theme }))), document.getElementsByTagName('body')[0]);\r\n});\r\n//# sourceMappingURL=Modal.js.map"]} */"));
|
|
15076
15309
|
var CloseBtn = /*#__PURE__*/_styled("span", {
|
|
15077
15310
|
target: "e1pxemtw0",
|
|
15078
15311
|
label: "CloseBtn"
|
|
15079
15312
|
})("position:absolute;top:0;right:0;margin:", function (props) {
|
|
15080
15313
|
return props.theme.spaceScale.spacing02;
|
|
15081
|
-
}, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Modal.tsx"],"names":[],"mappings":"AAyG6B","file":"Modal.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css, Global } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport ReactDOM from 'react-dom';\r\nimport { CloseIcon } from 'react-magma-icons';\r\nimport { useFocusLock } from '../../hooks/useFocusLock';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { magma } from '../../theme/magma';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { omit, useGenerateId, usePrevious } from '../../utils';\r\nimport { ButtonColor, ButtonVariant } from '../Button';\r\nimport { Heading } from '../Heading';\r\nimport { IconButton } from '../IconButton';\r\nimport { Transition } from '../Transition';\r\nimport { TypographyVisualStyle } from '../Typography';\r\nexport var ModalSize;\r\n(function (ModalSize) {\r\n    ModalSize[\"large\"] = \"large\";\r\n    ModalSize[\"medium\"] = \"medium\";\r\n    ModalSize[\"small\"] = \"small\";\r\n})(ModalSize || (ModalSize = {}));\r\nconst ModalContainer = styled(Transition) `\n  bottom: 0;\n  left: 0;\n  overflow-y: auto;\n  padding: ${props => props.theme.spaceScale.spacing03};\n  right: 0;\n  top: 0;\n  z-index: ${props => (props.modalCount >= 2 ? '999' : '998')};\n`;\r\nconst ModalBackdrop = styled(Transition) `\n  backdrop-filter: blur(3px);\n  background: ${props => transparentize(0.4, props.theme.colors.neutral900)};\n  bottom: 0;\n  left: 0;\n  right: 0;\n  top: 0;\n  z-index: 997;\n  position: fixed;\n`;\r\nconst ModalContent = styled.div `\n  background: ${props => props.isInverse\r\n    ? props.theme.colors.primary600\r\n    : props.theme.colors.neutral100};\n  border: ${props => {\r\n    if (!props.showBackgroundOverlay && props.isInverse) {\r\n        return `1px solid ${transparentize(0.5, props.theme.colors.tertiary)}`;\r\n    }\r\n    return 'none';\r\n}};\n  border-radius: ${props => props.theme.borderRadius};\n  box-shadow: ${props => {\r\n    const amount = props.isInverse ? 0.82 : 0.6;\r\n    return `0 2px 6px ${transparentize(amount, props.theme.colors.neutral900)}`;\r\n}};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  margin: 0 auto;\n  position: relative;\n  z-index: 1000;\n\n  max-width: ${props => {\r\n    switch (props.size) {\r\n        case 'large':\r\n            return props.theme.modal.width.large;\r\n        case 'small':\r\n            return props.theme.modal.width.small;\r\n        default:\r\n            return props.theme.modal.width.medium;\r\n    }\r\n}};\n\n  @media (min-width: ${props => props.theme.breakpoints.small}px) {\n    margin: ${props => props.theme.spaceScale.spacing08} auto;\n  }\n`;\r\nconst ModalHeader = styled.div `\n  padding: ${props => props.theme.spaceScale.spacing05}\n    ${props => props.theme.spaceScale.spacing05} 0\n    ${props => props.theme.spaceScale.spacing05};\n  @media (min-width: ${props => props.theme.breakpoints.small}px) {\n    padding: ${props => props.theme.spaceScale.spacing06}\n      ${props => props.theme.spaceScale.spacing06} 0\n      ${props => props.theme.spaceScale.spacing06};\n  }\n`;\r\nconst ModalWrapper = styled.div `\n  padding: ${props => props.theme.spaceScale.spacing05};\n  @media (min-width: ${props => props.theme.breakpoints.small}px) {\n    padding: ${props => props.theme.spaceScale.spacing06};\n  }\n`;\r\nconst H1 = styled(Heading) `\n  font-size: ${props => props.theme.typographyVisualStyles.headingSmall.desktop.fontSize};\n  line-height: ${props => props.theme.typographyVisualStyles.headingSmall.desktop.lineHeight};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  margin: 0;\n  padding-right: ${props => props.theme.spaceScale.spacing10};\n  font-weight: 600;\n`;\r\nconst CloseBtn = styled.span `\n  position: absolute;\n  top: 0;\n  right: 0;\n  margin: ${props => props.theme.spaceScale.spacing02};\n`;\r\nexport const Modal = React.forwardRef((props, ref) => {\r\n    const { ariaLabel, children, closeAriaLabel, closeButtonSize, containerStyle, containerTransition = { slideTop: true }, isBackgroundClickDisabled, isEscKeyDownDisabled, header, isCloseButtonHidden, isOpen, unmountOnExit = true, testId, isModalClosingControlledManually, headerRef, onClose, showBackgroundOverlay = true, ...rest } = props;\r\n    const lastFocus = React.useRef();\r\n    const headingRef = React.useRef();\r\n    const bodyRef = React.useRef();\r\n    const id = useGenerateId(props.id);\r\n    const headingId = `${id}_heading`;\r\n    const contentId = `${id}_content`;\r\n    const [isModalOpen, setIsModalOpen] = React.useState(isOpen);\r\n    const [currentTarget, setCurrentTarget] = React.useState(null);\r\n    const [modalCount, setModalCount] = React.useState(0);\r\n    const focusTrapElement = useFocusLock(isModalOpen, headingRef, bodyRef);\r\n    const prevOpen = usePrevious(isOpen);\r\n    React.useEffect(() => {\r\n        if (isModalClosingControlledManually &&\r\n            prevOpen &&\r\n            !isOpen &&\r\n            isModalOpen) {\r\n            setIsModalOpen(false);\r\n        }\r\n        else if (!prevOpen && isOpen) {\r\n            setIsModalOpen(true);\r\n            if (headerRef && typeof headerRef === 'function') {\r\n                headerRef(headingRef);\r\n            }\r\n        }\r\n        else if (prevOpen && !isOpen && isModalOpen) {\r\n            handleClose();\r\n        }\r\n    }, [isOpen]);\r\n    React.useEffect(() => {\r\n        if (isModalOpen) {\r\n            lastFocus.current = document.activeElement;\r\n            const count = document.querySelectorAll('[aria-modal=\"true\"]').length;\r\n            setModalCount(count);\r\n            if (!isEscKeyDownDisabled) {\r\n                document.body.addEventListener('keydown', handleEscapeKeyDown, false);\r\n            }\r\n        }\r\n        return () => {\r\n            document.body.removeEventListener('keydown', handleEscapeKeyDown, false);\r\n        };\r\n    }, [isModalOpen]);\r\n    function handleModalClick(event) {\r\n        if (!document.getElementById(contentId).contains(event.target) &&\r\n            event.target === currentTarget) {\r\n            handleClose(event);\r\n        }\r\n    }\r\n    function handleModalOnMouseDown(event) {\r\n        setCurrentTarget(event.target);\r\n    }\r\n    function handleEscapeKeyDown(event) {\r\n        if (event.key === 'Escape') {\r\n            event.preventDefault();\r\n            event.stopPropagation();\r\n            props.onEscKeyDown &&\r\n                typeof props.onEscKeyDown === 'function' &&\r\n                props.onEscKeyDown(event);\r\n            //Supports nested modals\r\n            const modalsInDom = document.querySelectorAll('[aria-modal=\"true\"]').length;\r\n            if (modalCount <= 1 && modalsInDom !== 1) {\r\n                if (document.getElementById(id).contains(event.target)) {\r\n                    handleClose(event);\r\n                }\r\n                else {\r\n                    headingRef.current.focus();\r\n                }\r\n            }\r\n            else {\r\n                handleClose(event);\r\n            }\r\n        }\r\n    }\r\n    function handleClose(event) {\r\n        event?.stopPropagation();\r\n        setTimeout(() => {\r\n            if (!props.isModalClosingControlledManually) {\r\n                setIsModalOpen(false);\r\n            }\r\n            lastFocus.current?.focus();\r\n            onClose && typeof onClose === 'function' && onClose();\r\n        }, 0);\r\n    }\r\n    const isInverse = useIsInverse(props.isInverse);\r\n    const other = omit(['onEscKeyDown'], rest);\r\n    const theme = React.useContext(ThemeContext);\r\n    const i18n = React.useContext(I18nContext);\r\n    const CloseIconButton = (React.createElement(CloseIcon, { size: magma.iconSizes[closeButtonSize]\r\n            ? magma.iconSizes[closeButtonSize]\r\n            : magma.iconSizes.medium }));\r\n    return isModalOpen\r\n        ? ReactDOM.createPortal(React.createElement(\"div\", { ref: focusTrapElement },\r\n            React.createElement(Global, { styles: css `\n                html {\n                  overflow: ${isOpen ? 'hidden' : 'auto'};\n                }\n              ` }),\r\n            React.createElement(ModalContainer, Object.assign({ \"aria-labelledby\": header ? headingId : null, \"aria-label\": !header ? ariaLabel : null, \"aria-modal\": true, \"data-testid\": testId, id: id, modalCount: modalCount, onClick: isBackgroundClickDisabled ? null : handleModalClick, onMouseDown: isBackgroundClickDisabled ? null : handleModalOnMouseDown, role: \"dialog\", style: containerStyle, theme: theme, isOpen: isModalOpen }, containerTransition, { unmountOnExit: unmountOnExit }),\r\n                React.createElement(ModalContent, Object.assign({}, other, { \"data-testid\": \"modal-content\", id: contentId, ref: ref, showBackgroundOverlay: showBackgroundOverlay, theme: theme }),\r\n                    header && (React.createElement(ModalHeader, { theme: theme }, header && (React.createElement(H1, { id: headingId, isInverse: isInverse, level: 1, ref: headingRef, visualStyle: TypographyVisualStyle.headingSmall, tabIndex: -1, theme: theme }, header)))),\r\n                    React.createElement(ModalWrapper, { ref: bodyRef, theme: theme }, children),\r\n                    !isCloseButtonHidden && (React.createElement(CloseBtn, { theme: theme },\r\n                        React.createElement(IconButton, { \"aria-label\": closeAriaLabel\r\n                                ? closeAriaLabel\r\n                                : i18n.modal.closeAriaLabel, color: ButtonColor.primary, icon: CloseIconButton, isInverse: isInverse, onClick: handleClose, testId: \"modal-closebtn\", variant: ButtonVariant.link }))))),\r\n            showBackgroundOverlay && (React.createElement(ModalBackdrop, { \"data-testid\": \"modal-backdrop\", onMouseDown: isBackgroundClickDisabled\r\n                    ? event => event.preventDefault()\r\n                    : null, fade: true, isOpen: isModalOpen, style: modalCount >= 2 && { zIndex: '998' }, unmountOnExit: true, theme: theme }))), document.getElementsByTagName('body')[0])\r\n        : null;\r\n});\r\n//# sourceMappingURL=Modal.js.map"]} */"));
|
|
15314
|
+
}, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Modal.tsx"],"names":[],"mappings":"AA0G6B","file":"Modal.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css, Global } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport ReactDOM from 'react-dom';\r\nimport { CloseIcon } from 'react-magma-icons';\r\nimport { useFocusLock } from '../../hooks/useFocusLock';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { magma } from '../../theme/magma';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { omit, useGenerateId, usePrevious } from '../../utils';\r\nimport { ButtonColor, ButtonVariant } from '../Button';\r\nimport { Heading } from '../Heading';\r\nimport { IconButton } from '../IconButton';\r\nimport { Transition } from '../Transition';\r\nimport { TypographyVisualStyle } from '../Typography';\r\nexport var ModalSize;\r\n(function (ModalSize) {\r\n    ModalSize[\"large\"] = \"large\";\r\n    ModalSize[\"medium\"] = \"medium\";\r\n    ModalSize[\"small\"] = \"small\";\r\n})(ModalSize || (ModalSize = {}));\r\nconst ModalContainer = styled(Transition) `\n  position: fixed;\n  bottom: 0;\n  left: 0;\n  overflow-y: auto;\n  padding: ${props => props.theme.spaceScale.spacing03};\n  right: 0;\n  top: 0;\n  z-index: ${props => (props.modalCount >= 2 ? '999' : '998')};\n`;\r\nconst ModalBackdrop = styled(Transition) `\n  backdrop-filter: blur(3px);\n  background: ${props => transparentize(0.4, props.theme.colors.neutral900)};\n  bottom: 0;\n  left: 0;\n  right: 0;\n  top: 0;\n  z-index: 997;\n  position: fixed;\n`;\r\nconst ModalContent = styled.div `\n  background: ${props => props.isInverse\r\n    ? props.theme.colors.primary600\r\n    : props.theme.colors.neutral100};\n  border: ${props => {\r\n    if (!props.showBackgroundOverlay && props.isInverse) {\r\n        return `1px solid ${transparentize(0.5, props.theme.colors.tertiary)}`;\r\n    }\r\n    return 'none';\r\n}};\n  border-radius: ${props => props.theme.borderRadius};\n  box-shadow: ${props => {\r\n    const amount = props.isInverse ? 0.82 : 0.6;\r\n    return `0 2px 6px ${transparentize(amount, props.theme.colors.neutral900)}`;\r\n}};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  margin: 0 auto;\n  position: relative;\n  z-index: 1000;\n\n  max-width: ${props => {\r\n    switch (props.size) {\r\n        case 'large':\r\n            return props.theme.modal.width.large;\r\n        case 'small':\r\n            return props.theme.modal.width.small;\r\n        default:\r\n            return props.theme.modal.width.medium;\r\n    }\r\n}};\n\n  @media (min-width: ${props => props.theme.breakpoints.small}px) {\n    margin: ${props => props.theme.spaceScale.spacing08} auto;\n  }\n`;\r\nconst ModalHeader = styled.div `\n  padding: ${props => props.theme.spaceScale.spacing05}\n    ${props => props.theme.spaceScale.spacing05} 0\n    ${props => props.theme.spaceScale.spacing05};\n  @media (min-width: ${props => props.theme.breakpoints.small}px) {\n    padding: ${props => props.theme.spaceScale.spacing06}\n      ${props => props.theme.spaceScale.spacing06} 0\n      ${props => props.theme.spaceScale.spacing06};\n  }\n`;\r\nconst ModalWrapper = styled.div `\n  padding: ${props => props.theme.spaceScale.spacing05};\n  @media (min-width: ${props => props.theme.breakpoints.small}px) {\n    padding: ${props => props.theme.spaceScale.spacing06};\n  }\n`;\r\nconst H1 = styled(Heading) `\n  font-size: ${props => props.theme.typographyVisualStyles.headingSmall.desktop.fontSize};\n  line-height: ${props => props.theme.typographyVisualStyles.headingSmall.desktop.lineHeight};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  margin: 0;\n  padding-right: ${props => props.theme.spaceScale.spacing10};\n  font-weight: 600;\n`;\r\nconst CloseBtn = styled.span `\n  position: absolute;\n  top: 0;\n  right: 0;\n  margin: ${props => props.theme.spaceScale.spacing02};\n`;\r\nexport const Modal = React.forwardRef((props, ref) => {\r\n    const { ariaLabel, children, closeAriaLabel, closeButtonSize, containerStyle, containerTransition, isBackgroundClickDisabled, isEscKeyDownDisabled, header, isCloseButtonHidden, isOpen, unmountOnExit = true, testId, isModalClosingControlledManually, headerRef, onClose, hasDrawerAnimation, showBackgroundOverlay = true, ...rest } = props;\r\n    const lastFocus = React.useRef();\r\n    const headingRef = React.useRef();\r\n    const bodyRef = React.useRef();\r\n    const id = useGenerateId(props.id);\r\n    const headingId = `${id}_heading`;\r\n    const contentId = `${id}_content`;\r\n    const [isModalOpen, setIsModalOpen] = React.useState(isOpen);\r\n    const [currentTarget, setCurrentTarget] = React.useState(null);\r\n    const [modalCount, setModalCount] = React.useState(0);\r\n    const focusTrapElement = useFocusLock(isModalOpen, headingRef, bodyRef);\r\n    const prevOpen = usePrevious(isOpen);\r\n    React.useEffect(() => {\r\n        if (isModalClosingControlledManually &&\r\n            prevOpen &&\r\n            !isOpen &&\r\n            isModalOpen) {\r\n            setIsModalOpen(false);\r\n        }\r\n        else if (!prevOpen && isOpen) {\r\n            setIsModalOpen(true);\r\n            if (headerRef && typeof headerRef === 'function') {\r\n                headerRef(headingRef);\r\n            }\r\n        }\r\n        else if (prevOpen && !isOpen && isModalOpen) {\r\n            handleClose();\r\n        }\r\n    }, [isOpen]);\r\n    React.useEffect(() => {\r\n        if (isModalOpen) {\r\n            lastFocus.current = document.activeElement;\r\n            const count = document.querySelectorAll('[aria-modal=\"true\"]').length;\r\n            setModalCount(count);\r\n            if (!isEscKeyDownDisabled) {\r\n                document.body.addEventListener('keydown', handleEscapeKeyDown, false);\r\n            }\r\n        }\r\n        return () => {\r\n            document.body.removeEventListener('keydown', handleEscapeKeyDown, false);\r\n        };\r\n    }, [isModalOpen]);\r\n    function handleModalClick(event) {\r\n        if (!document.getElementById(contentId).contains(event.target) &&\r\n            event.target === currentTarget) {\r\n            handleClose(event);\r\n        }\r\n    }\r\n    function handleModalOnMouseDown(event) {\r\n        setCurrentTarget(event.target);\r\n    }\r\n    function handleEscapeKeyDown(event) {\r\n        if (event.key === 'Escape') {\r\n            event.preventDefault();\r\n            event.stopPropagation();\r\n            props.onEscKeyDown &&\r\n                typeof props.onEscKeyDown === 'function' &&\r\n                props.onEscKeyDown(event);\r\n            //Supports nested modals\r\n            const modalsInDom = document.querySelectorAll('[aria-modal=\"true\"]').length;\r\n            if (modalCount <= 1 && modalsInDom !== 1) {\r\n                if (document.getElementById(id).contains(event.target)) {\r\n                    handleClose(event);\r\n                }\r\n                else {\r\n                    headingRef.current.focus();\r\n                }\r\n            }\r\n            else {\r\n                handleClose(event);\r\n            }\r\n        }\r\n    }\r\n    function handleClose(event) {\r\n        event?.stopPropagation();\r\n        setTimeout(() => {\r\n            if (!props.isModalClosingControlledManually) {\r\n                setIsModalOpen(false);\r\n            }\r\n            lastFocus.current?.focus();\r\n            onClose && typeof onClose === 'function' && onClose();\r\n        }, 0);\r\n    }\r\n    const isInverse = useIsInverse(props.isInverse);\r\n    const other = omit(['onEscKeyDown'], rest);\r\n    const theme = React.useContext(ThemeContext);\r\n    const i18n = React.useContext(I18nContext);\r\n    const CloseIconButton = (React.createElement(CloseIcon, { size: magma.iconSizes[closeButtonSize]\r\n            ? magma.iconSizes[closeButtonSize]\r\n            : magma.iconSizes.medium }));\r\n    // Fix for server-side rendering\r\n    if (typeof document === 'undefined') {\r\n        return null;\r\n    }\r\n    return ReactDOM.createPortal(React.createElement(\"div\", { ref: focusTrapElement },\r\n        React.createElement(Global, { styles: css `\n            html {\n              overflow: ${isOpen ? 'hidden' : 'auto'};\n            }\n          ` }),\r\n        React.createElement(ModalContainer, Object.assign({ \"aria-labelledby\": header ? headingId : null, \"aria-label\": !header ? ariaLabel : null, \"aria-modal\": true, \"data-testid\": testId, id: id, modalCount: modalCount, onClick: isBackgroundClickDisabled ? null : handleModalClick, onMouseDown: isBackgroundClickDisabled ? null : handleModalOnMouseDown, role: \"dialog\", style: containerStyle, theme: theme, isOpen: isModalOpen }, containerTransition, { unmountOnExit: unmountOnExit, hasDrawerAnimation: hasDrawerAnimation }),\r\n            React.createElement(ModalContent, Object.assign({}, other, { \"data-testid\": \"modal-content\", id: contentId, ref: ref, showBackgroundOverlay: showBackgroundOverlay, theme: theme }),\r\n                header && (React.createElement(ModalHeader, { theme: theme }, header && (React.createElement(H1, { id: headingId, isInverse: isInverse, level: 1, ref: headingRef, visualStyle: TypographyVisualStyle.headingSmall, tabIndex: -1, theme: theme }, header)))),\r\n                React.createElement(ModalWrapper, { ref: bodyRef, theme: theme }, children),\r\n                !isCloseButtonHidden && (React.createElement(CloseBtn, { theme: theme },\r\n                    React.createElement(IconButton, { \"aria-label\": closeAriaLabel ? closeAriaLabel : i18n.modal.closeAriaLabel, color: ButtonColor.primary, icon: CloseIconButton, isInverse: isInverse, onClick: handleClose, testId: \"modal-closebtn\", variant: ButtonVariant.link }))))),\r\n        showBackgroundOverlay && (React.createElement(ModalBackdrop, { \"data-testid\": \"modal-backdrop\", onMouseDown: isBackgroundClickDisabled ? undefined : handleClose, fade: hasDrawerAnimation, isOpen: isModalOpen, style: modalCount >= 2 && { zIndex: '998' }, unmountOnExit: true, theme: theme }))), document.getElementsByTagName('body')[0]);\r\n});\r\n//# sourceMappingURL=Modal.js.map"]} */"));
|
|
15082
15315
|
var Modal = /*#__PURE__*/forwardRef(function (props, ref) {
|
|
15083
15316
|
var ariaLabel = props.ariaLabel,
|
|
15084
15317
|
children = props.children,
|
|
15085
15318
|
closeAriaLabel = props.closeAriaLabel,
|
|
15086
15319
|
closeButtonSize = props.closeButtonSize,
|
|
15087
15320
|
containerStyle = props.containerStyle,
|
|
15088
|
-
|
|
15089
|
-
containerTransition = _props$containerTrans === void 0 ? {
|
|
15090
|
-
slideTop: true
|
|
15091
|
-
} : _props$containerTrans,
|
|
15321
|
+
containerTransition = props.containerTransition,
|
|
15092
15322
|
isBackgroundClickDisabled = props.isBackgroundClickDisabled,
|
|
15093
15323
|
isEscKeyDownDisabled = props.isEscKeyDownDisabled,
|
|
15094
15324
|
header = props.header,
|
|
@@ -15100,6 +15330,7 @@ var Modal = /*#__PURE__*/forwardRef(function (props, ref) {
|
|
|
15100
15330
|
isModalClosingControlledManually = props.isModalClosingControlledManually,
|
|
15101
15331
|
headerRef = props.headerRef,
|
|
15102
15332
|
onClose = props.onClose,
|
|
15333
|
+
hasDrawerAnimation = props.hasDrawerAnimation,
|
|
15103
15334
|
_props$showBackground = props.showBackgroundOverlay,
|
|
15104
15335
|
showBackgroundOverlay = _props$showBackground === void 0 ? true : _props$showBackground,
|
|
15105
15336
|
rest = _objectWithoutPropertiesLoose(props, _excluded$1i);
|
|
@@ -15189,10 +15420,14 @@ var Modal = /*#__PURE__*/forwardRef(function (props, ref) {
|
|
|
15189
15420
|
var CloseIconButton = createElement(CloseIcon, {
|
|
15190
15421
|
size: magma.iconSizes[closeButtonSize] ? magma.iconSizes[closeButtonSize] : magma.iconSizes.medium
|
|
15191
15422
|
});
|
|
15192
|
-
|
|
15423
|
+
// Fix for server-side rendering
|
|
15424
|
+
if (typeof document === 'undefined') {
|
|
15425
|
+
return null;
|
|
15426
|
+
}
|
|
15427
|
+
return ReactDOM__default.createPortal(createElement("div", {
|
|
15193
15428
|
ref: focusTrapElement
|
|
15194
15429
|
}, createElement(Global, {
|
|
15195
|
-
styles: /*#__PURE__*/css("html{overflow:", isOpen ? 'hidden' : 'auto', ";};label:styles;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Modal.tsx"],"names":[],"mappings":"AA4MsD","file":"Modal.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css, Global } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport ReactDOM from 'react-dom';\r\nimport { CloseIcon } from 'react-magma-icons';\r\nimport { useFocusLock } from '../../hooks/useFocusLock';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { magma } from '../../theme/magma';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { omit, useGenerateId, usePrevious } from '../../utils';\r\nimport { ButtonColor, ButtonVariant } from '../Button';\r\nimport { Heading } from '../Heading';\r\nimport { IconButton } from '../IconButton';\r\nimport { Transition } from '../Transition';\r\nimport { TypographyVisualStyle } from '../Typography';\r\nexport var ModalSize;\r\n(function (ModalSize) {\r\n    ModalSize[\"large\"] = \"large\";\r\n    ModalSize[\"medium\"] = \"medium\";\r\n    ModalSize[\"small\"] = \"small\";\r\n})(ModalSize || (ModalSize = {}));\r\nconst ModalContainer = styled(Transition) `\n  bottom: 0;\n  left: 0;\n  overflow-y: auto;\n  padding: ${props => props.theme.spaceScale.spacing03};\n  right: 0;\n  top: 0;\n  z-index: ${props => (props.modalCount >= 2 ? '999' : '998')};\n`;\r\nconst ModalBackdrop = styled(Transition) `\n  backdrop-filter: blur(3px);\n  background: ${props => transparentize(0.4, props.theme.colors.neutral900)};\n  bottom: 0;\n  left: 0;\n  right: 0;\n  top: 0;\n  z-index: 997;\n  position: fixed;\n`;\r\nconst ModalContent = styled.div `\n  background: ${props => props.isInverse\r\n    ? props.theme.colors.primary600\r\n    : props.theme.colors.neutral100};\n  border: ${props => {\r\n    if (!props.showBackgroundOverlay && props.isInverse) {\r\n        return `1px solid ${transparentize(0.5, props.theme.colors.tertiary)}`;\r\n    }\r\n    return 'none';\r\n}};\n  border-radius: ${props => props.theme.borderRadius};\n  box-shadow: ${props => {\r\n    const amount = props.isInverse ? 0.82 : 0.6;\r\n    return `0 2px 6px ${transparentize(amount, props.theme.colors.neutral900)}`;\r\n}};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  margin: 0 auto;\n  position: relative;\n  z-index: 1000;\n\n  max-width: ${props => {\r\n    switch (props.size) {\r\n        case 'large':\r\n            return props.theme.modal.width.large;\r\n        case 'small':\r\n            return props.theme.modal.width.small;\r\n        default:\r\n            return props.theme.modal.width.medium;\r\n    }\r\n}};\n\n  @media (min-width: ${props => props.theme.breakpoints.small}px) {\n    margin: ${props => props.theme.spaceScale.spacing08} auto;\n  }\n`;\r\nconst ModalHeader = styled.div `\n  padding: ${props => props.theme.spaceScale.spacing05}\n    ${props => props.theme.spaceScale.spacing05} 0\n    ${props => props.theme.spaceScale.spacing05};\n  @media (min-width: ${props => props.theme.breakpoints.small}px) {\n    padding: ${props => props.theme.spaceScale.spacing06}\n      ${props => props.theme.spaceScale.spacing06} 0\n      ${props => props.theme.spaceScale.spacing06};\n  }\n`;\r\nconst ModalWrapper = styled.div `\n  padding: ${props => props.theme.spaceScale.spacing05};\n  @media (min-width: ${props => props.theme.breakpoints.small}px) {\n    padding: ${props => props.theme.spaceScale.spacing06};\n  }\n`;\r\nconst H1 = styled(Heading) `\n  font-size: ${props => props.theme.typographyVisualStyles.headingSmall.desktop.fontSize};\n  line-height: ${props => props.theme.typographyVisualStyles.headingSmall.desktop.lineHeight};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  margin: 0;\n  padding-right: ${props => props.theme.spaceScale.spacing10};\n  font-weight: 600;\n`;\r\nconst CloseBtn = styled.span `\n  position: absolute;\n  top: 0;\n  right: 0;\n  margin: ${props => props.theme.spaceScale.spacing02};\n`;\r\nexport const Modal = React.forwardRef((props, ref) => {\r\n    const { ariaLabel, children, closeAriaLabel, closeButtonSize, containerStyle, containerTransition = { slideTop: true }, isBackgroundClickDisabled, isEscKeyDownDisabled, header, isCloseButtonHidden, isOpen, unmountOnExit = true, testId, isModalClosingControlledManually, headerRef, onClose, showBackgroundOverlay = true, ...rest } = props;\r\n    const lastFocus = React.useRef();\r\n    const headingRef = React.useRef();\r\n    const bodyRef = React.useRef();\r\n    const id = useGenerateId(props.id);\r\n    const headingId = `${id}_heading`;\r\n    const contentId = `${id}_content`;\r\n    const [isModalOpen, setIsModalOpen] = React.useState(isOpen);\r\n    const [currentTarget, setCurrentTarget] = React.useState(null);\r\n    const [modalCount, setModalCount] = React.useState(0);\r\n    const focusTrapElement = useFocusLock(isModalOpen, headingRef, bodyRef);\r\n    const prevOpen = usePrevious(isOpen);\r\n    React.useEffect(() => {\r\n        if (isModalClosingControlledManually &&\r\n            prevOpen &&\r\n            !isOpen &&\r\n            isModalOpen) {\r\n            setIsModalOpen(false);\r\n        }\r\n        else if (!prevOpen && isOpen) {\r\n            setIsModalOpen(true);\r\n            if (headerRef && typeof headerRef === 'function') {\r\n                headerRef(headingRef);\r\n            }\r\n        }\r\n        else if (prevOpen && !isOpen && isModalOpen) {\r\n            handleClose();\r\n        }\r\n    }, [isOpen]);\r\n    React.useEffect(() => {\r\n        if (isModalOpen) {\r\n            lastFocus.current = document.activeElement;\r\n            const count = document.querySelectorAll('[aria-modal=\"true\"]').length;\r\n            setModalCount(count);\r\n            if (!isEscKeyDownDisabled) {\r\n                document.body.addEventListener('keydown', handleEscapeKeyDown, false);\r\n            }\r\n        }\r\n        return () => {\r\n            document.body.removeEventListener('keydown', handleEscapeKeyDown, false);\r\n        };\r\n    }, [isModalOpen]);\r\n    function handleModalClick(event) {\r\n        if (!document.getElementById(contentId).contains(event.target) &&\r\n            event.target === currentTarget) {\r\n            handleClose(event);\r\n        }\r\n    }\r\n    function handleModalOnMouseDown(event) {\r\n        setCurrentTarget(event.target);\r\n    }\r\n    function handleEscapeKeyDown(event) {\r\n        if (event.key === 'Escape') {\r\n            event.preventDefault();\r\n            event.stopPropagation();\r\n            props.onEscKeyDown &&\r\n                typeof props.onEscKeyDown === 'function' &&\r\n                props.onEscKeyDown(event);\r\n            //Supports nested modals\r\n            const modalsInDom = document.querySelectorAll('[aria-modal=\"true\"]').length;\r\n            if (modalCount <= 1 && modalsInDom !== 1) {\r\n                if (document.getElementById(id).contains(event.target)) {\r\n                    handleClose(event);\r\n                }\r\n                else {\r\n                    headingRef.current.focus();\r\n                }\r\n            }\r\n            else {\r\n                handleClose(event);\r\n            }\r\n        }\r\n    }\r\n    function handleClose(event) {\r\n        event?.stopPropagation();\r\n        setTimeout(() => {\r\n            if (!props.isModalClosingControlledManually) {\r\n                setIsModalOpen(false);\r\n            }\r\n            lastFocus.current?.focus();\r\n            onClose && typeof onClose === 'function' && onClose();\r\n        }, 0);\r\n    }\r\n    const isInverse = useIsInverse(props.isInverse);\r\n    const other = omit(['onEscKeyDown'], rest);\r\n    const theme = React.useContext(ThemeContext);\r\n    const i18n = React.useContext(I18nContext);\r\n    const CloseIconButton = (React.createElement(CloseIcon, { size: magma.iconSizes[closeButtonSize]\r\n            ? magma.iconSizes[closeButtonSize]\r\n            : magma.iconSizes.medium }));\r\n    return isModalOpen\r\n        ? ReactDOM.createPortal(React.createElement(\"div\", { ref: focusTrapElement },\r\n            React.createElement(Global, { styles: css `\n                html {\n                  overflow: ${isOpen ? 'hidden' : 'auto'};\n                }\n              ` }),\r\n            React.createElement(ModalContainer, Object.assign({ \"aria-labelledby\": header ? headingId : null, \"aria-label\": !header ? ariaLabel : null, \"aria-modal\": true, \"data-testid\": testId, id: id, modalCount: modalCount, onClick: isBackgroundClickDisabled ? null : handleModalClick, onMouseDown: isBackgroundClickDisabled ? null : handleModalOnMouseDown, role: \"dialog\", style: containerStyle, theme: theme, isOpen: isModalOpen }, containerTransition, { unmountOnExit: unmountOnExit }),\r\n                React.createElement(ModalContent, Object.assign({}, other, { \"data-testid\": \"modal-content\", id: contentId, ref: ref, showBackgroundOverlay: showBackgroundOverlay, theme: theme }),\r\n                    header && (React.createElement(ModalHeader, { theme: theme }, header && (React.createElement(H1, { id: headingId, isInverse: isInverse, level: 1, ref: headingRef, visualStyle: TypographyVisualStyle.headingSmall, tabIndex: -1, theme: theme }, header)))),\r\n                    React.createElement(ModalWrapper, { ref: bodyRef, theme: theme }, children),\r\n                    !isCloseButtonHidden && (React.createElement(CloseBtn, { theme: theme },\r\n                        React.createElement(IconButton, { \"aria-label\": closeAriaLabel\r\n                                ? closeAriaLabel\r\n                                : i18n.modal.closeAriaLabel, color: ButtonColor.primary, icon: CloseIconButton, isInverse: isInverse, onClick: handleClose, testId: \"modal-closebtn\", variant: ButtonVariant.link }))))),\r\n            showBackgroundOverlay && (React.createElement(ModalBackdrop, { \"data-testid\": \"modal-backdrop\", onMouseDown: isBackgroundClickDisabled\r\n                    ? event => event.preventDefault()\r\n                    : null, fade: true, isOpen: isModalOpen, style: modalCount >= 2 && { zIndex: '998' }, unmountOnExit: true, theme: theme }))), document.getElementsByTagName('body')[0])\r\n        : null;\r\n});\r\n//# sourceMappingURL=Modal.js.map"]} */"))
|
|
15430
|
+
styles: /*#__PURE__*/css("html{overflow:", isOpen ? 'hidden' : 'auto', ";};label:styles;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Modal.tsx"],"names":[],"mappings":"AAgNkD","file":"Modal.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css, Global } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport ReactDOM from 'react-dom';\r\nimport { CloseIcon } from 'react-magma-icons';\r\nimport { useFocusLock } from '../../hooks/useFocusLock';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { magma } from '../../theme/magma';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { omit, useGenerateId, usePrevious } from '../../utils';\r\nimport { ButtonColor, ButtonVariant } from '../Button';\r\nimport { Heading } from '../Heading';\r\nimport { IconButton } from '../IconButton';\r\nimport { Transition } from '../Transition';\r\nimport { TypographyVisualStyle } from '../Typography';\r\nexport var ModalSize;\r\n(function (ModalSize) {\r\n    ModalSize[\"large\"] = \"large\";\r\n    ModalSize[\"medium\"] = \"medium\";\r\n    ModalSize[\"small\"] = \"small\";\r\n})(ModalSize || (ModalSize = {}));\r\nconst ModalContainer = styled(Transition) `\n  position: fixed;\n  bottom: 0;\n  left: 0;\n  overflow-y: auto;\n  padding: ${props => props.theme.spaceScale.spacing03};\n  right: 0;\n  top: 0;\n  z-index: ${props => (props.modalCount >= 2 ? '999' : '998')};\n`;\r\nconst ModalBackdrop = styled(Transition) `\n  backdrop-filter: blur(3px);\n  background: ${props => transparentize(0.4, props.theme.colors.neutral900)};\n  bottom: 0;\n  left: 0;\n  right: 0;\n  top: 0;\n  z-index: 997;\n  position: fixed;\n`;\r\nconst ModalContent = styled.div `\n  background: ${props => props.isInverse\r\n    ? props.theme.colors.primary600\r\n    : props.theme.colors.neutral100};\n  border: ${props => {\r\n    if (!props.showBackgroundOverlay && props.isInverse) {\r\n        return `1px solid ${transparentize(0.5, props.theme.colors.tertiary)}`;\r\n    }\r\n    return 'none';\r\n}};\n  border-radius: ${props => props.theme.borderRadius};\n  box-shadow: ${props => {\r\n    const amount = props.isInverse ? 0.82 : 0.6;\r\n    return `0 2px 6px ${transparentize(amount, props.theme.colors.neutral900)}`;\r\n}};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  margin: 0 auto;\n  position: relative;\n  z-index: 1000;\n\n  max-width: ${props => {\r\n    switch (props.size) {\r\n        case 'large':\r\n            return props.theme.modal.width.large;\r\n        case 'small':\r\n            return props.theme.modal.width.small;\r\n        default:\r\n            return props.theme.modal.width.medium;\r\n    }\r\n}};\n\n  @media (min-width: ${props => props.theme.breakpoints.small}px) {\n    margin: ${props => props.theme.spaceScale.spacing08} auto;\n  }\n`;\r\nconst ModalHeader = styled.div `\n  padding: ${props => props.theme.spaceScale.spacing05}\n    ${props => props.theme.spaceScale.spacing05} 0\n    ${props => props.theme.spaceScale.spacing05};\n  @media (min-width: ${props => props.theme.breakpoints.small}px) {\n    padding: ${props => props.theme.spaceScale.spacing06}\n      ${props => props.theme.spaceScale.spacing06} 0\n      ${props => props.theme.spaceScale.spacing06};\n  }\n`;\r\nconst ModalWrapper = styled.div `\n  padding: ${props => props.theme.spaceScale.spacing05};\n  @media (min-width: ${props => props.theme.breakpoints.small}px) {\n    padding: ${props => props.theme.spaceScale.spacing06};\n  }\n`;\r\nconst H1 = styled(Heading) `\n  font-size: ${props => props.theme.typographyVisualStyles.headingSmall.desktop.fontSize};\n  line-height: ${props => props.theme.typographyVisualStyles.headingSmall.desktop.lineHeight};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  margin: 0;\n  padding-right: ${props => props.theme.spaceScale.spacing10};\n  font-weight: 600;\n`;\r\nconst CloseBtn = styled.span `\n  position: absolute;\n  top: 0;\n  right: 0;\n  margin: ${props => props.theme.spaceScale.spacing02};\n`;\r\nexport const Modal = React.forwardRef((props, ref) => {\r\n    const { ariaLabel, children, closeAriaLabel, closeButtonSize, containerStyle, containerTransition, isBackgroundClickDisabled, isEscKeyDownDisabled, header, isCloseButtonHidden, isOpen, unmountOnExit = true, testId, isModalClosingControlledManually, headerRef, onClose, hasDrawerAnimation, showBackgroundOverlay = true, ...rest } = props;\r\n    const lastFocus = React.useRef();\r\n    const headingRef = React.useRef();\r\n    const bodyRef = React.useRef();\r\n    const id = useGenerateId(props.id);\r\n    const headingId = `${id}_heading`;\r\n    const contentId = `${id}_content`;\r\n    const [isModalOpen, setIsModalOpen] = React.useState(isOpen);\r\n    const [currentTarget, setCurrentTarget] = React.useState(null);\r\n    const [modalCount, setModalCount] = React.useState(0);\r\n    const focusTrapElement = useFocusLock(isModalOpen, headingRef, bodyRef);\r\n    const prevOpen = usePrevious(isOpen);\r\n    React.useEffect(() => {\r\n        if (isModalClosingControlledManually &&\r\n            prevOpen &&\r\n            !isOpen &&\r\n            isModalOpen) {\r\n            setIsModalOpen(false);\r\n        }\r\n        else if (!prevOpen && isOpen) {\r\n            setIsModalOpen(true);\r\n            if (headerRef && typeof headerRef === 'function') {\r\n                headerRef(headingRef);\r\n            }\r\n        }\r\n        else if (prevOpen && !isOpen && isModalOpen) {\r\n            handleClose();\r\n        }\r\n    }, [isOpen]);\r\n    React.useEffect(() => {\r\n        if (isModalOpen) {\r\n            lastFocus.current = document.activeElement;\r\n            const count = document.querySelectorAll('[aria-modal=\"true\"]').length;\r\n            setModalCount(count);\r\n            if (!isEscKeyDownDisabled) {\r\n                document.body.addEventListener('keydown', handleEscapeKeyDown, false);\r\n            }\r\n        }\r\n        return () => {\r\n            document.body.removeEventListener('keydown', handleEscapeKeyDown, false);\r\n        };\r\n    }, [isModalOpen]);\r\n    function handleModalClick(event) {\r\n        if (!document.getElementById(contentId).contains(event.target) &&\r\n            event.target === currentTarget) {\r\n            handleClose(event);\r\n        }\r\n    }\r\n    function handleModalOnMouseDown(event) {\r\n        setCurrentTarget(event.target);\r\n    }\r\n    function handleEscapeKeyDown(event) {\r\n        if (event.key === 'Escape') {\r\n            event.preventDefault();\r\n            event.stopPropagation();\r\n            props.onEscKeyDown &&\r\n                typeof props.onEscKeyDown === 'function' &&\r\n                props.onEscKeyDown(event);\r\n            //Supports nested modals\r\n            const modalsInDom = document.querySelectorAll('[aria-modal=\"true\"]').length;\r\n            if (modalCount <= 1 && modalsInDom !== 1) {\r\n                if (document.getElementById(id).contains(event.target)) {\r\n                    handleClose(event);\r\n                }\r\n                else {\r\n                    headingRef.current.focus();\r\n                }\r\n            }\r\n            else {\r\n                handleClose(event);\r\n            }\r\n        }\r\n    }\r\n    function handleClose(event) {\r\n        event?.stopPropagation();\r\n        setTimeout(() => {\r\n            if (!props.isModalClosingControlledManually) {\r\n                setIsModalOpen(false);\r\n            }\r\n            lastFocus.current?.focus();\r\n            onClose && typeof onClose === 'function' && onClose();\r\n        }, 0);\r\n    }\r\n    const isInverse = useIsInverse(props.isInverse);\r\n    const other = omit(['onEscKeyDown'], rest);\r\n    const theme = React.useContext(ThemeContext);\r\n    const i18n = React.useContext(I18nContext);\r\n    const CloseIconButton = (React.createElement(CloseIcon, { size: magma.iconSizes[closeButtonSize]\r\n            ? magma.iconSizes[closeButtonSize]\r\n            : magma.iconSizes.medium }));\r\n    // Fix for server-side rendering\r\n    if (typeof document === 'undefined') {\r\n        return null;\r\n    }\r\n    return ReactDOM.createPortal(React.createElement(\"div\", { ref: focusTrapElement },\r\n        React.createElement(Global, { styles: css `\n            html {\n              overflow: ${isOpen ? 'hidden' : 'auto'};\n            }\n          ` }),\r\n        React.createElement(ModalContainer, Object.assign({ \"aria-labelledby\": header ? headingId : null, \"aria-label\": !header ? ariaLabel : null, \"aria-modal\": true, \"data-testid\": testId, id: id, modalCount: modalCount, onClick: isBackgroundClickDisabled ? null : handleModalClick, onMouseDown: isBackgroundClickDisabled ? null : handleModalOnMouseDown, role: \"dialog\", style: containerStyle, theme: theme, isOpen: isModalOpen }, containerTransition, { unmountOnExit: unmountOnExit, hasDrawerAnimation: hasDrawerAnimation }),\r\n            React.createElement(ModalContent, Object.assign({}, other, { \"data-testid\": \"modal-content\", id: contentId, ref: ref, showBackgroundOverlay: showBackgroundOverlay, theme: theme }),\r\n                header && (React.createElement(ModalHeader, { theme: theme }, header && (React.createElement(H1, { id: headingId, isInverse: isInverse, level: 1, ref: headingRef, visualStyle: TypographyVisualStyle.headingSmall, tabIndex: -1, theme: theme }, header)))),\r\n                React.createElement(ModalWrapper, { ref: bodyRef, theme: theme }, children),\r\n                !isCloseButtonHidden && (React.createElement(CloseBtn, { theme: theme },\r\n                    React.createElement(IconButton, { \"aria-label\": closeAriaLabel ? closeAriaLabel : i18n.modal.closeAriaLabel, color: ButtonColor.primary, icon: CloseIconButton, isInverse: isInverse, onClick: handleClose, testId: \"modal-closebtn\", variant: ButtonVariant.link }))))),\r\n        showBackgroundOverlay && (React.createElement(ModalBackdrop, { \"data-testid\": \"modal-backdrop\", onMouseDown: isBackgroundClickDisabled ? undefined : handleClose, fade: hasDrawerAnimation, isOpen: isModalOpen, style: modalCount >= 2 && { zIndex: '998' }, unmountOnExit: true, theme: theme }))), document.getElementsByTagName('body')[0]);\r\n});\r\n//# sourceMappingURL=Modal.js.map"]} */"))
|
|
15196
15431
|
}), createElement(ModalContainer, Object.assign({
|
|
15197
15432
|
"aria-labelledby": header ? headingId : null,
|
|
15198
15433
|
"aria-label": !header ? ariaLabel : null,
|
|
@@ -15207,7 +15442,8 @@ var Modal = /*#__PURE__*/forwardRef(function (props, ref) {
|
|
|
15207
15442
|
theme: theme,
|
|
15208
15443
|
isOpen: isModalOpen
|
|
15209
15444
|
}, containerTransition, {
|
|
15210
|
-
unmountOnExit: unmountOnExit
|
|
15445
|
+
unmountOnExit: unmountOnExit,
|
|
15446
|
+
hasDrawerAnimation: hasDrawerAnimation
|
|
15211
15447
|
}), createElement(ModalContent, Object.assign({}, other, {
|
|
15212
15448
|
"data-testid": "modal-content",
|
|
15213
15449
|
id: contentId,
|
|
@@ -15239,17 +15475,15 @@ var Modal = /*#__PURE__*/forwardRef(function (props, ref) {
|
|
|
15239
15475
|
variant: ButtonVariant.link
|
|
15240
15476
|
})))), showBackgroundOverlay && createElement(ModalBackdrop, {
|
|
15241
15477
|
"data-testid": "modal-backdrop",
|
|
15242
|
-
onMouseDown: isBackgroundClickDisabled ?
|
|
15243
|
-
|
|
15244
|
-
} : null,
|
|
15245
|
-
fade: true,
|
|
15478
|
+
onMouseDown: isBackgroundClickDisabled ? undefined : handleClose,
|
|
15479
|
+
fade: hasDrawerAnimation,
|
|
15246
15480
|
isOpen: isModalOpen,
|
|
15247
15481
|
style: modalCount >= 2 && {
|
|
15248
15482
|
zIndex: '998'
|
|
15249
15483
|
},
|
|
15250
15484
|
unmountOnExit: true,
|
|
15251
15485
|
theme: theme
|
|
15252
|
-
})), document.getElementsByTagName('body')[0])
|
|
15486
|
+
})), document.getElementsByTagName('body')[0]);
|
|
15253
15487
|
});
|
|
15254
15488
|
|
|
15255
15489
|
var _excluded$1j = ["iconAriaLabel", "isClearable", "isInverse", "isLoading", "labelText", "placeholder", "onSearch", "onClear"];
|
|
@@ -18557,7 +18791,7 @@ var StyledContainer$5 = /*#__PURE__*/_styled("div", {
|
|
|
18557
18791
|
styles: "display:inline-block"
|
|
18558
18792
|
} : {
|
|
18559
18793
|
name: "1r5gb7q",
|
|
18560
|
-
styles: "display:inline-block/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlBvcG92ZXIudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQVdtQyIsImZpbGUiOiJQb3BvdmVyLnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBSZWFjdCBmcm9tICdyZWFjdCc7XHJcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcclxuaW1wb3J0IHsgb2Zmc2V0LCBmbGlwLCBhdXRvVXBkYXRlLCBhcnJvdywgc2hpZnQsIHVzZUZsb2F0aW5nLCB9IGZyb20gJ0BmbG9hdGluZy11aS9yZWFjdCc7XHJcbmltcG9ydCB7IHVzZUlzSW52ZXJzZSB9IGZyb20gJy4uLy4uL2ludmVyc2UnO1xyXG5pbXBvcnQgeyByZXNvbHZlUHJvcHMsIHVzZUZvcmtlZFJlZiwgdXNlR2VuZXJhdGVJZCB9IGZyb20gJy4uLy4uL3V0aWxzJztcclxuaW1wb3J0IHsgQnV0dG9uR3JvdXBDb250ZXh0IH0gZnJvbSAnLi4vQnV0dG9uR3JvdXAnO1xyXG5leHBvcnQgdmFyIFBvcG92ZXJQb3NpdGlvbjtcclxuKGZ1bmN0aW9uIChQb3BvdmVyUG9zaXRpb24pIHtcclxuICAgIFBvcG92ZXJQb3NpdGlvbltcImJvdHRvbVwiXSA9IFwiYm90dG9tXCI7XHJcbiAgICBQb3BvdmVyUG9zaXRpb25bXCJ0b3BcIl0gPSBcInRvcFwiO1xyXG59KShQb3BvdmVyUG9zaXRpb24gfHwgKFBvcG92ZXJQb3NpdGlvbiA9IHt9KSk7XHJcbmNvbnN0IFN0eWxlZENvbnRhaW5lciA9IHN0eWxlZC5kaXYgYFxuICBkaXNwbGF5OiBpbmxpbmUtYmxvY2s7XG5gO1xyXG5leHBvcnQgY29uc3QgUG9wb3ZlckNvbnRleHQgPSBSZWFjdC5jcmVhdGVDb250ZXh0KHtcclxuICAgIGlzT3BlbjogZmFsc2UsXHJcbiAgICBzZXRJc09wZW46ICgpID0+IGZhbHNlLFxyXG59KTtcclxuZXhwb3J0IGZ1bmN0aW9uIGhhc0FjdGl2ZUVsZW1lbnRzQ2hlY2tlcihyZWYpIHtcclxuICAgIHJldHVybiAoQXJyYXkuZnJvbShyZWYuY3VycmVudD8ucXVlcnlTZWxlY3RvckFsbCgnYnV0dG9uLCBbaHJlZl0sIGlucHV0LCBzZWxlY3QsIHRleHRhcmVhLCBbdGFiaW5kZXhdOm5vdChbdGFiaW5kZXg9XCItMVwiXSksIHZpZGVvJykgfHwgW10pLmZpbHRlcigoZWxlbWVudCkgPT4ge1xyXG4gICAgICAgIGNvbnN0IHN0eWxlID0gd2luZG93LmdldENvbXB1dGVkU3R5bGUoZWxlbWVudCk7XHJcbiAgICAgICAgcmV0dXJuIChlbGVtZW50IGluc3RhbmNlb2YgSFRNTEVsZW1lbnQgJiZcclxuICAgICAgICAgICAgc3R5bGUuZGlzcGxheSAhPT0gJ25vbmUnICYmXHJcbiAgICAgICAgICAgIHN0eWxlLnZpc2liaWxpdHkgIT09ICdoaWRkZW4nICYmXHJcbiAgICAgICAgICAgICFlbGVtZW50Lmhhc0F0dHJpYnV0ZSgnZGlzYWJsZWQnKSk7XHJcbiAgICB9KS5sZW5ndGggPiAwKTtcclxufVxyXG5leHBvcnQgY29uc3QgUG9wb3ZlciA9IFJlYWN0LmZvcndhcmRSZWYoKHByb3BzLCBmb3J3YXJkZWRSZWYpID0+IHtcclxuICAgIGNvbnN0IFtpc09wZW4sIHNldElzT3Blbl0gPSBSZWFjdC51c2VTdGF0ZShmYWxzZSk7XHJcbiAgICBjb25zdCBjb250ZXh0UHJvcHMgPSBSZWFjdC51c2VDb250ZXh0KEJ1dHRvbkdyb3VwQ29udGV4dCk7XHJcbiAgICBjb25zdCByZXNvbHZlZFByb3BzID0gcmVzb2x2ZVByb3BzKGNvbnRleHRQcm9wcywgcHJvcHMpO1xyXG4gICAgY29uc3Qgb3duUmVmID0gUmVhY3QudXNlUmVmKCk7XHJcbiAgICBjb25zdCB0b2dnbGVSZWYgPSBSZWFjdC51c2VSZWYoKTtcclxuICAgIGNvbnN0IGNvbnRlbnRSZWYgPSBSZWFjdC51c2VSZWYobnVsbCk7XHJcbiAgICBjb25zdCBwb3BvdmVyQ29udGVudElkID0gUmVhY3QudXNlUmVmKCcnKTtcclxuICAgIGNvbnN0IHBvcG92ZXJUcmlnZ2VySWQgPSBSZWFjdC51c2VSZWYoJycpO1xyXG4gICAgY29uc3QgYXJyb3dSZWYgPSBSZWFjdC51c2VSZWYobnVsbCk7XHJcbiAgICBjb25zdCBoYXNBY3RpdmVFbGVtZW50cyA9IFJlYWN0LnVzZU1lbW8oKCkgPT4gaGFzQWN0aXZlRWxlbWVudHNDaGVja2VyKGNvbnRlbnRSZWYpLCBbY29udGVudFJlZiwgY29udGVudFJlZi5jdXJyZW50XSk7XHJcbiAgICBjb25zdCB7IG9uQ2xvc2UsIG9uT3BlbiwgcG9zaXRpb24gPSBQb3BvdmVyUG9zaXRpb24uYm90dG9tLCBjaGlsZHJlbiwgdGVzdElkLCBtYXhIZWlnaHQsIHdpZHRoLCBob3ZlcmFibGUsIGlzRGlzYWJsZWQsIGhhc1BvaW50ZXIgPSB0cnVlLCBvcGVuQnlEZWZhdWx0LCBpZDogZGVmYXVsdElkLCBhcGlSZWYsIGZvY3VzVHJhcCwgLi4ub3RoZXIgfSA9IHByb3BzO1xyXG4gICAgUmVhY3QudXNlRWZmZWN0KCgpID0+IHtcclxuICAgICAgICBpZiAoYXBpUmVmKSB7XHJcbiAgICAgICAgICAgIGFwaVJlZi5jdXJyZW50ID0ge1xyXG4gICAgICAgICAgICAgICAgY2xvc2VQb3BvdmVyTWFudWFsbHkoZXZlbnQpIHtcclxuICAgICAgICAgICAgICAgICAgICBjbG9zZVBvcG92ZXIoZXZlbnQpO1xyXG4gICAgICAgICAgICAgICAgfSxcclxuICAgICAgICAgICAgfTtcclxuICAgICAgICB9XHJcbiAgICAgICAgaWYgKG9wZW5CeURlZmF1bHQpIHtcclxuICAgICAgICAgICAgb3BlblBvcG92ZXIoKTtcclxuICAgICAgICB9XHJcbiAgICB9LCBbXSk7XHJcbiAgICBSZWFjdC51c2VFZmZlY3QoKCkgPT4ge1xyXG4gICAgICAgIGNvbnN0IGhhbmRsZUVzYyA9IGV2ZW50ID0+IHtcclxuICAgICAgICAgICAgaWYgKGV2ZW50LmtleSA9PT0gJ0VzY2FwZScgJiYgaXNPcGVuKSB7XHJcbiAgICAgICAgICAgICAgICBjbG9zZVBvcG92ZXIoZXZlbnQpO1xyXG4gICAgICAgICAgICB9XHJcbiAgICAgICAgfTtcclxuICAgICAgICB3aW5kb3cuYWRkRXZlbnRMaXN0ZW5lcigna2V5ZG93bicsIGhhbmRsZUVzYyk7XHJcbiAgICAgICAgcmV0dXJuICgpID0+IHtcclxuICAgICAgICAgICAgd2luZG93LnJlbW92ZUV2ZW50TGlzdGVuZXIoJ2tleWRvd24nLCBoYW5kbGVFc2MpO1xyXG4gICAgICAgIH07XHJcbiAgICB9LCBbaXNPcGVuXSk7XHJcbiAgICBjb25zdCBwb3BvdmVySWQgPSB1c2VHZW5lcmF0ZUlkKGRlZmF1bHRJZCk7XHJcbiAgICBwb3BvdmVyVHJpZ2dlcklkLmN1cnJlbnQgPSBgJHtwb3BvdmVySWR9X3RyaWdnZXJgO1xyXG4gICAgcG9wb3ZlckNvbnRlbnRJZC5jdXJyZW50ID0gYCR7cG9wb3ZlcklkfV9jb250ZW50YDtcclxuICAgIGNvbnN0IHJlZiA9IHVzZUZvcmtlZFJlZihmb3J3YXJkZWRSZWYsIG93blJlZik7XHJcbiAgICBjb25zdCBpc0ludmVyc2UgPSB1c2VJc0ludmVyc2UocmVzb2x2ZWRQcm9wcy5pc0ludmVyc2UpO1xyXG4gICAgY29uc3QgaGFuZGxlTW91c2VPdmVyID0gKCkgPT4ge1xyXG4gICAgICAgIGlmIChob3ZlcmFibGUgJiYgIWlzRGlzYWJsZWQgJiYgIWhhc0FjdGl2ZUVsZW1lbnRzKSB7XHJcbiAgICAgICAgICAgIHNldElzT3Blbih0cnVlKTtcclxuICAgICAgICB9XHJcbiAgICB9O1xyXG4gICAgY29uc3QgaGFuZGxlTW91c2VMZWF2ZSA9ICgpID0+
|
|
18794
|
+
styles: "display:inline-block/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Popover.tsx"],"names":[],"mappings":"AAWmC","file":"Popover.tsx","sourcesContent":["import React from 'react';\r\nimport styled from '@emotion/styled';\r\nimport { offset, flip, autoUpdate, arrow, shift, useFloating, } from '@floating-ui/react';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { resolveProps, useForkedRef, useGenerateId } from '../../utils';\r\nimport { ButtonGroupContext } from '../ButtonGroup';\r\nexport var PopoverPosition;\r\n(function (PopoverPosition) {\r\n    PopoverPosition[\"bottom\"] = \"bottom\";\r\n    PopoverPosition[\"top\"] = \"top\";\r\n})(PopoverPosition || (PopoverPosition = {}));\r\nconst StyledContainer = styled.div `\n  display: inline-block;\n`;\r\nexport const PopoverContext = React.createContext({\r\n    isOpen: false,\r\n    setIsOpen: () => false,\r\n});\r\nexport function hasActiveElementsChecker(ref) {\r\n    return (Array.from(ref.current?.querySelectorAll('button, [href], input, select, textarea, [tabindex]:not([tabindex=\"-1\"]), video') || []).filter((element) => {\r\n        const style = window.getComputedStyle(element);\r\n        return (element instanceof HTMLElement &&\r\n            style.display !== 'none' &&\r\n            style.visibility !== 'hidden' &&\r\n            !element.hasAttribute('disabled'));\r\n    }).length > 0);\r\n}\r\nexport const Popover = React.forwardRef((props, forwardedRef) => {\r\n    const [isOpen, setIsOpen] = React.useState(false);\r\n    const contextProps = React.useContext(ButtonGroupContext);\r\n    const resolvedProps = resolveProps(contextProps, props);\r\n    const ownRef = React.useRef();\r\n    const toggleRef = React.useRef();\r\n    const contentRef = React.useRef(null);\r\n    const popoverContentId = React.useRef('');\r\n    const popoverTriggerId = React.useRef('');\r\n    const arrowRef = React.useRef(null);\r\n    const hasActiveElements = React.useMemo(() => hasActiveElementsChecker(contentRef), [contentRef, contentRef.current]);\r\n    const { onClose, onOpen, position = PopoverPosition.bottom, children, testId, maxHeight, width, hoverable, isDisabled, hasPointer = true, openByDefault, id: defaultId, apiRef, focusTrap, ...other } = props;\r\n    React.useEffect(() => {\r\n        if (apiRef) {\r\n            apiRef.current = {\r\n                closePopoverManually(event) {\r\n                    closePopover(event);\r\n                },\r\n            };\r\n        }\r\n        if (openByDefault) {\r\n            openPopover();\r\n        }\r\n    }, []);\r\n    React.useEffect(() => {\r\n        const handleEsc = event => {\r\n            if (event.key === 'Escape' && isOpen) {\r\n                closePopover(event);\r\n            }\r\n        };\r\n        window.addEventListener('keydown', handleEsc);\r\n        return () => {\r\n            window.removeEventListener('keydown', handleEsc);\r\n        };\r\n    }, [isOpen]);\r\n    const popoverId = useGenerateId(defaultId);\r\n    popoverTriggerId.current = `${popoverId}_trigger`;\r\n    popoverContentId.current = `${popoverId}_content`;\r\n    const ref = useForkedRef(forwardedRef, ownRef);\r\n    const isInverse = useIsInverse(resolvedProps.isInverse);\r\n    const handleMouseOver = () => {\r\n        if (hoverable && !isDisabled && !hasActiveElements) {\r\n            setIsOpen(true);\r\n        }\r\n    };\r\n    const handleMouseLeave = () => {\r\n        if (hoverable && !isDisabled && !hasActiveElements) {\r\n            setIsOpen(false);\r\n        }\r\n    };\r\n    function openPopover() {\r\n        setIsOpen(true);\r\n        if (!hoverable) {\r\n            toggleRef.current.focus();\r\n        }\r\n        onOpen && typeof onOpen === 'function' && onOpen();\r\n    }\r\n    function closePopover(event) {\r\n        setIsOpen(false);\r\n        if (toggleRef.current !== event.target && !hoverable) {\r\n            toggleRef.current.focus();\r\n        }\r\n        onClose && typeof onClose === 'function' && onClose(event);\r\n    }\r\n    function handleKeyDown(event) {\r\n        if (event.key === 'Escape') {\r\n            if (isOpen) {\r\n                event.stopPropagation();\r\n            }\r\n            closePopover(event);\r\n        }\r\n    }\r\n    function handlePopoverBlur(event) {\r\n        const { currentTarget, relatedTarget } = event;\r\n        const isInMenu = relatedTarget && currentTarget.contains(relatedTarget);\r\n        if (!isInMenu && isOpen) {\r\n            closePopover(event);\r\n        }\r\n    }\r\n    const { refs, floatingStyles, placement, context, elements, update } = useFloating({\r\n        //flip() - Changes the placement of the floating element to keep it in view.\r\n        //offset() - Translates the floating element along the specified axes. (Space between the Trigger and the Content).\r\n        //shift() - Shifts the floating element along the specified axes to keep it in view within the clipping context or viewport.\r\n        //arrow() - Positions an arrow element pointing at the reference element, ensuring proper alignment.\r\n        middleware: [\r\n            flip(),\r\n            shift({ padding: 12 }),\r\n            offset(hasPointer ? 12 : 4),\r\n            arrow({ element: arrowRef }),\r\n        ],\r\n        placement: position,\r\n        whileElementsMounted: autoUpdate,\r\n    });\r\n    React.useEffect(() => {\r\n        const referenceElement = elements.reference;\r\n        const floatingElement = elements.floating;\r\n        if (isOpen && referenceElement && floatingElement) {\r\n            return autoUpdate(referenceElement, floatingElement, update);\r\n        }\r\n    }, [isOpen, elements, update]);\r\n    const maxHeightString = typeof maxHeight === 'number' ? `${maxHeight}px` : maxHeight;\r\n    const widthString = width === 'target'\r\n        ? `${refs.reference.current?.getBoundingClientRect().width}px`\r\n        : typeof width === 'number'\r\n            ? `${width}px`\r\n            : width;\r\n    const onFocus = () => {\r\n        if (hoverable && !isDisabled && !hasActiveElements) {\r\n            openPopover();\r\n        }\r\n    };\r\n    return (React.createElement(PopoverContext.Provider, { value: {\r\n            floatingStyles,\r\n            position: placement,\r\n            closePopover,\r\n            popoverTriggerId,\r\n            popoverContentId,\r\n            openPopover,\r\n            isInverse,\r\n            isOpen,\r\n            maxHeight: maxHeightString,\r\n            width: widthString,\r\n            contentRef,\r\n            setIsOpen,\r\n            setFloating: refs.setFloating,\r\n            setReference: refs.setReference,\r\n            arrowRef,\r\n            arrowContext: context,\r\n            toggleRef,\r\n            isDisabled,\r\n            hoverable,\r\n            hasPointer,\r\n            focusTrap,\r\n            hasActiveElements,\r\n        } },\r\n        React.createElement(StyledContainer, Object.assign({}, other, { onKeyDown: handleKeyDown, onBlur: handlePopoverBlur, ref: ref, \"data-testid\": testId, onMouseOver: handleMouseOver, onMouseLeave: handleMouseLeave, id: popoverId, onFocus: onFocus }), children)));\r\n});\r\n//# sourceMappingURL=Popover.js.map"]} */",
|
|
18561
18795
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$z
|
|
18562
18796
|
});
|
|
18563
18797
|
var PopoverContext = /*#__PURE__*/React__default.createContext({
|
|
@@ -18660,7 +18894,9 @@ var Popover = /*#__PURE__*/React__default.forwardRef(function (props, forwardedR
|
|
|
18660
18894
|
}
|
|
18661
18895
|
function handleKeyDown(event) {
|
|
18662
18896
|
if (event.key === 'Escape') {
|
|
18663
|
-
|
|
18897
|
+
if (isOpen) {
|
|
18898
|
+
event.stopPropagation();
|
|
18899
|
+
}
|
|
18664
18900
|
closePopover(event);
|
|
18665
18901
|
}
|
|
18666
18902
|
}
|
|
@@ -19216,7 +19452,8 @@ var Drawer = /*#__PURE__*/forwardRef(function (props, ref) {
|
|
|
19216
19452
|
containerStyle: _extends({
|
|
19217
19453
|
padding: '0'
|
|
19218
19454
|
}, containerStyle),
|
|
19219
|
-
containerTransition: transitionPreset[DrawerPosition[position]],
|
|
19455
|
+
containerTransition: position ? transitionPreset[DrawerPosition[position]] : transitionPreset[DrawerPosition[DrawerPosition.top]],
|
|
19456
|
+
hasDrawerAnimation: true,
|
|
19220
19457
|
style: _extends({}, drawerStyle, style)
|
|
19221
19458
|
}, rest));
|
|
19222
19459
|
});
|