@b2y/ecommerce-common 1.0.4 → 1.0.6

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 (67) hide show
  1. package/README.md +4 -4
  2. package/constants/AppConstants.js +3 -3
  3. package/constants/ReportConstants.js +14 -14
  4. package/constants/StatusMessageConstants.js +17 -17
  5. package/dbconnection/Connect.js +379 -379
  6. package/enum/AddressTypeEnum.js +6 -6
  7. package/enum/BooleanEnum.js +4 -4
  8. package/enum/EntityTypeEnum.js +11 -11
  9. package/enum/GenderEnum.js +7 -7
  10. package/enum/NotificationStatusEnum.js +5 -5
  11. package/enum/NotificationTypeEnum.js +9 -9
  12. package/enum/OrderStatusEnum.js +7 -7
  13. package/enum/PaymentMethodEnum.js +6 -6
  14. package/enum/PaymentStatusEnum.js +6 -6
  15. package/enum/PaymentTypeEnum.js +6 -6
  16. package/enum/PlatformEnum.js +4 -4
  17. package/enum/RegistrationStatusEnum.js +5 -5
  18. package/enum/SortByEnum.js +7 -7
  19. package/index.js +22 -22
  20. package/model/Address.js +95 -95
  21. package/model/AttributeType.js +50 -50
  22. package/model/AttributeValue.js +64 -64
  23. package/model/Banner.js +78 -78
  24. package/model/Brand.js +76 -76
  25. package/model/Cart.js +76 -76
  26. package/model/Category.js +72 -72
  27. package/model/CategoryAttributeType.js +62 -62
  28. package/model/Colour.js +52 -52
  29. package/model/Customer.js +94 -94
  30. package/model/DeviceToken.js +51 -51
  31. package/model/Document.js +70 -70
  32. package/model/DynamicUIComponent.js +52 -52
  33. package/model/Feedback.js +79 -79
  34. package/model/Inventory.js +83 -83
  35. package/model/NotificationHistory.js +67 -67
  36. package/model/Order.js +94 -94
  37. package/model/OrderItem.js +98 -98
  38. package/model/OrderItemHistory.js +69 -69
  39. package/model/OrderStatus.js +48 -48
  40. package/model/Payment.js +101 -101
  41. package/model/PaymentMethod.js +36 -36
  42. package/model/PaymentStatus.js +36 -36
  43. package/model/PaymentType.js +36 -36
  44. package/model/Permission.js +55 -55
  45. package/model/Product.js +82 -82
  46. package/model/ProductGroup.js +48 -48
  47. package/model/ProductSpecification.js +65 -65
  48. package/model/ProductVariant.js +75 -75
  49. package/model/ProductVariantAttribute.js +58 -58
  50. package/model/Role.js +61 -61
  51. package/model/RolePermissionMapping.js +63 -63
  52. package/model/SpecificationType.js +41 -41
  53. package/model/Store.js +99 -99
  54. package/model/StoreUserMapping.js +44 -44
  55. package/model/Tenant.js +91 -91
  56. package/model/TenantSettings.js +47 -47
  57. package/model/User.js +132 -132
  58. package/model/WishList.js +62 -62
  59. package/package.json +28 -28
  60. package/utility/AppUtil.js +65 -57
  61. package/utility/DateUtil.js +55 -55
  62. package/utility/ExcelUtil.js +125 -125
  63. package/utility/LocationUtility.js +130 -130
  64. package/utility/OrderTimeFilterUtil.js +87 -87
  65. package/utility/QueryUtil.js +261 -261
  66. package/utility/Razorpay.js +65 -65
  67. package/utility/VariantPriceUtil.js +54 -54
