@egjs/react-flicking 4.16.0-beta.1 → 4.18.0-beta.3

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.
Files changed (52) hide show
  1. package/.env +1 -0
  2. package/package.json +2 -2
  3. package/dev/archive/App.css +0 -32
  4. package/dev/archive/App.tsx +0 -52
  5. package/dev/archive/DebugPage.css +0 -21
  6. package/dev/archive/DebugPage.tsx +0 -93
  7. package/dev/archive/Header.tsx +0 -52
  8. package/dev/archive/StatePage.css +0 -21
  9. package/dev/archive/StatePage.tsx +0 -107
  10. package/dev/archive/css/align.css +0 -79
  11. package/dev/archive/css/bound.css +0 -88
  12. package/dev/archive/css/common.css +0 -76
  13. package/dev/archive/css/cross.css +0 -21
  14. package/dev/archive/css/features.css +0 -49
  15. package/dev/archive/css/gap.css +0 -13
  16. package/dev/archive/css/highlight.css +0 -96
  17. package/dev/archive/css/infinite.css +0 -35
  18. package/dev/archive/css/parallax.css +0 -3
  19. package/dev/archive/css/plugins.css +0 -46
  20. package/dev/archive/css/progress.css +0 -16
  21. package/dev/archive/css/variable-size.css +0 -15
  22. package/dev/archive/features/Align.tsx +0 -149
  23. package/dev/archive/features/Bound.tsx +0 -83
  24. package/dev/archive/features/CrossFlicking.tsx +0 -74
  25. package/dev/archive/features/FreeScroll.tsx +0 -66
  26. package/dev/archive/features/InfiniteFlicking.tsx +0 -192
  27. package/dev/archive/features/PlaceHolderItem.tsx +0 -36
  28. package/dev/archive/features/Progress.tsx +0 -241
  29. package/dev/archive/features/PropChange.tsx +0 -171
  30. package/dev/archive/features/Snap.tsx +0 -95
  31. package/dev/archive/features/VariableSize.tsx +0 -42
  32. package/dev/archive/features/Virtual.tsx +0 -45
  33. package/dev/archive/plugins/Arrow.tsx +0 -25
  34. package/dev/archive/plugins/AutoPlay.tsx +0 -70
  35. package/dev/archive/plugins/Fade.tsx +0 -69
  36. package/dev/archive/plugins/Parallax.tsx +0 -70
  37. package/dev/archive/utils.ts +0 -3
  38. package/dev/basic-sample/App.tsx +0 -36
  39. package/dev/basic-sample/index.html +0 -12
  40. package/dev/basic-sample/main.tsx +0 -10
  41. package/dev/index.html +0 -18
  42. package/dev/plugin-check/App.tsx +0 -341
  43. package/dev/plugin-check/index.html +0 -15
  44. package/dev/plugin-check/main.tsx +0 -6
  45. package/dev/scratch/App.tsx +0 -34
  46. package/dev/scratch/index.html +0 -15
  47. package/dev/scratch/main.tsx +0 -13
  48. package/dev/tsconfig.json +0 -12
  49. package/dev/vite-env.d.ts +0 -3
  50. package/tsconfig.json +0 -23
  51. package/vite.config.ts +0 -38
  52. package/vite.dev.config.ts +0 -58
