@gt6/sdk 1.0.14 → 1.0.16

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.
@@ -1402,6 +1402,490 @@ class UsersAPI {
1402
1402
  }
1403
1403
  return null;
1404
1404
  }
1405
+ /**
1406
+ * 获取用户资料
1407
+ * @returns 用户资料响应
1408
+ */
1409
+ async getUserProfile() {
1410
+ try {
1411
+ // 获取用户token
1412
+ const token = this.getToken();
1413
+ if (!token) {
1414
+ return {
1415
+ success: false,
1416
+ message: '用户未登录'
1417
+ };
1418
+ }
1419
+ const response = await this.client.request('/web/user/profile', {
1420
+ method: 'GET',
1421
+ headers: {
1422
+ 'Authorization': `Bearer ${token}`,
1423
+ 'Content-Type': 'application/json'
1424
+ }
1425
+ });
1426
+ return response;
1427
+ }
1428
+ catch (error) {
1429
+ // 如果是HTTP错误,尝试解析响应体
1430
+ if (error.statusCode && error.message) {
1431
+ // 对于401错误,返回认证失败信息
1432
+ if (error.statusCode === 401) {
1433
+ return {
1434
+ success: false,
1435
+ message: '认证失败,请重新登录'
1436
+ };
1437
+ }
1438
+ // 对于其他HTTP错误,返回状态码信息
1439
+ return {
1440
+ success: false,
1441
+ message: error.message || `HTTP ${error.statusCode} 错误`
1442
+ };
1443
+ }
1444
+ // 对于网络错误或其他错误
1445
+ return {
1446
+ success: false,
1447
+ message: error instanceof Error ? error.message : '获取用户资料失败'
1448
+ };
1449
+ }
1450
+ }
1451
+ /**
1452
+ * 获取用户资料(简化版本)
1453
+ * @returns 用户资料或null
1454
+ */
1455
+ async getProfile() {
1456
+ const result = await this.getUserProfile();
1457
+ return result.success && result.user ? result.user : null;
1458
+ }
1459
+ /**
1460
+ * 更新用户资料
1461
+ * @param profileData 用户资料数据
1462
+ * @returns 更新响应
1463
+ */
1464
+ async updateProfile(profileData) {
1465
+ try {
1466
+ // 获取用户token
1467
+ const token = this.getToken();
1468
+ if (!token) {
1469
+ return {
1470
+ success: false,
1471
+ message: '用户未登录'
1472
+ };
1473
+ }
1474
+ const response = await this.client.request('/web/user/profile', {
1475
+ method: 'PUT',
1476
+ headers: {
1477
+ 'Authorization': `Bearer ${token}`,
1478
+ 'Content-Type': 'application/json'
1479
+ },
1480
+ body: JSON.stringify(profileData)
1481
+ });
1482
+ return response;
1483
+ }
1484
+ catch (error) {
1485
+ // 如果是HTTP错误,尝试解析响应体
1486
+ if (error.statusCode && error.message) {
1487
+ // 对于401错误,返回认证失败信息
1488
+ if (error.statusCode === 401) {
1489
+ return {
1490
+ success: false,
1491
+ message: '认证失败,请重新登录'
1492
+ };
1493
+ }
1494
+ // 对于其他HTTP错误,返回状态码信息
1495
+ return {
1496
+ success: false,
1497
+ message: error.message || `HTTP ${error.statusCode} 错误`
1498
+ };
1499
+ }
1500
+ // 对于网络错误或其他错误
1501
+ return {
1502
+ success: false,
1503
+ message: error instanceof Error ? error.message : '更新用户资料失败'
1504
+ };
1505
+ }
1506
+ }
1507
+ /**
1508
+ * 修改密码
1509
+ * @param passwordData 密码数据
1510
+ * @returns 修改密码响应
1511
+ */
1512
+ async changePassword(passwordData) {
1513
+ try {
1514
+ // 获取用户token
1515
+ const token = this.getToken();
1516
+ if (!token) {
1517
+ return {
1518
+ success: false,
1519
+ message: '用户未登录'
1520
+ };
1521
+ }
1522
+ const response = await this.client.request('/web/user/password', {
1523
+ method: 'PUT',
1524
+ headers: {
1525
+ 'Authorization': `Bearer ${token}`,
1526
+ 'Content-Type': 'application/json'
1527
+ },
1528
+ body: JSON.stringify(passwordData)
1529
+ });
1530
+ return response;
1531
+ }
1532
+ catch (error) {
1533
+ // 如果是HTTP错误,尝试解析响应体
1534
+ if (error.statusCode && error.message) {
1535
+ // 对于401错误,返回认证失败信息
1536
+ if (error.statusCode === 401) {
1537
+ return {
1538
+ success: false,
1539
+ message: '认证失败,请重新登录'
1540
+ };
1541
+ }
1542
+ // 对于其他HTTP错误,返回状态码信息
1543
+ return {
1544
+ success: false,
1545
+ message: error.message || `HTTP ${error.statusCode} 错误`
1546
+ };
1547
+ }
1548
+ // 对于网络错误或其他错误
1549
+ return {
1550
+ success: false,
1551
+ message: error instanceof Error ? error.message : '修改密码失败'
1552
+ };
1553
+ }
1554
+ }
1555
+ /**
1556
+ * 创建地址
1557
+ * @param addressData 地址数据
1558
+ * @returns 创建地址响应
1559
+ */
1560
+ async createAddress(addressData) {
1561
+ try {
1562
+ // 获取用户token
1563
+ const token = this.getToken();
1564
+ if (!token) {
1565
+ return {
1566
+ success: false,
1567
+ message: '用户未登录'
1568
+ };
1569
+ }
1570
+ const response = await this.client.request('/web/user/addresses', {
1571
+ method: 'POST',
1572
+ headers: {
1573
+ 'Authorization': `Bearer ${token}`,
1574
+ 'Content-Type': 'application/json'
1575
+ },
1576
+ body: JSON.stringify(addressData)
1577
+ });
1578
+ return response;
1579
+ }
1580
+ catch (error) {
1581
+ // 如果是HTTP错误,尝试解析响应体
1582
+ if (error.statusCode && error.message) {
1583
+ // 对于401错误,返回认证失败信息
1584
+ if (error.statusCode === 401) {
1585
+ return {
1586
+ success: false,
1587
+ message: '认证失败,请重新登录'
1588
+ };
1589
+ }
1590
+ // 对于其他HTTP错误,返回状态码信息
1591
+ return {
1592
+ success: false,
1593
+ message: error.message || `HTTP ${error.statusCode} 错误`
1594
+ };
1595
+ }
1596
+ // 对于网络错误或其他错误
1597
+ return {
1598
+ success: false,
1599
+ message: error instanceof Error ? error.message : '创建地址失败'
1600
+ };
1601
+ }
1602
+ }
1603
+ /**
1604
+ * 更新地址
1605
+ * @param addressId 地址ID
1606
+ * @param addressData 地址数据
1607
+ * @returns 更新地址响应
1608
+ */
1609
+ async updateAddress(addressId, addressData) {
1610
+ try {
1611
+ // 获取用户token
1612
+ const token = this.getToken();
1613
+ if (!token) {
1614
+ return {
1615
+ success: false,
1616
+ message: '用户未登录'
1617
+ };
1618
+ }
1619
+ const response = await this.client.request(`/web/user/addresses/${addressId}`, {
1620
+ method: 'PUT',
1621
+ headers: {
1622
+ 'Authorization': `Bearer ${token}`,
1623
+ 'Content-Type': 'application/json'
1624
+ },
1625
+ body: JSON.stringify(addressData)
1626
+ });
1627
+ return response;
1628
+ }
1629
+ catch (error) {
1630
+ // 如果是HTTP错误,尝试解析响应体
1631
+ if (error.statusCode && error.message) {
1632
+ // 对于401错误,返回认证失败信息
1633
+ if (error.statusCode === 401) {
1634
+ return {
1635
+ success: false,
1636
+ message: '认证失败,请重新登录'
1637
+ };
1638
+ }
1639
+ // 对于其他HTTP错误,返回状态码信息
1640
+ return {
1641
+ success: false,
1642
+ message: error.message || `HTTP ${error.statusCode} 错误`
1643
+ };
1644
+ }
1645
+ // 对于网络错误或其他错误
1646
+ return {
1647
+ success: false,
1648
+ message: error instanceof Error ? error.message : '更新地址失败'
1649
+ };
1650
+ }
1651
+ }
1652
+ /**
1653
+ * 删除地址
1654
+ * @param addressId 地址ID
1655
+ * @returns 删除地址响应
1656
+ */
1657
+ async deleteAddress(addressId) {
1658
+ try {
1659
+ // 获取用户token
1660
+ const token = this.getToken();
1661
+ if (!token) {
1662
+ return {
1663
+ success: false,
1664
+ message: '用户未登录'
1665
+ };
1666
+ }
1667
+ const response = await this.client.request(`/web/user/addresses/${addressId}`, {
1668
+ method: 'DELETE',
1669
+ headers: {
1670
+ 'Authorization': `Bearer ${token}`,
1671
+ 'Content-Type': 'application/json'
1672
+ }
1673
+ });
1674
+ return response;
1675
+ }
1676
+ catch (error) {
1677
+ // 如果是HTTP错误,尝试解析响应体
1678
+ if (error.statusCode && error.message) {
1679
+ // 对于401错误,返回认证失败信息
1680
+ if (error.statusCode === 401) {
1681
+ return {
1682
+ success: false,
1683
+ message: '认证失败,请重新登录'
1684
+ };
1685
+ }
1686
+ // 对于其他HTTP错误,返回状态码信息
1687
+ return {
1688
+ success: false,
1689
+ message: error.message || `HTTP ${error.statusCode} 错误`
1690
+ };
1691
+ }
1692
+ // 对于网络错误或其他错误
1693
+ return {
1694
+ success: false,
1695
+ message: error instanceof Error ? error.message : '删除地址失败'
1696
+ };
1697
+ }
1698
+ }
1699
+ /**
1700
+ * 上传文件
1701
+ * @param file 文件对象
1702
+ * @returns 上传响应
1703
+ */
1704
+ async uploadFile(file) {
1705
+ try {
1706
+ // 获取用户token
1707
+ const token = this.getToken();
1708
+ if (!token) {
1709
+ return {
1710
+ success: false,
1711
+ message: '用户未登录'
1712
+ };
1713
+ }
1714
+ // 创建FormData
1715
+ const formData = new FormData();
1716
+ formData.append('file', file);
1717
+ const response = await this.client.request('/web/upload', {
1718
+ method: 'POST',
1719
+ headers: {
1720
+ 'Authorization': `Bearer ${token}`
1721
+ },
1722
+ body: formData
1723
+ });
1724
+ return response;
1725
+ }
1726
+ catch (error) {
1727
+ // 如果是HTTP错误,尝试解析响应体
1728
+ if (error.statusCode && error.message) {
1729
+ // 对于401错误,返回认证失败信息
1730
+ if (error.statusCode === 401) {
1731
+ return {
1732
+ success: false,
1733
+ message: '认证失败,请重新登录'
1734
+ };
1735
+ }
1736
+ // 对于其他HTTP错误,返回状态码信息
1737
+ return {
1738
+ success: false,
1739
+ message: error.message || `HTTP ${error.statusCode} 错误`
1740
+ };
1741
+ }
1742
+ // 对于网络错误或其他错误
1743
+ return {
1744
+ success: false,
1745
+ message: error instanceof Error ? error.message : '文件上传失败'
1746
+ };
1747
+ }
1748
+ }
1749
+ }
1750
+
1751
+ /**
1752
+ * 交易管理API模块
1753
+ * 提供资金扣款、订单创建等功能
1754
+ */
1755
+ class TransactionsAPI {
1756
+ constructor(client) {
1757
+ this.client = client;
1758
+ }
1759
+ /**
1760
+ * 资金扣款
1761
+ * @param deductData 扣款数据
1762
+ * @returns 扣款响应
1763
+ */
1764
+ async deductFunds(deductData) {
1765
+ try {
1766
+ // 获取用户token
1767
+ const token = this.getToken();
1768
+ if (!token) {
1769
+ return {
1770
+ success: false,
1771
+ message: '用户未登录'
1772
+ };
1773
+ }
1774
+ const response = await this.client.request('/web/user/fund/deduct', {
1775
+ method: 'POST',
1776
+ headers: {
1777
+ 'Authorization': `Bearer ${token}`,
1778
+ 'Content-Type': 'application/json'
1779
+ },
1780
+ body: JSON.stringify(deductData)
1781
+ });
1782
+ return response;
1783
+ }
1784
+ catch (error) {
1785
+ // 如果是HTTP错误,尝试解析响应体
1786
+ if (error.statusCode && error.message) {
1787
+ // 对于401错误,返回认证失败信息
1788
+ if (error.statusCode === 401) {
1789
+ return {
1790
+ success: false,
1791
+ message: '认证失败,请重新登录'
1792
+ };
1793
+ }
1794
+ // 对于400错误,可能是余额不足等业务错误
1795
+ if (error.statusCode === 400) {
1796
+ return {
1797
+ success: false,
1798
+ message: error.message || '扣款失败,请检查余额'
1799
+ };
1800
+ }
1801
+ // 对于其他HTTP错误,返回状态码信息
1802
+ return {
1803
+ success: false,
1804
+ message: error.message || `HTTP ${error.statusCode} 错误`
1805
+ };
1806
+ }
1807
+ // 对于网络错误或其他错误
1808
+ return {
1809
+ success: false,
1810
+ message: error instanceof Error ? error.message : '资金扣款失败'
1811
+ };
1812
+ }
1813
+ }
1814
+ /**
1815
+ * 创建零售订单
1816
+ * @param orderData 订单数据
1817
+ * @returns 创建订单响应
1818
+ */
1819
+ async createRetailOrder(orderData) {
1820
+ try {
1821
+ // 获取用户token
1822
+ const token = this.getToken();
1823
+ if (!token) {
1824
+ return {
1825
+ success: false,
1826
+ message: '用户未登录'
1827
+ };
1828
+ }
1829
+ const response = await this.client.request('/web/orders', {
1830
+ method: 'POST',
1831
+ headers: {
1832
+ 'Authorization': `Bearer ${token}`,
1833
+ 'Content-Type': 'application/json'
1834
+ },
1835
+ body: JSON.stringify(orderData)
1836
+ });
1837
+ return response;
1838
+ }
1839
+ catch (error) {
1840
+ // 如果是HTTP错误,尝试解析响应体
1841
+ if (error.statusCode && error.message) {
1842
+ // 对于401错误,返回认证失败信息
1843
+ if (error.statusCode === 401) {
1844
+ return {
1845
+ success: false,
1846
+ message: '认证失败,请重新登录'
1847
+ };
1848
+ }
1849
+ // 对于400错误,可能是订单数据有误
1850
+ if (error.statusCode === 400) {
1851
+ return {
1852
+ success: false,
1853
+ message: error.message || '订单数据有误,请检查输入'
1854
+ };
1855
+ }
1856
+ // 对于其他HTTP错误,返回状态码信息
1857
+ return {
1858
+ success: false,
1859
+ message: error.message || `HTTP ${error.statusCode} 错误`
1860
+ };
1861
+ }
1862
+ // 对于网络错误或其他错误
1863
+ return {
1864
+ success: false,
1865
+ message: error instanceof Error ? error.message : '创建订单失败'
1866
+ };
1867
+ }
1868
+ }
1869
+ /**
1870
+ * 获取用户token(从本地存储)
1871
+ * @returns token或null
1872
+ */
1873
+ getToken() {
1874
+ if (typeof window !== 'undefined' && window.localStorage) {
1875
+ const userDataStr = localStorage.getItem('userData');
1876
+ if (userDataStr) {
1877
+ try {
1878
+ const userData = JSON.parse(userDataStr);
1879
+ return userData.token || null;
1880
+ }
1881
+ catch (error) {
1882
+ console.warn('解析用户数据失败:', error);
1883
+ return null;
1884
+ }
1885
+ }
1886
+ }
1887
+ return null;
1888
+ }
1405
1889
  }
