@pisell/private-materials 6.4.42 → 6.4.43

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 (188) hide show
  1. package/build/lowcode/assets-daily.json +11 -11
  2. package/build/lowcode/assets-dev.json +2 -2
  3. package/build/lowcode/assets-prod.json +11 -11
  4. package/build/lowcode/index.js +1 -1
  5. package/build/lowcode/meta.js +1 -1
  6. package/build/lowcode/preview.js +146 -146
  7. package/build/lowcode/render/default/view.css +1 -1
  8. package/build/lowcode/render/default/view.js +8 -8
  9. package/build/lowcode/view.css +1 -1
  10. package/build/lowcode/view.js +8 -8
  11. package/es/components/booking/components/actionButtons/index.js +37 -42
  12. package/es/components/booking/components/actionButtons/index.less +0 -28
  13. package/es/components/booking/components/footer/amount.d.ts +3 -3
  14. package/es/components/booking/components/footer/amount.js +13 -2
  15. package/es/components/booking/components/footer/index.js +168 -68
  16. package/es/components/booking/components/footer/utils.js +62 -33
  17. package/es/components/booking/info/model.js +5 -0
  18. package/es/components/booking/info/service/addService/index.js +2 -1
  19. package/es/components/booking/info2/index.js +42 -2
  20. package/es/components/booking/info2/service/addService/index.js +2 -1
  21. package/es/components/booking/info2/service/editService/index.js +12 -4
  22. package/es/components/checkout/PaymentModal.d.ts +2 -0
  23. package/es/components/checkout/PaymentModal.js +395 -240
  24. package/es/components/checkout/components/AdditionalModule/index.less +1 -1
  25. package/es/components/checkout/components/AmountSummary/index.js +161 -54
  26. package/es/components/checkout/components/CashPaymentModule/index.d.ts +5 -3
  27. package/es/components/checkout/components/CashPaymentModule/index.js +114 -137
  28. package/es/components/checkout/components/CashPaymentModule/index.less +200 -176
  29. package/es/components/checkout/components/PaymentDetailModal/index.js +2 -2
  30. package/es/components/checkout/components/PaymentOptionsModule/PaymentMethodItem.d.ts +29 -0
  31. package/es/components/checkout/components/PaymentOptionsModule/PaymentMethodItem.js +210 -0
  32. package/es/components/checkout/components/PaymentOptionsModule/index.d.ts +2 -4
  33. package/es/components/checkout/components/PaymentOptionsModule/index.js +12 -114
  34. package/es/components/checkout/components/PaymentOptionsModule/index.less +29 -0
  35. package/es/components/checkout/components/SavePayLaterHandler/index.js +1 -1
  36. package/es/components/checkout/components/SearchAndClientModule/index.js +40 -39
  37. package/es/components/checkout/components/WalletPassModule/index.js +3 -2
  38. package/es/components/checkout/components/WalletPassModule/utils.js +6 -1
  39. package/es/components/checkout/hooks/useWalletPass.d.ts +1 -1
  40. package/es/components/checkout/hooks/useWalletPass.js +2 -0
  41. package/es/components/checkout/index.less +1 -1
  42. package/es/components/checkout/locales.d.ts +33 -0
  43. package/es/components/checkout/locales.js +39 -3
  44. package/es/components/checkout/types.d.ts +1 -0
  45. package/es/components/eftposPay/hooks.d.ts +1 -1
  46. package/es/components/eftposPay/store/index.d.ts +2 -2
  47. package/es/components/shoppingCart/components/Cart/Product.js +143 -71
  48. package/es/components/shoppingCart/components/Cart/index.js +1 -1
  49. package/es/components/shoppingCart/components/Cart/index.less +31 -0
  50. package/es/components/shoppingCart/locales.d.ts +3 -0
  51. package/es/components/shoppingCart/locales.js +12 -3
  52. package/es/components/ticketBooking/utils/index.js +2 -1
  53. package/es/pro/pisellPriceKeyboardPopover/PisellPriceKeyboardPopover.js +1 -1
  54. package/es/pro/pisellSimplePriceKeyboardPopover/PisellPriceKeyboardPopover.d.ts +5 -0
  55. package/es/pro/pisellSimplePriceKeyboardPopover/PisellPriceKeyboardPopover.js +148 -0
  56. package/es/pro/pisellSimplePriceKeyboardPopover/PisellPriceKeyboardPopover.less +23 -0
  57. package/es/pro/pisellSimplePriceKeyboardPopover/index.d.ts +2 -0
  58. package/es/pro/pisellSimplePriceKeyboardPopover/index.js +1 -0
  59. package/es/pro/pisellSimplePriceKeyboardPopover/types.d.ts +33 -0
  60. package/es/pro/pisellSimplePriceKeyboardPopover/types.js +1 -0
  61. package/es/pro/priceKeyboard/components/cashKeyboard/CashKeyboardIntact.d.ts +4 -0
  62. package/es/pro/priceKeyboard/components/cashKeyboard/CashKeyboardIntact.js +310 -0
  63. package/es/pro/priceKeyboard/components/cashKeyboard/CashKeyboardSimple.d.ts +13 -0
  64. package/es/pro/priceKeyboard/components/cashKeyboard/CashKeyboardSimple.js +349 -0
  65. package/es/pro/priceKeyboard/components/cashKeyboard/index.d.ts +11 -0
  66. package/es/pro/priceKeyboard/components/cashKeyboard/index.js +49 -0
  67. package/es/pro/priceKeyboard/components/cashKeyboard/index.less +103 -0
  68. package/es/pro/priceKeyboard/components/cashKeyboard/locales.d.ts +39 -0
  69. package/es/pro/priceKeyboard/components/cashKeyboard/locales.js +41 -0
  70. package/es/pro/priceKeyboard/components/cashKeyboard/types.d.ts +97 -0
  71. package/es/pro/priceKeyboard/components/cashKeyboard/types.js +1 -0
  72. package/es/pro/priceKeyboard/components/discountKeyboard/index.d.ts +22 -0
  73. package/es/pro/priceKeyboard/components/discountKeyboard/index.js +442 -0
  74. package/es/pro/priceKeyboard/components/discountKeyboard/index.less +47 -0
  75. package/es/pro/priceKeyboard/components/discountKeyboard/locales.d.ts +42 -0
  76. package/es/pro/priceKeyboard/components/discountKeyboard/locales.js +44 -0
  77. package/es/pro/priceKeyboard/components/discountKeyboard/types.d.ts +17 -0
  78. package/es/pro/priceKeyboard/components/discountKeyboard/types.js +1 -0
  79. package/es/pro/priceKeyboard/components/paymentKeyboard/index.d.ts +11 -0
  80. package/es/pro/priceKeyboard/components/paymentKeyboard/index.js +444 -0
  81. package/es/pro/priceKeyboard/components/paymentKeyboard/index.less +64 -0
  82. package/es/pro/priceKeyboard/components/paymentKeyboard/locales.d.ts +45 -0
  83. package/es/pro/priceKeyboard/components/paymentKeyboard/locales.js +47 -0
  84. package/es/pro/priceKeyboard/components/paymentKeyboard/types.d.ts +39 -0
  85. package/es/pro/priceKeyboard/components/paymentKeyboard/types.js +1 -0
  86. package/es/pro/priceKeyboard/components/shortcuts/index.d.ts +17 -0
  87. package/es/pro/priceKeyboard/components/shortcuts/index.js +47 -0
  88. package/es/pro/priceKeyboard/components/shortcuts/index.less +39 -0
  89. package/es/pro/priceKeyboard/hooks/keyActions.d.ts +28 -0
  90. package/es/pro/priceKeyboard/hooks/keyActions.js +252 -0
  91. package/es/pro/priceKeyboard/hooks/rightItems.d.ts +27 -0
  92. package/es/pro/priceKeyboard/hooks/rightItems.js +50 -0
  93. package/es/pro/priceKeyboard/index.d.ts +3 -0
  94. package/es/pro/priceKeyboard/index.js +3 -0
  95. package/es/pro/priceKeyboard/index.less +215 -0
  96. package/es/pro/priceKeyboard/utils.d.ts +31 -0
  97. package/es/pro/priceKeyboard/utils.js +51 -0
  98. package/es/pro/skuDetailModal/index.js +19 -16
  99. package/lib/components/booking/components/actionButtons/index.js +31 -28
  100. package/lib/components/booking/components/actionButtons/index.less +0 -28
  101. package/lib/components/booking/components/footer/amount.d.ts +3 -3
  102. package/lib/components/booking/components/footer/amount.js +10 -4
  103. package/lib/components/booking/components/footer/index.js +107 -40
  104. package/lib/components/booking/components/footer/utils.js +35 -7
  105. package/lib/components/booking/info/model.js +3 -0
  106. package/lib/components/booking/info/service/addService/index.js +2 -1
  107. package/lib/components/booking/info2/index.js +18 -1
  108. package/lib/components/booking/info2/service/addService/index.js +2 -1
  109. package/lib/components/booking/info2/service/editService/index.js +12 -4
  110. package/lib/components/checkout/PaymentModal.d.ts +2 -0
  111. package/lib/components/checkout/PaymentModal.js +152 -73
  112. package/lib/components/checkout/components/AdditionalModule/index.less +1 -1
  113. package/lib/components/checkout/components/AmountSummary/index.js +114 -40
  114. package/lib/components/checkout/components/CashPaymentModule/index.d.ts +5 -3
  115. package/lib/components/checkout/components/CashPaymentModule/index.js +103 -140
  116. package/lib/components/checkout/components/CashPaymentModule/index.less +200 -176
  117. package/lib/components/checkout/components/PaymentDetailModal/index.js +2 -2
  118. package/lib/components/checkout/components/PaymentOptionsModule/PaymentMethodItem.d.ts +29 -0
  119. package/lib/components/checkout/components/PaymentOptionsModule/PaymentMethodItem.js +172 -0
  120. package/lib/components/checkout/components/PaymentOptionsModule/index.d.ts +2 -4
  121. package/lib/components/checkout/components/PaymentOptionsModule/index.js +11 -123
  122. package/lib/components/checkout/components/PaymentOptionsModule/index.less +29 -0
  123. package/lib/components/checkout/components/SavePayLaterHandler/index.js +1 -1
  124. package/lib/components/checkout/components/SearchAndClientModule/index.js +3 -29
  125. package/lib/components/checkout/components/WalletPassModule/index.js +3 -2
  126. package/lib/components/checkout/components/WalletPassModule/utils.js +4 -1
  127. package/lib/components/checkout/hooks/useWalletPass.d.ts +1 -1
  128. package/lib/components/checkout/hooks/useWalletPass.js +2 -0
  129. package/lib/components/checkout/index.less +1 -1
  130. package/lib/components/checkout/locales.d.ts +33 -0
  131. package/lib/components/checkout/locales.js +39 -3
  132. package/lib/components/checkout/types.d.ts +1 -0
  133. package/lib/components/eftposPay/hooks.d.ts +1 -1
  134. package/lib/components/eftposPay/store/index.d.ts +2 -2
  135. package/lib/components/shoppingCart/components/Cart/Product.js +111 -51
  136. package/lib/components/shoppingCart/components/Cart/index.js +1 -1
  137. package/lib/components/shoppingCart/components/Cart/index.less +31 -0
  138. package/lib/components/shoppingCart/locales.d.ts +3 -0
  139. package/lib/components/shoppingCart/locales.js +6 -3
  140. package/lib/components/ticketBooking/index.js +5 -1
  141. package/lib/components/ticketBooking/utils/index.js +2 -1
  142. package/lib/pro/pisellPriceKeyboardPopover/PisellPriceKeyboardPopover.js +2 -2
  143. package/lib/pro/pisellSimplePriceKeyboardPopover/PisellPriceKeyboardPopover.d.ts +5 -0
  144. package/lib/pro/pisellSimplePriceKeyboardPopover/PisellPriceKeyboardPopover.js +144 -0
  145. package/lib/pro/pisellSimplePriceKeyboardPopover/PisellPriceKeyboardPopover.less +23 -0
  146. package/lib/pro/pisellSimplePriceKeyboardPopover/index.d.ts +2 -0
  147. package/lib/pro/pisellSimplePriceKeyboardPopover/index.js +35 -0
  148. package/lib/pro/pisellSimplePriceKeyboardPopover/types.d.ts +33 -0
  149. package/lib/pro/pisellSimplePriceKeyboardPopover/types.js +17 -0
  150. package/lib/pro/priceKeyboard/components/cashKeyboard/CashKeyboardIntact.d.ts +4 -0
  151. package/lib/pro/priceKeyboard/components/cashKeyboard/CashKeyboardIntact.js +332 -0
  152. package/lib/pro/priceKeyboard/components/cashKeyboard/CashKeyboardSimple.d.ts +13 -0
  153. package/lib/pro/priceKeyboard/components/cashKeyboard/CashKeyboardSimple.js +399 -0
  154. package/lib/pro/priceKeyboard/components/cashKeyboard/index.d.ts +11 -0
  155. package/lib/pro/priceKeyboard/components/cashKeyboard/index.js +76 -0
  156. package/lib/pro/priceKeyboard/components/cashKeyboard/index.less +103 -0
  157. package/lib/pro/priceKeyboard/components/cashKeyboard/locales.d.ts +39 -0
  158. package/lib/pro/priceKeyboard/components/cashKeyboard/locales.js +65 -0
  159. package/lib/pro/priceKeyboard/components/cashKeyboard/types.d.ts +97 -0
  160. package/lib/pro/priceKeyboard/components/cashKeyboard/types.js +17 -0
  161. package/lib/pro/priceKeyboard/components/discountKeyboard/index.d.ts +22 -0
  162. package/lib/pro/priceKeyboard/components/discountKeyboard/index.js +485 -0
  163. package/lib/pro/priceKeyboard/components/discountKeyboard/index.less +47 -0
  164. package/lib/pro/priceKeyboard/components/discountKeyboard/locales.d.ts +42 -0
  165. package/lib/pro/priceKeyboard/components/discountKeyboard/locales.js +68 -0
  166. package/lib/pro/priceKeyboard/components/discountKeyboard/types.d.ts +17 -0
  167. package/lib/pro/priceKeyboard/components/discountKeyboard/types.js +17 -0
  168. package/lib/pro/priceKeyboard/components/paymentKeyboard/index.d.ts +11 -0
  169. package/lib/pro/priceKeyboard/components/paymentKeyboard/index.js +488 -0
  170. package/lib/pro/priceKeyboard/components/paymentKeyboard/index.less +64 -0
  171. package/lib/pro/priceKeyboard/components/paymentKeyboard/locales.d.ts +45 -0
  172. package/lib/pro/priceKeyboard/components/paymentKeyboard/locales.js +71 -0
  173. package/lib/pro/priceKeyboard/components/paymentKeyboard/types.d.ts +39 -0
  174. package/lib/pro/priceKeyboard/components/paymentKeyboard/types.js +17 -0
  175. package/lib/pro/priceKeyboard/components/shortcuts/index.d.ts +17 -0
  176. package/lib/pro/priceKeyboard/components/shortcuts/index.js +79 -0
  177. package/lib/pro/priceKeyboard/components/shortcuts/index.less +39 -0
  178. package/lib/pro/priceKeyboard/hooks/keyActions.d.ts +28 -0
  179. package/lib/pro/priceKeyboard/hooks/keyActions.js +176 -0
  180. package/lib/pro/priceKeyboard/hooks/rightItems.d.ts +27 -0
  181. package/lib/pro/priceKeyboard/hooks/rightItems.js +81 -0
  182. package/lib/pro/priceKeyboard/index.d.ts +3 -0
  183. package/lib/pro/priceKeyboard/index.js +45 -0
  184. package/lib/pro/priceKeyboard/index.less +215 -0
  185. package/lib/pro/priceKeyboard/utils.d.ts +31 -0
  186. package/lib/pro/priceKeyboard/utils.js +75 -0
  187. package/lib/pro/skuDetailModal/index.js +18 -22
  188. package/package.json +4 -4