@@ -1,49 +0,0 @@
1
- .flicking-viewport {
2
- width: 500px;
3
- height: 130px;
4
- margin: 0px auto;
5
- background: #eee;
6
- background: rgba(55, 55, 55 0.1);
7
- border-radius: 5px;
8
- }
9
- .panel {
10
- position: relative;
11
- display: block;
12
- border-radius: 5px;
13
- width: 200px;
14
- margin-top: 5px;
15
- background: #f55;
16
- height: 120px;
17
- text-align: center;
18
- line-height: 120px;
19
- }
20
- .flicking-viewport .panel0 {
21
- background: #f47071;
22
- }
23
- .flicking-viewport .panel1 {
24
- background: #f69462;
25
- }
26
- .flicking-viewport .panel2 {
27
- background: #ede484;
28
- }
29
- .flicking-viewport .panel3 {
30
- background: #90f290;
31
- }
32
- .flicking-viewport .panel4 {
33
- background: #78caff;
34
- }
35
- .flicking-viewport .infinite0 {
36
- background: #f47071;
37
- }
38
- .flicking-viewport .infinite1 {
39
- background: #f69462;
40
- }
41
- .flicking-viewport .infinite2 {
42
- background: #ede484;
43
- }
44
- .flicking-viewport .infinite3 {
45
- background: #90f290;
46
- }
47
- .flicking-viewport .infinite4 {
48
- background: #78caff;
49
- }
@@ -1,13 +0,0 @@
1
- #gap .flicking1 .panel:before {
2
- position: absolute;
3
- width: 20px;
4
- content: "2 0 p x";
5
- word-break: break-all;
6
- font-weight: bold;
7
- color: #333;
8
- left: 200px;
9
- top: 50%;
10
- transform: translateY(-50%);
11
- line-height: 1.2;
12
- text-align: center;
13
- }
@@ -1,96 +0,0 @@
1
- /*
2
-
3
- Atom One Dark by Daniel Gamage
4
- Original One Dark Syntax theme from https://github.com/atom/one-dark-syntax
5
-
6
- base: #282c34
7
- mono-1: #abb2bf
8
- mono-2: #818896
9
- mono-3: #5c6370
10
- hue-1: #56b6c2
11
- hue-2: #61aeee
12
- hue-3: #c678dd
13
- hue-4: #98c379
14
- hue-5: #e06c75
15
- hue-5-2: #be5046
16
- hue-6: #d19a66
17
- hue-6-2: #e6c07b
18
-
19
- */
20
-
21
- .hljs {
22
- display: block;
23
- overflow-x: auto;
24
- padding: 0.5em;
25
- color: #abb2bf;
26
- background: #282c34;
27
- }
28
-
29
- .hljs-comment,
30
- .hljs-quote {
31
- color: #5c6370;
32
- font-style: italic;
33
- }
34
-
35
- .hljs-doctag,
36
- .hljs-keyword,
37
- .hljs-formula {
38
- color: #c678dd;
39
- }
40
-
41
- .hljs-section,
42
- .hljs-name,
43
- .hljs-selector-tag,
44
- .hljs-deletion,
45
- .hljs-subst {
46
- color: #e06c75;
47
- }
48
-
49
- .hljs-literal {
50
- color: #56b6c2;
51
- }
52
-
53
- .hljs-string,
54
- .hljs-regexp,
55
- .hljs-addition,
56
- .hljs-attribute,
57
- .hljs-meta-string {
58
- color: #98c379;
59
- }
60
-
61
- .hljs-built_in,
62
- .hljs-class .hljs-title {
63
- color: #e6c07b;
64
- }
65
-
66
- .hljs-attr,
67
- .hljs-variable,
68
- .hljs-template-variable,
69
- .hljs-type,
70
- .hljs-selector-class,
71
- .hljs-selector-attr,
72
- .hljs-selector-pseudo,
73
- .hljs-number {
74
- color: #d19a66;
75
- }
76
-
77
- .hljs-symbol,
78
- .hljs-bullet,
79
- .hljs-link,
80
- .hljs-meta,
81
- .hljs-selector-id,
82
- .hljs-title {
83
- color: #61aeee;
84
- }
85
-
86
- .hljs-emphasis {
87
- font-style: italic;
88
- }
89
-
90
- .hljs-strong {
91
- font-weight: bold;
92
- }
93
-
94
- .hljs-link {
95
- text-decoration: underline;
96
- }
@@ -1,35 +0,0 @@
1
- #infinite .buttons {
2
- padding: 10px 0px;
3
- text-align: center;
4
- }
5
- #infinite .buttons button {
6
- padding: 10px 15px;
7
- background: #eee;
8
- border: 0;
9
- margin: 0px 2px;
10
- }
11
- #infinite .buttons button:hover {
12
- background: #ccc;
13
- }
14
- #infinite .panel,
15
- #infinite .infinite {
16
- font-weight: bold;
17
- }
18
- #infinite .flicking2 .infinite {
19
- transition: background ease 1s;
20
- }
21
- #infinite .flicking .infinite.placeholder {
22
- background: #ddd;
23
- color: transparent;
24
- }
25
-
26
- #infinite .infinite {
27
- position: relative;
28
- display: block;
29
- border-radius: 5px;
30
- width: 200px;
31
- margin-top: 5px;
32
- height: 120px;
33
- text-align: center;
34
- line-height: 120px;
35
- }
@@ -1,3 +0,0 @@
1
- #parallax .flicking-viewport .panel {
2
- width: 500px;
3
- }
@@ -1,46 +0,0 @@
1
- .plugins h1 {
2
- line-height: 1;
3
- }
4
- .plugins h1 a {
5
- font-size: 20px;
6
- vertical-align: bottom;
7
- margin-left: 10px;
8
- /* color: #55e; */
9
- }
10
- .plugins .flicking-viewport {
11
- width: 500px;
12
- height: 200px;
13
- margin: 0px auto;
14
- background: #eee;
15
- background: rgba(55, 55, 55 0.1);
16
- border-radius: 5px;
17
- }
18
- .plugins .flicking-viewport .panel {
19
- position: relative;
20
- display: block;
21
- border-radius: 5px;
22
- width: 400px;
23
- margin-top: 5px;
24
- background: #f55;
25
- height: 200px;
26
- text-align: center;
27
- line-height: 200px;
28
- overflow: hidden;
29
- }
30
- .plugins .panel:after {
31
- content: "";
32
- position: absolute;
33
- width: 100%;
34
- height: 100%;
35
- top: 0;
36
- left: 0;
37
- background: rgba(0, 0, 0, 0.1);
38
- }
39
- .plugins .panel img {
40
- top: -100%;
41
- bottom: -100%;
42
- margin: auto;
43
- position: absolute;
44
- left: 50%;
45
- transform: translate(-50%);
46
- }
@@ -1,16 +0,0 @@
1
- #progress .progress {
2
- position: relative;
3
- width: 400px;
4
- height: 10px;
5
- border-radius: 5px;
6
- background: #eee;
7
- margin: 10px auto;
8
- overflow: hidden;
9
- }
10
- #progress .thumb {
11
- position: relative;
12
- height: 100%;
13
- width: 0;
14
- border-radius: inherit;
15
- background: #ccc;
16
- }
@@ -1,15 +0,0 @@
1
- #variable-size .flicking-viewport .panel0 {
2
- width: 100px;
3
- }
4
- #variable-size .flicking-viewport .panel1 {
5
- width: 200px;
6
- }
7
- #variable-size .flicking-viewport .panel2 {
8
- width: 80px;
9
- }
10
- #variable-size .flicking-viewport .panel3 {
11
- width: 250px;
12
- }
13
- #variable-size .flicking-viewport .panel4 {
14
- width: 150px;
15
- }
@@ -1,149 +0,0 @@
1
- import Flicking from "@dev/react-flicking";
2
- import * as React from "react";
3
- import { insertCode } from "../utils";
4
- import "../css/align.css";
5
-
6
- export default class Align extends React.Component<{}> {
7
- public render() {
8
- return (
9
- <div id="align" className="container">
10
- <h1>Flexible Align</h1>
11
- <ul className="extra">
12
- <li>Use Hanger and Anchor to provide customizable alignment.</li>
13
- <li>The Hanger and Anchor have magnetically bonded effect which allows the panel position to be aligned</li>
14
- <li>
15
- <strong>Hanger:</strong> An alignment point within Flicking area. It hangs panel anchors to its position.
16
- </li>
17
- <li>
18
- <strong>Anchor:</strong> Alignment points based on each panels. Panel's anchor position is determined by
19
- this value. <br /> It will be used for a reference point where panel should stop when selected, interacting
20
- with hanger position.
21
- </li>
22
- </ul>
23
- <h2>Center Align (Default)</h2>
24
- <h3>hanger: 50%, anchor: 50%</h3>
25
- <div className="hanger hanger0"></div>
26
- <Flicking className="flicking flicking0">
27
- <div className="panel panel0">
28
- <div className="anchor"></div>
29
- </div>
30
- <div className="panel panel1">
31
- <div className="anchor"></div>
32
- </div>
33
- <div className="panel panel2">
34
- <div className="anchor"></div>
35
- </div>
36
- <div className="panel panel3">
37
- <div className="anchor"></div>
38
- </div>
39
- <div className="panel panel4">
40
- <div className="anchor"></div>
41
- </div>
42
- <div className="panel panel0">
43
- <div className="anchor"></div>
44
- </div>
45
- </Flicking>
46
- <pre>
47
- <code className="hljs html" data-script="flicking0"></code>
48
- </pre>
49
-
50
- <h2>Left Align</h2>
51
- <h2>hanger: 0, anchor: 0</h2>
52
- <div className="hanger hanger1"></div>
53
- <Flicking className="flicking flicking1" align="prev">
54
- <div className="panel panel0">
55
- <div className="anchor"></div>
56
- </div>
57
- <div className="panel panel1">
58
- <div className="anchor"></div>
59
- </div>
60
- <div className="panel panel2">
61
- <div className="anchor"></div>
62
- </div>
63
- <div className="panel panel3">
64
- <div className="anchor"></div>
65
- </div>
66
- <div className="panel panel4">
67
- <div className="anchor"></div>
68
- </div>
69
- <div className="panel panel0">
70
- <div className="anchor"></div>
71
- </div>
72
- </Flicking>
73
- <div className="pagination pagination1"></div>
74
- <pre>
75
- <code className="hljs html" data-script="flicking1"></code>
76
- </pre>
77
-
78
- <h2>Custom Align</h2>
79
- <h3>hanger: 30%, anchor: 50px</h3>
80
- <div className="hanger hanger2"></div>
81
- <Flicking className="flicking flicking2" align={{ camera: "30%", panel: "50px" }}>
82
- <div className="panel panel0">
83
- <div className="anchor"></div>
84
- </div>
85
- <div className="panel panel1">
86
- <div className="anchor"></div>
87
- </div>
88
- <div className="panel panel2">
89
- <div className="anchor"></div>
90
- </div>
91
- <div className="panel panel3">
92
- <div className="anchor"></div>
93
- </div>
94
- <div className="panel panel4">
95
- <div className="anchor"></div>
96
- </div>
97
- <div className="panel panel0">
98
- <div className="anchor"></div>
99
- </div>
100
- </Flicking>
101
- <div className="pagination pagination2"></div>
102
- <pre>
103
- <code className="hljs html" data-script="flicking2"></code>
104
- </pre>
105
- </div>
106
- );
107
- }
108
- public componentDidMount() {
109
- insertCode(
110
- "align",
111
- 0,
112
- `
113
- <Flicking className="flicking flicking0">
114
- <div className="panel"><div className="anchor"></div></div>
115
- <div className="panel"><div className="anchor"></div></div>
116
- <div className="panel"><div className="anchor"></div></div>
117
- <div className="panel"><div className="anchor"></div></div>
118
- <div className="panel"><div className="anchor"></div></div>
119
- <div className="panel"><div className="anchor"></div></div>
120
- </Flicking>`
121
- );
122
- insertCode(
123
- "align",
124
- 1,
125
- `
126
- <Flicking className="flicking flicking1" hanger={"0"} anchor={"0"}>
127
- <div className="panel"><div className="anchor"></div></div>
128
- <div className="panel"><div className="anchor"></div></div>
129
- <div className="panel"><div className="anchor"></div></div>
130
- <div className="panel"><div className="anchor"></div></div>
131
- <div className="panel"><div className="anchor"></div></div>
132
- <div className="panel"><div className="anchor"></div></div>
133
- </Flicking>`
134
- );
135
- insertCode(
136
- "align",
137
- 2,
138
- `
139
- <Flicking className="flicking flicking2" hanger={"30%"} anchor={"50px"}>
140
- <div className="panel"><div className="anchor"></div></div>
141
- <div className="panel"><div className="anchor"></div></div>
142
- <div className="panel"><div className="anchor"></div></div>
143
- <div className="panel"><div className="anchor"></div></div>
144
- <div className="panel"><div className="anchor"></div></div>
145
- <div className="panel"><div className="anchor"></div></div>
146
- </Flicking>`
147
- );
148
- }
149
- }
@@ -1,83 +0,0 @@
1
- import Flicking from "@dev/react-flicking";
2
- import * as React from "react";
3
- import { insertCode } from "../utils";
4
- import "../css/bound.css";
5
-
6
- export default class Bound extends React.Component<{}> {
7
- public render() {
8
- return (
9
- <div id="bound" className="container">
10
- <h1>
11
- Bound <img src="https://naver.github.io/egjs-flicking/images/bound-dog.png" alt="img" width="40px" />
12
- </h1>
13
- <ul className="extra">
14
- <li>Bound the panels so that they are not out of the flicking area.</li>
15
- <li>This prevents unwanted free space within the flicking area.</li>
16
- </ul>
17
- <h2>bound: false</h2>
18
- <div className="hanger hanger0"></div>
19
- <Flicking className="flicking flicking0" gap={10}>
20
- <div className="panel panel0">
21
- <div className="anchor"></div>
22
- </div>
23
- <div className="panel panel1">
24
- <div className="anchor"></div>
25
- </div>
26
- <div className="panel panel2">
27
- <div className="anchor"></div>
28
- </div>
29
- <div className="panel panel3">
30
- <div className="anchor"></div>
31
- </div>
32
- <div className="panel panel4">
33
- <div className="anchor"></div>
34
- </div>
35
- <div className="panel panel0">
36
- <div className="anchor"></div>
37
- </div>
38
- </Flicking>
39
- <h2>bound: true</h2>
40
- <div className="hanger hanger0"></div>
41
- <Flicking className="flicking flicking1" gap={10} bound={true}>
42
- <div className="panel panel0">
43
- <div className="anchor"></div>
44
- </div>
45
- <div className="panel panel1">
46
- <div className="anchor"></div>
47
- </div>
48
- <div className="panel panel2">
49
- <div className="anchor"></div>
50
- </div>
51
- <div className="panel panel3">
52
- <div className="anchor"></div>
53
- </div>
54
- <div className="panel panel4">
55
- <div className="anchor"></div>
56
- </div>
57
- <div className="panel panel0">
58
- <div className="anchor"></div>
59
- </div>
60
- </Flicking>
61
- <div className="pagination pagination2"></div>
62
- <pre>
63
- <code className="hljs html" data-script="flicking1"></code>
64
- </pre>
65
- </div>
66
- );
67
- }
68
- public componentDidMount() {
69
- insertCode(
70
- "bound",
71
- 1,
72
- `
73
- <Flicking className="flicking flicking1" bound={true}>
74
- <div className="panel"><div className="anchor"></div></div>
75
- <div className="panel"><div className="anchor"></div></div>
76
- <div className="panel"><div className="anchor"></div></div>
77
- <div className="panel"><div className="anchor"></div></div>
78
- <div className="panel"><div className="anchor"></div></div>
79
- <div className="panel"><div className="anchor"></div></div>
80
- </Flicking>`
81
- );
82
- }
83
- }
@@ -1,74 +0,0 @@
1
- import { CrossFlicking } from "@dev/react-flicking";
2
- import * as React from "react";
3
- import "../css/cross.css";
4
-
5
- export default class Cross extends React.Component<{}> {
6
- public render() {
7
- return (
8
- <div id="cross" className="container">
9
- <CrossFlicking className="flicking" preventDefaultOnDrag={true}>
10
- <div data-cross-groupkey="0" className="panel">
11
- <img src="https://naver.github.io/egjs-infinitegrid/assets/image/11.jpg" />
12
- 방송 1A
13
- </div>
14
- <div data-cross-groupkey="0" className="panel">
15
- <img src="https://naver.github.io/egjs-infinitegrid/assets/image/12.jpg" />
16
- 방송 1B
17
- </div>
18
- <div data-cross-groupkey="0" className="panel">
19
- <img src="https://naver.github.io/egjs-infinitegrid/assets/image/13.jpg" />
20
- 방송 1C
21
- </div>
22
- <div data-cross-groupkey="0" className="panel">
23
- <img src="https://naver.github.io/egjs-infinitegrid/assets/image/14.jpg" />
24
- 방송 1D
25
- </div>
26
- <div data-cross-groupkey="0" className="panel">
27
- <img src="https://naver.github.io/egjs-infinitegrid/assets/image/15.jpg" />
28
- 방송 1E
29
- </div>
30
- <div data-cross-groupkey="1" className="panel">
31
- <img src="https://naver.github.io/egjs-infinitegrid/assets/image/16.jpg" />
32
- 축구 2A
33
- </div>
34
- <div data-cross-groupkey="1" className="panel">
35
- <img src="https://naver.github.io/egjs-infinitegrid/assets/image/17.jpg" />
36
- 축구 2B
37
- </div>
38
- <div data-cross-groupkey="1" className="panel">
39
- <img src="https://naver.github.io/egjs-infinitegrid/assets/image/18.jpg" />
40
- 축구 2C
41
- </div>
42
- <div data-cross-groupkey="1" className="panel">
43
- <img src="https://naver.github.io/egjs-infinitegrid/assets/image/19.jpg" />
44
- 축구 2D
45
- </div>
46
- <div data-cross-groupkey="1" className="panel">
47
- <img src="https://naver.github.io/egjs-infinitegrid/assets/image/39.jpg" />
48
- 축구 2E
49
- </div>
50
- <div data-cross-groupkey="2" className="panel">
51
- <img src="https://naver.github.io/egjs-infinitegrid/assets/image/21.jpg" />
52
- 패션 3A
53
- </div>
54
- <div data-cross-groupkey="2" className="panel">
55
- <img src="https://naver.github.io/egjs-infinitegrid/assets/image/22.jpg" />
56
- 패션 3B
57
- </div>
58
- <div data-cross-groupkey="2" className="panel">
59
- <img src="https://naver.github.io/egjs-infinitegrid/assets/image/38.jpg" />
60
- 패션 3C
61
- </div>
62
- <div data-cross-groupkey="2" className="panel">
63
- <img src="https://naver.github.io/egjs-infinitegrid/assets/image/24.jpg" />
64
- 패션 3D
65
- </div>
66
- <div data-cross-groupkey="2" className="panel">
67
- <img src="https://naver.github.io/egjs-infinitegrid/assets/image/25.jpg" />
68
- 패션 3E
69
- </div>
70
- </CrossFlicking>
71
- </div>
72
- );
73
- }
74
- }
@@ -1,66 +0,0 @@
1
- import Flicking from "@dev/react-flicking";
2
- import * as React from "react";
3
- import { insertCode } from "../utils";
4
-
5
- export default class FreeScroll extends React.Component<{}> {
6
- public render() {
7
- return (
8
- <div id="free-scroll" className="container">
9
- <h1>Free Scroll</h1>
10
- <ul className="extra">
11
- <li>The panels are freely scrollable.</li>
12
- </ul>
13
- <h2>moveType: "freeScroll", deceleration: 0.0075(default)</h2>
14
- <Flicking className="flicking flicking0" gap={10} circular={true} moveType="freeScroll" renderOnlyVisible>
15
- <div className="panel panel0"></div>
16
- <div className="panel panel1"></div>
17
- <div className="panel panel2"></div>
18
- <div className="panel panel3"></div>
19
- <div className="panel panel4"></div>
20
- </Flicking>
21
- <pre>
22
- <code className="hljs html" data-script="flicking0"></code>
23
- </pre>
24
- <h2>moveType: "freeScroll", deceleration: 0.015</h2>
25
- <Flicking className="flicking flicking1" gap={10} circular={true} deceleration={0.015} moveType="freeScroll">
26
- <div className="panel panel0"></div>
27
- <div className="panel panel1"></div>
28
- <div className="panel panel2"></div>
29
- <div className="panel panel3"></div>
30
- <div className="panel panel4"></div>
31
- </Flicking>
32
- <pre>
33
- <code className="hljs html" data-script="flicking1"></code>
34
- </pre>
35
- </div>
36
- );
37
- }
38
- public componentDidMount() {
39
- insertCode(
40
- "free-scroll",
41
- 0,
42
- `
43
- <Flicking className="flicking flicking0" gap={10} circular={true} moveType="freeScroll">
44
- <div className="panel"></div>
45
- <div className="panel"></div>
46
- <div className="panel"></div>
47
- <div className="panel"></div>
48
- <div className="panel"></div>
49
- </Flicking>`
50
- );
51
- insertCode(
52
- "free-scroll",
53
- 1,
54
- `
55
- <Flicking
56
- className="flicking flicking1" gap={10}
57
- circular={true} deceleration={0.015} moveType="freeScroll">
58
- <div className="panel"></div>
59
- <div className="panel"></div>
60
- <div className="panel"></div>
61
- <div className="panel"></div>
62
- <div className="panel"></div>
63
- </Flicking>`
64
- );
65
- }
66
- }