@forwardslashns/taskit-validation-messages 1.0.64 → 1.2.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.
- package/.env.example +1 -0
- package/PUBLISHING.md +78 -0
- package/README.md +59 -0
- package/dist/index.d.ts +2 -2
- package/dist/index.d.ts.map +1 -1
- package/dist/validation/features/account-category.validation-messages.d.ts +21 -0
- package/dist/validation/features/account-category.validation-messages.d.ts.map +1 -0
- package/dist/validation/features/account-category.validation-messages.js +23 -0
- package/dist/validation/features/account-id.validation-messages.d.ts +26 -0
- package/dist/validation/features/account-id.validation-messages.d.ts.map +1 -0
- package/dist/validation/features/account-id.validation-messages.js +28 -0
- package/dist/validation/features/address.validation-messages.d.ts +62 -0
- package/dist/validation/features/address.validation-messages.d.ts.map +1 -0
- package/dist/validation/features/address.validation-messages.js +64 -0
- package/dist/validation/features/bank-and-credit-card.validation-messages.d.ts +19 -0
- package/dist/validation/features/bank-and-credit-card.validation-messages.d.ts.map +1 -0
- package/dist/validation/features/bank-and-credit-card.validation-messages.js +21 -0
- package/dist/validation/features/bank.validation-messages.d.ts +7 -0
- package/dist/validation/features/bank.validation-messages.d.ts.map +1 -0
- package/dist/validation/features/bank.validation-messages.js +9 -0
- package/dist/validation/features/business-activity.validation-messages.d.ts +21 -0
- package/dist/validation/features/business-activity.validation-messages.d.ts.map +1 -0
- package/dist/validation/features/business-activity.validation-messages.js +23 -0
- package/dist/validation/features/client-relationship.validation-messages.d.ts +63 -0
- package/dist/validation/features/client-relationship.validation-messages.d.ts.map +1 -0
- package/dist/validation/features/client-relationship.validation-messages.js +65 -0
- package/dist/validation/features/client.validation-messages.d.ts +387 -0
- package/dist/validation/features/client.validation-messages.d.ts.map +1 -0
- package/dist/validation/features/client.validation-messages.js +389 -0
- package/dist/validation/features/commission-detail.validation-messages.d.ts +24 -0
- package/dist/validation/features/commission-detail.validation-messages.d.ts.map +1 -0
- package/dist/validation/features/commission-detail.validation-messages.js +26 -0
- package/dist/validation/features/contact.validation-messages.d.ts +37 -0
- package/dist/validation/features/contact.validation-messages.d.ts.map +1 -0
- package/dist/validation/features/contact.validation-messages.js +39 -0
- package/dist/validation/features/credit-card.validation-messages.d.ts +11 -0
- package/dist/validation/features/credit-card.validation-messages.d.ts.map +1 -0
- package/dist/validation/features/credit-card.validation-messages.js +13 -0
- package/dist/validation/features/data-filter.validation-messages.d.ts +19 -0
- package/dist/validation/features/data-filter.validation-messages.d.ts.map +1 -0
- package/dist/validation/features/data-filter.validation-messages.js +21 -0
- package/dist/validation/features/filing-category.validation-messages.d.ts +21 -0
- package/dist/validation/features/filing-category.validation-messages.d.ts.map +1 -0
- package/dist/validation/features/filing-category.validation-messages.js +23 -0
- package/dist/validation/features/outside-provider.validation-messages.d.ts +13 -0
- package/dist/validation/features/outside-provider.validation-messages.d.ts.map +1 -0
- package/dist/validation/features/outside-provider.validation-messages.js +15 -0
- package/dist/validation/features/role-and-permission.validation-messages.d.ts +32 -0
- package/dist/validation/features/role-and-permission.validation-messages.d.ts.map +1 -0
- package/dist/validation/features/role-and-permission.validation-messages.js +34 -0
- package/dist/validation/features/state.validation-messages.d.ts +49 -0
- package/dist/validation/features/state.validation-messages.d.ts.map +1 -0
- package/dist/validation/features/state.validation-messages.js +51 -0
- package/dist/validation/features/user-preference.validation-messages.d.ts +20 -0
- package/dist/validation/features/user-preference.validation-messages.d.ts.map +1 -0
- package/dist/validation/features/user-preference.validation-messages.js +22 -0
- package/dist/validation/features/user.validation-messages.d.ts +48 -0
- package/dist/validation/features/user.validation-messages.d.ts.map +1 -0
- package/dist/validation/features/user.validation-messages.js +50 -0
- package/dist/validation/validation-message.formatter.d.ts +5 -1
- package/dist/validation/validation-message.formatter.d.ts.map +1 -1
- package/dist/validation/validation-message.formatter.js +4 -1
- package/dist/validation/validation-messages.d.ts +183 -1
- package/dist/validation/validation-messages.d.ts.map +1 -1
- package/dist/validation/validation-messages.js +36 -684
- package/package.json +8 -8
- package/publish.ps1 +37 -0
- package/src/index.ts +2 -2
- package/src/validation/features/account-category.validation-messages.ts +20 -0
- package/src/validation/features/account-id.validation-messages.ts +25 -0
- package/src/validation/features/address.validation-messages.ts +61 -0
- package/src/validation/features/bank-and-credit-card.validation-messages.ts +20 -0
- package/src/validation/features/bank.validation-messages.ts +6 -0
- package/src/validation/features/business-activity.validation-messages.ts +20 -0
- package/src/validation/features/client-relationship.validation-messages.ts +62 -0
- package/src/validation/features/client.validation-messages.ts +386 -0
- package/src/validation/features/commission-detail.validation-messages.ts +23 -0
- package/src/validation/features/contact.validation-messages.ts +36 -0
- package/src/validation/features/credit-card.validation-messages.ts +10 -0
- package/src/validation/features/data-filter.validation-messages.ts +18 -0
- package/src/validation/features/filing-category.validation-messages.ts +20 -0
- package/src/validation/features/outside-provider.validation-messages.ts +12 -0
- package/src/validation/features/role-and-permission.validation-messages.ts +31 -0
- package/src/validation/features/state.validation-messages.ts +48 -0
- package/src/validation/features/user-preference.validation-messages.ts +19 -0
- package/src/validation/features/user.validation-messages.ts +47 -0
- package/src/validation/validation-message.formatter.ts +11 -2
- package/src/validation/validation-messages.ts +37 -686
package/.env.example
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
NPM_TOKEN=your_npm_token_here
|
package/PUBLISHING.md
ADDED
|
@@ -0,0 +1,78 @@
|
|
|
1
|
+
# Publishing Guide
|
|
2
|
+
|
|
3
|
+
## Prerequisites
|
|
4
|
+
|
|
5
|
+
You need a valid NPM access token with publish permissions for the `@forwardslashns` scope.
|
|
6
|
+
|
|
7
|
+
### Generate a New Token (if needed)
|
|
8
|
+
|
|
9
|
+
1. Go to https://www.npmjs.com/settings/YOUR_USERNAME/tokens
|
|
10
|
+
2. Click "Generate New Token"
|
|
11
|
+
3. Choose "Classic Token"
|
|
12
|
+
4. Select "Automation" or "Publish" type
|
|
13
|
+
5. Copy the token (starts with `npm_`)
|
|
14
|
+
|
|
15
|
+
**Important:** The token must be associated with the `forwardslashns` npm account that has publish permissions for `@forwardslashns/taskit-validation-messages`.
|
|
16
|
+
|
|
17
|
+
## Setup
|
|
18
|
+
|
|
19
|
+
1. **Create `.env` file** (first time only):
|
|
20
|
+
```bash
|
|
21
|
+
cp .env.example .env
|
|
22
|
+
```
|
|
23
|
+
|
|
24
|
+
2. **Add your NPM token** to `.env`:
|
|
25
|
+
```
|
|
26
|
+
NPM_TOKEN=npm_your_actual_token_here
|
|
27
|
+
```
|
|
28
|
+
|
|
29
|
+
Make sure to use the **full token** (should be 40+ characters starting with `npm_`)
|
|
30
|
+
|
|
31
|
+
## Publishing
|
|
32
|
+
|
|
33
|
+
Run the publish script:
|
|
34
|
+
|
|
35
|
+
```powershell
|
|
36
|
+
pnpm run publish:token
|
|
37
|
+
```
|
|
38
|
+
|
|
39
|
+
Or directly:
|
|
40
|
+
|
|
41
|
+
```powershell
|
|
42
|
+
.\publish.ps1
|
|
43
|
+
```
|
|
44
|
+
|
|
45
|
+
## Troubleshooting
|
|
46
|
+
|
|
47
|
+
### "Access token expired or revoked"
|
|
48
|
+
|
|
49
|
+
This means your token is either:
|
|
50
|
+
- **Expired** - Generate a new token from npm
|
|
51
|
+
- **Invalid** - Check you copied the complete token
|
|
52
|
+
- **No permissions** - Token must belong to `forwardslashns` npm account with publish rights
|
|
53
|
+
|
|
54
|
+
**Solution:** Generate a fresh token from the npm account that owns the package.
|
|
55
|
+
|
|
56
|
+
### "Not in this registry"
|
|
57
|
+
|
|
58
|
+
- Verify the package exists: `npm view @forwardslashns/taskit-validation-messages`
|
|
59
|
+
- Ensure you have publish permissions for the `@forwardslashns` scope
|
|
60
|
+
|
|
61
|
+
### Token not loading
|
|
62
|
+
|
|
63
|
+
- Verify `.env` exists and contains `NPM_TOKEN=...`
|
|
64
|
+
- Check token has no extra spaces or quotes
|
|
65
|
+
- Run `Get-Content .env` to verify the file
|
|
66
|
+
|
|
67
|
+
## How It Works
|
|
68
|
+
|
|
69
|
+
1. Script loads `NPM_TOKEN` from `.env` file
|
|
70
|
+
2. Temporarily replaces `${NPM_TOKEN}` in `.npmrc` with actual token
|
|
71
|
+
3. Runs `pnpm publish`
|
|
72
|
+
4. Restores original `.npmrc` (keeps token out of git)
|
|
73
|
+
|
|
74
|
+
## Security
|
|
75
|
+
|
|
76
|
+
- `.env` is in `.gitignore` - never commit it
|
|
77
|
+
- `.npmrc` uses `${NPM_TOKEN}` placeholder - safe to commit
|
|
78
|
+
- Token is only in memory during publish
|
package/README.md
CHANGED
|
@@ -2,6 +2,13 @@
|
|
|
2
2
|
|
|
3
3
|
This package provides a centralized list of validation messages used across both frontend and backend of the project. It ensures consistent error display and simplifies maintenance by keeping all validation messages in one place, without altering code in development repositories.
|
|
4
4
|
|
|
5
|
+
## ✨ Features
|
|
6
|
+
|
|
7
|
+
- **Centralized validation messages** across all features
|
|
8
|
+
- **Type-safe** message retrieval with TypeScript
|
|
9
|
+
- **Dynamic parameter substitution** for contextual messages
|
|
10
|
+
- **Affected fields tracking** for better frontend UX (v1.1.0+)
|
|
11
|
+
|
|
5
12
|
# VALIDATION_MESSAGES
|
|
6
13
|
|
|
7
14
|
The package exposes validation messages that can be retrieved using specific aliases. These messages are organized by the features they belong to, making it easier to manage and update them.
|
|
@@ -9,3 +16,55 @@ The package exposes validation messages that can be retrieved using specific ali
|
|
|
9
16
|
# getValidationMessage
|
|
10
17
|
|
|
11
18
|
This mechanism allows for the retrieval and dynamic creation of validation messages by passing their aliases and any required parameters. Parameters are optional and passed as objects, following the structure defined within each validation message itself.
|
|
19
|
+
|
|
20
|
+
## Return Value (v1.1.0+)
|
|
21
|
+
|
|
22
|
+
`getValidationMessage` now returns a `ValidationMessageResult` object:
|
|
23
|
+
|
|
24
|
+
```typescript
|
|
25
|
+
{
|
|
26
|
+
content: string; // The formatted validation message
|
|
27
|
+
affectedFields: string[]; // Array of field identifiers affected by this validation error
|
|
28
|
+
}
|
|
29
|
+
```
|
|
30
|
+
|
|
31
|
+
## Usage
|
|
32
|
+
|
|
33
|
+
```typescript
|
|
34
|
+
import { getValidationMessage } from '@forwardslashns/taskit-validation-messages';
|
|
35
|
+
|
|
36
|
+
// Simple usage
|
|
37
|
+
const result = getValidationMessage('ACCOUNT_CATEGORY', 'NAME_ALREADY_EXISTS', {
|
|
38
|
+
name: 'Marketing',
|
|
39
|
+
});
|
|
40
|
+
|
|
41
|
+
console.log(result.content); // "Account category with the same name 'Marketing' already exists"
|
|
42
|
+
console.log(result.affectedFields); // ['name']
|
|
43
|
+
|
|
44
|
+
// In API responses
|
|
45
|
+
return reply.status(400).send({
|
|
46
|
+
message: result.content,
|
|
47
|
+
affectedFields: result.affectedFields,
|
|
48
|
+
});
|
|
49
|
+
```
|
|
50
|
+
|
|
51
|
+
## Migration from v1.0.x
|
|
52
|
+
|
|
53
|
+
See [MIGRATION_GUIDE.md](./MIGRATION_GUIDE.md) for detailed migration instructions.
|
|
54
|
+
|
|
55
|
+
**Quick update:**
|
|
56
|
+
|
|
57
|
+
```typescript
|
|
58
|
+
// Old (v1.0.x)
|
|
59
|
+
const message = getValidationMessage('FEATURE', 'ERROR');
|
|
60
|
+
|
|
61
|
+
// New (v1.1.0+)
|
|
62
|
+
const { content, affectedFields } = getValidationMessage('FEATURE', 'ERROR');
|
|
63
|
+
```
|
|
64
|
+
|
|
65
|
+
## Documentation
|
|
66
|
+
|
|
67
|
+
- [Migration Guide](./MIGRATION_GUIDE.md) - Upgrading from v1.0.x
|
|
68
|
+
- [Implementation Summary](./IMPLEMENTATION_SUMMARY.md) - Technical details
|
|
69
|
+
- [Backend Update Checklist](./BACKEND_UPDATE_CHECKLIST.md) - Step-by-step backend migration
|
|
70
|
+
- [Example Usage](./example-usage.ts) - Code examples
|
package/dist/index.d.ts
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { getValidationMessage } from './validation/validation-message.formatter';
|
|
1
|
+
import { getValidationMessage, ValidationMessageResult } from './validation/validation-message.formatter';
|
|
2
2
|
import { VALIDATION_MESSAGES } from './validation/validation-messages';
|
|
3
|
-
export { VALIDATION_MESSAGES, getValidationMessage };
|
|
3
|
+
export { VALIDATION_MESSAGES, getValidationMessage, ValidationMessageResult };
|
|
4
4
|
//# sourceMappingURL=index.d.ts.map
|
package/dist/index.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,oBAAoB,EAAE,MAAM,2CAA2C,CAAC;
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,oBAAoB,EAAE,uBAAuB,EAAE,MAAM,2CAA2C,CAAC;AAC1G,OAAO,EAAE,mBAAmB,EAAE,MAAM,kCAAkC,CAAC;AAEvE,OAAO,EAAE,mBAAmB,EAAE,oBAAoB,EAAE,uBAAuB,EAAE,CAAC"}
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
export declare const ACCOUNT_CATEGORY: {
|
|
2
|
+
readonly INVALID_REQUEST: {
|
|
3
|
+
readonly message: "Missing account category id in request";
|
|
4
|
+
readonly affectedFields: readonly [];
|
|
5
|
+
};
|
|
6
|
+
readonly ID_DOES_NOT_EXIST: {
|
|
7
|
+
readonly message: "Account category with id '{id}' does not exist";
|
|
8
|
+
readonly params: readonly ["id"];
|
|
9
|
+
readonly affectedFields: readonly ["accountCategoryId"];
|
|
10
|
+
};
|
|
11
|
+
readonly NAME_ALREADY_EXISTS: {
|
|
12
|
+
readonly message: "Account category with the same name '{name}' already exists";
|
|
13
|
+
readonly params: readonly ["name"];
|
|
14
|
+
readonly affectedFields: readonly ["name"];
|
|
15
|
+
};
|
|
16
|
+
readonly OPTION_IN_USE: {
|
|
17
|
+
readonly message: "This option is currently in use and cannot be deleted.";
|
|
18
|
+
readonly affectedFields: readonly [];
|
|
19
|
+
};
|
|
20
|
+
};
|
|
21
|
+
//# sourceMappingURL=account-category.validation-messages.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"account-category.validation-messages.d.ts","sourceRoot":"","sources":["../../../src/validation/features/account-category.validation-messages.ts"],"names":[],"mappings":"AAAA,eAAO,MAAM,gBAAgB;;;;;;;;;;;;;;;;;;;CAmBnB,CAAC"}
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.ACCOUNT_CATEGORY = void 0;
|
|
4
|
+
exports.ACCOUNT_CATEGORY = {
|
|
5
|
+
INVALID_REQUEST: {
|
|
6
|
+
message: 'Missing account category id in request',
|
|
7
|
+
affectedFields: [],
|
|
8
|
+
},
|
|
9
|
+
ID_DOES_NOT_EXIST: {
|
|
10
|
+
message: `Account category with id '{id}' does not exist`,
|
|
11
|
+
params: ['id'],
|
|
12
|
+
affectedFields: ['accountCategoryId'],
|
|
13
|
+
},
|
|
14
|
+
NAME_ALREADY_EXISTS: {
|
|
15
|
+
message: `Account category with the same name '{name}' already exists`,
|
|
16
|
+
params: ['name'],
|
|
17
|
+
affectedFields: ['name'],
|
|
18
|
+
},
|
|
19
|
+
OPTION_IN_USE: {
|
|
20
|
+
message: `This option is currently in use and cannot be deleted.`,
|
|
21
|
+
affectedFields: [],
|
|
22
|
+
},
|
|
23
|
+
};
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
export declare const ACCOUNT_ID: {
|
|
2
|
+
readonly INVALID_REQUEST: {
|
|
3
|
+
readonly message: "Missing account id identifier in request";
|
|
4
|
+
readonly affectedFields: readonly [];
|
|
5
|
+
};
|
|
6
|
+
readonly ID_DOES_NOT_EXIST: {
|
|
7
|
+
readonly message: "Account id with id '{id}' does not exist";
|
|
8
|
+
readonly params: readonly ["id"];
|
|
9
|
+
readonly affectedFields: readonly ["accountId"];
|
|
10
|
+
};
|
|
11
|
+
readonly NAME_ALREADY_EXISTS: {
|
|
12
|
+
readonly message: "Account id with the same name '{name}' already exists";
|
|
13
|
+
readonly params: readonly ["name"];
|
|
14
|
+
readonly affectedFields: readonly ["name"];
|
|
15
|
+
};
|
|
16
|
+
readonly ACCOUNT_CATEGORY_ID_DOES_NOT_EXIST: {
|
|
17
|
+
readonly message: "Account category with id '{id}' does not exist";
|
|
18
|
+
readonly params: readonly ["id"];
|
|
19
|
+
readonly affectedFields: readonly ["accountCategoryId"];
|
|
20
|
+
};
|
|
21
|
+
readonly OPTION_IN_USE: {
|
|
22
|
+
readonly message: "This option is currently in use and cannot be deleted.";
|
|
23
|
+
readonly affectedFields: readonly [];
|
|
24
|
+
};
|
|
25
|
+
};
|
|
26
|
+
//# sourceMappingURL=account-id.validation-messages.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"account-id.validation-messages.d.ts","sourceRoot":"","sources":["../../../src/validation/features/account-id.validation-messages.ts"],"names":[],"mappings":"AAAA,eAAO,MAAM,UAAU;;;;;;;;;;;;;;;;;;;;;;;;CAwBb,CAAC"}
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.ACCOUNT_ID = void 0;
|
|
4
|
+
exports.ACCOUNT_ID = {
|
|
5
|
+
INVALID_REQUEST: {
|
|
6
|
+
message: 'Missing account id identifier in request',
|
|
7
|
+
affectedFields: [],
|
|
8
|
+
},
|
|
9
|
+
ID_DOES_NOT_EXIST: {
|
|
10
|
+
message: `Account id with id '{id}' does not exist`,
|
|
11
|
+
params: ['id'],
|
|
12
|
+
affectedFields: ['accountId'],
|
|
13
|
+
},
|
|
14
|
+
NAME_ALREADY_EXISTS: {
|
|
15
|
+
message: `Account id with the same name '{name}' already exists`,
|
|
16
|
+
params: ['name'],
|
|
17
|
+
affectedFields: ['name'],
|
|
18
|
+
},
|
|
19
|
+
ACCOUNT_CATEGORY_ID_DOES_NOT_EXIST: {
|
|
20
|
+
message: `Account category with id '{id}' does not exist`,
|
|
21
|
+
params: ['id'],
|
|
22
|
+
affectedFields: ['accountCategoryId'],
|
|
23
|
+
},
|
|
24
|
+
OPTION_IN_USE: {
|
|
25
|
+
message: `This option is currently in use and cannot be deleted.`,
|
|
26
|
+
affectedFields: [],
|
|
27
|
+
},
|
|
28
|
+
};
|
|
@@ -0,0 +1,62 @@
|
|
|
1
|
+
export declare const ADDRESS: {
|
|
2
|
+
readonly STATES_NOT_FOUND: {
|
|
3
|
+
readonly message: "States with ids {ids} do not exist";
|
|
4
|
+
readonly params: readonly ["ids"];
|
|
5
|
+
readonly affectedFields: readonly ["stateId"];
|
|
6
|
+
};
|
|
7
|
+
readonly INVALID_STATE_TYPE: {
|
|
8
|
+
readonly message: "States with ids {ids} are not of type 'State'";
|
|
9
|
+
readonly params: readonly ["ids"];
|
|
10
|
+
readonly affectedFields: readonly ["stateId"];
|
|
11
|
+
};
|
|
12
|
+
readonly CITIES_NOT_FOUND: {
|
|
13
|
+
readonly message: "Cities with ids {ids} do not exist";
|
|
14
|
+
readonly params: readonly ["ids"];
|
|
15
|
+
readonly affectedFields: readonly ["cityId"];
|
|
16
|
+
};
|
|
17
|
+
readonly INVALID_CITY_TYPE: {
|
|
18
|
+
readonly message: "Cities with ids {ids} are not of type 'City'";
|
|
19
|
+
readonly params: readonly ["ids"];
|
|
20
|
+
readonly affectedFields: readonly ["cityId"];
|
|
21
|
+
};
|
|
22
|
+
readonly ZIP_CODES_NOT_FOUND: {
|
|
23
|
+
readonly message: "Zip codes with ids {ids} do not exist";
|
|
24
|
+
readonly params: readonly ["ids"];
|
|
25
|
+
readonly affectedFields: readonly ["zipCode"];
|
|
26
|
+
};
|
|
27
|
+
readonly CONTACT_ROLES_NOT_FOUND: {
|
|
28
|
+
readonly message: "Contact roles with ids {ids} do not exist";
|
|
29
|
+
readonly params: readonly ["ids"];
|
|
30
|
+
readonly affectedFields: readonly ["contactRoleId"];
|
|
31
|
+
};
|
|
32
|
+
readonly CONTACT_TYPES_NOT_FOUND: {
|
|
33
|
+
readonly message: "Contact types with ids {ids} do not exist";
|
|
34
|
+
readonly params: readonly ["ids"];
|
|
35
|
+
readonly affectedFields: readonly ["contactTypeId"];
|
|
36
|
+
};
|
|
37
|
+
readonly LEGAL_ADDRESS_MUST_BE_PROVIDED: {
|
|
38
|
+
readonly message: "The client must have a legal address. Please set the address type to 'Legal'.";
|
|
39
|
+
readonly affectedFields: readonly ["addresses"];
|
|
40
|
+
};
|
|
41
|
+
readonly MULTIPLE_LEGAL_ADDRESSES_PROVIDED: {
|
|
42
|
+
readonly message: "The client must have only one legal address. Please ensure only one address is set to 'Legal'.";
|
|
43
|
+
readonly affectedFields: readonly ["addresses"];
|
|
44
|
+
};
|
|
45
|
+
readonly BILLING_ADDRESS_MUST_BE_PROVIDED: {
|
|
46
|
+
readonly message: "The client must have a billing address. Please set the address type to 'Billing'.";
|
|
47
|
+
readonly affectedFields: readonly ["addresses"];
|
|
48
|
+
};
|
|
49
|
+
readonly MULTIPLE_BILLING_ADDRESSES_PROVIDED: {
|
|
50
|
+
readonly message: "The client must have only one billing address. Please ensure only one address is set to 'Billing'.";
|
|
51
|
+
readonly affectedFields: readonly ["addresses"];
|
|
52
|
+
};
|
|
53
|
+
readonly PRIMARY_ADDRESS_MUST_BE_PROVIDED: {
|
|
54
|
+
readonly message: "The client must have a primary address. Please set the address type to 'Primary'.";
|
|
55
|
+
readonly affectedFields: readonly ["addresses"];
|
|
56
|
+
};
|
|
57
|
+
readonly MULTIPLE_PRIMARY_ADDRESSES_PROVIDED: {
|
|
58
|
+
readonly message: "The client must have only one primary address. Please ensure only one address is set to 'Primary'.";
|
|
59
|
+
readonly affectedFields: readonly ["addresses"];
|
|
60
|
+
};
|
|
61
|
+
};
|
|
62
|
+
//# sourceMappingURL=address.validation-messages.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"address.validation-messages.d.ts","sourceRoot":"","sources":["../../../src/validation/features/address.validation-messages.ts"],"names":[],"mappings":"AAAA,eAAO,MAAM,OAAO;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CA4DV,CAAC"}
|
|
@@ -0,0 +1,64 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.ADDRESS = void 0;
|
|
4
|
+
exports.ADDRESS = {
|
|
5
|
+
STATES_NOT_FOUND: {
|
|
6
|
+
message: 'States with ids {ids} do not exist',
|
|
7
|
+
params: ['ids'],
|
|
8
|
+
affectedFields: ['stateId'],
|
|
9
|
+
},
|
|
10
|
+
INVALID_STATE_TYPE: {
|
|
11
|
+
message: `States with ids {ids} are not of type 'State'`,
|
|
12
|
+
params: ['ids'],
|
|
13
|
+
affectedFields: ['stateId'],
|
|
14
|
+
},
|
|
15
|
+
CITIES_NOT_FOUND: {
|
|
16
|
+
message: `Cities with ids {ids} do not exist`,
|
|
17
|
+
params: ['ids'],
|
|
18
|
+
affectedFields: ['cityId'],
|
|
19
|
+
},
|
|
20
|
+
INVALID_CITY_TYPE: {
|
|
21
|
+
message: `Cities with ids {ids} are not of type 'City'`,
|
|
22
|
+
params: ['ids'],
|
|
23
|
+
affectedFields: ['cityId'],
|
|
24
|
+
},
|
|
25
|
+
ZIP_CODES_NOT_FOUND: {
|
|
26
|
+
message: `Zip codes with ids {ids} do not exist`,
|
|
27
|
+
params: ['ids'],
|
|
28
|
+
affectedFields: ['zipCode'],
|
|
29
|
+
},
|
|
30
|
+
CONTACT_ROLES_NOT_FOUND: {
|
|
31
|
+
message: `Contact roles with ids {ids} do not exist`,
|
|
32
|
+
params: ['ids'],
|
|
33
|
+
affectedFields: ['contactRoleId'],
|
|
34
|
+
},
|
|
35
|
+
CONTACT_TYPES_NOT_FOUND: {
|
|
36
|
+
message: `Contact types with ids {ids} do not exist`,
|
|
37
|
+
params: ['ids'],
|
|
38
|
+
affectedFields: ['contactTypeId'],
|
|
39
|
+
},
|
|
40
|
+
LEGAL_ADDRESS_MUST_BE_PROVIDED: {
|
|
41
|
+
message: `The client must have a legal address. Please set the address type to 'Legal'.`,
|
|
42
|
+
affectedFields: ['addresses'],
|
|
43
|
+
},
|
|
44
|
+
MULTIPLE_LEGAL_ADDRESSES_PROVIDED: {
|
|
45
|
+
message: `The client must have only one legal address. Please ensure only one address is set to 'Legal'.`,
|
|
46
|
+
affectedFields: ['addresses'],
|
|
47
|
+
},
|
|
48
|
+
BILLING_ADDRESS_MUST_BE_PROVIDED: {
|
|
49
|
+
message: `The client must have a billing address. Please set the address type to 'Billing'.`,
|
|
50
|
+
affectedFields: ['addresses'],
|
|
51
|
+
},
|
|
52
|
+
MULTIPLE_BILLING_ADDRESSES_PROVIDED: {
|
|
53
|
+
message: `The client must have only one billing address. Please ensure only one address is set to 'Billing'.`,
|
|
54
|
+
affectedFields: ['addresses'],
|
|
55
|
+
},
|
|
56
|
+
PRIMARY_ADDRESS_MUST_BE_PROVIDED: {
|
|
57
|
+
message: `The client must have a primary address. Please set the address type to 'Primary'.`,
|
|
58
|
+
affectedFields: ['addresses'],
|
|
59
|
+
},
|
|
60
|
+
MULTIPLE_PRIMARY_ADDRESSES_PROVIDED: {
|
|
61
|
+
message: `The client must have only one primary address. Please ensure only one address is set to 'Primary'.`,
|
|
62
|
+
affectedFields: ['addresses'],
|
|
63
|
+
},
|
|
64
|
+
};
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
export declare const BANK_AND_CREDIT_CARD: {
|
|
2
|
+
readonly INVALID_ACCOUNT_NUMBER: {
|
|
3
|
+
readonly message: "Enter a valid account number.";
|
|
4
|
+
readonly affectedFields: readonly ["accountNumber"];
|
|
5
|
+
};
|
|
6
|
+
readonly INVALID_DESCRIPTION: {
|
|
7
|
+
readonly message: "There is another payment method with the same description. Please ensure all payment methods have different descriptions.";
|
|
8
|
+
readonly affectedFields: readonly ["description"];
|
|
9
|
+
};
|
|
10
|
+
readonly NO_DEFAULT_PAYMENT_METHOD: {
|
|
11
|
+
readonly message: "There must be at least one payment method marked as default. Please select a default payment method.";
|
|
12
|
+
readonly affectedFields: readonly ["paymentMethods"];
|
|
13
|
+
};
|
|
14
|
+
readonly MULTIPLE_DEFAULT_PAYMENT_METHODS: {
|
|
15
|
+
readonly message: "There can only be one default payment method. Please ensure only one payment method is marked as default.";
|
|
16
|
+
readonly affectedFields: readonly ["paymentMethods"];
|
|
17
|
+
};
|
|
18
|
+
};
|
|
19
|
+
//# sourceMappingURL=bank-and-credit-card.validation-messages.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"bank-and-credit-card.validation-messages.d.ts","sourceRoot":"","sources":["../../../src/validation/features/bank-and-credit-card.validation-messages.ts"],"names":[],"mappings":"AAAA,eAAO,MAAM,oBAAoB;;;;;;;;;;;;;;;;;CAmBvB,CAAC"}
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.BANK_AND_CREDIT_CARD = void 0;
|
|
4
|
+
exports.BANK_AND_CREDIT_CARD = {
|
|
5
|
+
INVALID_ACCOUNT_NUMBER: {
|
|
6
|
+
message: 'Enter a valid account number.',
|
|
7
|
+
affectedFields: ['accountNumber'],
|
|
8
|
+
},
|
|
9
|
+
INVALID_DESCRIPTION: {
|
|
10
|
+
message: 'There is another payment method with the same description. Please ensure all payment methods have different descriptions.',
|
|
11
|
+
affectedFields: ['description'],
|
|
12
|
+
},
|
|
13
|
+
NO_DEFAULT_PAYMENT_METHOD: {
|
|
14
|
+
message: 'There must be at least one payment method marked as default. Please select a default payment method.',
|
|
15
|
+
affectedFields: ['paymentMethods'],
|
|
16
|
+
},
|
|
17
|
+
MULTIPLE_DEFAULT_PAYMENT_METHODS: {
|
|
18
|
+
message: 'There can only be one default payment method. Please ensure only one payment method is marked as default.',
|
|
19
|
+
affectedFields: ['paymentMethods'],
|
|
20
|
+
},
|
|
21
|
+
};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"bank.validation-messages.d.ts","sourceRoot":"","sources":["../../../src/validation/features/bank.validation-messages.ts"],"names":[],"mappings":"AAAA,eAAO,MAAM,IAAI;;;;;CAKP,CAAC"}
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
export declare const BUSINESS_ACTIVITY: {
|
|
2
|
+
readonly INVALID_REQUEST: {
|
|
3
|
+
readonly message: "Missing business activity id in request.";
|
|
4
|
+
readonly affectedFields: readonly [];
|
|
5
|
+
};
|
|
6
|
+
readonly ID_DOES_NOT_EXIST: {
|
|
7
|
+
readonly message: "Business activity with id '{id}' does not exist.";
|
|
8
|
+
readonly params: readonly ["id"];
|
|
9
|
+
readonly affectedFields: readonly ["businessActivityId"];
|
|
10
|
+
};
|
|
11
|
+
readonly NAME_ALREADY_EXISTS: {
|
|
12
|
+
readonly message: "Business activity with the same name '{name}' already exists.";
|
|
13
|
+
readonly params: readonly ["name"];
|
|
14
|
+
readonly affectedFields: readonly ["name"];
|
|
15
|
+
};
|
|
16
|
+
readonly OPTION_IN_USE: {
|
|
17
|
+
readonly message: "This option is currently in use and cannot be deleted.";
|
|
18
|
+
readonly affectedFields: readonly [];
|
|
19
|
+
};
|
|
20
|
+
};
|
|
21
|
+
//# sourceMappingURL=business-activity.validation-messages.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"business-activity.validation-messages.d.ts","sourceRoot":"","sources":["../../../src/validation/features/business-activity.validation-messages.ts"],"names":[],"mappings":"AAAA,eAAO,MAAM,iBAAiB;;;;;;;;;;;;;;;;;;;CAmBpB,CAAC"}
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.BUSINESS_ACTIVITY = void 0;
|
|
4
|
+
exports.BUSINESS_ACTIVITY = {
|
|
5
|
+
INVALID_REQUEST: {
|
|
6
|
+
message: 'Missing business activity id in request.',
|
|
7
|
+
affectedFields: [],
|
|
8
|
+
},
|
|
9
|
+
ID_DOES_NOT_EXIST: {
|
|
10
|
+
message: `Business activity with id '{id}' does not exist.`,
|
|
11
|
+
params: ['id'],
|
|
12
|
+
affectedFields: ['businessActivityId'],
|
|
13
|
+
},
|
|
14
|
+
NAME_ALREADY_EXISTS: {
|
|
15
|
+
message: `Business activity with the same name '{name}' already exists.`,
|
|
16
|
+
params: ['name'],
|
|
17
|
+
affectedFields: ['name'],
|
|
18
|
+
},
|
|
19
|
+
OPTION_IN_USE: {
|
|
20
|
+
message: `This option is currently in use and cannot be deleted.`,
|
|
21
|
+
affectedFields: [],
|
|
22
|
+
},
|
|
23
|
+
};
|
|
@@ -0,0 +1,63 @@
|
|
|
1
|
+
export declare const CLIENT_RELATIONSHIP: {
|
|
2
|
+
readonly CURRENT_CLIENT_CANNOT_BE_RELATED_TO_CURRENT_CLIENT: {
|
|
3
|
+
readonly message: "A client cannot have a relationship with itself.";
|
|
4
|
+
readonly affectedFields: readonly ["relatedClientId"];
|
|
5
|
+
};
|
|
6
|
+
readonly INVALID_RELATIONSHIP_TYPE_FOR_ENTITY_TYPE: {
|
|
7
|
+
readonly message: "{clientName} is a/an {entityType}, which can't have {relationshipType}s. Please update the relationship type.";
|
|
8
|
+
readonly params: readonly ["clientName", "entityType", "relationshipType"];
|
|
9
|
+
readonly affectedFields: readonly ["relationshipTypeId"];
|
|
10
|
+
};
|
|
11
|
+
readonly PARENT_RELATIONSHIP_REQUIRES_FILES_UNDER_PARENT: {
|
|
12
|
+
readonly message: "A Parent relationship can only be added to an entity that files under parent. Please update the Sub/Parent status before adding a parent relationship, or choose a different relationship type.";
|
|
13
|
+
readonly affectedFields: readonly ["relationshipTypeId", "filingTypeId"];
|
|
14
|
+
};
|
|
15
|
+
readonly STARTING_DATE_BEFORE_CLIENT_DATE_ESTABLISHED: {
|
|
16
|
+
readonly message: "This relationship's start date cannot be before {clientName}'s date established, {clientDateEstablished}. Please adjust the dates to proceed.";
|
|
17
|
+
readonly params: readonly ["clientName", "clientDateEstablished"];
|
|
18
|
+
readonly affectedFields: readonly ["startingDate"];
|
|
19
|
+
};
|
|
20
|
+
readonly STARTING_DATE_ON_OR_AFTER_CLIENT_CLOSE_DATE: {
|
|
21
|
+
readonly message: "This relationship's start date cannot be on or after {clientName}'s close date, {clientCloseDate}. Please adjust the dates to proceed.";
|
|
22
|
+
readonly params: readonly ["clientName", "clientCloseDate"];
|
|
23
|
+
readonly affectedFields: readonly ["startingDate"];
|
|
24
|
+
};
|
|
25
|
+
readonly STARTING_DATE_BEFORE_RELATED_CLIENT_DATE_ESTABLISHED: {
|
|
26
|
+
readonly message: "This relationship's start date cannot be before {relatedClientName}'s date established, {relatedClientDateEstablished}. Please adjust the dates to proceed.";
|
|
27
|
+
readonly params: readonly ["relatedClientName", "relatedClientDateEstablished"];
|
|
28
|
+
readonly affectedFields: readonly ["startingDate"];
|
|
29
|
+
};
|
|
30
|
+
readonly STARTING_DATE_ON_OR_AFTER_RELATED_CLIENT_CLOSE_DATE: {
|
|
31
|
+
readonly message: "This relationship's start date cannot be on or after {relatedClientName}'s close date, {relatedClientCloseDate}. Please adjust the dates to proceed.";
|
|
32
|
+
readonly params: readonly ["relatedClientName", "relatedClientCloseDate"];
|
|
33
|
+
readonly affectedFields: readonly ["startingDate"];
|
|
34
|
+
};
|
|
35
|
+
readonly ENDING_DATE_ON_OR_BEFORE_STARTING_DATE: {
|
|
36
|
+
readonly message: "Please update the relationship ending date to be after the starting date, {startingDate}.";
|
|
37
|
+
readonly params: readonly ["startingDate"];
|
|
38
|
+
readonly affectedFields: readonly ["endingDate"];
|
|
39
|
+
};
|
|
40
|
+
readonly ENDING_DATE_AFTER_CLIENT_CLOSE_DATE: {
|
|
41
|
+
readonly message: "Please update the relationship ending date to be on or before the client's close date, {clientCloseDate}.";
|
|
42
|
+
readonly params: readonly ["clientCloseDate"];
|
|
43
|
+
readonly affectedFields: readonly ["endingDate"];
|
|
44
|
+
};
|
|
45
|
+
readonly ENDING_DATE_AFTER_RELATED_CLIENT_CLOSE_DATE: {
|
|
46
|
+
readonly message: "Please update the relationship ending date to be on or before {relatedClientName}'s close date, {relatedClientCloseDate}.";
|
|
47
|
+
readonly params: readonly ["relatedClientName", "relatedClientCloseDate"];
|
|
48
|
+
readonly affectedFields: readonly ["endingDate"];
|
|
49
|
+
};
|
|
50
|
+
readonly MULTIPLE_ACTIVE_PARENT_RELATIONSHIPS: {
|
|
51
|
+
readonly message: "All parent relationships besides the current one must have an ending date. Please add an ending date for any parent relationships that are no longer current, before adding this parent relationship.";
|
|
52
|
+
readonly affectedFields: readonly ["endingDate"];
|
|
53
|
+
};
|
|
54
|
+
readonly FINAL_REQUIRED_WHEN_ENDING_DATE_MATCHES_CLIENT_CLOSE_DATE: {
|
|
55
|
+
readonly message: "The client has a close date that is the same as the relationship ending date, therefore the relationship must be marked as final. Please update the relationship's final status to 'Yes', or adjust the dates.";
|
|
56
|
+
readonly affectedFields: readonly ["isFinal"];
|
|
57
|
+
};
|
|
58
|
+
readonly FINAL_REQUIRED_WHEN_ENDING_DATE_MATCHES_RELATED_CLIENT_CLOSE_DATE: {
|
|
59
|
+
readonly message: "The related client has a close date that is the same as the relationship ending date, therefore the relationship must be marked as final. Please update the relationship's final status to 'Yes', or adjust the dates.";
|
|
60
|
+
readonly affectedFields: readonly ["isFinal"];
|
|
61
|
+
};
|
|
62
|
+
};
|
|
63
|
+
//# sourceMappingURL=client-relationship.validation-messages.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"client-relationship.validation-messages.d.ts","sourceRoot":"","sources":["../../../src/validation/features/client-relationship.validation-messages.ts"],"names":[],"mappings":"AAAA,eAAO,MAAM,mBAAmB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CA6DtB,CAAC"}
|