@tomei/rental 0.16.3 → 0.16.4

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 (70) hide show
  1. package/.commitlintrc.json +22 -22
  2. package/.gitlab-ci.yml +16 -16
  3. package/.husky/commit-msg +15 -15
  4. package/.husky/pre-commit +7 -7
  5. package/.prettierrc +4 -4
  6. package/Jenkinsfile +51 -51
  7. package/README.md +8 -8
  8. package/dist/src/components/agreement/agreement.js +7 -7
  9. package/dist/src/components/rental/rental.d.ts +3 -3
  10. package/dist/src/components/rental/rental.js +20 -18
  11. package/dist/src/components/rental/rental.js.map +1 -1
  12. package/dist/src/enum/rental-status.enum.d.ts +1 -2
  13. package/dist/src/enum/rental-status.enum.js +0 -1
  14. package/dist/src/enum/rental-status.enum.js.map +1 -1
  15. package/dist/src/interfaces/rental-attr.interface.d.ts +1 -1
  16. package/dist/tsconfig.tsbuildinfo +1 -1
  17. package/eslint.config.mjs +58 -58
  18. package/jest.config.js +10 -10
  19. package/migrations/booking-table-migration.js +79 -79
  20. package/migrations/hirer-signature-table-migration.js +64 -64
  21. package/migrations/joint-hirer-table-migration.js +52 -52
  22. package/migrations/rental-aggreement-history-migration.js +41 -41
  23. package/migrations/rental-aggrement-table-migration.js +30 -30
  24. package/migrations/rental-price-table-migration.js +32 -32
  25. package/migrations/rental-table-migrations.js +96 -96
  26. package/package.json +75 -75
  27. package/sonar-project.properties +12 -12
  28. package/src/components/agreement/agreement.repository.ts +54 -54
  29. package/src/components/agreement/agreement.ts +180 -180
  30. package/src/components/agreement-history/agreement-history.repository.ts +54 -54
  31. package/src/components/agreement-history/agreement-history.ts +57 -57
  32. package/src/components/booking/booking.repository.ts +51 -51
  33. package/src/components/booking/booking.ts +492 -492
  34. package/src/components/hirer-signature/hirer-signature.repository.ts +54 -54
  35. package/src/components/hirer-signature/hirer-signature.ts +140 -140
  36. package/src/components/joint-hirer/joint-hirer.repository.ts +54 -54
  37. package/src/components/joint-hirer/joint-hirer.ts +137 -137
  38. package/src/components/rental/rental.repository.ts +51 -51
  39. package/src/components/rental/rental.ts +1119 -1116
  40. package/src/components/rental-price/rental-price.repository.ts +54 -54
  41. package/src/components/rental-price/rental-price.ts +100 -100
  42. package/src/database.ts +31 -31
  43. package/src/enum/account-type.enum.ts +4 -4
  44. package/src/enum/booking.enum.ts +5 -5
  45. package/src/enum/hirer-signature-status.enum.ts +4 -4
  46. package/src/enum/hirer-type.enum.ts +4 -4
  47. package/src/enum/index.ts +15 -15
  48. package/src/enum/rental-status.enum.ts +34 -39
  49. package/src/index.ts +36 -36
  50. package/src/interfaces/agreement-attr.interface.ts +7 -7
  51. package/src/interfaces/agreement-history-attr.interface.ts +7 -7
  52. package/src/interfaces/booking-attr.interface.ts +19 -19
  53. package/src/interfaces/booking-find-all-search-attr.interface.ts +12 -12
  54. package/src/interfaces/hirer-signature-attr.interface.ts +15 -15
  55. package/src/interfaces/index.ts +19 -19
  56. package/src/interfaces/joint-hirer-attr.interface.ts +10 -10
  57. package/src/interfaces/rental-attr.interface.ts +25 -25
  58. package/src/interfaces/rental-find-all-search-attr.interface.ts +11 -11
  59. package/src/interfaces/rental-price-attr.interface.ts +7 -7
  60. package/src/interfaces/response-hirer-signature-attr.interface.ts +15 -15
  61. package/src/models/agreement-history.entity.ts +51 -51
  62. package/src/models/agreement.entity.ts +47 -47
  63. package/src/models/booking.entity.ts +105 -105
  64. package/src/models/hirer-signature.entity.ts +81 -81
  65. package/src/models/index.ts +17 -17
  66. package/src/models/joint-hirer.entity.ts +63 -63
  67. package/src/models/rental-price.entity.ts +38 -38
  68. package/src/models/rental.entity.ts +133 -133
  69. package/tsconfig.build.json +5 -5
  70. package/tsconfig.json +24 -24
