sales-frontend-components 0.0.59 → 0.0.61
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/consent-contents/consent-content.module.scss +708 -0
- package/dist/consent-contents/examples/examples.module.scss +38 -0
- package/dist/consent-contents/info-bar/info-bar.module.scss +99 -0
- package/dist/index.cjs.js +46 -1
- package/dist/index.cjs.js.map +1 -1
- package/dist/index.esm.js +46 -1
- package/dist/index.esm.js.map +1 -1
- package/package.json +10 -10
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
@use 'sales-frontend-design-system/design-system-context' as *;
|
|
2
|
+
|
|
3
|
+
/* Example-only styles */
|
|
4
|
+
|
|
5
|
+
.gap-title-medium {
|
|
6
|
+
margin-bottom: margin(title-medium);
|
|
7
|
+
}
|
|
8
|
+
|
|
9
|
+
.gap-card {
|
|
10
|
+
margin-bottom: margin(card);
|
|
11
|
+
}
|
|
12
|
+
|
|
13
|
+
.control-bar {
|
|
14
|
+
display: flex;
|
|
15
|
+
gap: padding(xsmall);
|
|
16
|
+
align-items: center;
|
|
17
|
+
padding: padding(small);
|
|
18
|
+
margin-bottom: margin(title-medium);
|
|
19
|
+
background-color: colors(surface-neutral);
|
|
20
|
+
border: 1px solid colors(border-neutral_2);
|
|
21
|
+
border-radius: radius-basic(medium);
|
|
22
|
+
|
|
23
|
+
button {
|
|
24
|
+
padding: padding(xsmall) padding(small);
|
|
25
|
+
background-color: colors(surface-neutral_1);
|
|
26
|
+
border: 1px solid colors(border-neutral_3);
|
|
27
|
+
border-radius: radius-basic(small);
|
|
28
|
+
}
|
|
29
|
+
}
|
|
30
|
+
|
|
31
|
+
// 모바일: 타이틀과 디스크립션 사이 갭 확장(title-xlarge)
|
|
32
|
+
.mobile-gap-title-xlarge {
|
|
33
|
+
margin-bottom: margin(title-medium);
|
|
34
|
+
|
|
35
|
+
@media (width <= 768px) {
|
|
36
|
+
margin-bottom: margin(title-xlarge);
|
|
37
|
+
}
|
|
38
|
+
}
|
|
@@ -0,0 +1,99 @@
|
|
|
1
|
+
@use 'sales-frontend-design-system/design-system-context' as *;
|
|
2
|
+
|
|
3
|
+
/* ============================
|
|
4
|
+
Info Bar 컴포넌트 스타일
|
|
5
|
+
============================ */
|
|
6
|
+
|
|
7
|
+
// 평가 등급 바 섹션
|
|
8
|
+
.info-section {
|
|
9
|
+
display: flex;
|
|
10
|
+
gap: padding(xxsmall);
|
|
11
|
+
margin: padding(medium) 0;
|
|
12
|
+
}
|
|
13
|
+
|
|
14
|
+
// 개별 등급 아이템
|
|
15
|
+
.rating-item {
|
|
16
|
+
display: flex;
|
|
17
|
+
flex: 1;
|
|
18
|
+
flex-direction: column;
|
|
19
|
+
gap: 0.5rem;
|
|
20
|
+
align-items: center;
|
|
21
|
+
}
|
|
22
|
+
|
|
23
|
+
// Info Bar 기본 스타일
|
|
24
|
+
.info-bar {
|
|
25
|
+
position: relative;
|
|
26
|
+
width: 100%;
|
|
27
|
+
height: 0.5rem;
|
|
28
|
+
border-radius: radius-basic(full);
|
|
29
|
+
|
|
30
|
+
// 기본 상태에서는 원 숨김
|
|
31
|
+
&::after {
|
|
32
|
+
position: absolute;
|
|
33
|
+
top: 50%;
|
|
34
|
+
left: 50%;
|
|
35
|
+
width: 1rem;
|
|
36
|
+
height: 1rem;
|
|
37
|
+
content: '';
|
|
38
|
+
background-color: colors(surface-neutral);
|
|
39
|
+
border: 2px solid transparent;
|
|
40
|
+
border-radius: 50%;
|
|
41
|
+
opacity: 0;
|
|
42
|
+
transform: translate(-50%, -50%);
|
|
43
|
+
transition: opacity 0.2s ease;
|
|
44
|
+
}
|
|
45
|
+
|
|
46
|
+
// 활성 상태에서만 원 표시
|
|
47
|
+
&.active::after {
|
|
48
|
+
opacity: 1;
|
|
49
|
+
}
|
|
50
|
+
}
|
|
51
|
+
|
|
52
|
+
// 등급 라벨
|
|
53
|
+
.rating-label {
|
|
54
|
+
color: colors(text-body);
|
|
55
|
+
text-align: center;
|
|
56
|
+
|
|
57
|
+
@include apply-typography(body3);
|
|
58
|
+
}
|
|
59
|
+
|
|
60
|
+
// 각 등급별 색상
|
|
61
|
+
.info-bar-jade-green {
|
|
62
|
+
background: palette(jade-green400);
|
|
63
|
+
|
|
64
|
+
&.active::after {
|
|
65
|
+
border-color: palette(jade-green400);
|
|
66
|
+
}
|
|
67
|
+
}
|
|
68
|
+
|
|
69
|
+
.info-bar-indigo-blue {
|
|
70
|
+
background: palette(indigo-blue400);
|
|
71
|
+
|
|
72
|
+
&.active::after {
|
|
73
|
+
border-color: palette(indigo-blue400);
|
|
74
|
+
}
|
|
75
|
+
}
|
|
76
|
+
|
|
77
|
+
.info-bar-deep-yellow {
|
|
78
|
+
background: palette(deep-yellow400);
|
|
79
|
+
|
|
80
|
+
&.active::after {
|
|
81
|
+
border-color: palette(deep-yellow400);
|
|
82
|
+
}
|
|
83
|
+
}
|
|
84
|
+
|
|
85
|
+
.info-bar-orange {
|
|
86
|
+
background: palette(orange400);
|
|
87
|
+
|
|
88
|
+
&.active::after {
|
|
89
|
+
border-color: palette(orange400);
|
|
90
|
+
}
|
|
91
|
+
}
|
|
92
|
+
|
|
93
|
+
.info-bar-red {
|
|
94
|
+
background: palette(red400);
|
|
95
|
+
|
|
96
|
+
&.active::after {
|
|
97
|
+
border-color: palette(red400);
|
|
98
|
+
}
|
|
99
|
+
}
|
package/dist/index.cjs.js
CHANGED
|
@@ -798,6 +798,46 @@ function useCanvasPaint(paintProps = {}) {
|
|
|
798
798
|
const testSignatureBase64Data = "";
|
|
799
799
|
|
|
800
800
|
const FloatingButton = ({ onClick }) => {
|
|
801
|
+
const [position, setPosition] = React.useState({ x: 0, y: 0 });
|
|
802
|
+
const [isDragging, setIsDragging] = React.useState(false);
|
|
803
|
+
const dragHappened = React.useRef(false);
|
|
804
|
+
const dragStartPos = React.useRef({ x: 0, y: 0 });
|
|
805
|
+
const elementStartPos = React.useRef({ x: 0, y: 0 });
|
|
806
|
+
const handleMouseDown = (e) => {
|
|
807
|
+
if (e.button !== 0) {
|
|
808
|
+
return;
|
|
809
|
+
}
|
|
810
|
+
dragHappened.current = false;
|
|
811
|
+
setIsDragging(true);
|
|
812
|
+
dragStartPos.current = { x: e.clientX, y: e.clientY };
|
|
813
|
+
elementStartPos.current = { ...position };
|
|
814
|
+
const handleMouseMove = (event) => {
|
|
815
|
+
const dx = event.clientX - dragStartPos.current.x;
|
|
816
|
+
const dy = event.clientY - dragStartPos.current.y;
|
|
817
|
+
if (!dragHappened.current && (Math.abs(dx) > 5 || Math.abs(dy) > 5)) {
|
|
818
|
+
dragHappened.current = true;
|
|
819
|
+
}
|
|
820
|
+
setPosition({
|
|
821
|
+
x: elementStartPos.current.x + dx,
|
|
822
|
+
y: elementStartPos.current.y + dy
|
|
823
|
+
});
|
|
824
|
+
};
|
|
825
|
+
const handleMouseUp = () => {
|
|
826
|
+
window.removeEventListener("mousemove", handleMouseMove);
|
|
827
|
+
window.removeEventListener("mouseup", handleMouseUp);
|
|
828
|
+
setIsDragging(false);
|
|
829
|
+
};
|
|
830
|
+
window.addEventListener("mousemove", handleMouseMove);
|
|
831
|
+
window.addEventListener("mouseup", handleMouseUp);
|
|
832
|
+
};
|
|
833
|
+
const handleClick = (e) => {
|
|
834
|
+
if (dragHappened.current) {
|
|
835
|
+
e.preventDefault();
|
|
836
|
+
e.stopPropagation();
|
|
837
|
+
return;
|
|
838
|
+
}
|
|
839
|
+
onClick();
|
|
840
|
+
};
|
|
801
841
|
return /* @__PURE__ */ jsxRuntime.jsx(
|
|
802
842
|
salesFrontendDesignSystem.Button,
|
|
803
843
|
{
|
|
@@ -805,7 +845,12 @@ const FloatingButton = ({ onClick }) => {
|
|
|
805
845
|
appearance: "filled",
|
|
806
846
|
size: "xsmall",
|
|
807
847
|
className: styles$2["debug-floating-button"],
|
|
808
|
-
|
|
848
|
+
style: {
|
|
849
|
+
transform: `translate(${position.x}px, ${position.y}px)`,
|
|
850
|
+
cursor: isDragging ? "grabbing" : "grab"
|
|
851
|
+
},
|
|
852
|
+
onMouseDown: handleMouseDown,
|
|
853
|
+
onClick: handleClick,
|
|
809
854
|
children: "DEBUG"
|
|
810
855
|
}
|
|
811
856
|
);
|