package/model/Tenant.js CHANGED
@@ -1,91 +1,91 @@
1
- const { DataTypes } = require('sequelize');
2
-
3
- module.exports = (sequelize) => {
4
- return sequelize.define('Tenant', {
5
- TenantID: {
6
- type: DataTypes.UUID,
7
- primaryKey: true,
8
- allowNull: false,
9
- defaultValue: DataTypes.UUIDV4
10
- },
11
- CompanyName: {
12
- type: DataTypes.STRING(255),
13
- allowNull: false,
14
- unique: true
15
- },
16
- CompanyCode: {
17
- type: DataTypes.INTEGER,
18
- allowNull: false,
19
- unique: true
20
- },
21
- Email: {
22
- type: DataTypes.STRING(100),
23
- allowNull: false,
24
- unique: true
25
- },
26
- PhoneNumber: {
27
- type: DataTypes.STRING(20),
28
- allowNull: false,
29
- unique: true
30
- },
31
- CountryCallingCode: {
32
- type: DataTypes.STRING(5),
33
- allowNull: false
34
- },
35
- GSTNo: {
36
- type: DataTypes.STRING(20),
37
- allowNull: true
38
- },
39
- CustomerPortalDomain:{
40
- type: DataTypes.STRING(255),
41
- allowNull: false,
42
- unique: true
43
- },
44
- AdminPortalDomain:{
45
- type: DataTypes.STRING(255),
46
- allowNull: false,
47
- unique: true
48
- },
49
- AddressLine: {
50
- type: DataTypes.STRING(500),
51
- allowNull: false
52
- },
53
- CityName: {
54
- type: DataTypes.STRING(100),
55
- allowNull: false
56
- },
57
- StateCode: {
58
- type: DataTypes.STRING(3),
59
- allowNull: false
60
- },
61
- CountryCode: {
62
- type: DataTypes.CHAR(2),
63
- allowNull: false
64
- },
65
- Zipcode: {
66
- type: DataTypes.STRING(20),
67
- allowNull: false
68
- },
69
- CreatedBy: {
70
- type: DataTypes.UUID,
71
- allowNull: false
72
- },
73
- CreatedAt: {
74
- type: DataTypes.DATE,
75
- allowNull: false,
76
- defaultValue: DataTypes.NOW
77
- },
78
- UpdatedBy: {
79
- type: DataTypes.UUID,
80
- allowNull: false
81
- },
82
- UpdatedAt: {
83
- type: DataTypes.DATE,
84
- allowNull: false,
85
- defaultValue: DataTypes.NOW
86
- }
87
- }, {
88
- tableName: 'Tenant',
89
- timestamps: false
90
- });
91
- };
1
+ const { DataTypes } = require('sequelize');
2
+
3
+ module.exports = (sequelize) => {
4
+ return sequelize.define('Tenant', {
5
+ TenantID: {
6
+ type: DataTypes.UUID,
7
+ primaryKey: true,
8
+ allowNull: false,
9
+ defaultValue: DataTypes.UUIDV4
10
+ },
11
+ CompanyName: {
12
+ type: DataTypes.STRING(255),
13
+ allowNull: false,
14
+ unique: true
15
+ },
16
+ CompanyCode: {
17
+ type: DataTypes.INTEGER,
18
+ allowNull: false,
19
+ unique: true
20
+ },
21
+ Email: {
22
+ type: DataTypes.STRING(100),
23
+ allowNull: false,
24
+ unique: true
25
+ },
26
+ PhoneNumber: {
27
+ type: DataTypes.STRING(20),
28
+ allowNull: false,
29
+ unique: true
30
+ },
31
+ CountryCallingCode: {
32
+ type: DataTypes.STRING(5),
33
+ allowNull: false
34
+ },
35
+ GSTNo: {
36
+ type: DataTypes.STRING(20),
37
+ allowNull: true
38
+ },
39
+ CustomerPortalDomain:{
40
+ type: DataTypes.STRING(255),
41
+ allowNull: false,
42
+ unique: true
43
+ },
44
+ AdminPortalDomain:{
45
+ type: DataTypes.STRING(255),
46
+ allowNull: false,
47
+ unique: true
48
+ },
49
+ AddressLine: {
50
+ type: DataTypes.STRING(500),
51
+ allowNull: false
52
+ },
53
+ CityName: {
54
+ type: DataTypes.STRING(100),
55
+ allowNull: false
56
+ },
57
+ StateCode: {
58
+ type: DataTypes.STRING(3),
59
+ allowNull: false
60
+ },
61
+ CountryCode: {
62
+ type: DataTypes.CHAR(2),
63
+ allowNull: false
64
+ },
65
+ Zipcode: {
66
+ type: DataTypes.STRING(20),
67
+ allowNull: false
68
+ },
69
+ CreatedBy: {
70
+ type: DataTypes.UUID,
71
+ allowNull: false
72
+ },
73
+ CreatedAt: {
74
+ type: DataTypes.DATE,
75
+ allowNull: false,
76
+ defaultValue: DataTypes.NOW
77
+ },
78
+ UpdatedBy: {
79
+ type: DataTypes.UUID,
80
+ allowNull: false
81
+ },
82
+ UpdatedAt: {
83
+ type: DataTypes.DATE,
84
+ allowNull: false,
85
+ defaultValue: DataTypes.NOW
86
+ }
87
+ }, {
88
+ tableName: 'Tenant',
89
+ timestamps: false
90
+ });
91
+ };
@@ -1,48 +1,48 @@
1
- const { DataTypes } = require('sequelize');
2
-
3
-
4
- module.exports = (sequelize) => {
5
- return sequelize.define('TenantSettings', {
6
- TenantSettingID: {
7
- type: DataTypes.UUID,
8
- primaryKey: true,
9
- allowNull: false,
10
- defaultValue: DataTypes.UUIDV4
11
- },
12
- TenantID: {
13
- type: DataTypes.UUID,
14
- allowNull: false,
15
- references: {
16
- model: 'Tenant',
17
- key: 'TenantID'
18
- },
19
- onDelete: 'CASCADE',
20
- onUpdate: 'CASCADE'
21
- },
22
- ThemeColour:{
23
- type:DataTypes.STRING,
24
- allowNull: true
25
- },
26
- CreatedBy: {
27
- type: DataTypes.UUID,
28
- allowNull: false
29
- },
30
- CreatedAt: {
31
- type: DataTypes.DATE,
32
- allowNull: false,
33
- defaultValue: DataTypes.NOW
34
- },
35
- UpdatedBy: {
36
- type: DataTypes.UUID,
37
- allowNull: false
38
- },
39
- UpdatedAt: {
40
- type: DataTypes.DATE,
41
- allowNull: false,
42
- defaultValue: DataTypes.NOW
43
- }
44
- }, {
45
- tableName: 'TenantSettings',
46
- timestamps: false
47
- });
1
+ const { DataTypes } = require('sequelize');
2
+
3
+
4
+ module.exports = (sequelize) => {
5
+ return sequelize.define('TenantSettings', {
6
+ TenantSettingID: {
7
+ type: DataTypes.UUID,
8
+ primaryKey: true,
9
+ allowNull: false,
10
+ defaultValue: DataTypes.UUIDV4
11
+ },
12
+ TenantID: {
13
+ type: DataTypes.UUID,
14
+ allowNull: false,
15
+ references: {
16
+ model: 'Tenant',
17
+ key: 'TenantID'
18
+ },
19
+ onDelete: 'CASCADE',
20
+ onUpdate: 'CASCADE'
21
+ },
22
+ ThemeColour:{
23
+ type:DataTypes.STRING,
24
+ allowNull: true
25
+ },
26
+ CreatedBy: {
27
+ type: DataTypes.UUID,
28
+ allowNull: false
29
+ },
30
+ CreatedAt: {
31
+ type: DataTypes.DATE,
32
+ allowNull: false,
33
+ defaultValue: DataTypes.NOW
34
+ },
35
+ UpdatedBy: {
36
+ type: DataTypes.UUID,
37
+ allowNull: false
38
+ },
39
+ UpdatedAt: {
40
+ type: DataTypes.DATE,
41
+ allowNull: false,
42
+ defaultValue: DataTypes.NOW
43
+ }
44
+ }, {
45
+ tableName: 'TenantSettings',
46
+ timestamps: false
47
+ });
48
48
  };
package/model/User.js CHANGED
@@ -1,132 +1,132 @@
1
- const { DataTypes } = require('sequelize');
2
- const GenderEnum = require('../enum/GenderEnum')
3
- module.exports = (sequelize) => {
4
- return sequelize.define('User', {
5
- UserID: {
6
- type: DataTypes.UUID,
7
- primaryKey: true,
8
- allowNull: false,
9
- defaultValue: DataTypes.UUIDV4
10
- },
11
- TenantID: {
12
- type: DataTypes.UUID,
13
- allowNull: false,
14
- references: {
15
- model: 'Tenant',
16
- key: 'TenantID'
17
- },
18
- onDelete: 'CASCADE',
19
- onUpdate: 'CASCADE'
20
- },
21
- FirstName: {
22
- type: DataTypes.STRING(255),
23
- allowNull: false
24
- },
25
- LastName: {
26
- type: DataTypes.STRING(255),
27
- allowNull: false
28
- },
29
- EmployeeID: {
30
- type: DataTypes.STRING(50),
31
- allowNull: false,
32
- unique: true
33
- },
34
- Email: {
35
- type: DataTypes.STRING(100),
36
- allowNull: false,
37
- },
38
- Password: {
39
- type: DataTypes.STRING(255),
40
- allowNull: false
41
- },
42
- CountryCallingCode: {
43
- type: DataTypes.STRING(5),
44
- allowNull: false
45
- },
46
- PhoneNumber: {
47
- type: DataTypes.STRING(20),
48
- allowNull: false,
49
- },
50
- Gender: {
51
- type: DataTypes.ENUM(...Object.values(GenderEnum)),
52
- allowNull: true
53
- },
54
- RoleID: {
55
- type: DataTypes.UUID,
56
- allowNull: false,
57
- references: {
58
- model: 'Role',
59
- key: 'RoleID'
60
- },
61
- onDelete: 'RESTRICT',
62
- onUpdate: 'CASCADE'
63
- },
64
- AddressLine: {
65
- type: DataTypes.STRING(500),
66
- allowNull: false
67
- },
68
- CityName: {
69
- type: DataTypes.STRING(100),
70
- allowNull: false,
71
- },
72
- StateCode: {
73
- type:DataTypes.STRING(3),
74
- allowNull:false
75
- },
76
- CountryCode:{
77
- type:DataTypes.CHAR(2),
78
- allowNull:false
79
- },
80
- Zipcode: {
81
- type: DataTypes.STRING(20),
82
- allowNull: false
83
- },
84
- OTP: {
85
- type: DataTypes.STRING(10),
86
- allowNull: true
87
- },
88
- OtpExpiry: {
89
- type: DataTypes.DATE,
90
- allowNull: true
91
- },
92
- IsActive: {
93
- type: DataTypes.BOOLEAN,
94
- defaultValue: true
95
- },
96
- CreatedBy: {
97
- type: DataTypes.UUID,
98
- allowNull: false
99
- },
100
- CreatedAt: {
101
- type: DataTypes.DATE,
102
- defaultValue: DataTypes.NOW,
103
- allowNull: false
104
- },
105
- UpdatedBy: {
106
- type: DataTypes.UUID,
107
- allowNull: false
108
- },
109
- UpdatedAt: {
110
- type: DataTypes.DATE,
111
- defaultValue: DataTypes.NOW,
112
- allowNull: false
113
- }
114
- }, {
115
- tableName: 'User',
116
- timestamps: false,
117
- indexes: [
118
- {
119
- name: "UQ_User_Tenant_Email",
120
- unique: true,
121
- fields: ["TenantID", "Email"],
122
- },
123
- {
124
- name: "UQ_User_Tenant_Phone",
125
- unique: true,
126
- fields: ["TenantID", "CountryCallingCode", "PhoneNumber"],
127
- },
128
- ],
129
- });
130
- };
131
-
132
-
1
+ const { DataTypes } = require('sequelize');
2
+ const GenderEnum = require('../enum/GenderEnum')
3
+ module.exports = (sequelize) => {
4
+ return sequelize.define('User', {
5
+ UserID: {
6
+ type: DataTypes.UUID,
7
+ primaryKey: true,
8
+ allowNull: false,
9
+ defaultValue: DataTypes.UUIDV4
10
+ },
11
+ TenantID: {
12
+ type: DataTypes.UUID,
13
+ allowNull: false,
14
+ references: {
15
+ model: 'Tenant',
16
+ key: 'TenantID'
17
+ },
18
+ onDelete: 'CASCADE',
19
+ onUpdate: 'CASCADE'
20
+ },
21
+ FirstName: {
22
+ type: DataTypes.STRING(255),
23
+ allowNull: false
24
+ },
25
+ LastName: {
26
+ type: DataTypes.STRING(255),
27
+ allowNull: false
28
+ },
29
+ EmployeeID: {
30
+ type: DataTypes.STRING(50),
31
+ allowNull: false,
32
+ unique: true
33
+ },
34
+ Email: {
35
+ type: DataTypes.STRING(100),
36
+ allowNull: false,
37
+ },
38
+ Password: {
39
+ type: DataTypes.STRING(255),
40
+ allowNull: false
41
+ },
42
+ CountryCallingCode: {
43
+ type: DataTypes.STRING(5),
44
+ allowNull: false
45
+ },
46
+ PhoneNumber: {
47
+ type: DataTypes.STRING(20),
48
+ allowNull: false,
49
+ },
50
+ Gender: {
51
+ type: DataTypes.ENUM(...Object.values(GenderEnum)),
52
+ allowNull: true
53
+ },
54
+ RoleID: {
55
+ type: DataTypes.UUID,
56
+ allowNull: false,
57
+ references: {
58
+ model: 'Role',
59
+ key: 'RoleID'
60
+ },
61
+ onDelete: 'RESTRICT',
62
+ onUpdate: 'CASCADE'
63
+ },
64
+ AddressLine: {
65
+ type: DataTypes.STRING(500),
66
+ allowNull: false
67
+ },
68
+ CityName: {
69
+ type: DataTypes.STRING(100),
70
+ allowNull: false,
71
+ },
72
+ StateCode: {
73
+ type:DataTypes.STRING(3),
74
+ allowNull:false
75
+ },
76
+ CountryCode:{
77
+ type:DataTypes.CHAR(2),
78
+ allowNull:false
79
+ },
80
+ Zipcode: {
81
+ type: DataTypes.STRING(20),
82
+ allowNull: false
83
+ },
84
+ OTP: {
85
+ type: DataTypes.STRING(10),
86
+ allowNull: true
87
+ },
88
+ OtpExpiry: {
89
+ type: DataTypes.DATE,
90
+ allowNull: true
91
+ },
92
+ IsActive: {
93
+ type: DataTypes.BOOLEAN,
94
+ defaultValue: true
95
+ },
96
+ CreatedBy: {
97
+ type: DataTypes.UUID,
98
+ allowNull: false
99
+ },
100
+ CreatedAt: {
101
+ type: DataTypes.DATE,
102
+ defaultValue: DataTypes.NOW,
103
+ allowNull: false
104
+ },
105
+ UpdatedBy: {
106
+ type: DataTypes.UUID,
107
+ allowNull: false
108
+ },
109
+ UpdatedAt: {
110
+ type: DataTypes.DATE,
111
+ defaultValue: DataTypes.NOW,
112
+ allowNull: false
113
+ }
114
+ }, {
115
+ tableName: 'User',
116
+ timestamps: false,
117
+ indexes: [
118
+ {
119
+ name: "UQ_User_Tenant_Email",
120
+ unique: true,
121
+ fields: ["TenantID", "Email"],
122
+ },
123
+ {
124
+ name: "UQ_User_Tenant_Phone",
125
+ unique: true,
126
+ fields: ["TenantID", "CountryCallingCode", "PhoneNumber"],
127
+ },
128
+ ],
129
+ });
130
+ };
131
+
132
+
package/model/WishList.js CHANGED
@@ -1,63 +1,63 @@
1
- const { DataTypes } = require('sequelize');
2
-
3
- module.exports = (sequelize) => {
4
- return sequelize.define('WishList', {
5
- WishListID: {
6
- type: DataTypes.UUID,
7
- primaryKey: true,
8
- allowNull: false,
9
- defaultValue: DataTypes.UUIDV4
10
- },
11
- TenantID: {
12
- type: DataTypes.UUID,
13
- allowNull: false,
14
- references: {
15
- model: 'Tenant',
16
- key: 'TenantID'
17
- },
18
- onDelete: 'CASCADE',
19
- onUpdate: 'CASCADE'
20
- },
21
- ProductVariantID: {
22
- type: DataTypes.UUID,
23
- allowNull: false,
24
- references: {
25
- model: 'ProductVariant',
26
- key: 'ProductVariantID'
27
- },
28
- onDelete: 'RESTRICT',
29
- onUpdate: 'CASCADE'
30
- },
31
- CustomerID: {
32
- type: DataTypes.UUID,
33
- allowNull: false,
34
- references: {
35
- model: 'Customer',
36
- key: 'CustomerID'
37
- },
38
- onDelete: 'RESTRICT',
39
- onUpdate: 'CASCADE'
40
- },
41
- CreatedBy: {
42
- type: DataTypes.UUID,
43
- allowNull: false
44
- },
45
- CreatedAt: {
46
- type: DataTypes.DATE,
47
- allowNull: false,
48
- defaultValue: DataTypes.NOW
49
- },
50
- UpdatedBy: {
51
- type: DataTypes.UUID,
52
- allowNull: false
53
- },
54
- UpdatedAt: {
55
- type: DataTypes.DATE,
56
- allowNull: false,
57
- defaultValue: DataTypes.NOW
58
- }
59
- }, {
60
- tableName: 'WishList',
61
- timestamps: false
62
- });
1
+ const { DataTypes } = require('sequelize');
2
+
3
+ module.exports = (sequelize) => {
4
+ return sequelize.define('WishList', {
5
+ WishListID: {
6
+ type: DataTypes.UUID,
7
+ primaryKey: true,
8
+ allowNull: false,
9
+ defaultValue: DataTypes.UUIDV4
10
+ },
11
+ TenantID: {
12
+ type: DataTypes.UUID,
13
+ allowNull: false,
14
+ references: {
15
+ model: 'Tenant',
16
+ key: 'TenantID'
17
+ },
18
+ onDelete: 'CASCADE',
19
+ onUpdate: 'CASCADE'
20
+ },
21
+ ProductVariantID: {
22
+ type: DataTypes.UUID,
23
+ allowNull: false,
24
+ references: {
25
+ model: 'ProductVariant',
26
+ key: 'ProductVariantID'
27
+ },
28
+ onDelete: 'RESTRICT',
29
+ onUpdate: 'CASCADE'
30
+ },
31
+ CustomerID: {
32
+ type: DataTypes.UUID,
33
+ allowNull: false,
34
+ references: {
35
+ model: 'Customer',
36
+ key: 'CustomerID'
37
+ },
38
+ onDelete: 'RESTRICT',
39
+ onUpdate: 'CASCADE'
40
+ },
41
+ CreatedBy: {
42
+ type: DataTypes.UUID,
43
+ allowNull: false
44
+ },
45
+ CreatedAt: {
46
+ type: DataTypes.DATE,
47
+ allowNull: false,
48
+ defaultValue: DataTypes.NOW
49
+ },
50
+ UpdatedBy: {
51
+ type: DataTypes.UUID,
52
+ allowNull: false
53
+ },
54
+ UpdatedAt: {
55
+ type: DataTypes.DATE,
56
+ allowNull: false,
57
+ defaultValue: DataTypes.NOW
58
+ }
59
+ }, {
60
+ tableName: 'WishList',
61
+ timestamps: false
62
+ });
63
63
  };