ts-glitter 21.8.6 → 21.8.7

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.
@@ -647,55 +647,7 @@ export class Shopping {
647
647
  }
648
648
 
649
649
  if (query.status) {
650
- const statusSplit = query.status.split(',').map(status => status.trim());
651
- const statusJoin = statusSplit.map(status => `"${status}"`).join(',');
652
-
653
- // 基本條件
654
- const statusCondition = `JSON_EXTRACT(content, '$.status') IN (${statusJoin})`;
655
-
656
- // 時間條件
657
- const currentDate = db.escape(new Date().toISOString());
658
-
659
- const scheduleConditions = statusSplit
660
- .map(status => {
661
- switch (status) {
662
- case 'inRange':
663
- return `OR (
664
- JSON_EXTRACT(content, '$.status') IN ('active', 1)
665
- AND (
666
- content->>'$.active_schedule' IS NULL OR
667
- (
668
- (
669
- ((CONCAT(content->>'$.active_schedule.start_ISO_Date') IS NULL) and (CONCAT(content->>'$.active_schedule.startDate') IS NULL)) or
670
- ((CONCAT(content->>'$.active_schedule.start_ISO_Date') <= ${currentDate}) or (CONCAT(content->>'$.active_schedule.startDate') <= ${db.escape(moment().format('YYYY-MM-DD'))}))
671
- )
672
- AND (
673
- ((CONCAT(content->>'$.active_schedule.end_ISO_Date') IS NULL) and (CONCAT(content->>'$.active_schedule.endDate') IS NULL)) or
674
- (CONCAT(content->>'$.active_schedule.end_ISO_Date') >= ${currentDate}) or (CONCAT(content->>'$.active_schedule.endDate') >= ${db.escape(moment().format('YYYY-MM-DD'))})
675
- )
676
- )
677
- )
678
- )`;
679
- case 'beforeStart':
680
- return `
681
- OR (
682
- JSON_EXTRACT(content, '$.status') IN ('active', 1)
683
- AND CONCAT(content->>'$.active_schedule.start_ISO_Date') > ${currentDate}
684
- )`;
685
- case 'afterEnd':
686
- return `
687
- OR (
688
- JSON_EXTRACT(content, '$.status') IN ('active', 1)
689
- AND CONCAT(content->>'$.active_schedule.end_ISO_Date') < ${currentDate}
690
- )`;
691
- default:
692
- return '';
693
- }
694
- })
695
- .join('');
696
-
697
- // 組合 SQL 條件
698
- querySql.push(`(${statusCondition} ${scheduleConditions})`);
650
+ querySql.push(Shopping.productStatusSQL(query.status));
699
651
  }
700
652
 
701
653
  if (query.channel) {
@@ -4482,12 +4434,31 @@ export class Shopping {
4482
4434
  `,
4483
4435
  [{ content: JSON.stringify(content) }, content.id]
4484
4436
  );
4485
- // 同步更新蝦皮
4486
- if (content.shopee_id) {
4487
- await new Shopee(this.app, this.token).asyncStockToShopee({
4488
- product: { content },
4489
- callback: () => {},
4490
- });
4437
+
4438
+ // 刪除不存在的商品規格
4439
+ const null_variant_id_array = (
4440
+ await db.query(
4441
+ `SELECT v.id
4442
+ FROM \`${this.app}\`.t_variants v
4443
+ LEFT JOIN \`${this.app}\`.t_manager_post p ON v.product_id = p.id
4444
+ WHERE p.content->>'$.type' <> 'product' OR p.id IS NULL`,
4445
+ []
4446
+ )
4447
+ ).map((item: any) => item.id);
4448
+
4449
+ if (null_variant_id_array.length > 0) {
4450
+ await db.query(
4451
+ `DELETE FROM \`${this.app}\`.t_variants WHERE id IN (${null_variant_id_array.join(',')})
4452
+ `,
4453
+ []
4454
+ );
4455
+ }
4456
+ // 同步更新蝦皮
4457
+ if (content.shopee_id) {
4458
+ await new Shopee(this.app, this.token).asyncStockToShopee({
4459
+ product: { content },
4460
+ callback: () => {},
4461
+ });
4491
4462
  }
4492
4463
  } catch (error) {
4493
4464
  console.error(error);
@@ -5557,6 +5528,59 @@ export class Shopping {
5557
5528
  }
5558
5529
  }
5559
5530
 