@@ -0,0 +1,215 @@
1
+ .price-keyboard {
2
+ display: flex;
3
+ flex-direction: column;
4
+ gap: 20px;
5
+ background-color: #ffffff;
6
+ border-radius: 12px;
7
+ padding: 20px;
8
+ box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
9
+ }
10
+
11
+ .price-keyboard-inputs {
12
+ display: flex;
13
+ flex-direction: column;
14
+ gap: 16px;
15
+ }
16
+
17
+ .price-keyboard-inputs-default {
18
+ display: flex;
19
+ flex-direction: column;
20
+ gap: 16px;
21
+ }
22
+
23
+ .price-keyboard-input-wrapper {
24
+ display: flex;
25
+ align-items: center;
26
+ padding: 12px 16px;
27
+ background-color: #f9fafb;
28
+ border: 1px solid #d0d5dd;
29
+ border-radius: 8px;
30
+ transition: all 0.2s ease;
31
+
32
+ &:hover {
33
+ border-color: #98a2b3;
34
+ }
35
+
36
+ &:focus-within {
37
+ border-color: #1570ef;
38
+ box-shadow: 0 0 0 3px rgba(21, 112, 239, 0.1);
39
+ }
40
+ }
41
+
42
+ .price-keyboard-input {
43
+ flex: 1;
44
+ }
45
+
46
+ .price-keyboard-keyboard {
47
+ display: flex;
48
+ gap: 12px;
49
+ }
50
+
51
+ .price-keyboard-keyboard-numbers {
52
+ flex: 1;
53
+ display: grid;
54
+ grid-template-columns: repeat(3, 1fr);
55
+ gap: 8px;
56
+ }
57
+
58
+ .price-keyboard-keyboard-actions {
59
+ display: flex;
60
+ flex-direction: column;
61
+ gap: 8px;
62
+ width: 80px;
63
+ }
64
+
65
+ .price-keyboard-key {
66
+ display: flex;
67
+ align-items: center;
68
+ justify-content: center;
69
+ height: 48px;
70
+ border: 1px solid #d0d5dd;
71
+ border-radius: 8px;
72
+ background-color: #ffffff;
73
+ color: #344054;
74
+ font-size: 16px;
75
+ font-weight: 500;
76
+ cursor: pointer;
77
+ transition: all 0.2s ease;
78
+ outline: none;
79
+
80
+ &:hover {
81
+ background-color: #f9fafb;
82
+ border-color: #98a2b3;
83
+ }
84
+
85
+ &:active {
86
+ background-color: #f2f4f7;
87
+ transform: translateY(1px);
88
+ }
89
+
90
+ &:disabled {
91
+ opacity: 0.5;
92
+ cursor: not-allowed;
93
+
94
+ &:hover {
95
+ background-color: #ffffff;
96
+ border-color: #d0d5dd;
97
+ transform: none;
98
+ }
99
+ }
100
+
101
+ &.price-keyboard-key-primary {
102
+ background-color: #1570ef;
103
+ color: #ffffff;
104
+ border-color: #1570ef;
105
+
106
+ &:hover {
107
+ background-color: #1366d9;
108
+ border-color: #1366d9;
109
+ }
110
+
111
+ &:active {
112
+ background-color: #0f5bc4;
113
+ border-color: #0f5bc4;
114
+ }
115
+ }
116
+
117
+ &.price-keyboard-key-size-2 {
118
+ height: 104px; /* 48px * 2 + 8px gap */
119
+ }
120
+
121
+ &.price-keyboard-key-size-3 {
122
+ height: 160px; /* 48px * 3 + 16px gap */
123
+ }
124
+ }
125
+
126
+ .price-keyboard-delete-icon {
127
+ width: 20px;
128
+ height: 20px;
129
+ }
130
+
131
+ /* 响应式设计 */
132
+ @media (max-width: 768px) {
133
+ .price-keyboard {
134
+ padding: 16px;
135
+ gap: 16px;
136
+ }
137
+
138
+ .price-keyboard-keyboard {
139
+ flex-direction: column;
140
+ gap: 16px;
141
+ }
142
+
143
+ .price-keyboard-keyboard-actions {
144
+ flex-direction: row;
145
+ width: auto;
146
+ height: auto;
147
+ }
148
+
149
+ .price-keyboard-key {
150
+ height: 44px;
151
+ font-size: 14px;
152
+ }
153
+
154
+ .price-keyboard-key.price-keyboard-key-size-2 {
155
+ height: 44px;
156
+ flex: 2;
157
+ }
158
+
159
+ .price-keyboard-key.price-keyboard-key-size-3 {
160
+ height: 44px;
161
+ flex: 3;
162
+ }
163
+ }
164
+
165
+ /* 深色主题支持 */
166
+ @media (prefers-color-scheme: dark) {
167
+ .price-keyboard {
168
+ background-color: #1f2937;
169
+ box-shadow: 0 4px 12px rgba(0, 0, 0, 0.3);
170
+ }
171
+
172
+ .price-keyboard-input-wrapper {
173
+ background-color: #374151;
174
+ border-color: #4b5563;
175
+
176
+ &:hover {
177
+ border-color: #6b7280;
178
+ }
179
+
180
+ &:focus-within {
181
+ border-color: #3b82f6;
182
+ box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.1);
183
+ }
184
+ }
185
+
186
+ .price-keyboard-key {
187
+ background-color: #374151;
188
+ border-color: #4b5563;
189
+ color: #f9fafb;
190
+
191
+ &:hover {
192
+ background-color: #4b5563;
193
+ border-color: #6b7280;
194
+ }
195
+
196
+ &:active {
197
+ background-color: #6b7280;
198
+ }
199
+
200
+ &.price-keyboard-key-primary {
201
+ background-color: #3b82f6;
202
+ border-color: #3b82f6;
203
+
204
+ &:hover {
205
+ background-color: #2563eb;
206
+ border-color: #2563eb;
207
+ }
208
+
209
+ &:active {
210
+ background-color: #1d4ed8;
211
+ border-color: #1d4ed8;
212
+ }
213
+ }
214
+ }
215
+ }
@@ -0,0 +1,31 @@
1
+ export declare const DEFAULT_THEME_CONFIG: {
2
+ dark: {
3
+ titleColor: string;
4
+ subtitleColor: string;
5
+ keyboardBgColor: string;
6
+ keyboardWrapperBgColor: string;
7
+ bgColor: string;
8
+ bgColorGray200: string;
9
+ bgColorGray300: string;
10
+ textGray500: string;
11
+ textGray600: string;
12
+ textGray900: string;
13
+ };
14
+ light: {
15
+ titleColor: string;
16
+ subtitleColor: string;
17
+ keyboardBgColor: string;
18
+ keyboardWrapperBgColor: string;
19
+ bgColor: string;
20
+ bgColorGray200: string;
21
+ bgColorGray300: string;
22
+ textGray500: string;
23
+ textGray600: string;
24
+ textGray900: string;
25
+ };
26
+ };
27
+ /**
28
+ * 设置键盘主题
29
+ * @param theme 主题
30
+ */
31
+ export declare const setKeyboardTheme: (theme?: 'dark' | 'light') => void;
@@ -0,0 +1,51 @@
1
+ //@ts-ignore
2
+ import { setTheme } from '@pisell/utils';
3
+ export var DEFAULT_THEME_CONFIG = {
4
+ dark: {
5
+ titleColor: '#FFFFFF',
6
+ subtitleColor: '#D0D5DD',
7
+ keyboardBgColor: 'rgba(0, 0, 0, 0.4)',
8
+ keyboardWrapperBgColor: 'rgba(0, 0, 0, 0.7)',
9
+ bgColor: 'rgba(0, 0, 0, 0.70)',
10
+ bgColorGray200: 'rgba(0, 0, 0, 0.40)',
11
+ bgColorGray300: 'rgba(0, 0, 0, 0.40)',
12
+ textGray500: '#D0D5DD',
13
+ textGray600: '#FFFFFF',
14
+ textGray900: '#FFFFFF'
15
+ },
16
+ light: {
17
+ titleColor: '#101828',
18
+ subtitleColor: '#667085',
19
+ keyboardBgColor: '#D0D5DD',
20
+ keyboardWrapperBgColor: 'white',
21
+ bgColor: '#FFFFFF',
22
+ bgColorGray200: '#EAECF0',
23
+ bgColorGray300: '#D0D5DD',
24
+ textGray500: '#667085',
25
+ textGray600: '#475467',
26
+ textGray900: '#101828'
27
+ }
28
+ };
29
+
30
+ /**
31
+ * 设置键盘主题
32
+ * @param theme 主题
33
+ */
34
+ export var setKeyboardTheme = function setKeyboardTheme(theme) {
35
+ var currentTheme = DEFAULT_THEME_CONFIG[theme || 'light'];
36
+ setTheme({
37
+ // 标题颜色
38
+ '--pisell-pro-price-keyboard-title-color': currentTheme.titleColor,
39
+ // 副标题颜色
40
+ '--pisell-pro-price-keyboard-subtitle-color': currentTheme.subtitleColor,
41
+ // 背景颜色梯度
42
+ '--pisell-pro-price-keyboard-wrapper-bg-color': currentTheme.keyboardWrapperBgColor,
43
+ '--pisell-pro-price-keyboard-bg-color': currentTheme.keyboardBgColor,
44
+ '--pisell-pro-price-keyboard-bg-color-gray-200': currentTheme.bgColorGray200,
45
+ '--pisell-pro-price-keyboard-bg-color-gray-300': currentTheme.bgColorGray300,
46
+ // 文本颜色梯度
47
+ '--pisell-pro-price-keyboard-text-gray-500': currentTheme.textGray500,
48
+ '--pisell-pro-price-keyboard-text-gray-600': currentTheme.textGray600,
49
+ '--pisell-pro-price-keyboard-text-gray-900': currentTheme.textGray900
50
+ });
51
+ };
@@ -13,8 +13,6 @@ function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }
13
13
  import React, { forwardRef, useImperativeHandle, useState, useMemo } from 'react';
