@mirai/ui 2.0.1 → 2.0.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/build/components/Calendar/__tests__/__snapshots__/Calendar.test.jsx.snap +32 -32
- package/build/components/Modal/Modal.js +8 -4
- package/build/components/Modal/Modal.js.map +1 -1
- package/build/components/Slider/__tests__/__snapshots__/Slider.test.js.snap +11 -11
- package/build/components/Table/__tests__/__snapshots__/Table.test.js.snap +13 -13
- package/build/primitives/ScrollView/ScrollView.js +77 -25
- package/build/primitives/ScrollView/ScrollView.js.map +1 -1
- package/build/primitives/ScrollView/ScrollView.module.css +53 -7
- package/build/primitives/ScrollView/ScrollView.stories.js +1 -1
- package/build/primitives/ScrollView/ScrollView.stories.js.map +1 -1
- package/build/primitives/ScrollView/__tests__/__snapshots__/ScrollView.test.js.snap +9 -9
- package/package.json +1 -1
|
@@ -6,7 +6,7 @@ exports[`component:<Calendar> desktop environment prop:captions 1`] = `
|
|
|
6
6
|
class="view calendar"
|
|
7
7
|
>
|
|
8
8
|
<ui_scrollview
|
|
9
|
-
class="scrollview snap horizontal
|
|
9
|
+
class="scrollview snap horizontal scrollview"
|
|
10
10
|
>
|
|
11
11
|
<ui_view
|
|
12
12
|
class="view month"
|
|
@@ -1532,7 +1532,7 @@ exports[`component:<Calendar> desktop environment prop:disabledDates 1`] = `
|
|
|
1532
1532
|
class="view calendar"
|
|
1533
1533
|
>
|
|
1534
1534
|
<ui_scrollview
|
|
1535
|
-
class="scrollview snap horizontal
|
|
1535
|
+
class="scrollview snap horizontal scrollview"
|
|
1536
1536
|
>
|
|
1537
1537
|
<ui_view
|
|
1538
1538
|
class="view month"
|
|
@@ -2753,7 +2753,7 @@ exports[`component:<Calendar> desktop environment prop:disabledPast 1`] = `
|
|
|
2753
2753
|
class="view calendar"
|
|
2754
2754
|
>
|
|
2755
2755
|
<ui_scrollview
|
|
2756
|
-
class="scrollview snap horizontal
|
|
2756
|
+
class="scrollview snap horizontal scrollview"
|
|
2757
2757
|
>
|
|
2758
2758
|
<ui_view
|
|
2759
2759
|
class="view month"
|
|
@@ -4000,7 +4000,7 @@ exports[`component:<Calendar> desktop environment prop:format 1`] = `
|
|
|
4000
4000
|
class="view calendar"
|
|
4001
4001
|
>
|
|
4002
4002
|
<ui_scrollview
|
|
4003
|
-
class="scrollview snap horizontal
|
|
4003
|
+
class="scrollview snap horizontal scrollview"
|
|
4004
4004
|
>
|
|
4005
4005
|
<ui_view
|
|
4006
4006
|
class="view month"
|
|
@@ -5221,7 +5221,7 @@ exports[`component:<Calendar> desktop environment prop:from 1`] = `
|
|
|
5221
5221
|
class="view calendar"
|
|
5222
5222
|
>
|
|
5223
5223
|
<ui_scrollview
|
|
5224
|
-
class="scrollview snap horizontal
|
|
5224
|
+
class="scrollview snap horizontal scrollview"
|
|
5225
5225
|
>
|
|
5226
5226
|
<ui_view
|
|
5227
5227
|
class="view month"
|
|
@@ -6442,7 +6442,7 @@ exports[`component:<Calendar> desktop environment prop:highlights 1`] = `
|
|
|
6442
6442
|
class="view calendar"
|
|
6443
6443
|
>
|
|
6444
6444
|
<ui_scrollview
|
|
6445
|
-
class="scrollview snap horizontal
|
|
6445
|
+
class="scrollview snap horizontal scrollview"
|
|
6446
6446
|
>
|
|
6447
6447
|
<ui_view
|
|
6448
6448
|
class="view month"
|
|
@@ -7663,7 +7663,7 @@ exports[`component:<Calendar> desktop environment prop:locale 1`] = `
|
|
|
7663
7663
|
class="view calendar"
|
|
7664
7664
|
>
|
|
7665
7665
|
<ui_scrollview
|
|
7666
|
-
class="scrollview snap horizontal
|
|
7666
|
+
class="scrollview snap horizontal scrollview"
|
|
7667
7667
|
>
|
|
7668
7668
|
<ui_view
|
|
7669
7669
|
class="view month"
|
|
@@ -8884,7 +8884,7 @@ exports[`component:<Calendar> desktop environment prop:locale en-US 1`] = `
|
|
|
8884
8884
|
class="view calendar"
|
|
8885
8885
|
>
|
|
8886
8886
|
<ui_scrollview
|
|
8887
|
-
class="scrollview snap horizontal
|
|
8887
|
+
class="scrollview snap horizontal scrollview"
|
|
8888
8888
|
>
|
|
8889
8889
|
<ui_view
|
|
8890
8890
|
class="view month"
|
|
@@ -10105,7 +10105,7 @@ exports[`component:<Calendar> desktop environment prop:months 1`] = `
|
|
|
10105
10105
|
class="view calendar"
|
|
10106
10106
|
>
|
|
10107
10107
|
<ui_scrollview
|
|
10108
|
-
class="scrollview snap horizontal
|
|
10108
|
+
class="scrollview snap horizontal scrollview"
|
|
10109
10109
|
>
|
|
10110
10110
|
<ui_view
|
|
10111
10111
|
class="view month"
|
|
@@ -11912,7 +11912,7 @@ exports[`component:<Calendar> desktop environment prop:range prop:disabledDates
|
|
|
11912
11912
|
class="view calendar"
|
|
11913
11913
|
>
|
|
11914
11914
|
<ui_scrollview
|
|
11915
|
-
class="scrollview snap horizontal
|
|
11915
|
+
class="scrollview snap horizontal scrollview"
|
|
11916
11916
|
>
|
|
11917
11917
|
<ui_view
|
|
11918
11918
|
class="view month"
|
|
@@ -13133,7 +13133,7 @@ exports[`component:<Calendar> desktop environment prop:range prop:rangeMaxDays 1
|
|
|
13133
13133
|
class="view calendar"
|
|
13134
13134
|
>
|
|
13135
13135
|
<ui_scrollview
|
|
13136
|
-
class="scrollview snap horizontal
|
|
13136
|
+
class="scrollview snap horizontal scrollview"
|
|
13137
13137
|
>
|
|
13138
13138
|
<ui_view
|
|
13139
13139
|
class="view month"
|
|
@@ -14354,7 +14354,7 @@ exports[`component:<Calendar> desktop environment prop:range prop:rangeMinDays 1
|
|
|
14354
14354
|
class="view calendar"
|
|
14355
14355
|
>
|
|
14356
14356
|
<ui_scrollview
|
|
14357
|
-
class="scrollview snap horizontal
|
|
14357
|
+
class="scrollview snap horizontal scrollview"
|
|
14358
14358
|
>
|
|
14359
14359
|
<ui_view
|
|
14360
14360
|
class="view month"
|
|
@@ -15575,7 +15575,7 @@ exports[`component:<Calendar> desktop environment prop:range renders 1`] = `
|
|
|
15575
15575
|
class="view calendar"
|
|
15576
15576
|
>
|
|
15577
15577
|
<ui_scrollview
|
|
15578
|
-
class="scrollview snap horizontal
|
|
15578
|
+
class="scrollview snap horizontal scrollview"
|
|
15579
15579
|
>
|
|
15580
15580
|
<ui_view
|
|
15581
15581
|
class="view month"
|
|
@@ -16796,7 +16796,7 @@ exports[`component:<Calendar> desktop environment prop:to 1`] = `
|
|
|
16796
16796
|
class="view calendar"
|
|
16797
16797
|
>
|
|
16798
16798
|
<ui_scrollview
|
|
16799
|
-
class="scrollview snap horizontal
|
|
16799
|
+
class="scrollview snap horizontal scrollview"
|
|
16800
16800
|
>
|
|
16801
16801
|
<ui_view
|
|
16802
16802
|
class="view month"
|
|
@@ -17991,7 +17991,7 @@ exports[`component:<Calendar> desktop environment renders 1`] = `
|
|
|
17991
17991
|
class="view calendar"
|
|
17992
17992
|
>
|
|
17993
17993
|
<ui_scrollview
|
|
17994
|
-
class="scrollview snap horizontal
|
|
17994
|
+
class="scrollview snap horizontal scrollview"
|
|
17995
17995
|
>
|
|
17996
17996
|
<ui_view
|
|
17997
17997
|
class="view month"
|
|
@@ -19212,7 +19212,7 @@ exports[`component:<Calendar> inherit:className 1`] = `
|
|
|
19212
19212
|
class="view calendar mirai"
|
|
19213
19213
|
>
|
|
19214
19214
|
<ui_scrollview
|
|
19215
|
-
class="scrollview snap horizontal
|
|
19215
|
+
class="scrollview snap horizontal scrollview"
|
|
19216
19216
|
>
|
|
19217
19217
|
<ui_view
|
|
19218
19218
|
class="view month"
|
|
@@ -20433,7 +20433,7 @@ exports[`component:<Calendar> mobile environment prop:captions 1`] = `
|
|
|
20433
20433
|
class="view calendar"
|
|
20434
20434
|
>
|
|
20435
20435
|
<ui_scrollview
|
|
20436
|
-
class="scrollview snap horizontal
|
|
20436
|
+
class="scrollview snap horizontal scrollview"
|
|
20437
20437
|
>
|
|
20438
20438
|
<ui_view
|
|
20439
20439
|
class="view month"
|
|
@@ -21959,7 +21959,7 @@ exports[`component:<Calendar> mobile environment prop:disabledDates 1`] = `
|
|
|
21959
21959
|
class="view calendar"
|
|
21960
21960
|
>
|
|
21961
21961
|
<ui_scrollview
|
|
21962
|
-
class="scrollview snap horizontal
|
|
21962
|
+
class="scrollview snap horizontal scrollview"
|
|
21963
21963
|
>
|
|
21964
21964
|
<ui_view
|
|
21965
21965
|
class="view month"
|
|
@@ -23180,7 +23180,7 @@ exports[`component:<Calendar> mobile environment prop:disabledPast 1`] = `
|
|
|
23180
23180
|
class="view calendar"
|
|
23181
23181
|
>
|
|
23182
23182
|
<ui_scrollview
|
|
23183
|
-
class="scrollview snap horizontal
|
|
23183
|
+
class="scrollview snap horizontal scrollview"
|
|
23184
23184
|
>
|
|
23185
23185
|
<ui_view
|
|
23186
23186
|
class="view month"
|
|
@@ -24427,7 +24427,7 @@ exports[`component:<Calendar> mobile environment prop:format 1`] = `
|
|
|
24427
24427
|
class="view calendar"
|
|
24428
24428
|
>
|
|
24429
24429
|
<ui_scrollview
|
|
24430
|
-
class="scrollview snap horizontal
|
|
24430
|
+
class="scrollview snap horizontal scrollview"
|
|
24431
24431
|
>
|
|
24432
24432
|
<ui_view
|
|
24433
24433
|
class="view month"
|
|
@@ -25648,7 +25648,7 @@ exports[`component:<Calendar> mobile environment prop:from 1`] = `
|
|
|
25648
25648
|
class="view calendar"
|
|
25649
25649
|
>
|
|
25650
25650
|
<ui_scrollview
|
|
25651
|
-
class="scrollview snap horizontal
|
|
25651
|
+
class="scrollview snap horizontal scrollview"
|
|
25652
25652
|
>
|
|
25653
25653
|
<ui_view
|
|
25654
25654
|
class="view month"
|
|
@@ -26869,7 +26869,7 @@ exports[`component:<Calendar> mobile environment prop:highlights 1`] = `
|
|
|
26869
26869
|
class="view calendar"
|
|
26870
26870
|
>
|
|
26871
26871
|
<ui_scrollview
|
|
26872
|
-
class="scrollview snap horizontal
|
|
26872
|
+
class="scrollview snap horizontal scrollview"
|
|
26873
26873
|
>
|
|
26874
26874
|
<ui_view
|
|
26875
26875
|
class="view month"
|
|
@@ -28090,7 +28090,7 @@ exports[`component:<Calendar> mobile environment prop:locale 1`] = `
|
|
|
28090
28090
|
class="view calendar"
|
|
28091
28091
|
>
|
|
28092
28092
|
<ui_scrollview
|
|
28093
|
-
class="scrollview snap horizontal
|
|
28093
|
+
class="scrollview snap horizontal scrollview"
|
|
28094
28094
|
>
|
|
28095
28095
|
<ui_view
|
|
28096
28096
|
class="view month"
|
|
@@ -29311,7 +29311,7 @@ exports[`component:<Calendar> mobile environment prop:locale en-US 1`] = `
|
|
|
29311
29311
|
class="view calendar"
|
|
29312
29312
|
>
|
|
29313
29313
|
<ui_scrollview
|
|
29314
|
-
class="scrollview snap horizontal
|
|
29314
|
+
class="scrollview snap horizontal scrollview"
|
|
29315
29315
|
>
|
|
29316
29316
|
<ui_view
|
|
29317
29317
|
class="view month"
|
|
@@ -30532,7 +30532,7 @@ exports[`component:<Calendar> mobile environment prop:months 1`] = `
|
|
|
30532
30532
|
class="view calendar"
|
|
30533
30533
|
>
|
|
30534
30534
|
<ui_scrollview
|
|
30535
|
-
class="scrollview snap horizontal
|
|
30535
|
+
class="scrollview snap horizontal scrollview"
|
|
30536
30536
|
>
|
|
30537
30537
|
<ui_view
|
|
30538
30538
|
class="view month"
|
|
@@ -32339,7 +32339,7 @@ exports[`component:<Calendar> mobile environment prop:range prop:disabledDates 1
|
|
|
32339
32339
|
class="view calendar"
|
|
32340
32340
|
>
|
|
32341
32341
|
<ui_scrollview
|
|
32342
|
-
class="scrollview snap horizontal
|
|
32342
|
+
class="scrollview snap horizontal scrollview"
|
|
32343
32343
|
>
|
|
32344
32344
|
<ui_view
|
|
32345
32345
|
class="view month"
|
|
@@ -33560,7 +33560,7 @@ exports[`component:<Calendar> mobile environment prop:range prop:rangeMaxDays 1`
|
|
|
33560
33560
|
class="view calendar"
|
|
33561
33561
|
>
|
|
33562
33562
|
<ui_scrollview
|
|
33563
|
-
class="scrollview snap horizontal
|
|
33563
|
+
class="scrollview snap horizontal scrollview"
|
|
33564
33564
|
>
|
|
33565
33565
|
<ui_view
|
|
33566
33566
|
class="view month"
|
|
@@ -34781,7 +34781,7 @@ exports[`component:<Calendar> mobile environment prop:range prop:rangeMinDays 1`
|
|
|
34781
34781
|
class="view calendar"
|
|
34782
34782
|
>
|
|
34783
34783
|
<ui_scrollview
|
|
34784
|
-
class="scrollview snap horizontal
|
|
34784
|
+
class="scrollview snap horizontal scrollview"
|
|
34785
34785
|
>
|
|
34786
34786
|
<ui_view
|
|
34787
34787
|
class="view month"
|
|
@@ -36002,7 +36002,7 @@ exports[`component:<Calendar> mobile environment prop:range renders 1`] = `
|
|
|
36002
36002
|
class="view calendar"
|
|
36003
36003
|
>
|
|
36004
36004
|
<ui_scrollview
|
|
36005
|
-
class="scrollview snap horizontal
|
|
36005
|
+
class="scrollview snap horizontal scrollview"
|
|
36006
36006
|
>
|
|
36007
36007
|
<ui_view
|
|
36008
36008
|
class="view month"
|
|
@@ -37223,7 +37223,7 @@ exports[`component:<Calendar> mobile environment prop:to 1`] = `
|
|
|
37223
37223
|
class="view calendar"
|
|
37224
37224
|
>
|
|
37225
37225
|
<ui_scrollview
|
|
37226
|
-
class="scrollview snap horizontal
|
|
37226
|
+
class="scrollview snap horizontal scrollview"
|
|
37227
37227
|
>
|
|
37228
37228
|
<ui_view
|
|
37229
37229
|
class="view month"
|
|
@@ -38418,7 +38418,7 @@ exports[`component:<Calendar> mobile environment renders 1`] = `
|
|
|
38418
38418
|
class="view calendar"
|
|
38419
38419
|
>
|
|
38420
38420
|
<ui_scrollview
|
|
38421
|
-
class="scrollview snap horizontal
|
|
38421
|
+
class="scrollview snap horizontal scrollview"
|
|
38422
38422
|
>
|
|
38423
38423
|
<ui_view
|
|
38424
38424
|
class="view month"
|
|
@@ -39640,7 +39640,7 @@ exports[`component:<Calendar> testId 1`] = `
|
|
|
39640
39640
|
data-testid="mirai"
|
|
39641
39641
|
>
|
|
39642
39642
|
<ui_scrollview
|
|
39643
|
-
class="scrollview snap horizontal
|
|
39643
|
+
class="scrollview snap horizontal scrollview"
|
|
39644
39644
|
>
|
|
39645
39645
|
<ui_view
|
|
39646
39646
|
class="view month"
|
|
@@ -5,7 +5,6 @@ Object.defineProperty(exports, "__esModule", {
|
|
|
5
5
|
value: true
|
|
6
6
|
});
|
|
7
7
|
exports.Modal = void 0;
|
|
8
|
-
var _dataSources = require("@mirai/data-sources");
|
|
9
8
|
var _propTypes = _interopRequireDefault(require("prop-types"));
|
|
10
9
|
var _react = _interopRequireWildcard(require("react"));
|
|
11
10
|
var _reactDom = _interopRequireDefault(require("react-dom"));
|
|
@@ -34,6 +33,11 @@ function _iterableToArrayLimit(arr, i) { var _i = null == arr ? null : "undefine
|
|
|
34
33
|
function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }
|
|
35
34
|
function _objectWithoutProperties(source, excluded) { if (source == null) return {}; var target = _objectWithoutPropertiesLoose(source, excluded); var key, i; if (Object.getOwnPropertySymbols) { var sourceSymbolKeys = Object.getOwnPropertySymbols(source); for (i = 0; i < sourceSymbolKeys.length; i++) { key = sourceSymbolKeys[i]; if (excluded.indexOf(key) >= 0) continue; if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue; target[key] = source[key]; } } return target; }
|
|
36
35
|
function _objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; var sourceKeys = Object.keys(source); var key, i; for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } return target; }
|
|
36
|
+
// import { Event } from '@mirai/data-sources';
|
|
37
|
+
var Event = {
|
|
38
|
+
publish: function publish() {},
|
|
39
|
+
subscribe: function subscribe() {}
|
|
40
|
+
};
|
|
37
41
|
var Modal = function Modal(_ref) {
|
|
38
42
|
var _ref$blur = _ref.blur,
|
|
39
43
|
blur = _ref$blur === void 0 ? false : _ref$blur,
|
|
@@ -72,7 +76,7 @@ var Modal = function Modal(_ref) {
|
|
|
72
76
|
setDataset = _useState2[1];
|
|
73
77
|
(0, _react.useEffect)(function () {
|
|
74
78
|
if (!visible || !onClose) return;
|
|
75
|
-
|
|
79
|
+
Event.publish(_Modal.EVENT_VISIBLE, {
|
|
76
80
|
visible: visible,
|
|
77
81
|
displayName: displayName
|
|
78
82
|
});
|
|
@@ -101,7 +105,7 @@ var Modal = function Modal(_ref) {
|
|
|
101
105
|
var _ref$current;
|
|
102
106
|
var target = event.target;
|
|
103
107
|
if (onOverflow && !((_ref$current = ref.current) !== null && _ref$current !== void 0 && _ref$current.contains(target))) {
|
|
104
|
-
|
|
108
|
+
Event.publish(_Modal.EVENT_VISIBLE, {
|
|
105
109
|
visible: false,
|
|
106
110
|
displayName: displayName
|
|
107
111
|
});
|
|
@@ -109,7 +113,7 @@ var Modal = function Modal(_ref) {
|
|
|
109
113
|
}
|
|
110
114
|
};
|
|
111
115
|
var handleClose = function handleClose(event) {
|
|
112
|
-
|
|
116
|
+
Event.publish(_Modal.EVENT_VISIBLE, {
|
|
113
117
|
visible: false,
|
|
114
118
|
displayName: displayName
|
|
115
119
|
});
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Modal.js","names":["Modal","blur","children","displayName","fit","mobileBehavior","overflow","portal","preventDefault","title","visible","onBack","onClose","onOverflow","aria","buttonBack","ariaBack","buttonClose","ariaClose","others","useDevice","isDesktop","isMobile","height","ref","useRef","useState","dataset","setDataset","useEffect","Event","publish","EVENT_VISIBLE","handleKeydown","event","key","handleClose","document","addEventListener","removeEventListener","body","miraiModal","undefined","handleOverflow","target","current","contains","defaultDirection","Theme","getDirection","DIRECTION_TYPE","LEFT","renderer","IS_JEST","jsx","ReactDOM","createPortal","testId","role","tag","styles","style","container","modal","calcWidth","className","header","reverse","hideBack","hideClose","ICON","icon","button","CLOSE","EXPAND_MORE","React","Children","map","child","index","cloneElement","props","propTypes","PropTypes","bool","node","string","func","shape"],"sources":["../../../src/components/Modal/Modal.jsx"],"sourcesContent":["import { Event } from '@mirai/data-sources';\nimport PropTypes from 'prop-types';\nimport React, { useEffect, useRef, useState } from 'react';\nimport ReactDOM from 'react-dom';\n\nimport { Button } from '../../components';\nimport { IS_JEST, styles } from '../../helpers';\nimport { useDevice } from '../../hooks';\nimport { Icon, ICON, Pressable, Text, View } from '../../primitives';\nimport { DIRECTION_TYPE, Theme } from '../../theme';\nimport { EVENT_VISIBLE } from './Modal.constants';\nimport style from './Modal.module.css';\n\nconst Modal = ({\n blur = false,\n children,\n displayName,\n fit = false,\n mobileBehavior = false,\n overflow = true,\n portal = false,\n preventDefault = true,\n title,\n visible,\n onBack,\n onClose,\n onOverflow,\n aria: { buttonBack: ariaBack = 'Back', buttonClose: ariaClose = 'Close' } = {},\n ...others\n}) => {\n const { isDesktop, isMobile, height } = useDevice();\n const ref = useRef();\n\n const [dataset, setDataset] = useState();\n\n useEffect(() => {\n if (!visible || !onClose) return;\n Event.publish(EVENT_VISIBLE, { visible, displayName });\n\n const handleKeydown = (event) => event.key === 'Escape' && handleClose();\n\n document.addEventListener('keydown', handleKeydown);\n return () => document.removeEventListener('keydown', handleKeydown);\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [visible]);\n\n useEffect(() => {\n if (visible && !dataset) {\n setDataset(true);\n document.body.dataset.miraiModal = true;\n }\n\n return () => {\n if (visible && dataset) {\n setDataset(undefined);\n delete document.body.dataset.miraiModal;\n }\n };\n }, [dataset, visible]);\n\n const handleOverflow = (event) => {\n const { target } = event;\n\n if (onOverflow && !ref.current?.contains(target)) {\n Event.publish(EVENT_VISIBLE, { visible: false, displayName });\n onOverflow(event);\n }\n };\n\n const handleClose = (event) => {\n Event.publish(EVENT_VISIBLE, { visible: false, displayName });\n onClose(event);\n };\n\n const defaultDirection = Theme.getDirection() === DIRECTION_TYPE.LEFT;\n const renderer = IS_JEST || !portal ? (jsx) => jsx : ReactDOM.createPortal;\n const { testId } = others;\n\n return renderer(\n <Pressable\n preventDefault={preventDefault}\n role={`${others.role || 'modal'}-overflow`}\n tag={`${others.tag || 'modal'}_overflow`}\n onPress={visible && overflow ? handleOverflow : undefined}\n className={styles(\n style.container,\n isDesktop && mobileBehavior && style.mobileBehavior,\n overflow && style.overflow,\n overflow && blur && style.blur,\n visible && style.visible,\n onOverflow && style.onOverflow,\n )}\n style={{ height }}\n testId={testId ? `${testId}-overflow` : undefined}\n >\n <View\n {...others}\n fit\n ref={ref}\n role={others.role || 'modal'}\n className={styles(style.modal, !fit && style.calcWidth, visible && style.visible, others.className)}\n aria-hidden={visible ? 'false' : 'true'}\n >\n {(title || onBack || onClose) && (\n <View\n row\n className={styles(\n style.header,\n !defaultDirection && style.reverse,\n !onBack && style.hideBack,\n !onClose && style.hideClose,\n )}\n >\n {onBack && (\n <Button\n small\n squared\n transparent\n onPress={onBack}\n aria-label={ariaBack}\n testId={testId ? `${testId}-button-back` : undefined}\n >\n <Icon value={ICON.LEFT} className={style.icon} />\n </Button>\n )}\n {title && (\n <Text headline={!isMobile} className={style.title}>\n {title}\n </Text>\n )}\n {onClose && (\n <Button\n small\n squared\n transparent\n onPress={handleClose}\n className={style.button}\n aria-label={ariaClose}\n testId={testId ? `${testId}-button-close` : undefined}\n >\n <Icon value={isDesktop || title !== undefined ? ICON.CLOSE : ICON.EXPAND_MORE} className={style.icon} />\n </Button>\n )}\n </View>\n )}\n\n {React.Children.map(children, (child, index) =>\n !child || child === null\n ? null\n : React.cloneElement(child, { key: child.key || index, ...child.props, role: 'modal-content' }),\n )}\n </View>\n </Pressable>,\n document.body,\n );\n};\n\nModal.displayName = 'Component:Modal';\n\nModal.propTypes = {\n blur: PropTypes.bool,\n children: PropTypes.node,\n displayName: PropTypes.string,\n fit: PropTypes.bool,\n mobileBehavior: PropTypes.bool,\n overflow: PropTypes.bool,\n portal: PropTypes.bool,\n preventDefault: PropTypes.bool,\n title: PropTypes.string,\n visible: PropTypes.bool,\n onBack: PropTypes.func,\n onClose: PropTypes.func,\n onOverflow: PropTypes.func,\n aria: PropTypes.shape({\n buttonBack: PropTypes.string,\n buttonClose: PropTypes.string,\n }),\n};\n\nexport { Modal };\n"],"mappings":";;;;;;;AAAA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AAAuC;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAEvC,IAAMA,KAAK,GAAG,SAARA,KAAK,OAgBL;EAAA,qBAfJC,IAAI;IAAJA,IAAI,0BAAG,KAAK;IACZC,QAAQ,QAARA,QAAQ;IACRC,WAAW,QAAXA,WAAW;IAAA,gBACXC,GAAG;IAAHA,GAAG,yBAAG,KAAK;IAAA,2BACXC,cAAc;IAAdA,cAAc,oCAAG,KAAK;IAAA,qBACtBC,QAAQ;IAARA,QAAQ,8BAAG,IAAI;IAAA,mBACfC,MAAM;IAANA,MAAM,4BAAG,KAAK;IAAA,2BACdC,cAAc;IAAdA,cAAc,oCAAG,IAAI;IACrBC,KAAK,QAALA,KAAK;IACLC,OAAO,QAAPA,OAAO;IACPC,MAAM,QAANA,MAAM;IACNC,OAAO,QAAPA,OAAO;IACPC,UAAU,QAAVA,UAAU;IAAA,iBACVC,IAAI;EAAA,mCAAwE,CAAC,CAAC;EAAA,qCAAtEC,UAAU;IAAEC,QAAQ,qCAAG,MAAM;IAAA,kCAAEC,WAAW;IAAEC,SAAS,sCAAG,OAAO;IACpEC,MAAM;EAET,iBAAwC,IAAAC,gBAAS,GAAE;IAA3CC,SAAS,cAATA,SAAS;IAAEC,QAAQ,cAARA,QAAQ;IAAEC,MAAM,cAANA,MAAM;EACnC,IAAMC,GAAG,GAAG,IAAAC,aAAM,GAAE;EAEpB,gBAA8B,IAAAC,eAAQ,GAAE;IAAA;IAAjCC,OAAO;IAAEC,UAAU;EAE1B,IAAAC,gBAAS,EAAC,YAAM;IACd,IAAI,CAACnB,OAAO,IAAI,CAACE,OAAO,EAAE;IAC1BkB,kBAAK,CAACC,OAAO,CAACC,oBAAa,EAAE;MAAEtB,OAAO,EAAPA,OAAO;MAAEP,WAAW,EAAXA;IAAY,CAAC,CAAC;IAEtD,IAAM8B,aAAa,GAAG,SAAhBA,aAAa,CAAIC,KAAK;MAAA,OAAKA,KAAK,CAACC,GAAG,KAAK,QAAQ,IAAIC,WAAW,EAAE;IAAA;IAExEC,QAAQ,CAACC,gBAAgB,CAAC,SAAS,EAAEL,aAAa,CAAC;IACnD,OAAO;MAAA,OAAMI,QAAQ,CAACE,mBAAmB,CAAC,SAAS,EAAEN,aAAa,CAAC;IAAA;IACnE;EACF,CAAC,EAAE,CAACvB,OAAO,CAAC,CAAC;EAEb,IAAAmB,gBAAS,EAAC,YAAM;IACd,IAAInB,OAAO,IAAI,CAACiB,OAAO,EAAE;MACvBC,UAAU,CAAC,IAAI,CAAC;MAChBS,QAAQ,CAACG,IAAI,CAACb,OAAO,CAACc,UAAU,GAAG,IAAI;IACzC;IAEA,OAAO,YAAM;MACX,IAAI/B,OAAO,IAAIiB,OAAO,EAAE;QACtBC,UAAU,CAACc,SAAS,CAAC;QACrB,OAAOL,QAAQ,CAACG,IAAI,CAACb,OAAO,CAACc,UAAU;MACzC;IACF,CAAC;EACH,CAAC,EAAE,CAACd,OAAO,EAAEjB,OAAO,CAAC,CAAC;EAEtB,IAAMiC,cAAc,GAAG,SAAjBA,cAAc,CAAIT,KAAK,EAAK;IAAA;IAChC,IAAQU,MAAM,GAAKV,KAAK,CAAhBU,MAAM;IAEd,IAAI/B,UAAU,IAAI,kBAACW,GAAG,CAACqB,OAAO,yCAAX,aAAaC,QAAQ,CAACF,MAAM,CAAC,GAAE;MAChDd,kBAAK,CAACC,OAAO,CAACC,oBAAa,EAAE;QAAEtB,OAAO,EAAE,KAAK;QAAEP,WAAW,EAAXA;MAAY,CAAC,CAAC;MAC7DU,UAAU,CAACqB,KAAK,CAAC;IACnB;EACF,CAAC;EAED,IAAME,WAAW,GAAG,SAAdA,WAAW,CAAIF,KAAK,EAAK;IAC7BJ,kBAAK,CAACC,OAAO,CAACC,oBAAa,EAAE;MAAEtB,OAAO,EAAE,KAAK;MAAEP,WAAW,EAAXA;IAAY,CAAC,CAAC;IAC7DS,OAAO,CAACsB,KAAK,CAAC;EAChB,CAAC;EAED,IAAMa,gBAAgB,GAAGC,YAAK,CAACC,YAAY,EAAE,KAAKC,qBAAc,CAACC,IAAI;EACrE,IAAMC,QAAQ,GAAGC,gBAAO,IAAI,CAAC9C,MAAM,GAAG,UAAC+C,GAAG;IAAA,OAAKA,GAAG;EAAA,IAAGC,iBAAQ,CAACC,YAAY;EAC1E,IAAQC,MAAM,GAAKtC,MAAM,CAAjBsC,MAAM;EAEd,OAAOL,QAAQ,eACb,6BAAC,qBAAS;IACR,cAAc,EAAE5C,cAAe;IAC/B,IAAI,YAAKW,MAAM,CAACuC,IAAI,IAAI,OAAO,cAAY;IAC3C,GAAG,YAAKvC,MAAM,CAACwC,GAAG,IAAI,OAAO,cAAY;IACzC,OAAO,EAAEjD,OAAO,IAAIJ,QAAQ,GAAGqC,cAAc,GAAGD,SAAU;IAC1D,SAAS,EAAE,IAAAkB,eAAM,EACfC,oBAAK,CAACC,SAAS,EACfzC,SAAS,IAAIhB,cAAc,IAAIwD,oBAAK,CAACxD,cAAc,EACnDC,QAAQ,IAAIuD,oBAAK,CAACvD,QAAQ,EAC1BA,QAAQ,IAAIL,IAAI,IAAI4D,oBAAK,CAAC5D,IAAI,EAC9BS,OAAO,IAAImD,oBAAK,CAACnD,OAAO,EACxBG,UAAU,IAAIgD,oBAAK,CAAChD,UAAU,CAC9B;IACF,KAAK,EAAE;MAAEU,MAAM,EAANA;IAAO,CAAE;IAClB,MAAM,EAAEkC,MAAM,aAAMA,MAAM,iBAAcf;EAAU,gBAElD,6BAAC,gBAAI,eACCvB,MAAM;IACV,GAAG;IACH,GAAG,EAAEK,GAAI;IACT,IAAI,EAAEL,MAAM,CAACuC,IAAI,IAAI,OAAQ;IAC7B,SAAS,EAAE,IAAAE,eAAM,EAACC,oBAAK,CAACE,KAAK,EAAE,CAAC3D,GAAG,IAAIyD,oBAAK,CAACG,SAAS,EAAEtD,OAAO,IAAImD,oBAAK,CAACnD,OAAO,EAAES,MAAM,CAAC8C,SAAS,CAAE;IACpG,eAAavD,OAAO,GAAG,OAAO,GAAG;EAAO,IAEvC,CAACD,KAAK,IAAIE,MAAM,IAAIC,OAAO,kBAC1B,6BAAC,gBAAI;IACH,GAAG;IACH,SAAS,EAAE,IAAAgD,eAAM,EACfC,oBAAK,CAACK,MAAM,EACZ,CAACnB,gBAAgB,IAAIc,oBAAK,CAACM,OAAO,EAClC,CAACxD,MAAM,IAAIkD,oBAAK,CAACO,QAAQ,EACzB,CAACxD,OAAO,IAAIiD,oBAAK,CAACQ,SAAS;EAC3B,GAED1D,MAAM,iBACL,6BAAC,kBAAM;IACL,KAAK;IACL,OAAO;IACP,WAAW;IACX,OAAO,EAAEA,MAAO;IAChB,cAAYK,QAAS;IACrB,MAAM,EAAEyC,MAAM,aAAMA,MAAM,oBAAiBf;EAAU,gBAErD,6BAAC,gBAAI;IAAC,KAAK,EAAE4B,gBAAI,CAACnB,IAAK;IAAC,SAAS,EAAEU,oBAAK,CAACU;EAAK,EAAG,CAEpD,EACA9D,KAAK,iBACJ,6BAAC,gBAAI;IAAC,QAAQ,EAAE,CAACa,QAAS;IAAC,SAAS,EAAEuC,oBAAK,CAACpD;EAAM,GAC/CA,KAAK,CAET,EACAG,OAAO,iBACN,6BAAC,kBAAM;IACL,KAAK;IACL,OAAO;IACP,WAAW;IACX,OAAO,EAAEwB,WAAY;IACrB,SAAS,EAAEyB,oBAAK,CAACW,MAAO;IACxB,cAAYtD,SAAU;IACtB,MAAM,EAAEuC,MAAM,aAAMA,MAAM,qBAAkBf;EAAU,gBAEtD,6BAAC,gBAAI;IAAC,KAAK,EAAErB,SAAS,IAAIZ,KAAK,KAAKiC,SAAS,GAAG4B,gBAAI,CAACG,KAAK,GAAGH,gBAAI,CAACI,WAAY;IAAC,SAAS,EAAEb,oBAAK,CAACU;EAAK,EAAG,CAE3G,CAEJ,EAEAI,cAAK,CAACC,QAAQ,CAACC,GAAG,CAAC3E,QAAQ,EAAE,UAAC4E,KAAK,EAAEC,KAAK;IAAA,OACzC,CAACD,KAAK,IAAIA,KAAK,KAAK,IAAI,GACpB,IAAI,gBACJH,cAAK,CAACK,YAAY,CAACF,KAAK;MAAI3C,GAAG,EAAE2C,KAAK,CAAC3C,GAAG,IAAI4C;IAAK,GAAKD,KAAK,CAACG,KAAK;MAAEvB,IAAI,EAAE;IAAe,GAAG;EAAA,EAClG,CACI,CACG,EACZrB,QAAQ,CAACG,IAAI,CACd;AACH,CAAC;AAAC;AAEFxC,KAAK,CAACG,WAAW,GAAG,iBAAiB;AAErCH,KAAK,CAACkF,SAAS,GAAG;EAChBjF,IAAI,EAAEkF,kBAAS,CAACC,IAAI;EACpBlF,QAAQ,EAAEiF,kBAAS,CAACE,IAAI;EACxBlF,WAAW,EAAEgF,kBAAS,CAACG,MAAM;EAC7BlF,GAAG,EAAE+E,kBAAS,CAACC,IAAI;EACnB/E,cAAc,EAAE8E,kBAAS,CAACC,IAAI;EAC9B9E,QAAQ,EAAE6E,kBAAS,CAACC,IAAI;EACxB7E,MAAM,EAAE4E,kBAAS,CAACC,IAAI;EACtB5E,cAAc,EAAE2E,kBAAS,CAACC,IAAI;EAC9B3E,KAAK,EAAE0E,kBAAS,CAACG,MAAM;EACvB5E,OAAO,EAAEyE,kBAAS,CAACC,IAAI;EACvBzE,MAAM,EAAEwE,kBAAS,CAACI,IAAI;EACtB3E,OAAO,EAAEuE,kBAAS,CAACI,IAAI;EACvB1E,UAAU,EAAEsE,kBAAS,CAACI,IAAI;EAC1BzE,IAAI,EAAEqE,kBAAS,CAACK,KAAK,CAAC;IACpBzE,UAAU,EAAEoE,kBAAS,CAACG,MAAM;IAC5BrE,WAAW,EAAEkE,kBAAS,CAACG;EACzB,CAAC;AACH,CAAC"}
|
|
1
|
+
{"version":3,"file":"Modal.js","names":["Event","publish","subscribe","Modal","blur","children","displayName","fit","mobileBehavior","overflow","portal","preventDefault","title","visible","onBack","onClose","onOverflow","aria","buttonBack","ariaBack","buttonClose","ariaClose","others","useDevice","isDesktop","isMobile","height","ref","useRef","useState","dataset","setDataset","useEffect","EVENT_VISIBLE","handleKeydown","event","key","handleClose","document","addEventListener","removeEventListener","body","miraiModal","undefined","handleOverflow","target","current","contains","defaultDirection","Theme","getDirection","DIRECTION_TYPE","LEFT","renderer","IS_JEST","jsx","ReactDOM","createPortal","testId","role","tag","styles","style","container","modal","calcWidth","className","header","reverse","hideBack","hideClose","ICON","icon","button","CLOSE","EXPAND_MORE","React","Children","map","child","index","cloneElement","props","propTypes","PropTypes","bool","node","string","func","shape"],"sources":["../../../src/components/Modal/Modal.jsx"],"sourcesContent":["// import { Event } from '@mirai/data-sources';\nconst Event = {\n publish: () => {},\n subscribe: () => {},\n};\nimport PropTypes from 'prop-types';\nimport React, { useEffect, useRef, useState } from 'react';\nimport ReactDOM from 'react-dom';\n\nimport { Button } from '../../components';\nimport { IS_JEST, styles } from '../../helpers';\nimport { useDevice } from '../../hooks';\nimport { Icon, ICON, Pressable, Text, View } from '../../primitives';\nimport { DIRECTION_TYPE, Theme } from '../../theme';\nimport { EVENT_VISIBLE } from './Modal.constants';\nimport style from './Modal.module.css';\n\nconst Modal = ({\n blur = false,\n children,\n displayName,\n fit = false,\n mobileBehavior = false,\n overflow = true,\n portal = false,\n preventDefault = true,\n title,\n visible,\n onBack,\n onClose,\n onOverflow,\n aria: { buttonBack: ariaBack = 'Back', buttonClose: ariaClose = 'Close' } = {},\n ...others\n}) => {\n const { isDesktop, isMobile, height } = useDevice();\n const ref = useRef();\n\n const [dataset, setDataset] = useState();\n\n useEffect(() => {\n if (!visible || !onClose) return;\n Event.publish(EVENT_VISIBLE, { visible, displayName });\n\n const handleKeydown = (event) => event.key === 'Escape' && handleClose();\n\n document.addEventListener('keydown', handleKeydown);\n return () => document.removeEventListener('keydown', handleKeydown);\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [visible]);\n\n useEffect(() => {\n if (visible && !dataset) {\n setDataset(true);\n document.body.dataset.miraiModal = true;\n }\n\n return () => {\n if (visible && dataset) {\n setDataset(undefined);\n delete document.body.dataset.miraiModal;\n }\n };\n }, [dataset, visible]);\n\n const handleOverflow = (event) => {\n const { target } = event;\n\n if (onOverflow && !ref.current?.contains(target)) {\n Event.publish(EVENT_VISIBLE, { visible: false, displayName });\n onOverflow(event);\n }\n };\n\n const handleClose = (event) => {\n Event.publish(EVENT_VISIBLE, { visible: false, displayName });\n onClose(event);\n };\n\n const defaultDirection = Theme.getDirection() === DIRECTION_TYPE.LEFT;\n const renderer = IS_JEST || !portal ? (jsx) => jsx : ReactDOM.createPortal;\n const { testId } = others;\n\n return renderer(\n <Pressable\n preventDefault={preventDefault}\n role={`${others.role || 'modal'}-overflow`}\n tag={`${others.tag || 'modal'}_overflow`}\n onPress={visible && overflow ? handleOverflow : undefined}\n className={styles(\n style.container,\n isDesktop && mobileBehavior && style.mobileBehavior,\n overflow && style.overflow,\n overflow && blur && style.blur,\n visible && style.visible,\n onOverflow && style.onOverflow,\n )}\n style={{ height }}\n testId={testId ? `${testId}-overflow` : undefined}\n >\n <View\n {...others}\n fit\n ref={ref}\n role={others.role || 'modal'}\n className={styles(style.modal, !fit && style.calcWidth, visible && style.visible, others.className)}\n aria-hidden={visible ? 'false' : 'true'}\n >\n {(title || onBack || onClose) && (\n <View\n row\n className={styles(\n style.header,\n !defaultDirection && style.reverse,\n !onBack && style.hideBack,\n !onClose && style.hideClose,\n )}\n >\n {onBack && (\n <Button\n small\n squared\n transparent\n onPress={onBack}\n aria-label={ariaBack}\n testId={testId ? `${testId}-button-back` : undefined}\n >\n <Icon value={ICON.LEFT} className={style.icon} />\n </Button>\n )}\n {title && (\n <Text headline={!isMobile} className={style.title}>\n {title}\n </Text>\n )}\n {onClose && (\n <Button\n small\n squared\n transparent\n onPress={handleClose}\n className={style.button}\n aria-label={ariaClose}\n testId={testId ? `${testId}-button-close` : undefined}\n >\n <Icon value={isDesktop || title !== undefined ? ICON.CLOSE : ICON.EXPAND_MORE} className={style.icon} />\n </Button>\n )}\n </View>\n )}\n\n {React.Children.map(children, (child, index) =>\n !child || child === null\n ? null\n : React.cloneElement(child, { key: child.key || index, ...child.props, role: 'modal-content' }),\n )}\n </View>\n </Pressable>,\n document.body,\n );\n};\n\nModal.displayName = 'Component:Modal';\n\nModal.propTypes = {\n blur: PropTypes.bool,\n children: PropTypes.node,\n displayName: PropTypes.string,\n fit: PropTypes.bool,\n mobileBehavior: PropTypes.bool,\n overflow: PropTypes.bool,\n portal: PropTypes.bool,\n preventDefault: PropTypes.bool,\n title: PropTypes.string,\n visible: PropTypes.bool,\n onBack: PropTypes.func,\n onClose: PropTypes.func,\n onOverflow: PropTypes.func,\n aria: PropTypes.shape({\n buttonBack: PropTypes.string,\n buttonClose: PropTypes.string,\n }),\n};\n\nexport { Modal };\n"],"mappings":"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"}
|
|
@@ -33,7 +33,7 @@ exports[`component:<Slider> inherit:className 1`] = `
|
|
|
33
33
|
</ui_icon>
|
|
34
34
|
</ui_pressable>
|
|
35
35
|
<ui_scrollview
|
|
36
|
-
class="scrollview snap horizontal
|
|
36
|
+
class="scrollview snap horizontal scrollView"
|
|
37
37
|
style="width: 360px;"
|
|
38
38
|
>
|
|
39
39
|
<ui_view
|
|
@@ -148,7 +148,7 @@ exports[`component:<Slider> prop:auto 1`] = `
|
|
|
148
148
|
</ui_icon>
|
|
149
149
|
</ui_pressable>
|
|
150
150
|
<ui_scrollview
|
|
151
|
-
class="scrollview snap horizontal
|
|
151
|
+
class="scrollview snap horizontal scrollView"
|
|
152
152
|
style="width: 360px;"
|
|
153
153
|
>
|
|
154
154
|
<ui_view
|
|
@@ -263,7 +263,7 @@ exports[`component:<Slider> prop:behavior 1`] = `
|
|
|
263
263
|
</ui_icon>
|
|
264
264
|
</ui_pressable>
|
|
265
265
|
<ui_scrollview
|
|
266
|
-
class="scrollview snap horizontal
|
|
266
|
+
class="scrollview snap horizontal scrollView"
|
|
267
267
|
style="width: 360px;"
|
|
268
268
|
>
|
|
269
269
|
<ui_view
|
|
@@ -378,7 +378,7 @@ exports[`component:<Slider> prop:captions 1`] = `
|
|
|
378
378
|
</ui_icon>
|
|
379
379
|
</ui_pressable>
|
|
380
380
|
<ui_scrollview
|
|
381
|
-
class="scrollview snap horizontal
|
|
381
|
+
class="scrollview snap horizontal scrollView"
|
|
382
382
|
style="width: 360px;"
|
|
383
383
|
>
|
|
384
384
|
<ui_view
|
|
@@ -538,7 +538,7 @@ exports[`component:<Slider> prop:index 1`] = `
|
|
|
538
538
|
</ui_icon>
|
|
539
539
|
</ui_pressable>
|
|
540
540
|
<ui_scrollview
|
|
541
|
-
class="scrollview snap horizontal
|
|
541
|
+
class="scrollview snap horizontal scrollView"
|
|
542
542
|
style="width: 360px;"
|
|
543
543
|
>
|
|
544
544
|
<ui_view
|
|
@@ -653,7 +653,7 @@ exports[`component:<Slider> prop:indicator 1`] = `
|
|
|
653
653
|
</ui_icon>
|
|
654
654
|
</ui_pressable>
|
|
655
655
|
<ui_scrollview
|
|
656
|
-
class="scrollview snap horizontal
|
|
656
|
+
class="scrollview snap horizontal scrollView"
|
|
657
657
|
style="width: 360px;"
|
|
658
658
|
>
|
|
659
659
|
<ui_view
|
|
@@ -776,7 +776,7 @@ exports[`component:<Slider> prop:onCounter 1`] = `
|
|
|
776
776
|
</ui_icon>
|
|
777
777
|
</ui_pressable>
|
|
778
778
|
<ui_scrollview
|
|
779
|
-
class="scrollview snap horizontal
|
|
779
|
+
class="scrollview snap horizontal scrollView"
|
|
780
780
|
style="width: 360px;"
|
|
781
781
|
>
|
|
782
782
|
<ui_view
|
|
@@ -922,7 +922,7 @@ exports[`component:<Slider> prop:replay (false) 1`] = `
|
|
|
922
922
|
</ui_icon>
|
|
923
923
|
</ui_pressable>
|
|
924
924
|
<ui_scrollview
|
|
925
|
-
class="scrollview snap horizontal
|
|
925
|
+
class="scrollview snap horizontal scrollView"
|
|
926
926
|
style="width: 360px;"
|
|
927
927
|
>
|
|
928
928
|
<ui_view
|
|
@@ -1037,7 +1037,7 @@ exports[`component:<Slider> renders 1`] = `
|
|
|
1037
1037
|
</ui_icon>
|
|
1038
1038
|
</ui_pressable>
|
|
1039
1039
|
<ui_scrollview
|
|
1040
|
-
class="scrollview snap horizontal
|
|
1040
|
+
class="scrollview snap horizontal scrollView"
|
|
1041
1041
|
style="width: 360px;"
|
|
1042
1042
|
>
|
|
1043
1043
|
<ui_view
|
|
@@ -1152,7 +1152,7 @@ exports[`component:<Slider> tag 1`] = `
|
|
|
1152
1152
|
</ui_icon>
|
|
1153
1153
|
</ui_pressable>
|
|
1154
1154
|
<ui_scrollview
|
|
1155
|
-
class="scrollview snap horizontal
|
|
1155
|
+
class="scrollview snap horizontal scrollView"
|
|
1156
1156
|
style="width: 360px;"
|
|
1157
1157
|
>
|
|
1158
1158
|
<ui_view
|
|
@@ -1268,7 +1268,7 @@ exports[`component:<Slider> testId 1`] = `
|
|
|
1268
1268
|
</ui_icon>
|
|
1269
1269
|
</ui_pressable>
|
|
1270
1270
|
<ui_scrollview
|
|
1271
|
-
class="scrollview snap horizontal
|
|
1271
|
+
class="scrollview snap horizontal scrollView"
|
|
1272
1272
|
style="width: 360px;"
|
|
1273
1273
|
>
|
|
1274
1274
|
<ui_view
|
|
@@ -3,7 +3,7 @@
|
|
|
3
3
|
exports[`component:<Table> inherit:className 1`] = `
|
|
4
4
|
<DocumentFragment>
|
|
5
5
|
<ui_scrollview
|
|
6
|
-
class="scrollview snap vertical
|
|
6
|
+
class="scrollview snap vertical container mirai"
|
|
7
7
|
>
|
|
8
8
|
<table
|
|
9
9
|
class="table"
|
|
@@ -427,7 +427,7 @@ exports[`component:<Table> inherit:className 1`] = `
|
|
|
427
427
|
exports[`component:<Table> prop:filter 1`] = `
|
|
428
428
|
<DocumentFragment>
|
|
429
429
|
<ui_scrollview
|
|
430
|
-
class="scrollview snap vertical
|
|
430
|
+
class="scrollview snap vertical container"
|
|
431
431
|
>
|
|
432
432
|
<ui_view
|
|
433
433
|
class="view row wide filters"
|
|
@@ -1036,7 +1036,7 @@ exports[`component:<Table> prop:filter 1`] = `
|
|
|
1036
1036
|
exports[`component:<Table> prop:inline (false 1`] = `
|
|
1037
1037
|
<DocumentFragment>
|
|
1038
1038
|
<ui_scrollview
|
|
1039
|
-
class="scrollview snap vertical
|
|
1039
|
+
class="scrollview snap vertical container outlined"
|
|
1040
1040
|
>
|
|
1041
1041
|
<table
|
|
1042
1042
|
class="table"
|
|
@@ -1460,7 +1460,7 @@ exports[`component:<Table> prop:inline (false 1`] = `
|
|
|
1460
1460
|
exports[`component:<Table> prop:onScroll 1`] = `
|
|
1461
1461
|
<DocumentFragment>
|
|
1462
1462
|
<ui_scrollview
|
|
1463
|
-
class="scrollview snap vertical
|
|
1463
|
+
class="scrollview snap vertical container"
|
|
1464
1464
|
data-testid="onScroll"
|
|
1465
1465
|
>
|
|
1466
1466
|
<table
|
|
@@ -1981,7 +1981,7 @@ exports[`component:<Table> prop:onScroll 1`] = `
|
|
|
1981
1981
|
exports[`component:<Table> prop:onSelect 1`] = `
|
|
1982
1982
|
<DocumentFragment>
|
|
1983
1983
|
<ui_scrollview
|
|
1984
|
-
class="scrollview snap vertical
|
|
1984
|
+
class="scrollview snap vertical container"
|
|
1985
1985
|
data-testid="onSelect"
|
|
1986
1986
|
>
|
|
1987
1987
|
<table
|
|
@@ -2630,7 +2630,7 @@ exports[`component:<Table> prop:onSelect 1`] = `
|
|
|
2630
2630
|
exports[`component:<Table> prop:pagination 1`] = `
|
|
2631
2631
|
<DocumentFragment>
|
|
2632
2632
|
<ui_scrollview
|
|
2633
|
-
class="scrollview snap vertical
|
|
2633
|
+
class="scrollview snap vertical container"
|
|
2634
2634
|
>
|
|
2635
2635
|
<table
|
|
2636
2636
|
class="table"
|
|
@@ -2953,7 +2953,7 @@ exports[`component:<Table> prop:pagination 1`] = `
|
|
|
2953
2953
|
exports[`component:<Table> prop:search 1`] = `
|
|
2954
2954
|
<DocumentFragment>
|
|
2955
2955
|
<ui_scrollview
|
|
2956
|
-
class="scrollview snap vertical
|
|
2956
|
+
class="scrollview snap vertical container"
|
|
2957
2957
|
>
|
|
2958
2958
|
<table
|
|
2959
2959
|
class="table"
|
|
@@ -3175,7 +3175,7 @@ exports[`component:<Table> prop:search 1`] = `
|
|
|
3175
3175
|
exports[`component:<Table> prop:selected 1`] = `
|
|
3176
3176
|
<DocumentFragment>
|
|
3177
3177
|
<ui_scrollview
|
|
3178
|
-
class="scrollview snap vertical
|
|
3178
|
+
class="scrollview snap vertical container"
|
|
3179
3179
|
>
|
|
3180
3180
|
<table
|
|
3181
3181
|
class="table"
|
|
@@ -3599,7 +3599,7 @@ exports[`component:<Table> prop:selected 1`] = `
|
|
|
3599
3599
|
exports[`component:<Table> prop:sort 1`] = `
|
|
3600
3600
|
<DocumentFragment>
|
|
3601
3601
|
<ui_scrollview
|
|
3602
|
-
class="scrollview snap vertical
|
|
3602
|
+
class="scrollview snap vertical container"
|
|
3603
3603
|
>
|
|
3604
3604
|
<table
|
|
3605
3605
|
class="table"
|
|
@@ -3898,7 +3898,7 @@ exports[`component:<Table> prop:sort 1`] = `
|
|
|
3898
3898
|
exports[`component:<Table> prop:store 1`] = `
|
|
3899
3899
|
<DocumentFragment>
|
|
3900
3900
|
<ui_scrollview
|
|
3901
|
-
class="scrollview snap vertical
|
|
3901
|
+
class="scrollview snap vertical container"
|
|
3902
3902
|
>
|
|
3903
3903
|
<ui_view
|
|
3904
3904
|
class="view row wide filters"
|
|
@@ -4288,7 +4288,7 @@ exports[`component:<Table> prop:store 1`] = `
|
|
|
4288
4288
|
exports[`component:<Table> renders 1`] = `
|
|
4289
4289
|
<DocumentFragment>
|
|
4290
4290
|
<ui_scrollview
|
|
4291
|
-
class="scrollview snap vertical
|
|
4291
|
+
class="scrollview snap vertical container"
|
|
4292
4292
|
>
|
|
4293
4293
|
<table
|
|
4294
4294
|
class="table"
|
|
@@ -4712,7 +4712,7 @@ exports[`component:<Table> renders 1`] = `
|
|
|
4712
4712
|
exports[`component:<Table> tag 1`] = `
|
|
4713
4713
|
<DocumentFragment>
|
|
4714
4714
|
<ui_tag
|
|
4715
|
-
class="scrollview snap vertical
|
|
4715
|
+
class="scrollview snap vertical container"
|
|
4716
4716
|
>
|
|
4717
4717
|
<table
|
|
4718
4718
|
class="table"
|
|
@@ -5136,7 +5136,7 @@ exports[`component:<Table> tag 1`] = `
|
|
|
5136
5136
|
exports[`component:<Table> testId 1`] = `
|
|
5137
5137
|
<DocumentFragment>
|
|
5138
5138
|
<ui_scrollview
|
|
5139
|
-
class="scrollview snap vertical
|
|
5139
|
+
class="scrollview snap vertical container"
|
|
5140
5140
|
data-testid="mirai"
|
|
5141
5141
|
>
|
|
5142
5142
|
<table
|
|
@@ -8,7 +8,9 @@ exports.ScrollView = void 0;
|
|
|
8
8
|
var _propTypes = _interopRequireDefault(require("prop-types"));
|
|
9
9
|
var _react = _interopRequireWildcard(require("react"));
|
|
10
10
|
var _helpers = require("../../helpers");
|
|
11
|
+
var _Icon = require("../Icon");
|
|
11
12
|
var _Primitive = require("../Primitive");
|
|
13
|
+
var _View = require("../View");
|
|
12
14
|
var _ScrollViewModule = _interopRequireDefault(require("./ScrollView.module.css"));
|
|
13
15
|
var _excluded = ["behavior", "children", "height", "horizontal", "scrollEventThrottle", "scrollIndicator", "scrollTo", "snap", "width", "onScroll"];
|
|
14
16
|
function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
|
|
@@ -19,6 +21,12 @@ function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { va
|
|
|
19
21
|
function _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
|
|
20
22
|
function _toPropertyKey(arg) { var key = _toPrimitive(arg, "string"); return _typeof(key) === "symbol" ? key : String(key); }
|
|
21
23
|
function _toPrimitive(input, hint) { if (_typeof(input) !== "object" || input === null) return input; var prim = input[Symbol.toPrimitive]; if (prim !== undefined) { var res = prim.call(input, hint || "default"); if (_typeof(res) !== "object") return res; throw new TypeError("@@toPrimitive must return a primitive value."); } return (hint === "string" ? String : Number)(input); }
|
|
24
|
+
function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); }
|
|
25
|
+
function _nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
|
|
26
|
+
function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }
|
|
27
|
+
function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; }
|
|
28
|
+
function _iterableToArrayLimit(arr, i) { var _i = null == arr ? null : "undefined" != typeof Symbol && arr[Symbol.iterator] || arr["@@iterator"]; if (null != _i) { var _s, _e, _x, _r, _arr = [], _n = !0, _d = !1; try { if (_x = (_i = _i.call(arr)).next, 0 === i) { if (Object(_i) !== _i) return; _n = !1; } else for (; !(_n = (_s = _x.call(_i)).done) && (_arr.push(_s.value), _arr.length !== i); _n = !0) { ; } } catch (err) { _d = !0, _e = err; } finally { try { if (!_n && null != _i.return && (_r = _i.return(), Object(_r) !== _r)) return; } finally { if (_d) throw _e; } } return _arr; } }
|
|
29
|
+
function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }
|
|
22
30
|
function _objectWithoutProperties(source, excluded) { if (source == null) return {}; var target = _objectWithoutPropertiesLoose(source, excluded); var key, i; if (Object.getOwnPropertySymbols) { var sourceSymbolKeys = Object.getOwnPropertySymbols(source); for (i = 0; i < sourceSymbolKeys.length; i++) { key = sourceSymbolKeys[i]; if (excluded.indexOf(key) >= 0) continue; if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue; target[key] = source[key]; } } return target; }
|
|
23
31
|
function _objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; var sourceKeys = Object.keys(source); var key, i; for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } return target; }
|
|
24
32
|
var ScrollView = function ScrollView(_ref) {
|
|
@@ -35,53 +43,97 @@ var ScrollView = function ScrollView(_ref) {
|
|
|
35
43
|
_ref$snap = _ref.snap,
|
|
36
44
|
snap = _ref$snap === void 0 ? true : _ref$snap,
|
|
37
45
|
width = _ref.width,
|
|
38
|
-
onScroll = _ref.onScroll,
|
|
46
|
+
_ref$onScroll = _ref.onScroll,
|
|
47
|
+
onScroll = _ref$onScroll === void 0 ? function () {} : _ref$onScroll,
|
|
39
48
|
others = _objectWithoutProperties(_ref, _excluded);
|
|
40
49
|
var ref = (0, _react.useRef)();
|
|
50
|
+
var _useState = (0, _react.useState)(),
|
|
51
|
+
_useState2 = _slicedToArray(_useState, 2),
|
|
52
|
+
value = _useState2[0],
|
|
53
|
+
setValue = _useState2[1];
|
|
41
54
|
var timeout = null;
|
|
42
55
|
(0, _react.useEffect)(function () {
|
|
43
|
-
var _current$scrollTo;
|
|
44
56
|
var _ref2 = ref || {},
|
|
45
|
-
|
|
46
|
-
|
|
57
|
+
el = _ref2.current;
|
|
58
|
+
if (!scrollIndicator || !el) return;
|
|
59
|
+
var callback = function callback() {
|
|
60
|
+
return setValue(calcValue(el));
|
|
61
|
+
};
|
|
62
|
+
var observer = new MutationObserver(callback);
|
|
63
|
+
observer.observe(el, {
|
|
64
|
+
childList: true,
|
|
65
|
+
subtree: true
|
|
66
|
+
});
|
|
67
|
+
return function () {
|
|
68
|
+
return observer.disconnect();
|
|
69
|
+
};
|
|
70
|
+
// eslint-disable-next-line react-hooks/exhaustive-deps
|
|
71
|
+
}, [ref]);
|
|
72
|
+
(0, _react.useEffect)(function () {
|
|
73
|
+
var _current$scrollTo;
|
|
74
|
+
var _ref3 = ref || {},
|
|
75
|
+
_ref3$current = _ref3.current,
|
|
76
|
+
current = _ref3$current === void 0 ? {} : _ref3$current;
|
|
47
77
|
if (!current.scrollTo || scrollTo === undefined) return;
|
|
48
78
|
current.scrollTo((_current$scrollTo = {}, _defineProperty(_current$scrollTo, horizontal ? 'left' : 'top', scrollTo), _defineProperty(_current$scrollTo, "behavior", behavior), _current$scrollTo));
|
|
49
79
|
// eslint-disable-next-line react-hooks/exhaustive-deps
|
|
50
80
|
}, [scrollTo]);
|
|
51
|
-
var handleScroll = function handleScroll(
|
|
52
|
-
var
|
|
53
|
-
|
|
54
|
-
var
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
81
|
+
var handleScroll = function handleScroll() {
|
|
82
|
+
var _ref4 = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {},
|
|
83
|
+
target = _ref4.target;
|
|
84
|
+
var next = calcValue(target);
|
|
85
|
+
setValue(next);
|
|
86
|
+
clearTimeout(timeout);
|
|
87
|
+
timeout = setTimeout(function () {
|
|
88
|
+
return onScroll(next);
|
|
89
|
+
}, scrollEventThrottle);
|
|
90
|
+
};
|
|
91
|
+
var calcValue = function calcValue() {
|
|
92
|
+
var _ref5 = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {},
|
|
93
|
+
clientHeight = _ref5.clientHeight,
|
|
94
|
+
clientWidth = _ref5.clientWidth,
|
|
95
|
+
scrollHeight = _ref5.scrollHeight,
|
|
96
|
+
scrollWidth = _ref5.scrollWidth,
|
|
97
|
+
scrollTop = _ref5.scrollTop,
|
|
98
|
+
scrollLeft = _ref5.scrollLeft;
|
|
60
99
|
var x = parseInt(scrollLeft, 10);
|
|
61
100
|
var y = parseInt(scrollTop, 10);
|
|
62
101
|
var offsetX = scrollWidth - clientWidth;
|
|
63
102
|
var offsetY = scrollHeight - clientHeight;
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
percentY: offsetY ? parseInt(y * 100 / offsetY, 10) : 0
|
|
71
|
-
});
|
|
72
|
-
}, scrollEventThrottle);
|
|
103
|
+
return offsetY > 0 ? {
|
|
104
|
+
x: x,
|
|
105
|
+
y: y,
|
|
106
|
+
percentX: offsetX ? parseInt(x * 100 / offsetX, 10) : 0,
|
|
107
|
+
percentY: offsetY ? parseInt(y * 100 / offsetY, 10) : 0
|
|
108
|
+
} : undefined;
|
|
73
109
|
};
|
|
110
|
+
var percent = scrollIndicator && value ? horizontal ? value.percentX : value.percentY : undefined;
|
|
74
111
|
return /*#__PURE__*/_react.default.createElement(_Primitive.Primitive, _objectSpread(_objectSpread({}, others), {}, {
|
|
75
112
|
ref: ref,
|
|
76
113
|
role: others.role || 'scrollview',
|
|
77
114
|
tag: others.tag || 'scrollview',
|
|
78
|
-
onScroll:
|
|
79
|
-
className: (0, _helpers.styles)(_ScrollViewModule.default.scrollview, snap && _ScrollViewModule.default.snap, horizontal ? _ScrollViewModule.default.horizontal : _ScrollViewModule.default.vertical,
|
|
115
|
+
onScroll: handleScroll,
|
|
116
|
+
className: (0, _helpers.styles)(_ScrollViewModule.default.scrollview, snap && _ScrollViewModule.default.snap, horizontal ? _ScrollViewModule.default.horizontal : _ScrollViewModule.default.vertical, others.className),
|
|
80
117
|
style: _objectSpread(_objectSpread({}, others.style), {}, {
|
|
81
118
|
height: height,
|
|
82
119
|
width: width
|
|
83
120
|
})
|
|
84
|
-
}), children
|
|
121
|
+
}), /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, children, percent >= 0 && /*#__PURE__*/_react.default.createElement(_View.View, {
|
|
122
|
+
className: (0, _helpers.styles)(_ScrollViewModule.default.indicator, horizontal ? _ScrollViewModule.default.horizontal : _ScrollViewModule.default.vertical, percent > 95 && _ScrollViewModule.default.hide)
|
|
123
|
+
}, /*#__PURE__*/_react.default.createElement(_View.View, {
|
|
124
|
+
className: _ScrollViewModule.default.progress,
|
|
125
|
+
style: horizontal ? {
|
|
126
|
+
height: '100%',
|
|
127
|
+
width: "".concat(percent || 0, "%")
|
|
128
|
+
} : {
|
|
129
|
+
height: "".concat(percent || 0, "%"),
|
|
130
|
+
width: '100%'
|
|
131
|
+
}
|
|
132
|
+
}), /*#__PURE__*/_react.default.createElement(_Icon.Icon, {
|
|
133
|
+
headline: true,
|
|
134
|
+
level: 2,
|
|
135
|
+
value: horizontal ? _Icon.ICON.RIGHT : _Icon.ICON.DOWN
|
|
136
|
+
}))));
|
|
85
137
|
};
|
|
86
138
|
exports.ScrollView = ScrollView;
|
|
87
139
|
ScrollView.displayName = 'Primitive:ScrollView';
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ScrollView.js","names":["ScrollView","behavior","children","height","horizontal","scrollEventThrottle","scrollIndicator","scrollTo","snap","width","onScroll","others","ref","useRef","timeout","useEffect","current","undefined","handleScroll","target","clientHeight","clientWidth","scrollHeight","scrollWidth","scrollTop","scrollLeft","x","parseInt","y","offsetX","offsetY","
|
|
1
|
+
{"version":3,"file":"ScrollView.js","names":["ScrollView","behavior","children","height","horizontal","scrollEventThrottle","scrollIndicator","scrollTo","snap","width","onScroll","others","ref","useRef","useState","value","setValue","timeout","useEffect","el","current","callback","calcValue","observer","MutationObserver","observe","childList","subtree","disconnect","undefined","handleScroll","target","next","clearTimeout","setTimeout","clientHeight","clientWidth","scrollHeight","scrollWidth","scrollTop","scrollLeft","x","parseInt","y","offsetX","offsetY","percentX","percentY","percent","React","createElement","Primitive","role","tag","className","styles","style","scrollview","vertical","indicator","hide","progress","ICON","RIGHT","DOWN","displayName","propTypes","PropTypes","string","node","isRequired","number","bool","func"],"sources":["../../../src/primitives/ScrollView/ScrollView.jsx"],"sourcesContent":["import PropTypes from 'prop-types';\nimport React, { useEffect, useRef, useState } from 'react';\n\nimport { styles } from '../../helpers';\nimport { Icon, ICON } from '../Icon';\nimport { Primitive } from '../Primitive';\nimport { View } from '../View';\nimport style from './ScrollView.module.css';\n\nconst ScrollView = ({\n behavior = 'smooth',\n children,\n height,\n horizontal,\n scrollEventThrottle = 16, // * 60fps\n scrollIndicator = false,\n scrollTo,\n snap = true,\n width,\n onScroll = () => {},\n ...others\n}) => {\n const ref = useRef();\n\n const [value, setValue] = useState();\n\n let timeout = null;\n\n useEffect(() => {\n const { current: el } = ref || {};\n if (!scrollIndicator || !el) return;\n\n const callback = () => setValue(calcValue(el));\n const observer = new MutationObserver(callback);\n observer.observe(el, { childList: true, subtree: true });\n\n return () => observer.disconnect();\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [ref]);\n\n useEffect(() => {\n const { current = {} } = ref || {};\n if (!current.scrollTo || scrollTo === undefined) return;\n\n current.scrollTo({ [horizontal ? 'left' : 'top']: scrollTo, behavior });\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [scrollTo]);\n\n const handleScroll = ({ target } = {}) => {\n const next = calcValue(target);\n setValue(next);\n clearTimeout(timeout);\n timeout = setTimeout(() => onScroll(next), scrollEventThrottle);\n };\n\n const calcValue = ({ clientHeight, clientWidth, scrollHeight, scrollWidth, scrollTop, scrollLeft } = {}) => {\n const x = parseInt(scrollLeft, 10);\n const y = parseInt(scrollTop, 10);\n const offsetX = scrollWidth - clientWidth;\n const offsetY = scrollHeight - clientHeight;\n\n return offsetY > 0\n ? {\n x,\n y,\n percentX: offsetX ? parseInt((x * 100) / offsetX, 10) : 0,\n percentY: offsetY ? parseInt((y * 100) / offsetY, 10) : 0,\n }\n : undefined;\n };\n\n const percent = scrollIndicator && value ? (horizontal ? value.percentX : value.percentY) : undefined;\n\n return React.createElement(\n Primitive,\n {\n ...others,\n ref,\n role: others.role || 'scrollview',\n tag: others.tag || 'scrollview',\n onScroll: handleScroll,\n className: styles(\n style.scrollview,\n snap && style.snap,\n horizontal ? style.horizontal : style.vertical,\n others.className,\n ),\n style: { ...others.style, height, width },\n },\n <>\n {children}\n {percent >= 0 && (\n <View\n className={styles(\n style.indicator,\n horizontal ? style.horizontal : style.vertical,\n percent > 95 && style.hide,\n )}\n >\n <View\n className={style.progress}\n style={\n horizontal ? { height: '100%', width: `${percent || 0}%` } : { height: `${percent || 0}%`, width: '100%' }\n }\n />\n <Icon headline level={2} value={horizontal ? ICON.RIGHT : ICON.DOWN} />\n </View>\n )}\n </>,\n );\n};\n\nScrollView.displayName = 'Primitive:ScrollView';\n\nScrollView.propTypes = {\n behavior: PropTypes.string,\n children: PropTypes.node.isRequired,\n height: PropTypes.number,\n horizontal: PropTypes.bool,\n scrollEventThrottle: PropTypes.number,\n scrollIndicator: PropTypes.bool,\n scrollTo: PropTypes.number,\n snap: PropTypes.bool,\n width: PropTypes.number,\n onScroll: PropTypes.func,\n};\n\nexport { ScrollView };\n"],"mappings":"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"}
|
|
@@ -3,6 +3,13 @@
|
|
|
3
3
|
display: flex;
|
|
4
4
|
height: fit-content;
|
|
5
5
|
width: fit-content;
|
|
6
|
+
position: relative;
|
|
7
|
+
scrollbar-width: none;
|
|
8
|
+
-ms-overflow-style: none;
|
|
9
|
+
}
|
|
10
|
+
|
|
11
|
+
.scrollview::-webkit-scrollbar {
|
|
12
|
+
display: none;
|
|
6
13
|
}
|
|
7
14
|
|
|
8
15
|
.scrollview.horizontal {
|
|
@@ -24,15 +31,54 @@
|
|
|
24
31
|
scroll-snap-type: x mandatory;
|
|
25
32
|
}
|
|
26
33
|
|
|
27
|
-
.scrollview.
|
|
28
|
-
|
|
29
|
-
-ms-overflow-style: none;
|
|
34
|
+
.scrollview.snap > * {
|
|
35
|
+
scroll-snap-align: start;
|
|
30
36
|
}
|
|
31
37
|
|
|
32
|
-
.scrollview.
|
|
33
|
-
|
|
38
|
+
.scrollview .indicator {
|
|
39
|
+
align-items: center;
|
|
40
|
+
background-color: var(--mirai-ui-base);
|
|
41
|
+
border-radius: 50%;
|
|
42
|
+
box-shadow: var(--mirai-ui-shadow);
|
|
43
|
+
justify-content: center;
|
|
44
|
+
min-height: var(--mirai-ui-button-height);
|
|
45
|
+
min-width: var(--mirai-ui-button-height);
|
|
46
|
+
overflow: hidden;
|
|
47
|
+
position: sticky;
|
|
48
|
+
transition: transform var(--mirai-ui-motion-collapse) var(--mirai-ui-motion-easing);
|
|
34
49
|
}
|
|
35
50
|
|
|
36
|
-
.
|
|
37
|
-
|
|
51
|
+
.indicator.horizontal {
|
|
52
|
+
right: var(--mirai-ui-space-M);
|
|
53
|
+
top: 50%;
|
|
54
|
+
transform-origin: top center;
|
|
55
|
+
transform: scale(1) translateY(-50%);
|
|
56
|
+
}
|
|
57
|
+
|
|
58
|
+
.indicator.vertical {
|
|
59
|
+
bottom: var(--mirai-ui-space-M);
|
|
60
|
+
left: 50%;
|
|
61
|
+
transform-origin: center left;
|
|
62
|
+
transform: scale(1) translateX(-50%);
|
|
63
|
+
}
|
|
64
|
+
|
|
65
|
+
.indicator.horizontal.hide {
|
|
66
|
+
transform: scale(0) translateY(-50%);
|
|
67
|
+
}
|
|
68
|
+
|
|
69
|
+
.indicator.vertical.hide {
|
|
70
|
+
transform: scale(0) translateX(-50%);
|
|
71
|
+
}
|
|
72
|
+
|
|
73
|
+
.indicator .progress {
|
|
74
|
+
background-color: var(--mirai-ui-content-border);
|
|
75
|
+
height: 0%;
|
|
76
|
+
left: 0;
|
|
77
|
+
position: absolute;
|
|
78
|
+
top: 0;
|
|
79
|
+
width: 100%;
|
|
80
|
+
}
|
|
81
|
+
|
|
82
|
+
.indicator [data-role='icon'] {
|
|
83
|
+
z-index: var(--mirai-ui-layer-M);
|
|
38
84
|
}
|
|
@@ -23,7 +23,7 @@ var containerStyle = {
|
|
|
23
23
|
backgroundColor: 'var(--mirai-ui-content-background)',
|
|
24
24
|
border: 'solid var(--mirai-ui-border-width) var(--mirai-ui-content-border)',
|
|
25
25
|
borderRadius: 'var(--mirai-ui-border-radius)',
|
|
26
|
-
padding: 'var(--mirai-ui-space-S)'
|
|
26
|
+
padding: '0 var(--mirai-ui-space-S)'
|
|
27
27
|
};
|
|
28
28
|
var boxStyle = {
|
|
29
29
|
backgroundColor: 'var(--mirai-ui-content-border)',
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ScrollView.stories.js","names":["title","containerStyle","backgroundColor","border","borderRadius","padding","boxStyle","display","margin","minHeight","minWidth","Story","props","style","storyName","args","behavior","height","horizontal","scrollEventThrottle","scrollIndicator","scrollTo","undefined","snap","tag","width","onScroll","console","log","testId","argTypes","options","control","type","defaultValue"],"sources":["../../../src/primitives/ScrollView/ScrollView.stories.jsx"],"sourcesContent":["/* eslint-disable react/prop-types */\nimport React from 'react';\n\nimport { ScrollView } from './ScrollView';\nimport { Primitive } from '../Primitive';\n\nexport default { title: 'Primitives' };\n\nconst containerStyle = {\n backgroundColor: 'var(--mirai-ui-content-background)',\n border: 'solid var(--mirai-ui-border-width) var(--mirai-ui-content-border)',\n borderRadius: 'var(--mirai-ui-border-radius)',\n padding: 'var(--mirai-ui-space-S)',\n};\n\nconst boxStyle = {\n backgroundColor: 'var(--mirai-ui-content-border)',\n display: 'block',\n margin: 'var(--mirai-ui-space-S)',\n minHeight: 'calc(var(--mirai-ui-space-XXL) * 2)',\n minWidth: 'calc(var(--mirai-ui-space-XXL) * 2)',\n};\n\nexport const Story = (props) => (\n
|
|
1
|
+
{"version":3,"file":"ScrollView.stories.js","names":["title","containerStyle","backgroundColor","border","borderRadius","padding","boxStyle","display","margin","minHeight","minWidth","Story","props","style","storyName","args","behavior","height","horizontal","scrollEventThrottle","scrollIndicator","scrollTo","undefined","snap","tag","width","onScroll","console","log","testId","argTypes","options","control","type","defaultValue"],"sources":["../../../src/primitives/ScrollView/ScrollView.stories.jsx"],"sourcesContent":["/* eslint-disable react/prop-types */\nimport React from 'react';\n\nimport { ScrollView } from './ScrollView';\nimport { Primitive } from '../Primitive';\n\nexport default { title: 'Primitives' };\n\nconst containerStyle = {\n backgroundColor: 'var(--mirai-ui-content-background)',\n border: 'solid var(--mirai-ui-border-width) var(--mirai-ui-content-border)',\n borderRadius: 'var(--mirai-ui-border-radius)',\n padding: '0 var(--mirai-ui-space-S)',\n};\n\nconst boxStyle = {\n backgroundColor: 'var(--mirai-ui-content-border)',\n display: 'block',\n margin: 'var(--mirai-ui-space-S)',\n minHeight: 'calc(var(--mirai-ui-space-XXL) * 2)',\n minWidth: 'calc(var(--mirai-ui-space-XXL) * 2)',\n};\n\nexport const Story = (props) => {\n return (\n <ScrollView {...props} style={{ ...containerStyle, ...props.style }}>\n <Primitive className=\"children\" style={boxStyle}>\n child:1\n </Primitive>\n <Primitive className=\"children\" style={boxStyle}>\n child:2\n </Primitive>\n <Primitive className=\"children\" style={boxStyle}>\n child:3\n </Primitive>\n <Primitive className=\"children\" style={boxStyle}>\n child:4\n </Primitive>\n <Primitive className=\"children\" style={boxStyle}>\n child:5\n </Primitive>\n </ScrollView>\n );\n};\n\nStory.storyName = 'Scrollview';\n\nStory.args = {\n behavior: 'smooth',\n height: 256,\n horizontal: false,\n scrollEventThrottle: 16,\n scrollIndicator: false,\n scrollTo: undefined,\n snap: true,\n tag: 'div',\n width: 256,\n onScroll: (...props) => console.log('<ScrollView>::onScroll', ...props),\n // inherited properties\n testId: 'test-story',\n style: {},\n};\n\nStory.argTypes = {\n behavior: {\n options: ['auto', 'smooth', 'initial', 'inherit'],\n control: { type: 'select' },\n defaultValue: 'smooth',\n },\n};\n"],"mappings":";;;;;;AACA;AAEA;AACA;AAAyC;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,eAE1B;EAAEA,KAAK,EAAE;AAAa,CAAC;AAAA;AAEtC,IAAMC,cAAc,GAAG;EACrBC,eAAe,EAAE,oCAAoC;EACrDC,MAAM,EAAE,mEAAmE;EAC3EC,YAAY,EAAE,+BAA+B;EAC7CC,OAAO,EAAE;AACX,CAAC;AAED,IAAMC,QAAQ,GAAG;EACfJ,eAAe,EAAE,gCAAgC;EACjDK,OAAO,EAAE,OAAO;EAChBC,MAAM,EAAE,yBAAyB;EACjCC,SAAS,EAAE,qCAAqC;EAChDC,QAAQ,EAAE;AACZ,CAAC;AAEM,IAAMC,KAAK,GAAG,SAARA,KAAK,CAAIC,KAAK,EAAK;EAC9B,oBACE,6BAAC,sBAAU,eAAKA,KAAK;IAAE,KAAK,kCAAOX,cAAc,GAAKW,KAAK,CAACC,KAAK;EAAG,iBAClE,6BAAC,oBAAS;IAAC,SAAS,EAAC,UAAU;IAAC,KAAK,EAAEP;EAAS,aAEpC,eACZ,6BAAC,oBAAS;IAAC,SAAS,EAAC,UAAU;IAAC,KAAK,EAAEA;EAAS,aAEpC,eACZ,6BAAC,oBAAS;IAAC,SAAS,EAAC,UAAU;IAAC,KAAK,EAAEA;EAAS,aAEpC,eACZ,6BAAC,oBAAS;IAAC,SAAS,EAAC,UAAU;IAAC,KAAK,EAAEA;EAAS,aAEpC,eACZ,6BAAC,oBAAS;IAAC,SAAS,EAAC,UAAU;IAAC,KAAK,EAAEA;EAAS,aAEpC,CACD;AAEjB,CAAC;AAAC;AAEFK,KAAK,CAACG,SAAS,GAAG,YAAY;AAE9BH,KAAK,CAACI,IAAI,GAAG;EACXC,QAAQ,EAAE,QAAQ;EAClBC,MAAM,EAAE,GAAG;EACXC,UAAU,EAAE,KAAK;EACjBC,mBAAmB,EAAE,EAAE;EACvBC,eAAe,EAAE,KAAK;EACtBC,QAAQ,EAAEC,SAAS;EACnBC,IAAI,EAAE,IAAI;EACVC,GAAG,EAAE,KAAK;EACVC,KAAK,EAAE,GAAG;EACVC,QAAQ,EAAE;IAAA;IAAA,kCAAId,KAAK;MAALA,KAAK;IAAA;IAAA,OAAK,YAAAe,OAAO,EAACC,GAAG,kBAAC,wBAAwB,SAAKhB,KAAK,EAAC;EAAA;EACvE;EACAiB,MAAM,EAAE,YAAY;EACpBhB,KAAK,EAAE,CAAC;AACV,CAAC;AAEDF,KAAK,CAACmB,QAAQ,GAAG;EACfd,QAAQ,EAAE;IACRe,OAAO,EAAE,CAAC,MAAM,EAAE,QAAQ,EAAE,SAAS,EAAE,SAAS,CAAC;IACjDC,OAAO,EAAE;MAAEC,IAAI,EAAE;IAAS,CAAC;IAC3BC,YAAY,EAAE;EAChB;AACF,CAAC"}
|
|
@@ -3,7 +3,7 @@
|
|
|
3
3
|
exports[`primitive:<ScrollView> inherit:className 1`] = `
|
|
4
4
|
<DocumentFragment>
|
|
5
5
|
<ui_scrollview
|
|
6
|
-
class="scrollview snap vertical
|
|
6
|
+
class="scrollview snap vertical mirai"
|
|
7
7
|
>
|
|
8
8
|
<div
|
|
9
9
|
style="height: 128px; width: 128px;"
|
|
@@ -62,7 +62,7 @@ exports[`primitive:<ScrollView> inherit:className 1`] = `
|
|
|
62
62
|
exports[`primitive:<ScrollView> prop:height 1`] = `
|
|
63
63
|
<DocumentFragment>
|
|
64
64
|
<ui_scrollview
|
|
65
|
-
class="scrollview snap vertical
|
|
65
|
+
class="scrollview snap vertical"
|
|
66
66
|
style="height: 256px;"
|
|
67
67
|
>
|
|
68
68
|
<div
|
|
@@ -122,7 +122,7 @@ exports[`primitive:<ScrollView> prop:height 1`] = `
|
|
|
122
122
|
exports[`primitive:<ScrollView> prop:horizontal 1`] = `
|
|
123
123
|
<DocumentFragment>
|
|
124
124
|
<ui_scrollview
|
|
125
|
-
class="scrollview snap horizontal
|
|
125
|
+
class="scrollview snap horizontal"
|
|
126
126
|
>
|
|
127
127
|
<div
|
|
128
128
|
style="height: 128px; width: 128px;"
|
|
@@ -240,7 +240,7 @@ exports[`primitive:<ScrollView> prop:scrollIndicator 1`] = `
|
|
|
240
240
|
exports[`primitive:<ScrollView> prop:scrollto 1`] = `
|
|
241
241
|
<DocumentFragment>
|
|
242
242
|
<ui_scrollview
|
|
243
|
-
class="scrollview snap vertical
|
|
243
|
+
class="scrollview snap vertical"
|
|
244
244
|
>
|
|
245
245
|
<div
|
|
246
246
|
style="height: 128px; width: 128px;"
|
|
@@ -299,7 +299,7 @@ exports[`primitive:<ScrollView> prop:scrollto 1`] = `
|
|
|
299
299
|
exports[`primitive:<ScrollView> prop:snap 1`] = `
|
|
300
300
|
<DocumentFragment>
|
|
301
301
|
<ui_scrollview
|
|
302
|
-
class="scrollview vertical
|
|
302
|
+
class="scrollview vertical"
|
|
303
303
|
>
|
|
304
304
|
<div
|
|
305
305
|
style="height: 128px; width: 128px;"
|
|
@@ -358,7 +358,7 @@ exports[`primitive:<ScrollView> prop:snap 1`] = `
|
|
|
358
358
|
exports[`primitive:<ScrollView> prop:width 1`] = `
|
|
359
359
|
<DocumentFragment>
|
|
360
360
|
<ui_scrollview
|
|
361
|
-
class="scrollview snap vertical
|
|
361
|
+
class="scrollview snap vertical"
|
|
362
362
|
style="width: 256px;"
|
|
363
363
|
>
|
|
364
364
|
<div
|
|
@@ -418,7 +418,7 @@ exports[`primitive:<ScrollView> prop:width 1`] = `
|
|
|
418
418
|
exports[`primitive:<ScrollView> renders 1`] = `
|
|
419
419
|
<DocumentFragment>
|
|
420
420
|
<ui_scrollview
|
|
421
|
-
class="scrollview snap vertical
|
|
421
|
+
class="scrollview snap vertical"
|
|
422
422
|
>
|
|
423
423
|
<div
|
|
424
424
|
style="height: 128px; width: 128px;"
|
|
@@ -477,7 +477,7 @@ exports[`primitive:<ScrollView> renders 1`] = `
|
|
|
477
477
|
exports[`primitive:<ScrollView> tag 1`] = `
|
|
478
478
|
<DocumentFragment>
|
|
479
479
|
<ui_tag
|
|
480
|
-
class="scrollview snap vertical
|
|
480
|
+
class="scrollview snap vertical"
|
|
481
481
|
>
|
|
482
482
|
<div
|
|
483
483
|
style="height: 128px; width: 128px;"
|
|
@@ -536,7 +536,7 @@ exports[`primitive:<ScrollView> tag 1`] = `
|
|
|
536
536
|
exports[`primitive:<ScrollView> testId 1`] = `
|
|
537
537
|
<DocumentFragment>
|
|
538
538
|
<ui_scrollview
|
|
539
|
-
class="scrollview snap vertical
|
|
539
|
+
class="scrollview snap vertical"
|
|
540
540
|
data-testid="mirai"
|
|
541
541
|
>
|
|
542
542
|
<div
|