1406
1890
 
1407
1891
  /**
@@ -1416,6 +1900,7 @@ class GT6SDK {
1416
1900
  this.settings = new SettingsAPI(client);
1417
1901
  this.forms = new FormsAPI(client);
1418
1902
  this.users = new UsersAPI(client);
1903
+ this.transactions = new TransactionsAPI(client);
1419
1904
  }
1420
1905
  /**
1421
1906
  * 获取客户端实例(用于高级用法)
@@ -1729,7 +2214,67 @@ class GT6SDK {
1729
2214
  async getAddressById(addressId) {
1730
2215
  return this.users.getAddressById(addressId);
1731
2216
  }
2217
+ /**
2218
+ * 便捷方法:获取用户资料
2219
+ */
2220
+ async getUserProfile() {
2221
+ return this.users.getUserProfile();
2222
+ }
2223
+ /**
2224
+ * 便捷方法:获取用户资料(简化版本)
2225
+ */
2226
+ async getProfile() {
2227
+ return this.users.getProfile();
2228
+ }
2229
+ /**
2230
+ * 便捷方法:更新用户资料
2231
+ */
2232
+ async updateProfile(profileData) {
2233
+ return this.users.updateProfile(profileData);
2234
+ }
2235
+ /**
2236
+ * 便捷方法:修改密码
2237
+ */
2238
+ async changePassword(passwordData) {
2239
+ return this.users.changePassword(passwordData);
2240
+ }
2241
+ /**
2242
+ * 便捷方法:创建地址
2243
+ */
2244
+ async createAddress(addressData) {
2245
+ return this.users.createAddress(addressData);
2246
+ }
2247
+ /**
2248
+ * 便捷方法:更新地址
2249
+ */
2250
+ async updateAddress(addressId, addressData) {
2251
+ return this.users.updateAddress(addressId, addressData);
2252
+ }
2253
+ /**
2254
+ * 便捷方法:删除地址
2255
+ */
2256
+ async deleteAddress(addressId) {
2257
+ return this.users.deleteAddress(addressId);
2258
+ }
2259
+ /**
2260
+ * 便捷方法:上传文件
2261
+ */
2262
+ async uploadFile(file) {
2263
+ return this.users.uploadFile(file);
2264
+ }
2265
+ /**
2266
+ * 便捷方法:资金扣款
2267
+ */
2268
+ async deductFunds(deductData) {
2269
+ return this.transactions.deductFunds(deductData);
2270
+ }
2271
+ /**
2272
+ * 便捷方法:创建零售订单
2273
+ */
2274
+ async createRetailOrder(orderData) {
2275
+ return this.transactions.createRetailOrder(orderData);
2276
+ }
1732
2277
  }
1733
2278
 
1734
- export { ArticlesAPI, FormsAPI, GT6Client, GT6Error, GT6SDK, ProductsAPI, SettingsAPI, UsersAPI, GT6SDK as default };
2279
+ export { ArticlesAPI, FormsAPI, GT6Client, GT6Error, GT6SDK, ProductsAPI, SettingsAPI, TransactionsAPI, UsersAPI, GT6SDK as default };
1735
2280
  //# sourceMappingURL=gt6-sdk.esm.js.map