14
14
  import { PisellModal, Button } from '@pisell/materials';
15
15
  import Decimal from 'decimal.js';
16
- import { PisellAdjustPrice } from '@pisell/materials';
17
- import { createPortal } from 'react-dom';
18
16
  import cloneDeep from 'lodash/cloneDeep';
19
17
  import { locales } from '@pisell/utils';
20
18
  import Delete_wght300_24px from '@pisell/icon/es/Delete_wght300_24px';
@@ -23,6 +21,7 @@ import "./index.less";
23
21
  import PisellNumberSelector from "../pisellNumberSelector";
24
22
  import NoteModal from "../../plus/noteModal";
25
23
  import useEngineContext from "../../hooks/useEngineContext";
24
+ import { DiscountKeyboard } from "../priceKeyboard";
26
25
  var SkuDetailModal = function SkuDetailModal(_ref, ref) {
27
26
  var _context$appHelper, _store$getState, _context$engine, _productData$_extend2, _productData$_extend4, _productData$_extend6;
28
27
  var onConfirm = _ref.onConfirm,
@@ -346,21 +345,25 @@ var SkuDetailModal = function SkuDetailModal(_ref, ref) {
346
345
  onCancel: onNoteCancel,
347
346
  onConfirm: onNoteConfirm,
348
347
  onDelete: onNoteDelete
349
- }), showPriceAdjustModal && /*#__PURE__*/createPortal( /*#__PURE__*/React.createElement("div", {
350
- className: "pisell-price-adjust-overlay"
351
- }, /*#__PURE__*/React.createElement("div", {
352
- className: "pisell-price-adjust-backdrop",
353
- onMouseDown: function onMouseDown(e) {
354
- e.preventDefault();
355
- setShowPriceAdjustModal(false);
348
+ }), /*#__PURE__*/React.createElement(DiscountKeyboard, {
349
+ containerProps: {
350
+ renderType: 'modal',
351
+ open: showPriceAdjustModal,
352
+ onCancel: function onCancel() {
353
+ return setShowPriceAdjustModal(false);
354
+ }
356
355
  }
357
- }), /*#__PURE__*/React.createElement("div", {
358
- className: "pisell-price-adjust-container"
359
- }, /*#__PURE__*/React.createElement(PisellAdjustPrice, {
360
- originValue: priceOverride,
361
- value: priceOverride,
362
- onChange: handlePriceAdjustConfirm,
356
+ // 允许一口价超出原价
357
+ ,
358
+ enableExceedMaxAmount: true,
359
+ originalValue: priceOverride,
360
+ defaultValue: priceOverride,
361
+ onEnter: function onEnter(discountAmount) {
362
+ // 将折扣值转化为最终值
363
+ var finalPrice = new Decimal(priceOverride || 0).minus(discountAmount).toNumber();
364
+ handlePriceAdjustConfirm(finalPrice);
365
+ },
363
366
  selectType: "dark"
364
- }))), document.body)));
367
+ })));
365
368
  };
