@b2y/ecommerce-common 1.0.9 → 1.1.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.
@@ -1,7 +1,8 @@
1
1
  const AccessModeEnum = Object.freeze({
2
2
  FULL: "Full",
3
3
  READ_ONLY: "Read Only",
4
- BLOCKED: "Blocked"
4
+ BLOCKED: "Blocked",
5
+ PAYMENT_REQUIRED: "Payment Required"
5
6
  });
6
7
 
7
8
  module.exports = AccessModeEnum;
@@ -0,0 +1,6 @@
1
+ const BillingCycleEnum = Object.freeze({
2
+ MONTHLY: "Monthly",
3
+ YEARLY: "Yearly"
4
+ });
5
+
6
+ module.exports = BillingCycleEnum;
@@ -0,0 +1,7 @@
1
+ const FeatureTypeEnum = Object.freeze({
2
+ BOOLEAN: "Boolean",
3
+ LIMIT: "Limit",
4
+ METERED: "Metered"
5
+ });
6
+
7
+ module.exports = FeatureTypeEnum;
@@ -1,5 +1,5 @@
1
1
  const { DataTypes } = require('sequelize');
2
-
2
+ const FeatureTypeEnum = require('../enum/FeatureTypeEnum');
3
3
  module.exports = (sequelize) => {
4
4
  return sequelize.define(
5
5
  "SubscriptionFeature",
@@ -20,7 +20,7 @@ module.exports = (sequelize) => {
20
20
  unique: true,
21
21
  },
22
22
  FeatureType: {
23
- type: DataTypes.STRING(20),
23
+ type: DataTypes.ENUM(...Object.values(FeatureTypeEnum)),
24
24
  allowNull: false,
25
25
  },
26
26
  CreatedBy: {
@@ -1,5 +1,5 @@
1
1
  const { DataTypes } = require('sequelize');
2
-
2
+ const BillingCycleEnum = require('../enum/BillingCycleEnum');
3
3
  module.exports = (sequelize) => {
4
4
  return sequelize.define(
5
5
  "SubscriptionPlan",
@@ -24,13 +24,18 @@ module.exports = (sequelize) => {
24
24
  allowNull: false,
25
25
  },
26
26
  BillingCycle: {
27
- type: DataTypes.STRING(20),
27
+ type: DataTypes.ENUM(...Object.values(BillingCycleEnum)),
28
28
  allowNull: false,
29
29
  },
30
30
  Currency: {
31
31
  type: DataTypes.STRING(10),
32
32
  allowNull: false,
33
33
  },
34
+ TrialPeriodDays: {
35
+ type: DataTypes.INTEGER,
36
+ allowNull: false,
37
+ defaultValue: 0
38
+ },
34
39
  IsActive: {
35
40
  type: DataTypes.BOOLEAN,
36
41
  defaultValue: true,
@@ -1,5 +1,5 @@
1
1
  const { DataTypes } = require('sequelize');
2
-
2
+ const SubscriptionStatusEnum = require('../enum/SubscriptionStatusEnum');
3
3
  module.exports = (sequelize) => {
4
4
  return sequelize.define(
5
5
  "TenantSubscription",
@@ -19,27 +19,33 @@ module.exports = (sequelize) => {
19
19
  allowNull: false,
20
20
  },
21
21
  Status: {
22
- type: DataTypes.STRING(20),
22
+ type: DataTypes.ENUM(...Object.values(SubscriptionStatusEnum)),
23
23
  allowNull: false,
24
24
  },
25
25
  StartDate: {
26
26
  type: DataTypes.DATE,
27
- allowNull: false,
28
- defaultValue: DataTypes.NOW,
27
+ allowNull: false
29
28
  },
30
29
  EndDate: {
31
30
  type: DataTypes.DATE,
32
31
  allowNull: false,
33
- defaultValue: DataTypes.NOW,
34
32
  },
35
33
  GraceEndDate: {
36
34
  type: DataTypes.DATE,
35
+ allowNull: true,
36
+ },
37
+ TrialEndDate: {
38
+ type: DataTypes.DATE,
39
+ allowNull: true
40
+ },
41
+ IsTrial: {
42
+ type: DataTypes.BOOLEAN,
37
43
  allowNull: false,
38
- defaultValue: DataTypes.NOW,
44
+ defaultValue: false
39
45
  },
40
46
  AutoRenew: {
41
47
  type: DataTypes.BOOLEAN,
42
- defaultValue: true,
48
+ defaultValue: false,
43
49
  },
44
50
  CreatedBy: {
45
51
  type: DataTypes.UUID,
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@b2y/ecommerce-common",
3
- "version": "1.0.9",
3
+ "version": "1.1.0",
4
4
  "description": "E-commerce common library",
5
5
  "main": "index.js",
6
6
  "scripts": {
@@ -51,7 +51,7 @@ class QueryUtil {
51
51
  { StoreName: { [Sequelize.Op.iLike]: `%${searchText}%` } },
52
52
  { AddressLine1: { [Sequelize.Op.iLike]: `%${searchText}%` } },
53
53
  { AddressLine2: { [Sequelize.Op.iLike]: `%${searchText}%` } },
54
- { "$City.CityName$": { [Sequelize.Op.iLike]: `%${searchText}%` } },
54
+ { CityName: { [Sequelize.Op.iLike]: `%${searchText}%` } },
55
55
  ];
56
56
  }
57
57
 
@@ -5,21 +5,35 @@ function ResolveAccessMode(subscription) {
5
5
 
6
6
  if (!subscription) return AccessModeEnum.BLOCKED;
7
7
 
8
- if (Object.values(SubscriptionStatusEnum).includes(subscription.Status)) {
8
+ if ([SubscriptionStatusEnum.CANCELLED, SubscriptionStatusEnum.EXPIRED, SubscriptionStatusEnum.SUSPENDED].includes(subscription.Status)) {
9
9
  return AccessModeEnum.BLOCKED;
10
10
  }
11
-
12
- if (now <= new Date(subscription.EndDate)) {
13
- return AccessModeEnum.FULL;
14
- }
15
-
16
- if (
17
- subscription.GraceEndDate &&
18
- now <= new Date(subscription.GraceEndDate)
19
- ) {
20
- return AccessModeEnum.READ_ONLY;
21
- }
22
-
11
+
12
+ if (subscription.Status === SubscriptionStatusEnum.ACTIVE) {
13
+ if (subscription.IsTrial === true) {
14
+ const trialEndDate = subscription.TrialEndDate
15
+ ? new Date(subscription.TrialEndDate)
16
+ : null;
17
+ if (trialEndDate && now < trialEndDate) {
18
+ return AccessModeEnum.FULL;
19
+ }
20
+ return AccessModeEnum.PAYMENT_REQUIRED;
21
+ }
22
+ const endDate = new Date(subscription.EndDate);
23
+ const graceEndDate = subscription.GraceEndDate
24
+ ? new Date(subscription.GraceEndDate)
25
+ : null;
26
+ // Still in the paid period
27
+ if (now < endDate) {
28
+ return AccessModeEnum.FULL;
29
+ }
30
+ // Past EndDate, but within Grace Period
31
+ if (graceEndDate && now <= graceEndDate) {
32
+ return AccessModeEnum.READ_ONLY;
33
+ }
34
+ // Past both EndDate and Grace Period
35
+ return AccessModeEnum.BLOCKED;
36
+ }
23
37
  return AccessModeEnum.BLOCKED;
24
38
  };
25
39
  module.exports = ResolveAccessMode;