@@ -1,32 +1,32 @@
1
- 'use strict';
2
-
3
- /** @type {import('sequelize-cli').Migration} */
4
- module.exports = {
5
- async up(queryInterface, Sequelize) {
6
- await queryInterface.createTable('rental_Price', {
7
- PriceId: {
8
- type: Sequelize.STRING(30),
9
- allowNull: false,
10
- primaryKey: true,
11
- },
12
- RetailPrice: {
13
- type: Sequelize.DECIMAL(10, 2),
14
- allowNull: false,
15
- },
16
- Currency: {
17
- type: Sequelize.CHAR(3),
18
- allowNull: false,
19
- },
20
- PromoCode: {
21
- type: Sequelize.STRING(10),
22
- },
23
- Remarks: {
24
- type: Sequelize.STRING(3000),
25
- },
26
- });
27
- },
28
-
29
- async down(queryInterface) {
30
- await queryInterface.dropTable('rental_Price');
31
- },
32
- };
1
+ 'use strict';
2
+
3
+ /** @type {import('sequelize-cli').Migration} */
4
+ module.exports = {
5
+ async up(queryInterface, Sequelize) {
6
+ await queryInterface.createTable('rental_Price', {
7
+ PriceId: {
8
+ type: Sequelize.STRING(30),
9
+ allowNull: false,
10
+ primaryKey: true,
11
+ },
12
+ RetailPrice: {
13
+ type: Sequelize.DECIMAL(10, 2),
14
+ allowNull: false,
15
+ },
16
+ Currency: {
17
+ type: Sequelize.CHAR(3),
18
+ allowNull: false,
19
+ },
20
+ PromoCode: {
21
+ type: Sequelize.STRING(10),
22
+ },
23
+ Remarks: {
24
+ type: Sequelize.STRING(3000),
25
+ },
26
+ });
27
+ },
28
+
29
+ async down(queryInterface) {
30
+ await queryInterface.dropTable('rental_Price');
31
+ },
32
+ };
@@ -1,96 +1,96 @@
1
- 'use strict';
2
-
3
- /** @type {import('sequelize-cli').Migration} */
4
- module.exports = {
5
- async up(queryInterface, Sequelize) {
6
- await queryInterface.createTable('rental_Rental', {
7
- RentalId: {
8
- type: Sequelize.STRING(30),
9
- allowNull: false,
10
- primaryKey: true,
11
- },
12
- CustomerId: {
13
- type: Sequelize.STRING(30),
14
- allowNull: false,
15
- },
16
- CustomerType: {
17
- type: Sequelize.STRING(30),
18
- allowNull: false,
19
- },
20
- ItemId: {
21
- type: Sequelize.STRING(30),
22
- allowNull: false,
23
- },
24
- ItemType: {
25
- type: Sequelize.STRING(30),
26
- allowNull: false,
27
- },
28
- PriceId: {
29
- type: Sequelize.STRING(30),
30
- allowNull: false,
31
- references: {
32
- model: 'rental_Price',
33
- key: 'PriceId',
34
- },
35
- onUpdate: 'CASCADE',
36
- onDelete: 'CASCADE',
37
- },
38
- StartDateTime: {
39
- type: Sequelize.DATE,
40
- allowNull: false,
41
- },
42
- EndDateTime: {
43
- type: Sequelize.DATE,
44
- allowNull: false,
45
- },
46
- Status: {
47
- type: Sequelize.STRING(50),
48
- allowNull: false,
49
- },
50
- CancelRemarks: {
51
- type: Sequelize.STRING(3000),
52
- },
53
- TerminateRemarks: {
54
- type: Sequelize.STRING(3000),
55
- },
56
- EscheatmentYN: {
57
- type: Sequelize.CHAR(1),
58
- },
59
- AgreementNo: {
60
- type: Sequelize.STRING(30),
61
- allowNull: false,
62
- unique: true,
63
- references: {
64
- model: 'rental_Agreement',
65
- key: 'AgreementNo',
66
- },
67
- onUpdate: 'CASCADE',
68
- onDelete: 'CASCADE',
69
- },
70
- AccountType: {
71
- type: Sequelize.STRING(10),
72
- allowNull: false,
73
- },
74
- CreatedById: {
75
- type: Sequelize.STRING(30),
76
- allowNull: false,
77
- },
78
- CreatedAt: {
79
- type: Sequelize.DATE,
80
- allowNull: false,
81
- },
82
- UpdatedById: {
83
- type: Sequelize.STRING(30),
84
- allowNull: false,
85
- },
86
- UpdatedAt: {
87
- type: Sequelize.DATE,
88
- allowNull: false,
89
- },
90
- });
91
- },
92
-
93
- async down(queryInterface) {
94
- await queryInterface.dropTable('rental_Rental');
95
- },
96
- };
1
+ 'use strict';
2
+
3
+ /** @type {import('sequelize-cli').Migration} */
4
+ module.exports = {
5
+ async up(queryInterface, Sequelize) {
6
+ await queryInterface.createTable('rental_Rental', {
7
+ RentalId: {
8
+ type: Sequelize.STRING(30),
9
+ allowNull: false,
10
+ primaryKey: true,
11
+ },
12
+ CustomerId: {
13
+ type: Sequelize.STRING(30),
14
+ allowNull: false,
15
+ },
16
+ CustomerType: {
17
+ type: Sequelize.STRING(30),
18
+ allowNull: false,
19
+ },
20
+ ItemId: {
21
+ type: Sequelize.STRING(30),
22
+ allowNull: false,
23
+ },
24
+ ItemType: {
25
+ type: Sequelize.STRING(30),
26
+ allowNull: false,
27
+ },
28
+ PriceId: {
29
+ type: Sequelize.STRING(30),
30
+ allowNull: false,
31
+ references: {
32
+ model: 'rental_Price',
33
+ key: 'PriceId',
34
+ },
35
+ onUpdate: 'CASCADE',
36
+ onDelete: 'CASCADE',
37
+ },
38
+ StartDateTime: {
39
+ type: Sequelize.DATE,
40
+ allowNull: false,
41
+ },
42
+ EndDateTime: {
43
+ type: Sequelize.DATE,
44
+ allowNull: false,
45
+ },
46
+ Status: {
47
+ type: Sequelize.STRING(50),
48
+ allowNull: false,
49
+ },
50
+ CancelRemarks: {
51
+ type: Sequelize.STRING(3000),
52
+ },
53
+ TerminateRemarks: {
54
+ type: Sequelize.STRING(3000),
55
+ },
56
+ EscheatmentYN: {
57
+ type: Sequelize.CHAR(1),
58
+ },
59
+ AgreementNo: {
60
+ type: Sequelize.STRING(30),
61
+ allowNull: false,
62
+ unique: true,
63
+ references: {
64
+ model: 'rental_Agreement',
65
+ key: 'AgreementNo',
66
+ },
67
+ onUpdate: 'CASCADE',
68
+ onDelete: 'CASCADE',
69
+ },
70
+ AccountType: {
71
+ type: Sequelize.STRING(10),
72
+ allowNull: false,
73
+ },
74
+ CreatedById: {
75
+ type: Sequelize.STRING(30),
76
+ allowNull: false,
77
+ },
78
+ CreatedAt: {
79
+ type: Sequelize.DATE,
80
+ allowNull: false,
81
+ },
82
+ UpdatedById: {
83
+ type: Sequelize.STRING(30),
84
+ allowNull: false,
85
+ },
86
+ UpdatedAt: {
87
+ type: Sequelize.DATE,
88
+ allowNull: false,
89
+ },
90
+ });
91
+ },
92
+
93
+ async down(queryInterface) {
94
+ await queryInterface.dropTable('rental_Rental');
95
+ },
96
+ };
package/package.json CHANGED
@@ -1,75 +1,75 @@
1
- {
2
- "name": "@tomei/rental",
3
- "version": "0.16.3",
4
- "description": "Tomei Rental Package",
5
- "main": "dist/index.js",
6
- "scripts": {
7
- "start:dev": "tsc -w",
8
- "build": "tsc",
9
- "prepare": "husky install",
10
- "format": "prettier --write \"src/**/*.ts\"",
11
- "lint": "npx eslint . --fix",
12
- "test": "jest --forceExit --detectOpenHandles"
13
- },
14
- "repository": {
15
- "type": "git",
16
- "url": "git+ssh://git@gitlab.com/tomei-package/rental.git"
17
- },
18
- "keywords": [
19
- "tomei",
20
- "rental"
21
- ],
22
- "author": "Tomei",
23
- "license": "ISC",
24
- "bugs": {
25
- "url": "https://gitlab.com/tomei-package/rental/issues"
26
- },
27
- "homepage": "https://gitlab.com/tomei-package/rental#readme",
28
- "devDependencies": {
29
- "@commitlint/cli": "^19.6.0",
30
- "@commitlint/config-conventional": "^19.6.0",
31
- "@eslint/js": "^9.15.0",
32
- "@tsconfig/node18": "^18.2.4",
33
- "@types/jest": "^29.5.14",
34
- "@types/luxon": "^3.4.2",
35
- "@types/node": "^22.10.0",
36
- "@types/validator": "^13.12.2",
37
- "@typescript-eslint/eslint-plugin": "^8.16.0",
38
- "dotenv": "^16.4.5",
39
- "eslint": "^9.15.0",
40
- "eslint-config-prettier": "^9.1.0",
41
- "eslint-plugin-import": "^2.31.0",
42
- "eslint-plugin-prettier": "^5.2.1",
43
- "globals": "^15.12.0",
44
- "husky": "^9.1.7",
45
- "jest": "^29.7.0",
46
- "jest-mock-extended": "^3.0.7",
47
- "lint-staged": "^15.2.10",
48
- "prettier": "^3.4.1",
49
- "ts-jest": "^29.2.5",
50
- "ts-node": "^10.9.2",
51
- "tsc-watch": "^6.2.1",
52
- "tsconfig-paths": "^4.2.0",
53
- "typescript": "^5.7.2",
54
- "typescript-eslint": "^8.16.0"
55
- },
56
- "publishConfig": {
57
- "access": "public"
58
- },
59
- "peerDependencies": {
60
- "@tomei/activity-history": "^0.2.23",
61
- "@tomei/config": "^0.3.21",
62
- "@tomei/general": "^0.21.3",
63
- "@tomei/sso": "^0.51.6",
64
- "luxon": "^3.5.0",
65
- "reflect-metadata": "^0.2.2",
66
- "sequelize": "^6.37.5",
67
- "sequelize-typescript": "^2.1.6"
68
- },
69
- "lint-staged": {
70
- "*/**/*.{js,ts,tsx}": [
71
- "prettier --write \"src/**/*.ts\" \"test/**/*.ts\"",
72
- "eslint \"{src,apps,libs,test}/**/*.ts\" --fix"
73
- ]
74
- }
75
- }
1
+ {
2
+ "name": "@tomei/rental",
3
+ "version": "0.16.4",
4
+ "description": "Tomei Rental Package",
5
+ "main": "dist/index.js",
6
+ "scripts": {
7
+ "start:dev": "tsc -w",
8
+ "build": "tsc",
9
+ "prepare": "husky install",
10
+ "format": "prettier --write \"src/**/*.ts\"",
11
+ "lint": "npx eslint . --fix",
12
+ "test": "jest --forceExit --detectOpenHandles"
13
+ },
14
+ "repository": {
15
+ "type": "git",
16
+ "url": "git+ssh://git@gitlab.com/tomei-package/rental.git"
17
+ },
18
+ "keywords": [
19
+ "tomei",
20
+ "rental"
21
+ ],
22
+ "author": "Tomei",
23
+ "license": "ISC",
24
+ "bugs": {
25
+ "url": "https://gitlab.com/tomei-package/rental/issues"
26
+ },
27
+ "homepage": "https://gitlab.com/tomei-package/rental#readme",
28
+ "devDependencies": {
29
+ "@commitlint/cli": "^19.6.0",
30
+ "@commitlint/config-conventional": "^19.6.0",
31
+ "@eslint/js": "^9.15.0",
32
+ "@tsconfig/node18": "^18.2.4",
33
+ "@types/jest": "^29.5.14",
34
+ "@types/luxon": "^3.4.2",
35
+ "@types/node": "^22.10.0",
36
+ "@types/validator": "^13.12.2",
37
+ "@typescript-eslint/eslint-plugin": "^8.16.0",
38
+ "dotenv": "^16.4.5",
39
+ "eslint": "^9.15.0",
40
+ "eslint-config-prettier": "^9.1.0",
41
+ "eslint-plugin-import": "^2.31.0",
42
+ "eslint-plugin-prettier": "^5.2.1",
43
+ "globals": "^15.12.0",
44
+ "husky": "^9.1.7",
45
+ "jest": "^29.7.0",
46
+ "jest-mock-extended": "^3.0.7",
47
+ "lint-staged": "^15.2.10",
48
+ "prettier": "^3.4.1",
49
+ "ts-jest": "^29.2.5",
50
+ "ts-node": "^10.9.2",
51
+ "tsc-watch": "^6.2.1",
52
+ "tsconfig-paths": "^4.2.0",
53
+ "typescript": "^5.7.2",
54
+ "typescript-eslint": "^8.16.0"
55
+ },
56
+ "publishConfig": {
57
+ "access": "public"
58
+ },
59
+ "peerDependencies": {
60
+ "@tomei/activity-history": "^0.2.23",
61
+ "@tomei/config": "^0.3.21",
62
+ "@tomei/general": "^0.21.3",
63
+ "@tomei/sso": "^0.51.6",
64
+ "luxon": "^3.5.0",
65
+ "reflect-metadata": "^0.2.2",
66
+ "sequelize": "^6.37.5",
67
+ "sequelize-typescript": "^2.1.6"
68
+ },
69
+ "lint-staged": {
70
+ "*/**/*.{js,ts,tsx}": [
71
+ "prettier --write \"src/**/*.ts\" \"test/**/*.ts\"",
72
+ "eslint \"{src,apps,libs,test}/**/*.ts\" --fix"
73
+ ]
74
+ }
75
+ }
@@ -1,13 +1,13 @@
1
- sonar.projectKey=all-tomei-projects_rental
2
- sonar.organization=all-tomei-projects
3
-
4
- # This is the name and version displayed in the SonarCloud UI.
5
- #sonar.projectName=Rental
6
- #sonar.projectVersion=1.0
7
-
8
-
9
- # Path is relative to the sonar-project.properties file. Replace "\" by "/" on Windows.
10
- #sonar.sources=.
11
-
12
- # Encoding of the source code. Default is default system encoding
1
+ sonar.projectKey=all-tomei-projects_rental
2
+ sonar.organization=all-tomei-projects
3
+
4
+ # This is the name and version displayed in the SonarCloud UI.
5
+ #sonar.projectName=Rental
6
+ #sonar.projectVersion=1.0
7
+
8
+
9
+ # Path is relative to the sonar-project.properties file. Replace "\" by "/" on Windows.
10
+ #sonar.sources=.
11
+
12
+ # Encoding of the source code. Default is default system encoding
13
13
  #sonar.sourceEncoding=UTF-8