366
369
  export default /*#__PURE__*/forwardRef(SkuDetailModal);
@@ -33,8 +33,8 @@ __export(actionButtons_exports, {
33
33
  });
34
34
  module.exports = __toCommonJS(actionButtons_exports);
35
35
  var import_react = __toESM(require("react"));
36
- var import_react_dom = require("react-dom");
37
36
  var import_antd = require("antd");
37
+ var import_decimal = __toESM(require("decimal.js"));
38
38
  var import_icon = require("@pisell/icon");
39
39
  var import_utils = require("@pisell/utils");
40
40
  var import_materials = require("@pisell/materials");
@@ -48,6 +48,7 @@ var import_useCustomer = require("../../../ticketBooking/hooks/pisellos/useCusto
48
48
  var import_ahooks = require("ahooks");
49
49
  var import_useEngineContext = __toESM(require("../../../../hooks/useEngineContext"));
50
50
  var import_useScanManager = __toESM(require("../../../ticketBooking/hooks/pisellos/useScanManager"));
51
+ var import_priceKeyboard = require("../../../../pro/priceKeyboard");
51
52
  var createToastContent = (text) => /* @__PURE__ */ import_react.default.createElement("div", { className: "action-buttons-toast-content" }, text);
52
53
  var ActionButtons = ({
53
54
  state,
@@ -146,6 +147,9 @@ var ActionButtons = ({
146
147
  return 0;
147
148
  }
148
149
  }, [state, hasCartItems]);
150
+ const currentTotalPriceAfterDiscount = (0, import_react.useMemo)(() => {
151
+ return new import_decimal.default(currentTotalPrice).minus(state.shop_discount || 0).toNumber();
152
+ }, [state.shop_discount, currentTotalPrice]);
149
153
  const [discountList, setDiscountList] = (0, import_react.useState)([]);
150
154
  const usedVouchersCount = (0, import_react.useMemo)(() => {
151
155
  var _a2, _b2;
@@ -217,6 +221,12 @@ var ActionButtons = ({
217
221
  shop_discount: "0"
218
222
  }
219
223
  });
224
+ dispatch({
225
+ type: "setPaymentPaid",
226
+ payload: {
227
+ value: {}
228
+ }
229
+ });
220
230
  setShowClearModal(false);
221
231
  Toast == null ? void 0 : Toast.success(
222
232
  createToastContent(
@@ -264,6 +274,12 @@ var ActionButtons = ({
264
274
  orderNote: ""
265
275
  }
266
276
  });
277
+ dispatch({
278
+ type: "setPaymentPaid",
279
+ payload: {
280
+ value: {}
281
+ }
282
+ });
267
283
  setShowClearModal(false);
268
284
  Toast == null ? void 0 : Toast.success(
269
285
  createToastContent(
@@ -293,13 +309,7 @@ var ActionButtons = ({
293
309
  });
294
310
  }
295
311
  }, [(_g = state.service) == null ? void 0 : _g.value, (_h = state.addons) == null ? void 0 : _h.value]);
296
- const handlePriceAdjustConfirm = (newPrice) => {
297
- const { productAmount } = (0, import_amount.getSumTotal)(state, {
298
- isEdit: true,
299
- ScheduleModule,
300
- ...getDataFromHost()
301
- });
302
- const discountAmount = Math.max(0, productAmount - newPrice);
312
+ const handlePriceAdjustConfirm = (discountAmount) => {
303
313
  dispatch({
304
314
  type: "setState",
305
315
  payload: {
@@ -419,26 +429,19 @@ var ActionButtons = ({
419
429
  onClearItemsOnly: handleClearItemsOnly,
420
430
  onClearAllAndReset: handleClearAllAndReset
421
431
  }
422
- ), showPriceAdjustModal && (0, import_react_dom.createPortal)(
423
- /* @__PURE__ */ import_react.default.createElement("div", { className: "pisell-price-adjust-overlay" }, /* @__PURE__ */ import_react.default.createElement(
424
- "div",
425
- {
426
- className: "pisell-price-adjust-backdrop",
427
- onMouseDown: (e) => {
428
- e.preventDefault();
429
- setShowPriceAdjustModal(false);
430
- }
431
- }
432
- ), /* @__PURE__ */ import_react.default.createElement("div", { className: "pisell-price-adjust-container" }, /* @__PURE__ */ import_react.default.createElement(
433
- import_materials.PisellAdjustPrice,
434
- {
435
- selectType: "dark",
436
- originValue: currentTotalPrice,
437
- value: currentTotalPrice,
438
- onChange: handlePriceAdjustConfirm
439
- }
440
- ))),
441
- document.body
432
+ ), /* @__PURE__ */ import_react.default.createElement(
433
+ import_priceKeyboard.DiscountKeyboard,
434
+ {
435
+ containerProps: {
436
+ renderType: "modal",
437
+ open: showPriceAdjustModal,
438
+ onCancel: () => setShowPriceAdjustModal(false)
439
+ },
440
+ selectType: "dark",
441
+ originalValue: currentTotalPrice,
442
+ defaultValue: currentTotalPriceAfterDiscount,
443
+ onEnter: handlePriceAdjustConfirm
444
+ }
442
445
  ), /* @__PURE__ */ import_react.default.createElement(
443
446
  import_customiseItemModal.default,
444
447
  {
@@ -185,31 +185,3 @@
185
185
  font-weight: 400 !important;
186
186
  color: inherit !important;
187
187
  }
188
-
189
- // 价格调整覆盖层样式 - 现在通过 Portal 渲染到 document.body
190
- .pisell-price-adjust-overlay {
191
- position: fixed;
192
- top: 0;
193
- left: 0;
194
- right: 0;
195
- bottom: 0;
196
- z-index: 9999; // 由于现在渲染到 document.body,使用更高的 z-index
197
- display: flex;
198
- align-items: center;
199
- justify-content: center;
200
- }
201
-
202
- .pisell-price-adjust-backdrop {
203
- position: absolute;
204
- top: 0;
205
- left: 0;
206
- right: 0;
207
- bottom: 0;
208
- background: transparent; // 纯透明遮罩
209
- cursor: pointer; // 显示点击手势
210
- }
211
-
212
- .pisell-price-adjust-container {
213
- position: relative;
214
- z-index: 10000; // 确保键盘在遮罩之上
215
- }
@@ -23,12 +23,12 @@ export declare const getSumTotal: (state: any, options: {
23
23
  surcharge: any;
24
24
  otherAmount: any;
25
25
  sumTotalAmount: number;
26
- paidAmount: number;
26
+ paidAmount: any;
27
27
  notPaidAmount: number;
28
28
  paySurchargeFee: number;
29
29
  expectAmount: number;
30
- actualPaidAmount: number;
31
- orderPaidAmount: number;
30
+ actualPaidAmount: any;
31
+ orderPaidAmount: any;
32
32
  totalRefundAmount: number;
33
33
  dueAmount: number;
34
34
  roundingAmount: number;
@@ -419,16 +419,22 @@ var getSurchargeAmount = (state, surcharge, options) => {
419
419
  }, 0);
420
420
  };
421
421
  var getPaidAmount = (state) => {
422
- var _a;
422
+ var _a, _b, _c, _d, _e;
423
423
  const { bookingDetail, bookingId } = state;
424
+ if ((_b = (_a = state.paymentPaid) == null ? void 0 : _a.value) == null ? void 0 : _b.paidAmount) {
425
+ return (_d = (_c = state.paymentPaid) == null ? void 0 : _c.value) == null ? void 0 : _d.paidAmount;
426
+ }
424
427
  if (!bookingDetail || !bookingId) return 0;
425
- return Number((_a = state.bookingDetail) == null ? void 0 : _a.paid_amount) || 0;
428
+ return Number((_e = state.bookingDetail) == null ? void 0 : _e.paid_amount) || 0;
426
429
  };
427
430
  var getOrderPaidAmount = (state) => {
428
- var _a;
431
+ var _a, _b, _c, _d, _e;
429
432
  const { bookingDetail, bookingId } = state;
433
+ if ((_b = (_a = state.paymentPaid) == null ? void 0 : _a.value) == null ? void 0 : _b.paidAmountWithoutSurcharge) {
434
+ return (_d = (_c = state.paymentPaid) == null ? void 0 : _c.value) == null ? void 0 : _d.paidAmountWithoutSurcharge;
435
+ }
430
436
  if (!bookingDetail || !bookingId) return 0;
431
- return Number((_a = state.bookingDetail) == null ? void 0 : _a.order_paid_amount) || 0;
437
+ return Number((_e = state.bookingDetail) == null ? void 0 : _e.order_paid_amount) || 0;
432
438
  };
433
439
  var getIsPriceIncludeTax = (state) => {
434
440
  var _a;