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.
@@ -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
- onClick,
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
  );