@bee-hole/server 2.0.7 → 2.2.0

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 (110) hide show
  1. package/i18n/ar-EG.toml +5 -0
  2. package/i18n/bn-BD.toml +5 -0
  3. package/i18n/de-DE.toml +5 -0
  4. package/i18n/en-US.toml +5 -0
  5. package/i18n/es-ES.toml +5 -0
  6. package/i18n/fr-FR.toml +5 -0
  7. package/i18n/hi-IN.toml +5 -0
  8. package/i18n/id-ID.toml +5 -0
  9. package/i18n/it-IT.toml +5 -0
  10. package/i18n/ja-JP.toml +5 -0
  11. package/i18n/ko-KR.toml +5 -0
  12. package/i18n/ms-MY.toml +5 -0
  13. package/i18n/pt-PT.toml +5 -0
  14. package/i18n/ru-RU.toml +5 -0
  15. package/i18n/th-TH.toml +5 -0
  16. package/i18n/vi-VN.toml +5 -0
  17. package/i18n/zh-CN.toml +12 -1
  18. package/i18n/zh-TW.toml +5 -0
  19. package/main.exe +0 -0
  20. package/mainD +0 -0
  21. package/package.json +2 -2
  22. package/resource/public/cp/css/{app~f075b844.e4324fc5.css → app~f075b844.b5d17e09.css} +1 -1
  23. package/resource/public/cp/css/{app~f075b844.e4324fc5.css.gz → app~f075b844.b5d17e09.css.gz} +0 -0
  24. package/resource/public/cp/css/chunk-1b5a347c.e253dc48.css +1 -0
  25. package/resource/public/cp/css/chunk-286b8764.59941530.css +1 -0
  26. package/resource/public/cp/css/chunk-286b8764.59941530.css.gz +0 -0
  27. package/resource/public/cp/css/chunk-452aba94.704d1e60.css +1 -0
  28. package/resource/public/cp/css/chunk-452aba94.704d1e60.css.gz +0 -0
  29. package/resource/public/cp/css/{chunk-3d9ea586.7018f7b6.css → chunk-5f4b374c.7b717a3a.css} +1 -1
  30. package/resource/public/cp/css/chunk-5f4b374c.7b717a3a.css.gz +0 -0
  31. package/resource/public/cp/css/lang-package~4e34e71e.20d5c1cf.css +11 -0
  32. package/resource/public/cp/css/lang-package~4e34e71e.20d5c1cf.css.gz +0 -0
  33. package/resource/public/cp/css/lang-zh-TW-service~f63b1681.ae14bf9e.css +1 -0
  34. package/resource/public/cp/css/lang-zh-TW-service~f63b1681.ae14bf9e.css.gz +0 -0
  35. package/resource/public/cp/index.html +1 -1
  36. package/resource/public/cp/js/app~f075b844.c63f49e6.js +1 -0
  37. package/resource/public/cp/js/app~f075b844.c63f49e6.js.gz +0 -0
  38. package/resource/public/cp/js/{chunk-03e1387e.4b04328b.js → chunk-03e1387e.b54aa7be.js} +1 -1
  39. package/resource/public/cp/js/chunk-03e1387e.b54aa7be.js.gz +0 -0
  40. package/resource/public/cp/js/chunk-1b5a347c.1668b912.js +1 -0
  41. package/resource/public/cp/js/chunk-1b5a347c.1668b912.js.gz +0 -0
  42. package/resource/public/cp/js/chunk-286b8764.4b8918c0.js +1 -0
  43. package/resource/public/cp/js/chunk-286b8764.4b8918c0.js.gz +0 -0
  44. package/resource/public/cp/js/chunk-452aba94.dbd0bfb2.js +1 -0
  45. package/resource/public/cp/js/chunk-452aba94.dbd0bfb2.js.gz +0 -0
  46. package/resource/public/cp/js/chunk-5f214972.19f21b30.js +1 -0
  47. package/resource/public/cp/js/chunk-5f214972.19f21b30.js.gz +0 -0
  48. package/resource/public/cp/js/chunk-5f4b374c.061b86cf.js +1 -0
  49. package/resource/public/cp/js/chunk-5f4b374c.061b86cf.js.gz +0 -0
  50. package/resource/public/cp/js/lang-ar-EG~31ecd969.6b49e02d.js +3 -0
  51. package/resource/public/cp/js/lang-ar-EG~31ecd969.6b49e02d.js.gz +0 -0
  52. package/resource/public/cp/js/{lang-bn-BD~ede72586.d8f682d7.js → lang-bn-BD~ede72586.3e0972ac.js} +1 -1
  53. package/resource/public/cp/js/lang-bn-BD~ede72586.3e0972ac.js.gz +0 -0
  54. package/resource/public/cp/js/lang-en-US~31ecd969.03513bfc.js +3 -0
  55. package/resource/public/cp/js/lang-en-US~31ecd969.03513bfc.js.gz +0 -0
  56. package/resource/public/cp/js/lang-ko-KR~31ecd969.b239f513.js +1 -0
  57. package/resource/public/cp/js/lang-ko-KR~31ecd969.b239f513.js.gz +0 -0
  58. package/resource/public/cp/js/lang-ms-MY~d756050e.cc1e7d5c.js +1 -0
  59. package/resource/public/cp/js/lang-ms-MY~d756050e.cc1e7d5c.js.gz +0 -0
  60. package/resource/public/cp/js/lang-package~4e34e71e.a62f5d47.js +11 -0
  61. package/resource/public/cp/js/lang-package~4e34e71e.a62f5d47.js.gz +0 -0
  62. package/resource/public/cp/js/lang-zh-TW-service~f63b1681.8d266d29.js +1 -0
  63. package/resource/public/cp/js/lang-zh-TW-service~f63b1681.8d266d29.js.gz +0 -0
  64. package/resource/public/cp/js/lang-zh-TW~31ecd969.f4885c13.js +1 -0
  65. package/resource/public/cp/js/lang-zh-TW~31ecd969.f4885c13.js.gz +0 -0
  66. package/resource/public/html/h5pay.html +49 -10
  67. package/storage/init/init.sql +167 -5
  68. package/storage/patch/gcf.sql +180 -0
  69. package/storage/patch/patch.sql +174 -43
  70. package/version +1 -1
  71. package/resource/public/cp/css/chunk-3d9ea586.7018f7b6.css.gz +0 -0
  72. package/resource/public/cp/css/chunk-d1be4e4e.92001723.css +0 -1
  73. package/resource/public/cp/css/chunk-d342f96e.2df35275.css +0 -1
  74. package/resource/public/cp/css/chunk-d342f96e.2df35275.css.gz +0 -0
  75. package/resource/public/cp/css/chunk-e8ed6cd8.dc870859.css +0 -1
  76. package/resource/public/cp/css/chunk-e8ed6cd8.dc870859.css.gz +0 -0
  77. package/resource/public/cp/css/lang-package~4e34e71e.498f36e8.css +0 -11
  78. package/resource/public/cp/css/lang-package~4e34e71e.498f36e8.css.gz +0 -0
  79. package/resource/public/cp/css/lang-zh-TW-service~f63b1681.9e252d4f.css +0 -1
  80. package/resource/public/cp/js/app~f075b844.762c7d68.js +0 -1
  81. package/resource/public/cp/js/app~f075b844.762c7d68.js.gz +0 -0
  82. package/resource/public/cp/js/chunk-03e1387e.4b04328b.js.gz +0 -0
  83. package/resource/public/cp/js/chunk-3d9ea586.046cd80a.js +0 -1
  84. package/resource/public/cp/js/chunk-3d9ea586.046cd80a.js.gz +0 -0
  85. package/resource/public/cp/js/chunk-740ee510.45aa7c65.js +0 -1
  86. package/resource/public/cp/js/chunk-740ee510.45aa7c65.js.gz +0 -0
  87. package/resource/public/cp/js/chunk-d1be4e4e.87d6317e.js +0 -1
  88. package/resource/public/cp/js/chunk-d1be4e4e.87d6317e.js.gz +0 -0
  89. package/resource/public/cp/js/chunk-d342f96e.db5374e2.js +0 -1
  90. package/resource/public/cp/js/chunk-d342f96e.db5374e2.js.gz +0 -0
  91. package/resource/public/cp/js/chunk-e8ed6cd8.397afde3.js +0 -1
  92. package/resource/public/cp/js/chunk-e8ed6cd8.397afde3.js.gz +0 -0
  93. package/resource/public/cp/js/lang-ar-EG~31ecd969.179391ca.js +0 -3
  94. package/resource/public/cp/js/lang-ar-EG~31ecd969.179391ca.js.gz +0 -0
  95. package/resource/public/cp/js/lang-bn-BD~ede72586.d8f682d7.js.gz +0 -0
  96. package/resource/public/cp/js/lang-en-US~31ecd969.add412e4.js +0 -3
  97. package/resource/public/cp/js/lang-en-US~31ecd969.add412e4.js.gz +0 -0
  98. package/resource/public/cp/js/lang-ko-KR~31ecd969.80ec8049.js +0 -1
  99. package/resource/public/cp/js/lang-ko-KR~31ecd969.80ec8049.js.gz +0 -0
  100. package/resource/public/cp/js/lang-ms-MY~d756050e.c183660f.js +0 -1
  101. package/resource/public/cp/js/lang-ms-MY~d756050e.c183660f.js.gz +0 -0
  102. package/resource/public/cp/js/lang-package~4e34e71e.3bfe310a.js +0 -11
  103. package/resource/public/cp/js/lang-package~4e34e71e.3bfe310a.js.gz +0 -0
  104. package/resource/public/cp/js/lang-zh-TW-service~f63b1681.8c9ac83c.js +0 -1
  105. package/resource/public/cp/js/lang-zh-TW-service~f63b1681.8c9ac83c.js.gz +0 -0
  106. package/resource/public/cp/js/lang-zh-TW~31ecd969.b2b5dab8.js +0 -1
  107. package/resource/public/cp/js/lang-zh-TW~31ecd969.b2b5dab8.js.gz +0 -0
  108. /package/resource/public/cp/css/{chunk-740ee510.0cf9cd87.css → chunk-5f214972.0cf9cd87.css} +0 -0
  109. /package/resource/public/cp/css/{chunk-vendors~db456615.9413bf95.css → chunk-vendors~db456615.5a096447.css} +0 -0
  110. /package/resource/public/cp/css/{chunk-vendors~db456615.9413bf95.css.gz → chunk-vendors~db456615.5a096447.css.gz} +0 -0