5531
+ static productStatusSQL(queryStatus: string, table: string = '') {
5532
+ const tableName = table ? `${table}.` : '';
5533
+ const statusSplit = queryStatus.split(',').map(status => status.trim());
5534
+ const statusJoin = statusSplit.map(status => `"${status}"`).join(',');
5535
+
5536
+ // 基本條件
5537
+ const statusCondition = `JSON_EXTRACT(${tableName}content, '$.status') IN (${statusJoin})`;
5538
+
5539
+ // 時間條件
5540
+ const currentDate = db.escape(new Date().toISOString());
5541
+
5542
+ const scheduleConditions = statusSplit
5543
+ .map(status => {
5544
+ switch (status) {
5545
+ case 'inRange':
5546
+ return `OR (
5547
+ JSON_EXTRACT(${tableName}content, '$.status') IN ('active', 1)
5548
+ AND (
5549
+ ${tableName}content->>'$.active_schedule' IS NULL OR
5550
+ (
5551
+ (
5552
+ ((CONCAT(${tableName}content->>'$.active_schedule.start_ISO_Date') IS NULL) and (CONCAT(${tableName}content->>'$.active_schedule.startDate') IS NULL)) or
5553
+ ((CONCAT(${tableName}content->>'$.active_schedule.start_ISO_Date') <= ${currentDate}) or (CONCAT(${tableName}content->>'$.active_schedule.startDate') <= ${db.escape(moment().format('YYYY-MM-DD'))}))
5554
+ )
5555
+ AND (
5556
+ ((CONCAT(${tableName}content->>'$.active_schedule.end_ISO_Date') IS NULL) and (CONCAT(${tableName}content->>'$.active_schedule.endDate') IS NULL)) or
5557
+ (CONCAT(${tableName}content->>'$.active_schedule.end_ISO_Date') >= ${currentDate}) or (CONCAT(${tableName}content->>'$.active_schedule.endDate') >= ${db.escape(moment().format('YYYY-MM-DD'))})
5558
+ )
5559
+ )
5560
+ )
5561
+ )`;
5562
+ case 'beforeStart':
5563
+ return `
5564
+ OR (
5565
+ JSON_EXTRACT(${tableName}content, '$.status') IN ('active', 1)
5566
+ AND CONCAT(${tableName}content->>'$.active_schedule.start_ISO_Date') > ${currentDate}
5567
+ )`;
5568
+ case 'afterEnd':
5569
+ return `
5570
+ OR (
5571
+ JSON_EXTRACT(${tableName}content, '$.status') IN ('active', 1)
5572
+ AND CONCAT(${tableName}content->>'$.active_schedule.end_ISO_Date') < ${currentDate}
5573
+ )`;
5574
+ default:
5575
+ return '';
5576
+ }
5577
+ })
5578
+ .join('');
5579
+
5580
+ // 組合 SQL 條件
5581
+ return `(${statusCondition} ${scheduleConditions})`;
5582
+ }
5583
+
5560
5584
  async getVariants(query: {
5561
5585
  page: number;
5562
5586
  limit: number;
@@ -5621,11 +5645,14 @@ export class Shopping {
5621
5645
  })
5622
5646
  .join(' or ')})`
5623
5647
  );
5624
- query.status &&
5648
+
5649
+ if (query.status) {
5625
5650
  querySql.push(`
5626
- v.product_id in (select p.id
5627
- from \`${this.app}\`.t_manager_post as p where (JSON_EXTRACT(p.content, '$.status') = '${query.status}'))
5628
- `);
5651
+ v.product_id IN (SELECT p.id
5652
+ FROM \`${this.app}\`.t_manager_post AS p WHERE ${Shopping.productStatusSQL(query.status, 'p')})
5653
+ `);
5654
+ }
5655
+
5629
5656
  query.min_price && querySql.push(`(v.content->>'$.sale_price' >= ${query.min_price})`);
5630
5657
  query.max_price && querySql.push(`(v.content->>'$.sale_price' <= ${query.min_price})`);
5631
5658
 
@@ -5967,9 +5994,7 @@ export class Shopping {
5967
5994
  async getProductComment(product_id: number) {
5968
5995
  try {
5969
5996
  const comments = await db.query(
5970
- `SELECT *
5971
- FROM \`${this.app}\`.t_product_comment
5972
- WHERE product_id = ?;
5997
+ `SELECT * FROM \`${this.app}\`.t_product_comment WHERE product_id = ?;
5973
5998
  `,
5974
5999
  [product_id]
5975
6000
  );