@@ -1,54 +1,54 @@
1
- import { RepositoryBase, IRepositoryBase } from '@tomei/general';
2
- import { AgreementModel } from '../../models/agreement.entity';
3
-
4
- export class AgreementRepository
5
- extends RepositoryBase<AgreementModel>
6
- implements IRepositoryBase<AgreementModel>
7
- {
8
- constructor() {
9
- super(AgreementModel);
10
- }
11
-
12
- async findByPk(
13
- id: string,
14
- transaction?: any,
15
- ): Promise<AgreementModel | null> {
16
- try {
17
- const result = await AgreementModel.findByPk(id, {
18
- transaction: transaction,
19
- });
20
-
21
- return result;
22
- } catch (error) {
23
- throw new Error(`An Error occured when fetching : ${error.message}`);
24
- }
25
- }
26
-
27
- async delete(AgreementNo: string, dbTransaction?: any) {
28
- try {
29
- const options = {
30
- where: {
31
- AgreementNo,
32
- },
33
- transaction: dbTransaction,
34
- };
35
- await AgreementModel.destroy(options);
36
- } catch (error) {
37
- throw new Error(`An Error occured when delete : ${error.message}`);
38
- }
39
- }
40
-
41
- async findAndCountAll(options?: any) {
42
- try {
43
- let Agreements: any;
44
- if (options) {
45
- Agreements = await AgreementModel.findAndCountAll(options);
46
- } else {
47
- Agreements = await AgreementModel.findAndCountAll();
48
- }
49
- return Agreements;
50
- } catch (error) {
51
- throw new Error(`An Error occured when retriving : ${error.message}`);
52
- }
53
- }
54
- }
1
+ import { RepositoryBase, IRepositoryBase } from '@tomei/general';
2
+ import { AgreementModel } from '../../models/agreement.entity';
3
+
4
+ export class AgreementRepository
5
+ extends RepositoryBase<AgreementModel>
6
+ implements IRepositoryBase<AgreementModel>
7
+ {
8
+ constructor() {
9
+ super(AgreementModel);
10
+ }
11
+
12
+ async findByPk(
13
+ id: string,
14
+ transaction?: any,
15
+ ): Promise<AgreementModel | null> {
16
+ try {
17
+ const result = await AgreementModel.findByPk(id, {
18
+ transaction: transaction,
19
+ });
20
+
21
+ return result;
22
+ } catch (error) {
23
+ throw new Error(`An Error occured when fetching : ${error.message}`);
24
+ }
25
+ }
26
+
27
+ async delete(AgreementNo: string, dbTransaction?: any) {
28
+ try {
29
+ const options = {
30
+ where: {
31
+ AgreementNo,
32
+ },
33
+ transaction: dbTransaction,
34
+ };
35
+ await AgreementModel.destroy(options);
36
+ } catch (error) {
37
+ throw new Error(`An Error occured when delete : ${error.message}`);
38
+ }
39
+ }
40
+
41
+ async findAndCountAll(options?: any) {
42
+ try {
43
+ let Agreements: any;
44
+ if (options) {
45
+ Agreements = await AgreementModel.findAndCountAll(options);
46
+ } else {
47
+ Agreements = await AgreementModel.findAndCountAll();
48
+ }
49
+ return Agreements;
50
+ } catch (error) {
51
+ throw new Error(`An Error occured when retriving : ${error.message}`);
52
+ }
53
+ }
54
+ }