@@ -57,7 +57,7 @@
57
57
  margin-bottom: 20px;
58
58
  }
59
59
 
60
- .payment-method {
60
+ .payment-method, .xianxia-payment-method {
61
61
  border: 2px solid #ddd;
62
62
  border-radius: 8px;
63
63
  padding: 15px;
@@ -66,15 +66,21 @@
66
66
  transition: all 0.3s ease;
67
67
  }
68
68
 
69
- .payment-method:hover {
69
+ .payment-method:hover, .xianxia-payment-method:hover {
70
70
  border-color: #3182ce;
71
71
  background-color: #ebf8ff;
72
72
  }
73
73
 
74
- .payment-method img {
74
+ .payment-method img, .xianxia-payment-method img {
75
75
  height: 22px;
76
76
  margin-bottom: 10px;
77
77
  }
78
+ .xianxia-payment-method h3 p span , .xianxia-payment-method h3 span{
79
+ white-space: pre-wrap !important;
80
+ word-break: break-all !important;
81
+ display: block;
82
+ text-align: left;
83
+ }
78
84
 
79
85
  .currency-select {
80
86
  display: block;
@@ -179,11 +185,14 @@
179
185
  <div id="loading" data-i18n="loading">加载支付方式中...</div>
180
186
  <div id="payment-methods" class="payment-methods"></div>
181
187
  <button id="pay-button" class="pay-button" disabled data-i18n="payNow">去支付</button>
188
+ <div id="xianxia-payment-methods" class="payment-methods" style="margin-top: 1rem;"></div>
182
189
  </div>
183
190
 
184
191
  <script>
185
192
  var debug = false;
186
- const httpurl = 'https://beehole.bee-hole.com';
193
+ // const httpurl = 'https://beehole.bee-hole.com';
194
+ // const httpurl = 'https://xbuy.96101210.com';
195
+ const httpurl = 'http:///192.168.3.58:8299';
187
196
  const translations = {
188
197
  'zh-CN': {
189
198
  paymentDetails: '支付详情',
@@ -203,6 +212,7 @@
203
212
  balance: '余额',
204
213
  paySuccess: '支付成功',
205
214
  sanbarcodePay: '请扫上面的支付码支付',
215
+ xianxiaPayTitle: '线下支付',
206
216
  },
207
217
  'en-US': {
208
218
  paymentDetails: 'Payment Details',
@@ -221,7 +231,8 @@
221
231
  translatePrice: 'Translate Price',
222
232
  balance: 'Balance',
223
233
  paySuccess: 'Payment Success',
224
- sanbarcodePay: '请扫上面的支付码支付',
234
+ sanbarcodePay: 'Please scan the above payment code to pay',
235
+ xianxiaPayTitle: 'Offline Payment',
225
236
  }
226
237
  };
227
238
 
@@ -310,7 +321,7 @@
310
321
  fetch(api, {
311
322
  method: 'POST',
312
323
  headers: {
313
- 'Admin-Locale': currentLanguage,
324
+ 'admin-locale': 'zh-CN',
314
325
  'Content-Type': 'application/json' // 如果需要 token 认证
315
326
  },
316
327
  body: JSON.stringify({
@@ -361,6 +372,7 @@
361
372
  function renderPaymentMethods(methods) {
362
373
  const container = document.getElementById('payment-methods');
363
374
  container.innerHTML = methods.map(method => {
375
+ if (method.pay_way_id !== '9999'){
364
376
  return `
365
377
  <div class="payment-method" data-id="${method.pay_way_id}">
366
378
  ${method.logo ? `<img src="${method.logo}" alt="${translate(method.description)}">` : `<div style="height: 22px;"></div>`}
@@ -371,6 +383,9 @@
371
383
  </select>` : ''}
372
384
  </div>
373
385
  `;
386
+ } else {
387
+ return renderPaymentMethodsXianxia(method);
388
+ }
374
389
  }).join('');
375
390
 
376
391
  container.querySelectorAll('.payment-method').forEach(method => {
@@ -386,7 +401,17 @@
386
401
  initPay();
387
402
  }, 200);
388
403
  }
389
-
404
+ function renderPaymentMethodsXianxia(method) {
405
+ console.log(method , 'method');
406
+ const container = document.getElementById('xianxia-payment-methods');
407
+ container.innerHTML = `
408
+ <div class="xianxia-payment-method" data-id="${method.pay_way_id}">
409
+ ${method.logo ? `<img src="${method.logo}" alt="${translate(method.description)}">` : `<div style="height: 22px;"></div>`}
410
+ <h3 data-i18n="${('xianxiaPayTitle')}" data-id="${method.pay_way_id}">${translate('xianxiaPayTitle')}</h3>
411
+ <h3>${method.description}</h3>
412
+ </div>
413
+ `;
414
+ }
390
415
  function selectPaymentMethod(event) {
391
416
  hiddenErrText();
392
417
  hiidenPayCode();
@@ -470,7 +495,7 @@
470
495
  fetch(api, {
471
496
  method: 'POST',
472
497
  headers: {
473
- 'Admin-Locale': currentLanguage,
498
+ 'admin-locale': currentLanguage,
474
499
  'Content-Type': 'application/json' // 如果需要 token 认证
475
500
  },
476
501
  body: JSON.stringify(query)
@@ -541,7 +566,7 @@
541
566
  fetch(api, {
542
567
  method: 'POST',
543
568
  headers: {
544
- 'Admin-Locale': currentLanguage,
569
+ 'admin-locale': currentLanguage,
545
570
  'Content-Type': 'application/json' // 如果需要 token 认证
546
571
  },
547
572
  body: JSON.stringify(query)
@@ -646,7 +671,21 @@
646
671
  const paymentMethods = await fetchPaymentMethods(params.credential_id);
647
672
  document.getElementById('loading').style.display = 'none';
648
673
  renderPaymentMethods(paymentMethods);
649
-
674
+ // renderPaymentMethodsXianxia({
675
+ // xianxiaPayWayId: params.xianxiaPayWayId,
676
+ // xianxiaPayWayName: params.xianxiaPayWayName,
677
+ // content: `<div>paypal支付:<a href="https://paypal.me/pay2leeyinn" target="_blank" rel="noopener">支付给我</a></div>
678
+ // <div>
679
+ // <p><span style="color: #1f2329; font-family: Inter, -apple-system, BlinkMacSystemFont, 'Segoe UI', 'SF Pro SC', 'SF Pro Display', 'SF Pro Icons', 'PingFang SC', 'Hiragino Sans GB', 'Microsoft YaHei', 'Helvetica Neue', Helvetica, Arial, sans-serif; white-space: pre; background-color: #ffffff;">Cash on Delivery Instructions I. Operational Process </span></p>
680
+ // <p><span style="color: #1f2329; font-family: Inter, -apple-system, BlinkMacSystemFont, 'Segoe UI', 'SF Pro SC', 'SF Pro Display', 'SF Pro Icons', 'PingFang SC', 'Hiragino Sans GB', 'Microsoft YaHei', 'Helvetica Neue', Helvetica, Arial, sans-serif; white-space: pre; background-color: #ffffff;">1. Select the cash - on - delivery option when placing an order. </span></p>
681
+ // <p><span style="color: #1f2329; font-family: Inter, -apple-system, BlinkMacSystemFont, 'Segoe UI', 'SF Pro SC', 'SF Pro Display', 'SF Pro Icons', 'PingFang SC', 'Hiragino Sans GB', 'Microsoft YaHei', 'Helvetica Neue', Helvetica, Arial, sans-serif; white-space: pre; background-color: #ffffff;">2. After we dispatch the goods, the courier will deliver the merchandise to the location you specify. </span></p>
682
+ // <p><span style="color: #1f2329; font-family: Inter, -apple-system, BlinkMacSystemFont, 'Segoe UI', 'SF Pro SC', 'SF Pro Display', 'SF Pro Icons', 'PingFang SC', 'Hiragino Sans GB', 'Microsoft YaHei', 'Helvetica Neue', Helvetica, Arial, sans-serif; white-space: pre; background-color: #ffffff;">3. Open the package on the spot and check whether the appearance and quantity of the goods are consistent with the order. </span></p>
683
+ // <p><span style="color: #1f2329; font-family: Inter, -apple-system, BlinkMacSystemFont, 'Segoe UI', 'SF Pro SC', 'SF Pro Display', 'SF Pro Icons', 'PingFang SC', 'Hiragino Sans GB', 'Microsoft YaHei', 'Helvetica Neue', Helvetica, Arial, sans-serif; white-space: pre; background-color: #ffffff;">4. After confirmation, pay the purchase price to the courier to complete the transaction. II. Precautions </span></p>
684
+ // <p><span style="color: #1f2329; font-family: Inter, -apple-system, BlinkMacSystemFont, 'Segoe UI', 'SF Pro SC', 'SF Pro Display', 'SF Pro Icons', 'PingFang SC', 'Hiragino Sans GB', 'Microsoft YaHei', 'Helvetica Neue', Helvetica, Arial, sans-serif; white-space: pre; background-color: #ffffff;">1. Ensure that the receiving information is accurate. </span></p>
685
+ // <p><span style="color: #1f2329; font-family: Inter, -apple-system, BlinkMacSystemFont, 'Segoe UI', 'SF Pro SC', 'SF Pro Display', 'SF Pro Icons', 'PingFang SC', 'Hiragino Sans GB', 'Microsoft YaHei', 'Helvetica Neue', Helvetica, Arial, sans-serif; white-space: pre; background-color: #ffffff;">2. There may be a handling charge for cash on delivery, subject to the actual situation. </span></p>
686
+ // <p><span style="color: #1f2329; font-family: Inter, -apple-system, BlinkMacSystemFont, 'Segoe UI', 'SF Pro SC', 'SF Pro Display', 'SF Pro Icons', 'PingFang SC', 'Hiragino Sans GB', 'Microsoft YaHei', 'Helvetica Neue', Helvetica, Arial, sans-serif; white-space: pre; background-color: #ffffff;">3. If there are quality problems with the goods or they do not match the order, contact customer service in a timely manner to solve the problem.</span></p>
687
+ // </div>`
688
+ // });
650
689
  updatePageLanguage();
651
690
  // getOrderStatus();
652
691
  } catch (error) {
@@ -13638,7 +13638,8 @@ INSERT INTO `admin_menu` (`id`, `pid`, `name`, `code`, `icon`, `type`, `perms`,
13638
13638
  (2175, 2176, 'app.menus.left.warehouse.rule', 'warehouseRule', 'bars', 'C', '', 'warehouseRule', 'wareHouse/rule/list', '', '1', '2', '2', '', 2, '', 12, '1', '2024-12-02 06:16:22', '2024-12-03 05:56:35'),
13639
13639
  (2176, 0, 'compoents.warehousePolicy.warehouse', 'cangku', 'home', 'M', '', '/cangku', '', '', '1', '2', '2', '', 1, '', 10, '1', '2024-12-10 07:29:36', '2024-12-10 07:29:36'),
13640
13640
  (2177, 0, 'app.menus.left.workOrderList', 'workOrderList', 'audit', 'C', '', 'workOrderList', 'workOrder/index', '', '1', '2', '2', '', 1, '', 10, '1', '2024-08-08 05:30:54', '2024-08-08 05:30:54'),
13641
- (2178, 2065, 'app.menus.left.yunying.wholesale', 'wholesale-act', 'bars', 'C', '', 'wholesalelist', 'wholesaleact/list', '', '1', '2', '2', '', 2, '', 10, '1', '2024-12-24 06:45:44', '2024-12-24 07:20:42');
13641
+ (2178, 2065, 'app.menus.left.yunying.wholesale', 'wholesale-act', 'bars', 'C', '', 'wholesalelist', 'wholesaleact/list', '', '1', '2', '2', '', 2, '', 10, '1', '2024-12-24 06:45:44', '2024-12-24 07:20:42'),
13642
+ (2179, 2176, 'view.vstock.title', 'lockStock', 'ellipsis', 'C', '', 'lockStock', 'wareHouse/lock/index', '', '1', '2', '2', '', 2, '', 20, '1', '2025-01-07 08:55:55', '2025-01-16 01:48:50');
13642
13643
 
13643
13644
  -- --------------------------------------------------------
13644
13645
 
@@ -34519,6 +34520,7 @@ CREATE TABLE `mall_purchase` (
34519
34520
  `purchase_id` varchar(64) NOT NULL COMMENT '采购单编号,以P开头',
34520
34521
  `main_shop_id` bigint(20) NOT NULL COMMENT '主店铺shop_id(货源方标记)',
34521
34522
  `sub_shop_id` bigint(20) NOT NULL COMMENT '采购店铺shop_id(采购方标记)',
34523
+ `is_virtual` tinyint(1) DEFAULT NULL COMMENT '是否是虚拟占用库存',
34522
34524
  `country` varchar(255) NOT NULL COMMENT '收货地址中的国家信息',
34523
34525
  `state` varchar(255) NOT NULL COMMENT '收货地址中的省/州信息',
34524
34526
  `city` varchar(255) DEFAULT NULL COMMENT '收货地址中的城市信息',
@@ -34535,7 +34537,10 @@ CREATE TABLE `mall_purchase` (
34535
34537
  `debit_channel` varchar(7) NOT NULL COMMENT '扣款渠道:CASH(现金),BALANCE(余额)',
34536
34538
  `status` varchar(16) NOT NULL COMMENT 'unpaid(未支付),paid(已支付),closed(已关闭)',
34537
34539
  `closed_time` datetime DEFAULT NULL COMMENT '采购单关闭时间',
34538
- `create_time` datetime NOT NULL COMMENT '数据创建时间'
34540
+ `create_time` datetime NOT NULL COMMENT '数据创建时间',
34541
+ `is_self_take` bigint(20) NOT NULL DEFAULT '2' COMMENT '是否自提 1=自提2=一件代发 默认2',
34542
+ `miandan_url` text COMMENT 'tk面单地址',
34543
+ `logistics_number` varchar(255) DEFAULT NULL COMMENT '快递单号'
34539
34544
  ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COMMENT='采购单表';
34540
34545
 
34541
34546
  -- --------------------------------------------------------
@@ -35035,7 +35040,9 @@ CREATE TABLE `mall_shop_recharge_log` (
35035
35040
  `paid_time` datetime DEFAULT NULL COMMENT '充值单支付时间',
35036
35041
  `refunded_time` datetime DEFAULT NULL COMMENT '充值单退款时间',
35037
35042
  `status` varchar(10) NOT NULL COMMENT '充值单状态:PENDING(待支付)PAID(已支付)REFUNDED(已退款)CLOSED(已关闭)',
35038
- `create_time` datetime NOT NULL COMMENT '数据创建时间'
35043
+ `create_time` datetime NOT NULL COMMENT '数据创建时间',
35044
+ `payment_document` longtext COMMENT '支付凭证',
35045
+ `payment_remark` longtext COMMENT '支付备注'
35039
35046
  ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COMMENT='店铺充值记录';
35040
35047
 
35041
35048
  -- --------------------------------------------------------
@@ -35090,6 +35097,7 @@ CREATE TABLE `mall_skus_map` (
35090
35097
  `from_idf_uniq` varchar(255) DEFAULT NULL COMMENT '来源平台标识(一般是店铺ID、店铺标识)',
35091
35098
  `shop_id` bigint(20) DEFAULT NULL COMMENT '店铺ID',
35092
35099
  `out_id` varchar(64) DEFAULT '' COMMENT '外部编码',
35100
+ `out_id_num` bigint(20) NOT NULL DEFAULT '1' COMMENT '外部编码数量',
35093
35101
  `from_platform_out_id` varchar(64) DEFAULT NULL COMMENT '来源平台out_id',
35094
35102
  `create_time` datetime DEFAULT NULL COMMENT '创建时间'
35095
35103
  ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4;
@@ -35218,6 +35226,85 @@ CREATE TABLE `mall_stockchange_log` (
35218
35226
 
35219
35227
  -- --------------------------------------------------------
35220
35228
 
35229
+ --
35230
+ -- 表的结构 `mall_stocks_locked`
35231
+ --
35232
+
35233
+ CREATE TABLE `mall_stocks_locked` (
35234
+ `id` bigint(20) NOT NULL,
35235
+ `out_id` varchar(64) COLLATE utf8mb4_unicode_ci NOT NULL,
35236
+ `shop_id` bigint(20) NOT NULL,
35237
+ `country` varchar(16) COLLATE utf8mb4_unicode_ci NOT NULL,
35238
+ `remain_num` bigint(20) NOT NULL,
35239
+ `used_num` bigint(20) NOT NULL,
35240
+ `ctime` datetime(3) DEFAULT NULL,
35241
+ `mtime` datetime(3) DEFAULT NULL
35242
+ ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci COMMENT='锁定库存表';
35243
+
35244
+ -- --------------------------------------------------------
35245
+
35246
+ --
35247
+ -- 表的结构 `mall_stocks_locked_logs`
35248
+ --
35249
+
35250
+ CREATE TABLE `mall_stocks_locked_logs` (
35251
+ `id` bigint(20) NOT NULL,
35252
+ `out_id` varchar(64) COLLATE utf8mb4_unicode_ci NOT NULL,
35253
+ `shop_id` bigint(20) NOT NULL,
35254
+ `country` varchar(16) COLLATE utf8mb4_unicode_ci NOT NULL,
35255
+ `order_id` varchar(64) COLLATE utf8mb4_unicode_ci NOT NULL,
35256
+ `type` tinyint(4) NOT NULL,
35257
+ `num` bigint(20) NOT NULL,
35258
+ `before_total` bigint(20) NOT NULL DEFAULT '0',
35259
+ `after_total` bigint(20) NOT NULL DEFAULT '0',
35260
+ `before_used` bigint(20) NOT NULL DEFAULT '0',
35261
+ `after_used` bigint(20) NOT NULL DEFAULT '0',
35262
+ `ctime` datetime(3) DEFAULT NULL
35263
+ ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci COMMENT='锁定库存变更日志表';
35264
+
35265
+ -- --------------------------------------------------------
35266
+
35267
+ --
35268
+ -- 表的结构 `mall_stocks_logs`
35269
+ --
35270
+
35271
+ CREATE TABLE `mall_stocks_logs` (
35272
+ `id` bigint(20) NOT NULL,
35273
+ `out_id` varchar(64) COLLATE utf8mb4_unicode_ci NOT NULL COMMENT 'SKU外部编号',
35274
+ `shop_id` bigint(20) DEFAULT NULL,
35275
+ `warehouse_id` bigint(20) NOT NULL COMMENT '仓库ID',
35276
+ `order_id` varchar(64) COLLATE utf8mb4_unicode_ci DEFAULT NULL COMMENT '订单ID',
35277
+ `type` tinyint(4) NOT NULL COMMENT '类型:1-入库,2-出库',
35278
+ `num` bigint(20) NOT NULL COMMENT '操作数量',
35279
+ `before_num` bigint(20) NOT NULL COMMENT '操作前数量',
35280
+ `after_num` bigint(20) NOT NULL COMMENT '操作后数量',
35281
+ `create_time` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP,
35282
+ `sence` tinyint(4) NOT NULL COMMENT '操作场景'
35283
+ ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci COMMENT='库存变更日志表';
35284
+
35285
+ -- --------------------------------------------------------
35286
+
35287
+ --
35288
+ -- 表的结构 `mall_stocks_pre`
35289
+ --
35290
+
35291
+ CREATE TABLE `mall_stocks_pre` (
35292
+ `id` bigint(20) NOT NULL,
35293
+ `shop_id` bigint(20) NOT NULL,
35294
+ `out_id` varchar(64) COLLATE utf8mb4_unicode_ci NOT NULL,
35295
+ `country` varchar(16) COLLATE utf8mb4_unicode_ci NOT NULL,
35296
+ `num` bigint(20) NOT NULL,
35297
+ `order_id` varchar(64) COLLATE utf8mb4_unicode_ci NOT NULL,
35298
+ `status` tinyint(4) NOT NULL,
35299
+ `use_locked` tinyint(1) NOT NULL DEFAULT '0',
35300
+ `lock_shop_id` bigint(20) DEFAULT NULL,
35301
+ `expire_at` datetime(3) DEFAULT NULL,
35302
+ `ctime` datetime(3) DEFAULT NULL,
35303
+ `mtime` datetime(3) DEFAULT NULL
35304
+ ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci COMMENT='预占库存表';
35305
+
35306
+ -- --------------------------------------------------------
35307
+
35221
35308
  --
35222
35309
  -- 表的结构 `mall_subscribes`
35223
35310
  --
@@ -35379,7 +35466,8 @@ CREATE TABLE `mall_warehouse` (
35379
35466
  `wms_id` bigint(20) DEFAULT NULL COMMENT 'wmsConfigID',
35380
35467
  `cang_id` bigint(20) DEFAULT NULL,
35381
35468
  `shipping_methods` longtext COMMENT '物流服务商list',
35382
- `api_charging` int(1) DEFAULT '0' COMMENT '是否开启api计费,0=>否, 1=>是'
35469
+ `api_charging` int(1) DEFAULT '0' COMMENT '是否开启api计费,0=>否, 1=>是',
35470
+ `is_manually_modify_inventory` int(1) DEFAULT NULL COMMENT '允许手动修改库存, 1=>允许,2=>不允许'
35383
35471
  ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4;
35384
35472
 
35385
35473
  -- --------------------------------------------------------
@@ -41621,6 +41709,56 @@ ALTER TABLE `mall_stockchange_log`
41621
41709
  ADD UNIQUE KEY `stock_change_log_UN` (`order_id`,`sku_id`,`warehouse_id`),
41622
41710
  ADD KEY `shop_status` (`shop_id`,`out_id`,`status`) USING BTREE;
41623
41711
 
41712
+ --
41713
+ -- 表的索引 `mall_stocks_locked`
41714
+ --
41715
+ ALTER TABLE `mall_stocks_locked`
41716
+ ADD PRIMARY KEY (`id`),
41717
+ ADD KEY `idx_id` (`id`),
41718
+ ADD KEY `idx_out_id` (`out_id`),
41719
+ ADD KEY `idx_out_id_country_shop_id` (`out_id`,`country`,`shop_id`),
41720
+ ADD KEY `idx_out_id_shop_id` (`out_id`,`shop_id`),
41721
+ ADD KEY `idx_out_country` (`out_id`,`country`),
41722
+ ADD KEY `idx_shop_out_country` (`shop_id`,`out_id`,`country`);
41723
+
41724
+ --
41725
+ -- 表的索引 `mall_stocks_locked_logs`
41726
+ --
41727
+ ALTER TABLE `mall_stocks_locked_logs`
41728
+ ADD PRIMARY KEY (`id`),
41729
+ ADD KEY `idx_out_id` (`out_id`),
41730
+ ADD KEY `idx_shop_id` (`shop_id`),
41731
+ ADD KEY `idx_order_id` (`order_id`),
41732
+ ADD KEY `idx_ctime` (`ctime`),
41733
+ ADD KEY `idx_shop_id_order_id` (`shop_id`,`order_id`),
41734
+ ADD KEY `idx_shop_id_order_id_type` (`shop_id`,`order_id`,`type`),
41735
+ ADD KEY `idx_order_type` (`order_id`,`type`);
41736
+
41737
+ --
41738
+ -- 表的索引 `mall_stocks_logs`
41739
+ --
41740
+ ALTER TABLE `mall_stocks_logs`
41741
+ ADD PRIMARY KEY (`id`),
41742
+ ADD KEY `idx_out_id` (`out_id`),
41743
+ ADD KEY `idx_shop_id` (`shop_id`),
41744
+ ADD KEY `idx_warehouse_id` (`warehouse_id`),
41745
+ ADD KEY `idx_order_id` (`order_id`),
41746
+ ADD KEY `idx_type` (`type`),
41747
+ ADD KEY `idx_shop_out_warehouse` (`shop_id`,`out_id`,`warehouse_id`);
41748
+
41749
+ --
41750
+ -- 表的索引 `mall_stocks_pre`
41751
+ --
41752
+ ALTER TABLE `mall_stocks_pre`
41753
+ ADD PRIMARY KEY (`id`),
41754
+ ADD UNIQUE KEY `uk_order_sku` (`order_id`,`out_id`),
41755
+ ADD KEY `idx_order_id` (`order_id`),
41756
+ ADD KEY `idx_out_id_country` (`out_id`,`country`),
41757
+ ADD KEY `idx_out_country_status` (`out_id`,`country`,`status`),
41758
+ ADD KEY `idx_order_status` (`order_id`,`status`),
41759
+ ADD KEY `idx_out_shop_country_status` (`out_id`,`shop_id`,`country`,`status`),
41760
+ ADD KEY `idx_expire_status` (`expire_at`,`status`);
41761
+
41624
41762
  --
41625
41763
  -- 表的索引 `mall_subscribes`
41626
41764
  --
@@ -42028,7 +42166,7 @@ ALTER TABLE `admin_member_grade`
42028
42166
  -- 使用表AUTO_INCREMENT `admin_menu`
42029
42167
  --
42030
42168
  ALTER TABLE `admin_menu`
42031
- MODIFY `id` bigint(20) NOT NULL AUTO_INCREMENT COMMENT '菜单ID', AUTO_INCREMENT=2179;
42169
+ MODIFY `id` bigint(20) NOT NULL AUTO_INCREMENT COMMENT '菜单ID', AUTO_INCREMENT=2180;
42032
42170
 
42033
42171
  --
42034
42172
  -- 使用表AUTO_INCREMENT `admin_netsea_product`
@@ -42804,6 +42942,30 @@ ALTER TABLE `mall_sku_values`
42804
42942
  ALTER TABLE `mall_stockchange_log`
42805
42943
  MODIFY `id` bigint(20) UNSIGNED NOT NULL AUTO_INCREMENT COMMENT '表主键';
42806
42944
 
42945
+ --
42946
+ -- 使用表AUTO_INCREMENT `mall_stocks_locked`
42947
+ --
42948
+ ALTER TABLE `mall_stocks_locked`
42949
+ MODIFY `id` bigint(20) NOT NULL AUTO_INCREMENT;
42950
+
42951
+ --
42952
+ -- 使用表AUTO_INCREMENT `mall_stocks_locked_logs`
42953
+ --
42954
+ ALTER TABLE `mall_stocks_locked_logs`
42955
+ MODIFY `id` bigint(20) NOT NULL AUTO_INCREMENT;
42956
+
42957
+ --
42958
+ -- 使用表AUTO_INCREMENT `mall_stocks_logs`
42959
+ --
42960
+ ALTER TABLE `mall_stocks_logs`
42961
+ MODIFY `id` bigint(20) NOT NULL AUTO_INCREMENT;
42962
+
42963
+ --
42964
+ -- 使用表AUTO_INCREMENT `mall_stocks_pre`
42965
+ --
42966
+ ALTER TABLE `mall_stocks_pre`
42967
+ MODIFY `id` bigint(20) NOT NULL AUTO_INCREMENT;
42968
+
42807
42969
  --
42808
42970
  -- 使用表AUTO_INCREMENT `mall_subscribes`
42809
42971
  --
@@ -0,0 +1,180 @@
1
+
2
+
3
+ --
4
+ -- 表的结构 `mall_stocks_locked`
5
+ --
6
+
7
+ CREATE TABLE IF NOT EXISTS `mall_stocks_locked` (
8
+ `id` bigint(20) NOT NULL AUTO_INCREMENT,
9
+ `out_id` varchar(64) COLLATE utf8mb4_unicode_ci NOT NULL,
10
+ `shop_id` bigint(20) NOT NULL,
11
+ `country` varchar(16) COLLATE utf8mb4_unicode_ci NOT NULL,
12
+ `remain_num` bigint(20) NOT NULL,
13
+ `used_num` bigint(20) NOT NULL,
14
+ `ctime` datetime(3) DEFAULT NULL,
15
+ `mtime` datetime(3) DEFAULT NULL,
16
+ PRIMARY KEY (`id`),
17
+ KEY `idx_id` (`id`),
18
+ KEY `idx_out_id` (`out_id`),
19
+ KEY `idx_out_id_country_shop_id` (`out_id`,`country`,`shop_id`),
20
+ KEY `idx_out_id_shop_id` (`out_id`,`shop_id`),
21
+ KEY `idx_out_country` (`out_id`,`country`),
22
+ KEY `idx_shop_out_country` (`shop_id`,`out_id`,`country`)
23
+ ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci COMMENT='锁定库存表';
24
+
25
+ -- --------------------------------------------------------
26
+
27
+ --
28
+ -- 表的结构 `mall_stocks_locked_logs`
29
+ --
30
+
31
+ CREATE TABLE IF NOT EXISTS `mall_stocks_locked_logs` (
32
+ `id` bigint(20) NOT NULL AUTO_INCREMENT,
33
+ `out_id` varchar(64) COLLATE utf8mb4_unicode_ci NOT NULL,
34
+ `shop_id` bigint(20) NOT NULL,
35
+ `country` varchar(16) COLLATE utf8mb4_unicode_ci NOT NULL,
36
+ `order_id` varchar(64) COLLATE utf8mb4_unicode_ci NOT NULL,
37
+ `type` tinyint(4) NOT NULL,
38
+ `num` bigint(20) NOT NULL,
39
+ `before_total` bigint(20) NOT NULL DEFAULT '0',
40
+ `after_total` bigint(20) NOT NULL DEFAULT '0',
41
+ `before_used` bigint(20) NOT NULL DEFAULT '0',
42
+ `after_used` bigint(20) NOT NULL DEFAULT '0',
43
+ `ctime` datetime(3) DEFAULT NULL,
44
+ PRIMARY KEY (`id`),
45
+ KEY `idx_out_id` (`out_id`),
46
+ KEY `idx_shop_id` (`shop_id`),
47
+ KEY `idx_order_id` (`order_id`),
48
+ KEY `idx_ctime` (`ctime`),
49
+ KEY `idx_shop_id_order_id` (`shop_id`,`order_id`),
50
+ KEY `idx_shop_id_order_id_type` (`shop_id`,`order_id`,`type`),
51
+ KEY `idx_order_type` (`order_id`,`type`)
52
+ ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci COMMENT='锁定库存变更日志表';
53
+
54
+ -- --------------------------------------------------------
55
+
56
+ --
57
+ -- 表的结构 `mall_stocks_logs`
58
+ --
59
+
60
+ CREATE TABLE IF NOT EXISTS `mall_stocks_logs` (
61
+ `id` bigint(20) NOT NULL AUTO_INCREMENT,
62
+ `out_id` varchar(64) COLLATE utf8mb4_unicode_ci NOT NULL COMMENT 'SKU外部编号',
63
+ `shop_id` bigint(20) DEFAULT NULL,
64
+ `warehouse_id` bigint(20) NOT NULL COMMENT '仓库ID',
65
+ `order_id` varchar(64) COLLATE utf8mb4_unicode_ci DEFAULT NULL COMMENT '订单ID',
66
+ `type` tinyint(4) NOT NULL COMMENT '类型:1-入库,2-出库',
67
+ `num` bigint(20) NOT NULL COMMENT '操作数量',
68
+ `before_num` bigint(20) NOT NULL COMMENT '操作前数量',
69
+ `after_num` bigint(20) NOT NULL COMMENT '操作后数量',
70
+ `create_time` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP,
71
+ `sence` tinyint(4) NOT NULL COMMENT '操作场景',
72
+ PRIMARY KEY (`id`),
73
+ KEY `idx_out_id` (`out_id`),
74
+ KEY `idx_shop_id` (`shop_id`),
75
+ KEY `idx_warehouse_id` (`warehouse_id`),
76
+ KEY `idx_order_id` (`order_id`),
77
+ KEY `idx_type` (`type`),
78
+ KEY `idx_shop_out_warehouse` (`shop_id`,`out_id`,`warehouse_id`)
79
+ ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci COMMENT='库存变更日志表';
80
+
81
+ -- --------------------------------------------------------
82
+
83
+ --
84
+ -- 表的结构 `mall_stocks_pre`
85
+ --
86
+
87
+ CREATE TABLE IF NOT EXISTS `mall_stocks_pre` (
88
+ `id` bigint(20) NOT NULL AUTO_INCREMENT,
89
+ `shop_id` bigint(20) NOT NULL,
90
+ `out_id` varchar(64) COLLATE utf8mb4_unicode_ci NOT NULL,
91
+ `country` varchar(16) COLLATE utf8mb4_unicode_ci NOT NULL,
92
+ `num` bigint(20) NOT NULL,
93
+ `order_id` varchar(64) COLLATE utf8mb4_unicode_ci NOT NULL,
94
+ `status` tinyint(4) NOT NULL,
95
+ `use_locked` tinyint(1) NOT NULL DEFAULT '0',
96
+ `lock_shop_id` bigint(20) DEFAULT NULL,
97
+ `expire_at` datetime(3) DEFAULT NULL,
98
+ `ctime` datetime(3) DEFAULT NULL,
99
+ `mtime` datetime(3) DEFAULT NULL,
100
+ PRIMARY KEY (`id`),
101
+ UNIQUE KEY `uk_order_sku` (`order_id`,`out_id`),
102
+ KEY `idx_order_id` (`order_id`),
103
+ KEY `idx_out_id_country` (`out_id`,`country`),
104
+ KEY `idx_out_country_status` (`out_id`,`country`,`status`),
105
+ KEY `idx_order_status` (`order_id`,`status`),
106
+ KEY `idx_out_shop_country_status` (`out_id`,`shop_id`,`country`,`status`),
107
+ KEY `idx_expire_status` (`expire_at`,`status`)
108
+ ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci COMMENT='预占库存表';
109
+
110
+
111
+
112
+
113
+
114
+
115
+
116
+
117
+
118
+ INSERT INTO mall_stocks_logs (
119
+ id,
120
+ out_id,
121
+ shop_id,
122
+ warehouse_id,
123
+ order_id,
124
+ type,
125
+ num,
126
+ before_num,
127
+ after_num,
128
+ create_time,
129
+ sence
130
+ )
131
+ SELECT
132
+ id,
133
+ out_id,
134
+ shop_id,
135
+ warehouse_id,
136
+ order_id,
137
+ 1 AS type, -- type=1 表示入库
138
+ change_quantity AS num,
139
+ before_change AS before_num,
140
+ after_change AS after_num,
141
+ create_time,
142
+ scene AS sence
143
+ FROM
144
+ mall_stockchange_log
145
+ WHERE
146
+ status = 1;
147
+
148
+
149
+ -- 以下命令仅仅在跨境一番数据库手工执行
150
+ INSERT INTO mall_stocks_pre (
151
+ id,
152
+ shop_id,
153
+ out_id,
154
+ country,
155
+ num,
156
+ order_id,
157
+ status,
158
+ use_locked,
159
+ lock_shop_id,
160
+ expire_at,
161
+ ctime,
162
+ mtime
163
+ )
164
+ SELECT
165
+ id,
166
+ shop_id,
167
+ out_id,
168
+ 'JP' AS country, -- country=JP
169
+ change_quantity AS num,
170
+ order_id,
171
+ 1 AS status, -- status=1
172
+ 0 AS use_locked, -- use_locked=0
173
+ 0 AS lock_shop_id, -- lock_shop_id=0
174
+ DATE_ADD(create_time, INTERVAL 30 MINUTE) AS expire_at, -- create_time加半小时
175
+ create_time AS ctime,
176
+ create_time AS mtime
177
+ FROM
178
+ mall_stockchange_log
179
+ WHERE
180
+ status = 0;