@doctorus/common 0.0.16 → 0.0.18
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/lib/status/account-location-status.d.ts +43 -0
- package/lib/status/account-location-status.js +141 -0
- package/lib/status/index.d.ts +4 -0
- package/lib/status/index.js +28 -1
- package/lib/status/medical-history-status.d.ts +41 -0
- package/lib/status/medical-history-status.js +103 -0
- package/lib/status/medical-service-status.d.ts +1 -22
- package/lib/status/medical-service-status.js +2 -2
- package/lib/status/types.d.ts +36 -0
- package/lib/status/types.js +7 -0
- package/lib/status/utils.d.ts +118 -0
- package/lib/status/utils.js +197 -0
- package/package.json +1 -1
|
@@ -0,0 +1,43 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Account Location Status enumeration and metadata
|
|
3
|
+
* Defines availability policies for medical service locations
|
|
4
|
+
*/
|
|
5
|
+
import type { StatusMetadata, Locale } from './types';
|
|
6
|
+
export declare enum AccountLocationStatus {
|
|
7
|
+
INHERIT = "inherit",
|
|
8
|
+
ALWAYS_OPEN = "always_open",
|
|
9
|
+
CLOSED = "closed",
|
|
10
|
+
PERIODS = "periods"
|
|
11
|
+
}
|
|
12
|
+
/**
|
|
13
|
+
* Account Location Status metadata configuration
|
|
14
|
+
*/
|
|
15
|
+
export declare const ACCOUNT_LOCATION_STATUS_METADATA: Record<AccountLocationStatus, StatusMetadata>;
|
|
16
|
+
/**
|
|
17
|
+
* Get status metadata
|
|
18
|
+
*/
|
|
19
|
+
export declare function getStatusMetadata(status: AccountLocationStatus): StatusMetadata;
|
|
20
|
+
/**
|
|
21
|
+
* Get status icon
|
|
22
|
+
*/
|
|
23
|
+
export declare function getStatusIcon(status: AccountLocationStatus): string;
|
|
24
|
+
/**
|
|
25
|
+
* Get status color
|
|
26
|
+
*/
|
|
27
|
+
export declare function getStatusColor(status: AccountLocationStatus): string;
|
|
28
|
+
/**
|
|
29
|
+
* Get status label (short or long)
|
|
30
|
+
*/
|
|
31
|
+
export declare function getStatusLabel(status: AccountLocationStatus, locale?: Locale, format?: 'short' | 'long'): string;
|
|
32
|
+
/**
|
|
33
|
+
* Get status description
|
|
34
|
+
*/
|
|
35
|
+
export declare function getStatusDescription(status: AccountLocationStatus, locale?: Locale): string;
|
|
36
|
+
/**
|
|
37
|
+
* Get all available statuses
|
|
38
|
+
*/
|
|
39
|
+
export declare function getAllAccountLocationStatuses(): AccountLocationStatus[];
|
|
40
|
+
/**
|
|
41
|
+
* Check if a value is a valid AccountLocationStatus
|
|
42
|
+
*/
|
|
43
|
+
export declare function isValidAccountLocationStatus(value: string): value is AccountLocationStatus;
|
|
@@ -0,0 +1,141 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
/**
|
|
3
|
+
* Account Location Status enumeration and metadata
|
|
4
|
+
* Defines availability policies for medical service locations
|
|
5
|
+
*/
|
|
6
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
7
|
+
exports.ACCOUNT_LOCATION_STATUS_METADATA = exports.AccountLocationStatus = void 0;
|
|
8
|
+
exports.getStatusMetadata = getStatusMetadata;
|
|
9
|
+
exports.getStatusIcon = getStatusIcon;
|
|
10
|
+
exports.getStatusColor = getStatusColor;
|
|
11
|
+
exports.getStatusLabel = getStatusLabel;
|
|
12
|
+
exports.getStatusDescription = getStatusDescription;
|
|
13
|
+
exports.getAllAccountLocationStatuses = getAllAccountLocationStatuses;
|
|
14
|
+
exports.isValidAccountLocationStatus = isValidAccountLocationStatus;
|
|
15
|
+
var AccountLocationStatus;
|
|
16
|
+
(function (AccountLocationStatus) {
|
|
17
|
+
AccountLocationStatus["INHERIT"] = "inherit";
|
|
18
|
+
AccountLocationStatus["ALWAYS_OPEN"] = "always_open";
|
|
19
|
+
AccountLocationStatus["CLOSED"] = "closed";
|
|
20
|
+
AccountLocationStatus["PERIODS"] = "periods";
|
|
21
|
+
})(AccountLocationStatus || (exports.AccountLocationStatus = AccountLocationStatus = {}));
|
|
22
|
+
/**
|
|
23
|
+
* Account Location Status metadata configuration
|
|
24
|
+
*/
|
|
25
|
+
exports.ACCOUNT_LOCATION_STATUS_METADATA = {
|
|
26
|
+
[AccountLocationStatus.INHERIT]: {
|
|
27
|
+
icon: 'settings_backup_restore',
|
|
28
|
+
color: '#808080', // Gray
|
|
29
|
+
label: {
|
|
30
|
+
short: {
|
|
31
|
+
'us-EN': 'Inherit',
|
|
32
|
+
'fr-FR': 'Hériter',
|
|
33
|
+
},
|
|
34
|
+
long: {
|
|
35
|
+
'us-EN': 'Inherit Settings',
|
|
36
|
+
'fr-FR': 'Hériter des paramètres',
|
|
37
|
+
},
|
|
38
|
+
},
|
|
39
|
+
description: {
|
|
40
|
+
'us-EN': 'Location inherits availability settings from parent',
|
|
41
|
+
'fr-FR': 'Le lieu hérite les paramètres de disponibilité du parent',
|
|
42
|
+
},
|
|
43
|
+
},
|
|
44
|
+
[AccountLocationStatus.ALWAYS_OPEN]: {
|
|
45
|
+
icon: 'public',
|
|
46
|
+
color: '#4CAF50', // Green
|
|
47
|
+
label: {
|
|
48
|
+
short: {
|
|
49
|
+
'us-EN': 'Always Open',
|
|
50
|
+
'fr-FR': 'Toujours ouvert',
|
|
51
|
+
},
|
|
52
|
+
long: {
|
|
53
|
+
'us-EN': 'Always Open',
|
|
54
|
+
'fr-FR': 'Toujours ouvert',
|
|
55
|
+
},
|
|
56
|
+
},
|
|
57
|
+
description: {
|
|
58
|
+
'us-EN': 'Location is available 24/7 without restrictions',
|
|
59
|
+
'fr-FR': 'Le lieu est disponible 24h/24, 7j/7 sans restrictions',
|
|
60
|
+
},
|
|
61
|
+
},
|
|
62
|
+
[AccountLocationStatus.CLOSED]: {
|
|
63
|
+
icon: 'block',
|
|
64
|
+
color: '#F44336', // Red
|
|
65
|
+
label: {
|
|
66
|
+
short: {
|
|
67
|
+
'us-EN': 'Closed',
|
|
68
|
+
'fr-FR': 'Fermé',
|
|
69
|
+
},
|
|
70
|
+
long: {
|
|
71
|
+
'us-EN': 'Closed',
|
|
72
|
+
'fr-FR': 'Fermé',
|
|
73
|
+
},
|
|
74
|
+
},
|
|
75
|
+
description: {
|
|
76
|
+
'us-EN': 'Location is closed and unavailable for services',
|
|
77
|
+
'fr-FR': 'Le lieu est fermé et indisponible pour les services',
|
|
78
|
+
},
|
|
79
|
+
},
|
|
80
|
+
[AccountLocationStatus.PERIODS]: {
|
|
81
|
+
icon: 'schedule',
|
|
82
|
+
color: '#2196F3', // Blue
|
|
83
|
+
label: {
|
|
84
|
+
short: {
|
|
85
|
+
'us-EN': 'Periods',
|
|
86
|
+
'fr-FR': 'Périodes',
|
|
87
|
+
},
|
|
88
|
+
long: {
|
|
89
|
+
'us-EN': 'Custom Periods',
|
|
90
|
+
'fr-FR': 'Périodes personnalisées',
|
|
91
|
+
},
|
|
92
|
+
},
|
|
93
|
+
description: {
|
|
94
|
+
'us-EN': 'Location has custom availability periods',
|
|
95
|
+
'fr-FR': 'Le lieu a des périodes de disponibilité personnalisées',
|
|
96
|
+
},
|
|
97
|
+
},
|
|
98
|
+
};
|
|
99
|
+
/**
|
|
100
|
+
* Get status metadata
|
|
101
|
+
*/
|
|
102
|
+
function getStatusMetadata(status) {
|
|
103
|
+
return exports.ACCOUNT_LOCATION_STATUS_METADATA[status];
|
|
104
|
+
}
|
|
105
|
+
/**
|
|
106
|
+
* Get status icon
|
|
107
|
+
*/
|
|
108
|
+
function getStatusIcon(status) {
|
|
109
|
+
return exports.ACCOUNT_LOCATION_STATUS_METADATA[status].icon;
|
|
110
|
+
}
|
|
111
|
+
/**
|
|
112
|
+
* Get status color
|
|
113
|
+
*/
|
|
114
|
+
function getStatusColor(status) {
|
|
115
|
+
return exports.ACCOUNT_LOCATION_STATUS_METADATA[status].color;
|
|
116
|
+
}
|
|
117
|
+
/**
|
|
118
|
+
* Get status label (short or long)
|
|
119
|
+
*/
|
|
120
|
+
function getStatusLabel(status, locale = 'us-EN', format = 'short') {
|
|
121
|
+
return exports.ACCOUNT_LOCATION_STATUS_METADATA[status].label[format][locale];
|
|
122
|
+
}
|
|
123
|
+
/**
|
|
124
|
+
* Get status description
|
|
125
|
+
*/
|
|
126
|
+
function getStatusDescription(status, locale = 'us-EN') {
|
|
127
|
+
return exports.ACCOUNT_LOCATION_STATUS_METADATA[status].description[locale];
|
|
128
|
+
}
|
|
129
|
+
/**
|
|
130
|
+
* Get all available statuses
|
|
131
|
+
*/
|
|
132
|
+
function getAllAccountLocationStatuses() {
|
|
133
|
+
return Object.values(AccountLocationStatus);
|
|
134
|
+
}
|
|
135
|
+
/**
|
|
136
|
+
* Check if a value is a valid AccountLocationStatus
|
|
137
|
+
*/
|
|
138
|
+
function isValidAccountLocationStatus(value) {
|
|
139
|
+
return Object.values(AccountLocationStatus).includes(value);
|
|
140
|
+
}
|
|
141
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"account-location-status.js","sourceRoot":"","sources":["../../src/status/account-location-status.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * Account Location Status enumeration and metadata\n * Defines availability policies for medical service locations\n */\n\nimport type { StatusMetadata, Locale } from './types';\n\nexport enum AccountLocationStatus {\n  INHERIT = 'inherit',\n  ALWAYS_OPEN = 'always_open',\n  CLOSED = 'closed',\n  PERIODS = 'periods',\n}\n\n/**\n * Account Location Status metadata configuration\n */\nexport const ACCOUNT_LOCATION_STATUS_METADATA: Record<AccountLocationStatus, StatusMetadata> = {\n  [AccountLocationStatus.INHERIT]: {\n    icon: 'settings_backup_restore',\n    color: '#808080', // Gray\n    label: {\n      short: {\n        'us-EN': 'Inherit',\n        'fr-FR': 'Hériter',\n      },\n      long: {\n        'us-EN': 'Inherit Settings',\n        'fr-FR': 'Hériter des paramètres',\n      },\n    },\n    description: {\n      'us-EN': 'Location inherits availability settings from parent',\n      'fr-FR': 'Le lieu hérite les paramètres de disponibilité du parent',\n    },\n  },\n  [AccountLocationStatus.ALWAYS_OPEN]: {\n    icon: 'public',\n    color: '#4CAF50', // Green\n    label: {\n      short: {\n        'us-EN': 'Always Open',\n        'fr-FR': 'Toujours ouvert',\n      },\n      long: {\n        'us-EN': 'Always Open',\n        'fr-FR': 'Toujours ouvert',\n      },\n    },\n    description: {\n      'us-EN': 'Location is available 24/7 without restrictions',\n      'fr-FR': 'Le lieu est disponible 24h/24, 7j/7 sans restrictions',\n    },\n  },\n  [AccountLocationStatus.CLOSED]: {\n    icon: 'block',\n    color: '#F44336', // Red\n    label: {\n      short: {\n        'us-EN': 'Closed',\n        'fr-FR': 'Fermé',\n      },\n      long: {\n        'us-EN': 'Closed',\n        'fr-FR': 'Fermé',\n      },\n    },\n    description: {\n      'us-EN': 'Location is closed and unavailable for services',\n      'fr-FR': 'Le lieu est fermé et indisponible pour les services',\n    },\n  },\n  [AccountLocationStatus.PERIODS]: {\n    icon: 'schedule',\n    color: '#2196F3', // Blue\n    label: {\n      short: {\n        'us-EN': 'Periods',\n        'fr-FR': 'Périodes',\n      },\n      long: {\n        'us-EN': 'Custom Periods',\n        'fr-FR': 'Périodes personnalisées',\n      },\n    },\n    description: {\n      'us-EN': 'Location has custom availability periods',\n      'fr-FR': 'Le lieu a des périodes de disponibilité personnalisées',\n    },\n  },\n};\n\n/**\n * Get status metadata\n */\nexport function getStatusMetadata(status: AccountLocationStatus): StatusMetadata {\n  return ACCOUNT_LOCATION_STATUS_METADATA[status];\n}\n\n/**\n * Get status icon\n */\nexport function getStatusIcon(status: AccountLocationStatus): string {\n  return ACCOUNT_LOCATION_STATUS_METADATA[status].icon;\n}\n\n/**\n * Get status color\n */\nexport function getStatusColor(status: AccountLocationStatus): string {\n  return ACCOUNT_LOCATION_STATUS_METADATA[status].color;\n}\n\n/**\n * Get status label (short or long)\n */\nexport function getStatusLabel(\n  status: AccountLocationStatus,\n  locale: Locale = 'us-EN',\n  format: 'short' | 'long' = 'short',\n): string {\n  return ACCOUNT_LOCATION_STATUS_METADATA[status].label[format][locale];\n}\n\n/**\n * Get status description\n */\nexport function getStatusDescription(status: AccountLocationStatus, locale: Locale = 'us-EN'): string {\n  return ACCOUNT_LOCATION_STATUS_METADATA[status].description[locale];\n}\n\n/**\n * Get all available statuses\n */\nexport function getAllAccountLocationStatuses(): AccountLocationStatus[] {\n  return Object.values(AccountLocationStatus);\n}\n\n/**\n * Check if a value is a valid AccountLocationStatus\n */\nexport function isValidAccountLocationStatus(value: string): value is AccountLocationStatus {\n  return Object.values(AccountLocationStatus).includes(value as AccountLocationStatus);\n}\n"]}
|
package/lib/status/index.d.ts
CHANGED
|
@@ -1,4 +1,8 @@
|
|
|
1
1
|
/**
|
|
2
2
|
* Status module exports
|
|
3
3
|
*/
|
|
4
|
+
export * from './types';
|
|
4
5
|
export * from './medical-service-status';
|
|
6
|
+
export * as AccountLocationStatus from './account-location-status';
|
|
7
|
+
export * as MedicalHistoryStatus from './medical-history-status';
|
|
8
|
+
export * from './utils';
|
package/lib/status/index.js
CHANGED
|
@@ -10,12 +10,39 @@ var __createBinding = (this && this.__createBinding) || (Object.create ? (functi
|
|
|
10
10
|
if (k2 === undefined) k2 = k;
|
|
11
11
|
o[k2] = m[k];
|
|
12
12
|
}));
|
|
13
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
14
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
15
|
+
}) : function(o, v) {
|
|
16
|
+
o["default"] = v;
|
|
17
|
+
});
|
|
13
18
|
var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
14
19
|
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
15
20
|
};
|
|
21
|
+
var __importStar = (this && this.__importStar) || (function () {
|
|
22
|
+
var ownKeys = function(o) {
|
|
23
|
+
ownKeys = Object.getOwnPropertyNames || function (o) {
|
|
24
|
+
var ar = [];
|
|
25
|
+
for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
|
|
26
|
+
return ar;
|
|
27
|
+
};
|
|
28
|
+
return ownKeys(o);
|
|
29
|
+
};
|
|
30
|
+
return function (mod) {
|
|
31
|
+
if (mod && mod.__esModule) return mod;
|
|
32
|
+
var result = {};
|
|
33
|
+
if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
|
|
34
|
+
__setModuleDefault(result, mod);
|
|
35
|
+
return result;
|
|
36
|
+
};
|
|
37
|
+
})();
|
|
16
38
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
39
|
+
exports.MedicalHistoryStatus = exports.AccountLocationStatus = void 0;
|
|
17
40
|
/**
|
|
18
41
|
* Status module exports
|
|
19
42
|
*/
|
|
43
|
+
__exportStar(require("./types"), exports);
|
|
20
44
|
__exportStar(require("./medical-service-status"), exports);
|
|
21
|
-
|
|
45
|
+
exports.AccountLocationStatus = __importStar(require("./account-location-status"));
|
|
46
|
+
exports.MedicalHistoryStatus = __importStar(require("./medical-history-status"));
|
|
47
|
+
__exportStar(require("./utils"), exports);
|
|
48
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvc3RhdHVzL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztBQUFBOztHQUVHO0FBQ0gsMENBQXdCO0FBQ3hCLDJEQUF5QztBQUN6QyxtRkFBbUU7QUFDbkUsaUZBQWlFO0FBQ2pFLDBDQUF3QiIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogU3RhdHVzIG1vZHVsZSBleHBvcnRzXG4gKi9cbmV4cG9ydCAqIGZyb20gJy4vdHlwZXMnO1xuZXhwb3J0ICogZnJvbSAnLi9tZWRpY2FsLXNlcnZpY2Utc3RhdHVzJztcbmV4cG9ydCAqIGFzIEFjY291bnRMb2NhdGlvblN0YXR1cyBmcm9tICcuL2FjY291bnQtbG9jYXRpb24tc3RhdHVzJztcbmV4cG9ydCAqIGFzIE1lZGljYWxIaXN0b3J5U3RhdHVzIGZyb20gJy4vbWVkaWNhbC1oaXN0b3J5LXN0YXR1cyc7XG5leHBvcnQgKiBmcm9tICcuL3V0aWxzJztcbiJdfQ==
|
|
@@ -0,0 +1,41 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Medical History Status enumeration and metadata
|
|
3
|
+
* Defines the status of medical history records (active or expired)
|
|
4
|
+
*/
|
|
5
|
+
import type { StatusMetadata, Locale } from './types';
|
|
6
|
+
export declare enum MedicalHistoryStatus {
|
|
7
|
+
CURRENT = "current",
|
|
8
|
+
EXPIRED = "expired"
|
|
9
|
+
}
|
|
10
|
+
/**
|
|
11
|
+
* Medical History Status metadata configuration
|
|
12
|
+
*/
|
|
13
|
+
export declare const MEDICAL_HISTORY_STATUS_METADATA: Record<MedicalHistoryStatus, StatusMetadata>;
|
|
14
|
+
/**
|
|
15
|
+
* Get status metadata
|
|
16
|
+
*/
|
|
17
|
+
export declare function getStatusMetadata(status: MedicalHistoryStatus): StatusMetadata;
|
|
18
|
+
/**
|
|
19
|
+
* Get status icon
|
|
20
|
+
*/
|
|
21
|
+
export declare function getStatusIcon(status: MedicalHistoryStatus): string;
|
|
22
|
+
/**
|
|
23
|
+
* Get status color
|
|
24
|
+
*/
|
|
25
|
+
export declare function getStatusColor(status: MedicalHistoryStatus): string;
|
|
26
|
+
/**
|
|
27
|
+
* Get status label (short or long)
|
|
28
|
+
*/
|
|
29
|
+
export declare function getStatusLabel(status: MedicalHistoryStatus, locale?: Locale, format?: 'short' | 'long'): string;
|
|
30
|
+
/**
|
|
31
|
+
* Get status description
|
|
32
|
+
*/
|
|
33
|
+
export declare function getStatusDescription(status: MedicalHistoryStatus, locale?: Locale): string;
|
|
34
|
+
/**
|
|
35
|
+
* Get all available statuses
|
|
36
|
+
*/
|
|
37
|
+
export declare function getAllMedicalHistoryStatuses(): MedicalHistoryStatus[];
|
|
38
|
+
/**
|
|
39
|
+
* Check if a value is a valid MedicalHistoryStatus
|
|
40
|
+
*/
|
|
41
|
+
export declare function isValidMedicalHistoryStatus(value: string): value is MedicalHistoryStatus;
|
|
@@ -0,0 +1,103 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
/**
|
|
3
|
+
* Medical History Status enumeration and metadata
|
|
4
|
+
* Defines the status of medical history records (active or expired)
|
|
5
|
+
*/
|
|
6
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
7
|
+
exports.MEDICAL_HISTORY_STATUS_METADATA = exports.MedicalHistoryStatus = void 0;
|
|
8
|
+
exports.getStatusMetadata = getStatusMetadata;
|
|
9
|
+
exports.getStatusIcon = getStatusIcon;
|
|
10
|
+
exports.getStatusColor = getStatusColor;
|
|
11
|
+
exports.getStatusLabel = getStatusLabel;
|
|
12
|
+
exports.getStatusDescription = getStatusDescription;
|
|
13
|
+
exports.getAllMedicalHistoryStatuses = getAllMedicalHistoryStatuses;
|
|
14
|
+
exports.isValidMedicalHistoryStatus = isValidMedicalHistoryStatus;
|
|
15
|
+
var MedicalHistoryStatus;
|
|
16
|
+
(function (MedicalHistoryStatus) {
|
|
17
|
+
MedicalHistoryStatus["CURRENT"] = "current";
|
|
18
|
+
MedicalHistoryStatus["EXPIRED"] = "expired";
|
|
19
|
+
})(MedicalHistoryStatus || (exports.MedicalHistoryStatus = MedicalHistoryStatus = {}));
|
|
20
|
+
/**
|
|
21
|
+
* Medical History Status metadata configuration
|
|
22
|
+
*/
|
|
23
|
+
exports.MEDICAL_HISTORY_STATUS_METADATA = {
|
|
24
|
+
[MedicalHistoryStatus.CURRENT]: {
|
|
25
|
+
icon: 'check_circle',
|
|
26
|
+
color: '#4CAF50', // Green
|
|
27
|
+
label: {
|
|
28
|
+
short: {
|
|
29
|
+
'us-EN': 'Active',
|
|
30
|
+
'fr-FR': 'Actif',
|
|
31
|
+
},
|
|
32
|
+
long: {
|
|
33
|
+
'us-EN': 'Currently Active',
|
|
34
|
+
'fr-FR': 'Actuellement actif',
|
|
35
|
+
},
|
|
36
|
+
},
|
|
37
|
+
description: {
|
|
38
|
+
'us-EN': 'Medical history record is currently active and relevant',
|
|
39
|
+
'fr-FR': "L'historique médical est actuellement actif et pertinent",
|
|
40
|
+
},
|
|
41
|
+
},
|
|
42
|
+
[MedicalHistoryStatus.EXPIRED]: {
|
|
43
|
+
icon: 'do_not_disturb_on',
|
|
44
|
+
color: '#808080', // Gray
|
|
45
|
+
label: {
|
|
46
|
+
short: {
|
|
47
|
+
'us-EN': 'Expired',
|
|
48
|
+
'fr-FR': 'Expiré',
|
|
49
|
+
},
|
|
50
|
+
long: {
|
|
51
|
+
'us-EN': 'Expired Record',
|
|
52
|
+
'fr-FR': 'Enregistrement expiré',
|
|
53
|
+
},
|
|
54
|
+
},
|
|
55
|
+
description: {
|
|
56
|
+
'us-EN': 'Medical history record has expired and is no longer current',
|
|
57
|
+
'fr-FR': "L'historique médical a expiré et n'est plus actuel",
|
|
58
|
+
},
|
|
59
|
+
},
|
|
60
|
+
};
|
|
61
|
+
/**
|
|
62
|
+
* Get status metadata
|
|
63
|
+
*/
|
|
64
|
+
function getStatusMetadata(status) {
|
|
65
|
+
return exports.MEDICAL_HISTORY_STATUS_METADATA[status];
|
|
66
|
+
}
|
|
67
|
+
/**
|
|
68
|
+
* Get status icon
|
|
69
|
+
*/
|
|
70
|
+
function getStatusIcon(status) {
|
|
71
|
+
return exports.MEDICAL_HISTORY_STATUS_METADATA[status].icon;
|
|
72
|
+
}
|
|
73
|
+
/**
|
|
74
|
+
* Get status color
|
|
75
|
+
*/
|
|
76
|
+
function getStatusColor(status) {
|
|
77
|
+
return exports.MEDICAL_HISTORY_STATUS_METADATA[status].color;
|
|
78
|
+
}
|
|
79
|
+
/**
|
|
80
|
+
* Get status label (short or long)
|
|
81
|
+
*/
|
|
82
|
+
function getStatusLabel(status, locale = 'us-EN', format = 'short') {
|
|
83
|
+
return exports.MEDICAL_HISTORY_STATUS_METADATA[status].label[format][locale];
|
|
84
|
+
}
|
|
85
|
+
/**
|
|
86
|
+
* Get status description
|
|
87
|
+
*/
|
|
88
|
+
function getStatusDescription(status, locale = 'us-EN') {
|
|
89
|
+
return exports.MEDICAL_HISTORY_STATUS_METADATA[status].description[locale];
|
|
90
|
+
}
|
|
91
|
+
/**
|
|
92
|
+
* Get all available statuses
|
|
93
|
+
*/
|
|
94
|
+
function getAllMedicalHistoryStatuses() {
|
|
95
|
+
return Object.values(MedicalHistoryStatus);
|
|
96
|
+
}
|
|
97
|
+
/**
|
|
98
|
+
* Check if a value is a valid MedicalHistoryStatus
|
|
99
|
+
*/
|
|
100
|
+
function isValidMedicalHistoryStatus(value) {
|
|
101
|
+
return Object.values(MedicalHistoryStatus).includes(value);
|
|
102
|
+
}
|
|
103
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWVkaWNhbC1oaXN0b3J5LXN0YXR1cy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9zdGF0dXMvbWVkaWNhbC1oaXN0b3J5LXN0YXR1cy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiO0FBQUE7OztHQUdHOzs7QUFzREgsOENBRUM7QUFLRCxzQ0FFQztBQUtELHdDQUVDO0FBS0Qsd0NBTUM7QUFLRCxvREFFQztBQUtELG9FQUVDO0FBS0Qsa0VBRUM7QUFsR0QsSUFBWSxvQkFHWDtBQUhELFdBQVksb0JBQW9CO0lBQzlCLDJDQUFtQixDQUFBO0lBQ25CLDJDQUFtQixDQUFBO0FBQ3JCLENBQUMsRUFIVyxvQkFBb0Isb0NBQXBCLG9CQUFvQixRQUcvQjtBQUVEOztHQUVHO0FBQ1UsUUFBQSwrQkFBK0IsR0FBaUQ7SUFDM0YsQ0FBQyxvQkFBb0IsQ0FBQyxPQUFPLENBQUMsRUFBRTtRQUM5QixJQUFJLEVBQUUsY0FBYztRQUNwQixLQUFLLEVBQUUsU0FBUyxFQUFFLFFBQVE7UUFDMUIsS0FBSyxFQUFFO1lBQ0wsS0FBSyxFQUFFO2dCQUNMLE9BQU8sRUFBRSxRQUFRO2dCQUNqQixPQUFPLEVBQUUsT0FBTzthQUNqQjtZQUNELElBQUksRUFBRTtnQkFDSixPQUFPLEVBQUUsa0JBQWtCO2dCQUMzQixPQUFPLEVBQUUsb0JBQW9CO2FBQzlCO1NBQ0Y7UUFDRCxXQUFXLEVBQUU7WUFDWCxPQUFPLEVBQUUseURBQXlEO1lBQ2xFLE9BQU8sRUFBRSwwREFBMEQ7U0FDcEU7S0FDRjtJQUNELENBQUMsb0JBQW9CLENBQUMsT0FBTyxDQUFDLEVBQUU7UUFDOUIsSUFBSSxFQUFFLG1CQUFtQjtRQUN6QixLQUFLLEVBQUUsU0FBUyxFQUFFLE9BQU87UUFDekIsS0FBSyxFQUFFO1lBQ0wsS0FBSyxFQUFFO2dCQUNMLE9BQU8sRUFBRSxTQUFTO2dCQUNsQixPQUFPLEVBQUUsUUFBUTthQUNsQjtZQUNELElBQUksRUFBRTtnQkFDSixPQUFPLEVBQUUsZ0JBQWdCO2dCQUN6QixPQUFPLEVBQUUsdUJBQXVCO2FBQ2pDO1NBQ0Y7UUFDRCxXQUFXLEVBQUU7WUFDWCxPQUFPLEVBQUUsNkRBQTZEO1lBQ3RFLE9BQU8sRUFBRSxvREFBb0Q7U0FDOUQ7S0FDRjtDQUNGLENBQUM7QUFFRjs7R0FFRztBQUNILFNBQWdCLGlCQUFpQixDQUFDLE1BQTRCO0lBQzVELE9BQU8sdUNBQStCLENBQUMsTUFBTSxDQUFDLENBQUM7QUFDakQsQ0FBQztBQUVEOztHQUVHO0FBQ0gsU0FBZ0IsYUFBYSxDQUFDLE1BQTRCO0lBQ3hELE9BQU8sdUNBQStCLENBQUMsTUFBTSxDQUFDLENBQUMsSUFBSSxDQUFDO0FBQ3RELENBQUM7QUFFRDs7R0FFRztBQUNILFNBQWdCLGNBQWMsQ0FBQyxNQUE0QjtJQUN6RCxPQUFPLHVDQUErQixDQUFDLE1BQU0sQ0FBQyxDQUFDLEtBQUssQ0FBQztBQUN2RCxDQUFDO0FBRUQ7O0dBRUc7QUFDSCxTQUFnQixjQUFjLENBQzVCLE1BQTRCLEVBQzVCLFNBQWlCLE9BQU8sRUFDeEIsU0FBMkIsT0FBTztJQUVsQyxPQUFPLHVDQUErQixDQUFDLE1BQU0sQ0FBQyxDQUFDLEtBQUssQ0FBQyxNQUFNLENBQUMsQ0FBQyxNQUFNLENBQUMsQ0FBQztBQUN2RSxDQUFDO0FBRUQ7O0dBRUc7QUFDSCxTQUFnQixvQkFBb0IsQ0FBQyxNQUE0QixFQUFFLFNBQWlCLE9BQU87SUFDekYsT0FBTyx1Q0FBK0IsQ0FBQyxNQUFNLENBQUMsQ0FBQyxXQUFXLENBQUMsTUFBTSxDQUFDLENBQUM7QUFDckUsQ0FBQztBQUVEOztHQUVHO0FBQ0gsU0FBZ0IsNEJBQTRCO0lBQzFDLE9BQU8sTUFBTSxDQUFDLE1BQU0sQ0FBQyxvQkFBb0IsQ0FBQyxDQUFDO0FBQzdDLENBQUM7QUFFRDs7R0FFRztBQUNILFNBQWdCLDJCQUEyQixDQUFDLEtBQWE7SUFDdkQsT0FBTyxNQUFNLENBQUMsTUFBTSxDQUFDLG9CQUFvQixDQUFDLENBQUMsUUFBUSxDQUFDLEtBQTZCLENBQUMsQ0FBQztBQUNyRixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBNZWRpY2FsIEhpc3RvcnkgU3RhdHVzIGVudW1lcmF0aW9uIGFuZCBtZXRhZGF0YVxuICogRGVmaW5lcyB0aGUgc3RhdHVzIG9mIG1lZGljYWwgaGlzdG9yeSByZWNvcmRzIChhY3RpdmUgb3IgZXhwaXJlZClcbiAqL1xuXG5pbXBvcnQgdHlwZSB7IFN0YXR1c01ldGFkYXRhLCBMb2NhbGUgfSBmcm9tICcuL3R5cGVzJztcblxuZXhwb3J0IGVudW0gTWVkaWNhbEhpc3RvcnlTdGF0dXMge1xuICBDVVJSRU5UID0gJ2N1cnJlbnQnLFxuICBFWFBJUkVEID0gJ2V4cGlyZWQnLFxufVxuXG4vKipcbiAqIE1lZGljYWwgSGlzdG9yeSBTdGF0dXMgbWV0YWRhdGEgY29uZmlndXJhdGlvblxuICovXG5leHBvcnQgY29uc3QgTUVESUNBTF9ISVNUT1JZX1NUQVRVU19NRVRBREFUQTogUmVjb3JkPE1lZGljYWxIaXN0b3J5U3RhdHVzLCBTdGF0dXNNZXRhZGF0YT4gPSB7XG4gIFtNZWRpY2FsSGlzdG9yeVN0YXR1cy5DVVJSRU5UXToge1xuICAgIGljb246ICdjaGVja19jaXJjbGUnLFxuICAgIGNvbG9yOiAnIzRDQUY1MCcsIC8vIEdyZWVuXG4gICAgbGFiZWw6IHtcbiAgICAgIHNob3J0OiB7XG4gICAgICAgICd1cy1FTic6ICdBY3RpdmUnLFxuICAgICAgICAnZnItRlInOiAnQWN0aWYnLFxuICAgICAgfSxcbiAgICAgIGxvbmc6IHtcbiAgICAgICAgJ3VzLUVOJzogJ0N1cnJlbnRseSBBY3RpdmUnLFxuICAgICAgICAnZnItRlInOiAnQWN0dWVsbGVtZW50IGFjdGlmJyxcbiAgICAgIH0sXG4gICAgfSxcbiAgICBkZXNjcmlwdGlvbjoge1xuICAgICAgJ3VzLUVOJzogJ01lZGljYWwgaGlzdG9yeSByZWNvcmQgaXMgY3VycmVudGx5IGFjdGl2ZSBhbmQgcmVsZXZhbnQnLFxuICAgICAgJ2ZyLUZSJzogXCJMJ2hpc3RvcmlxdWUgbcOpZGljYWwgZXN0IGFjdHVlbGxlbWVudCBhY3RpZiBldCBwZXJ0aW5lbnRcIixcbiAgICB9LFxuICB9LFxuICBbTWVkaWNhbEhpc3RvcnlTdGF0dXMuRVhQSVJFRF06IHtcbiAgICBpY29uOiAnZG9fbm90X2Rpc3R1cmJfb24nLFxuICAgIGNvbG9yOiAnIzgwODA4MCcsIC8vIEdyYXlcbiAgICBsYWJlbDoge1xuICAgICAgc2hvcnQ6IHtcbiAgICAgICAgJ3VzLUVOJzogJ0V4cGlyZWQnLFxuICAgICAgICAnZnItRlInOiAnRXhwaXLDqScsXG4gICAgICB9LFxuICAgICAgbG9uZzoge1xuICAgICAgICAndXMtRU4nOiAnRXhwaXJlZCBSZWNvcmQnLFxuICAgICAgICAnZnItRlInOiAnRW5yZWdpc3RyZW1lbnQgZXhwaXLDqScsXG4gICAgICB9LFxuICAgIH0sXG4gICAgZGVzY3JpcHRpb246IHtcbiAgICAgICd1cy1FTic6ICdNZWRpY2FsIGhpc3RvcnkgcmVjb3JkIGhhcyBleHBpcmVkIGFuZCBpcyBubyBsb25nZXIgY3VycmVudCcsXG4gICAgICAnZnItRlInOiBcIkwnaGlzdG9yaXF1ZSBtw6lkaWNhbCBhIGV4cGlyw6kgZXQgbidlc3QgcGx1cyBhY3R1ZWxcIixcbiAgICB9LFxuICB9LFxufTtcblxuLyoqXG4gKiBHZXQgc3RhdHVzIG1ldGFkYXRhXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBnZXRTdGF0dXNNZXRhZGF0YShzdGF0dXM6IE1lZGljYWxIaXN0b3J5U3RhdHVzKTogU3RhdHVzTWV0YWRhdGEge1xuICByZXR1cm4gTUVESUNBTF9ISVNUT1JZX1NUQVRVU19NRVRBREFUQVtzdGF0dXNdO1xufVxuXG4vKipcbiAqIEdldCBzdGF0dXMgaWNvblxuICovXG5leHBvcnQgZnVuY3Rpb24gZ2V0U3RhdHVzSWNvbihzdGF0dXM6IE1lZGljYWxIaXN0b3J5U3RhdHVzKTogc3RyaW5nIHtcbiAgcmV0dXJuIE1FRElDQUxfSElTVE9SWV9TVEFUVVNfTUVUQURBVEFbc3RhdHVzXS5pY29uO1xufVxuXG4vKipcbiAqIEdldCBzdGF0dXMgY29sb3JcbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIGdldFN0YXR1c0NvbG9yKHN0YXR1czogTWVkaWNhbEhpc3RvcnlTdGF0dXMpOiBzdHJpbmcge1xuICByZXR1cm4gTUVESUNBTF9ISVNUT1JZX1NUQVRVU19NRVRBREFUQVtzdGF0dXNdLmNvbG9yO1xufVxuXG4vKipcbiAqIEdldCBzdGF0dXMgbGFiZWwgKHNob3J0IG9yIGxvbmcpXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBnZXRTdGF0dXNMYWJlbChcbiAgc3RhdHVzOiBNZWRpY2FsSGlzdG9yeVN0YXR1cyxcbiAgbG9jYWxlOiBMb2NhbGUgPSAndXMtRU4nLFxuICBmb3JtYXQ6ICdzaG9ydCcgfCAnbG9uZycgPSAnc2hvcnQnLFxuKTogc3RyaW5nIHtcbiAgcmV0dXJuIE1FRElDQUxfSElTVE9SWV9TVEFUVVNfTUVUQURBVEFbc3RhdHVzXS5sYWJlbFtmb3JtYXRdW2xvY2FsZV07XG59XG5cbi8qKlxuICogR2V0IHN0YXR1cyBkZXNjcmlwdGlvblxuICovXG5leHBvcnQgZnVuY3Rpb24gZ2V0U3RhdHVzRGVzY3JpcHRpb24oc3RhdHVzOiBNZWRpY2FsSGlzdG9yeVN0YXR1cywgbG9jYWxlOiBMb2NhbGUgPSAndXMtRU4nKTogc3RyaW5nIHtcbiAgcmV0dXJuIE1FRElDQUxfSElTVE9SWV9TVEFUVVNfTUVUQURBVEFbc3RhdHVzXS5kZXNjcmlwdGlvbltsb2NhbGVdO1xufVxuXG4vKipcbiAqIEdldCBhbGwgYXZhaWxhYmxlIHN0YXR1c2VzXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBnZXRBbGxNZWRpY2FsSGlzdG9yeVN0YXR1c2VzKCk6IE1lZGljYWxIaXN0b3J5U3RhdHVzW10ge1xuICByZXR1cm4gT2JqZWN0LnZhbHVlcyhNZWRpY2FsSGlzdG9yeVN0YXR1cyk7XG59XG5cbi8qKlxuICogQ2hlY2sgaWYgYSB2YWx1ZSBpcyBhIHZhbGlkIE1lZGljYWxIaXN0b3J5U3RhdHVzXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBpc1ZhbGlkTWVkaWNhbEhpc3RvcnlTdGF0dXModmFsdWU6IHN0cmluZyk6IHZhbHVlIGlzIE1lZGljYWxIaXN0b3J5U3RhdHVzIHtcbiAgcmV0dXJuIE9iamVjdC52YWx1ZXMoTWVkaWNhbEhpc3RvcnlTdGF0dXMpLmluY2x1ZGVzKHZhbHVlIGFzIE1lZGljYWxIaXN0b3J5U3RhdHVzKTtcbn1cbiJdfQ==
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
/**
|
|
2
2
|
* Medical Service Status enumeration and metadata
|
|
3
3
|
*/
|
|
4
|
-
import type { Locale } from '
|
|
4
|
+
import type { StatusMetadata, Locale } from './types';
|
|
5
5
|
export declare enum MedicalServiceStatus {
|
|
6
6
|
PENDING = "pending",
|
|
7
7
|
IN_PROGRESS = "in_progress",
|
|
@@ -9,27 +9,6 @@ export declare enum MedicalServiceStatus {
|
|
|
9
9
|
CANCELED = "canceled",
|
|
10
10
|
COMPLETED = "completed"
|
|
11
11
|
}
|
|
12
|
-
/**
|
|
13
|
-
* Status metadata including icons, colors, and translations
|
|
14
|
-
*/
|
|
15
|
-
export interface StatusMetadata {
|
|
16
|
-
icon: string;
|
|
17
|
-
color: string;
|
|
18
|
-
label: {
|
|
19
|
-
short: {
|
|
20
|
-
'us-EN': string;
|
|
21
|
-
'fr-FR': string;
|
|
22
|
-
};
|
|
23
|
-
long: {
|
|
24
|
-
'us-EN': string;
|
|
25
|
-
'fr-FR': string;
|
|
26
|
-
};
|
|
27
|
-
};
|
|
28
|
-
description: {
|
|
29
|
-
'us-EN': string;
|
|
30
|
-
'fr-FR': string;
|
|
31
|
-
};
|
|
32
|
-
}
|
|
33
12
|
/**
|
|
34
13
|
* Medical Service Status metadata configuration
|
|
35
14
|
*/
|
|
@@ -44,7 +44,7 @@ exports.MEDICAL_SERVICE_STATUS_METADATA = {
|
|
|
44
44
|
},
|
|
45
45
|
},
|
|
46
46
|
[MedicalServiceStatus.ON_WAITING_ROOM]: {
|
|
47
|
-
icon: '
|
|
47
|
+
icon: 'event_busy',
|
|
48
48
|
color: '#FF9800', // Orange
|
|
49
49
|
label: {
|
|
50
50
|
short: {
|
|
@@ -188,4 +188,4 @@ function isValidTransition(from, to) {
|
|
|
188
188
|
function getAllowedTransitions(status) {
|
|
189
189
|
return exports.MEDICAL_SERVICE_STATUS_TRANSITIONS[status] ?? [];
|
|
190
190
|
}
|
|
191
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"medical-service-status.js","sourceRoot":"","sources":["../../src/status/medical-service-status.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * Medical Service Status enumeration and metadata\n */\n\nimport type { Locale } from '../operations/labels';\n\nexport enum MedicalServiceStatus {\n  PENDING = 'pending',\n  IN_PROGRESS = 'in_progress',\n  ON_WAITING_ROOM = 'on_waiting_room',\n  CANCELED = 'canceled',\n  COMPLETED = 'completed',\n}\n\n/**\n * Status metadata including icons, colors, and translations\n */\nexport interface StatusMetadata {\n  icon: string; // Material icon name\n  color: string; // Hex color or CSS color name\n  label: {\n    short: {\n      'us-EN': string;\n      'fr-FR': string;\n    };\n    long: {\n      'us-EN': string;\n      'fr-FR': string;\n    };\n  };\n  description: {\n    'us-EN': string;\n    'fr-FR': string;\n  };\n}\n\n/**\n * Medical Service Status metadata configuration\n */\nexport const MEDICAL_SERVICE_STATUS_METADATA: Record<MedicalServiceStatus, StatusMetadata> = {\n  [MedicalServiceStatus.PENDING]: {\n    icon: 'schedule',\n    color: '#9E9E9E', // Gray\n    label: {\n      short: {\n        'us-EN': 'Pending',\n        'fr-FR': 'En attente',\n      },\n      long: {\n        'us-EN': 'Pending Service',\n        'fr-FR': 'Service en attente',\n      },\n    },\n    description: {\n      'us-EN': 'The medical service is scheduled and waiting to begin',\n      'fr-FR': 'Le service médical est planifié et en attente de démarrage',\n    },\n  },\n  [MedicalServiceStatus.ON_WAITING_ROOM]: {\n    icon: 'person_pin_circle',\n    color: '#FF9800', // Orange\n    label: {\n      short: {\n        'us-EN': 'Waiting',\n        'fr-FR': 'En attente',\n      },\n      long: {\n        'us-EN': 'In Waiting Room',\n        'fr-FR': \"Dans la salle d'attente\",\n      },\n    },\n    description: {\n      'us-EN': 'Patient has checked in and is waiting in the waiting room',\n      'fr-FR': \"Le patient s'est enregistré et attend dans la salle d'attente\",\n    },\n  },\n  [MedicalServiceStatus.IN_PROGRESS]: {\n    icon: 'medical_services',\n    color: '#2196F3', // Blue\n    label: {\n      short: {\n        'us-EN': 'In Progress',\n        'fr-FR': 'En cours',\n      },\n      long: {\n        'us-EN': 'Service In Progress',\n        'fr-FR': 'Service en cours',\n      },\n    },\n    description: {\n      'us-EN': 'The medical service consultation is currently in progress',\n      'fr-FR': 'La consultation du service médical est actuellement en cours',\n    },\n  },\n  [MedicalServiceStatus.COMPLETED]: {\n    icon: 'check_circle',\n    color: '#4CAF50', // Green\n    label: {\n      short: {\n        'us-EN': 'Completed',\n        'fr-FR': 'Terminé',\n      },\n      long: {\n        'us-EN': 'Service Completed',\n        'fr-FR': 'Service terminé',\n      },\n    },\n    description: {\n      'us-EN': 'The medical service has been successfully completed',\n      'fr-FR': 'Le service médical a été terminé avec succès',\n    },\n  },\n  [MedicalServiceStatus.CANCELED]: {\n    icon: 'cancel',\n    color: '#F44336', // Red\n    label: {\n      short: {\n        'us-EN': 'Canceled',\n        'fr-FR': 'Annulé',\n      },\n      long: {\n        'us-EN': 'Service Canceled',\n        'fr-FR': 'Service annulé',\n      },\n    },\n    description: {\n      'us-EN': 'The medical service has been canceled and will not proceed',\n      'fr-FR': 'Le service médical a été annulé et ne sera pas effectué',\n    },\n  },\n};\n\n/**\n * Get status metadata\n */\nexport function getStatusMetadata(status: MedicalServiceStatus): StatusMetadata {\n  return MEDICAL_SERVICE_STATUS_METADATA[status];\n}\n\n/**\n * Get status icon\n */\nexport function getStatusIcon(status: MedicalServiceStatus): string {\n  return MEDICAL_SERVICE_STATUS_METADATA[status].icon;\n}\n\n/**\n * Get status color\n */\nexport function getStatusColor(status: MedicalServiceStatus): string {\n  return MEDICAL_SERVICE_STATUS_METADATA[status].color;\n}\n\n/**\n * Get status label (short or long)\n */\nexport function getStatusLabel(\n  status: MedicalServiceStatus,\n  locale: Locale = 'us-EN',\n  format: 'short' | 'long' = 'short',\n): string {\n  return MEDICAL_SERVICE_STATUS_METADATA[status].label[format][locale];\n}\n\n/**\n * Get status description\n */\nexport function getStatusDescription(status: MedicalServiceStatus, locale: Locale = 'us-EN'): string {\n  return MEDICAL_SERVICE_STATUS_METADATA[status].description[locale];\n}\n\n/**\n * Get all available statuses\n */\nexport function getAllMedicalServiceStatuses(): MedicalServiceStatus[] {\n  return Object.values(MedicalServiceStatus);\n}\n\n/**\n * Check if a value is a valid MedicalServiceStatus\n */\nexport function isValidMedicalServiceStatus(value: string): value is MedicalServiceStatus {\n  return Object.values(MedicalServiceStatus).includes(value as MedicalServiceStatus);\n}\n\n/**\n * Status transition rules (optional: define which transitions are allowed)\n */\nexport const MEDICAL_SERVICE_STATUS_TRANSITIONS: Record<MedicalServiceStatus, MedicalServiceStatus[]> = {\n  [MedicalServiceStatus.PENDING]: [\n    MedicalServiceStatus.ON_WAITING_ROOM,\n    MedicalServiceStatus.IN_PROGRESS,\n    MedicalServiceStatus.CANCELED,\n  ],\n  [MedicalServiceStatus.ON_WAITING_ROOM]: [\n    MedicalServiceStatus.IN_PROGRESS,\n    MedicalServiceStatus.CANCELED,\n    MedicalServiceStatus.PENDING,\n  ],\n  [MedicalServiceStatus.IN_PROGRESS]: [MedicalServiceStatus.COMPLETED, MedicalServiceStatus.CANCELED],\n  [MedicalServiceStatus.COMPLETED]: [MedicalServiceStatus.IN_PROGRESS], // Allow reopening\n  [MedicalServiceStatus.CANCELED]: [MedicalServiceStatus.PENDING], // Allow uncanceling\n};\n\n/**\n * Check if a status transition is valid\n */\nexport function isValidTransition(from: MedicalServiceStatus, to: MedicalServiceStatus): boolean {\n  return MEDICAL_SERVICE_STATUS_TRANSITIONS[from]?.includes(to) ?? false;\n}\n\n/**\n * Get allowed transitions from a status\n */\nexport function getAllowedTransitions(status: MedicalServiceStatus): MedicalServiceStatus[] {\n  return MEDICAL_SERVICE_STATUS_TRANSITIONS[status] ?? [];\n}\n"]}
|
|
191
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"medical-service-status.js","sourceRoot":"","sources":["../../src/status/medical-service-status.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * Medical Service Status enumeration and metadata\n */\n\nimport type { StatusMetadata, Locale } from './types';\n\nexport enum MedicalServiceStatus {\n  PENDING = 'pending',\n  IN_PROGRESS = 'in_progress',\n  ON_WAITING_ROOM = 'on_waiting_room',\n  CANCELED = 'canceled',\n  COMPLETED = 'completed',\n}\n\n/**\n * Medical Service Status metadata configuration\n */\nexport const MEDICAL_SERVICE_STATUS_METADATA: Record<MedicalServiceStatus, StatusMetadata> = {\n  [MedicalServiceStatus.PENDING]: {\n    icon: 'schedule',\n    color: '#9E9E9E', // Gray\n    label: {\n      short: {\n        'us-EN': 'Pending',\n        'fr-FR': 'En attente',\n      },\n      long: {\n        'us-EN': 'Pending Service',\n        'fr-FR': 'Service en attente',\n      },\n    },\n    description: {\n      'us-EN': 'The medical service is scheduled and waiting to begin',\n      'fr-FR': 'Le service médical est planifié et en attente de démarrage',\n    },\n  },\n  [MedicalServiceStatus.ON_WAITING_ROOM]: {\n    icon: 'event_busy',\n    color: '#FF9800', // Orange\n    label: {\n      short: {\n        'us-EN': 'Waiting',\n        'fr-FR': 'En attente',\n      },\n      long: {\n        'us-EN': 'In Waiting Room',\n        'fr-FR': \"Dans la salle d'attente\",\n      },\n    },\n    description: {\n      'us-EN': 'Patient has checked in and is waiting in the waiting room',\n      'fr-FR': \"Le patient s'est enregistré et attend dans la salle d'attente\",\n    },\n  },\n  [MedicalServiceStatus.IN_PROGRESS]: {\n    icon: 'medical_services',\n    color: '#2196F3', // Blue\n    label: {\n      short: {\n        'us-EN': 'In Progress',\n        'fr-FR': 'En cours',\n      },\n      long: {\n        'us-EN': 'Service In Progress',\n        'fr-FR': 'Service en cours',\n      },\n    },\n    description: {\n      'us-EN': 'The medical service consultation is currently in progress',\n      'fr-FR': 'La consultation du service médical est actuellement en cours',\n    },\n  },\n  [MedicalServiceStatus.COMPLETED]: {\n    icon: 'check_circle',\n    color: '#4CAF50', // Green\n    label: {\n      short: {\n        'us-EN': 'Completed',\n        'fr-FR': 'Terminé',\n      },\n      long: {\n        'us-EN': 'Service Completed',\n        'fr-FR': 'Service terminé',\n      },\n    },\n    description: {\n      'us-EN': 'The medical service has been successfully completed',\n      'fr-FR': 'Le service médical a été terminé avec succès',\n    },\n  },\n  [MedicalServiceStatus.CANCELED]: {\n    icon: 'cancel',\n    color: '#F44336', // Red\n    label: {\n      short: {\n        'us-EN': 'Canceled',\n        'fr-FR': 'Annulé',\n      },\n      long: {\n        'us-EN': 'Service Canceled',\n        'fr-FR': 'Service annulé',\n      },\n    },\n    description: {\n      'us-EN': 'The medical service has been canceled and will not proceed',\n      'fr-FR': 'Le service médical a été annulé et ne sera pas effectué',\n    },\n  },\n};\n\n/**\n * Get status metadata\n */\nexport function getStatusMetadata(status: MedicalServiceStatus): StatusMetadata {\n  return MEDICAL_SERVICE_STATUS_METADATA[status];\n}\n\n/**\n * Get status icon\n */\nexport function getStatusIcon(status: MedicalServiceStatus): string {\n  return MEDICAL_SERVICE_STATUS_METADATA[status].icon;\n}\n\n/**\n * Get status color\n */\nexport function getStatusColor(status: MedicalServiceStatus): string {\n  return MEDICAL_SERVICE_STATUS_METADATA[status].color;\n}\n\n/**\n * Get status label (short or long)\n */\nexport function getStatusLabel(\n  status: MedicalServiceStatus,\n  locale: Locale = 'us-EN',\n  format: 'short' | 'long' = 'short',\n): string {\n  return MEDICAL_SERVICE_STATUS_METADATA[status].label[format][locale];\n}\n\n/**\n * Get status description\n */\nexport function getStatusDescription(status: MedicalServiceStatus, locale: Locale = 'us-EN'): string {\n  return MEDICAL_SERVICE_STATUS_METADATA[status].description[locale];\n}\n\n/**\n * Get all available statuses\n */\nexport function getAllMedicalServiceStatuses(): MedicalServiceStatus[] {\n  return Object.values(MedicalServiceStatus);\n}\n\n/**\n * Check if a value is a valid MedicalServiceStatus\n */\nexport function isValidMedicalServiceStatus(value: string): value is MedicalServiceStatus {\n  return Object.values(MedicalServiceStatus).includes(value as MedicalServiceStatus);\n}\n\n/**\n * Status transition rules (optional: define which transitions are allowed)\n */\nexport const MEDICAL_SERVICE_STATUS_TRANSITIONS: Record<MedicalServiceStatus, MedicalServiceStatus[]> = {\n  [MedicalServiceStatus.PENDING]: [\n    MedicalServiceStatus.ON_WAITING_ROOM,\n    MedicalServiceStatus.IN_PROGRESS,\n    MedicalServiceStatus.CANCELED,\n  ],\n  [MedicalServiceStatus.ON_WAITING_ROOM]: [\n    MedicalServiceStatus.IN_PROGRESS,\n    MedicalServiceStatus.CANCELED,\n    MedicalServiceStatus.PENDING,\n  ],\n  [MedicalServiceStatus.IN_PROGRESS]: [MedicalServiceStatus.COMPLETED, MedicalServiceStatus.CANCELED],\n  [MedicalServiceStatus.COMPLETED]: [MedicalServiceStatus.IN_PROGRESS], // Allow reopening\n  [MedicalServiceStatus.CANCELED]: [MedicalServiceStatus.PENDING], // Allow uncanceling\n};\n\n/**\n * Check if a status transition is valid\n */\nexport function isValidTransition(from: MedicalServiceStatus, to: MedicalServiceStatus): boolean {\n  return MEDICAL_SERVICE_STATUS_TRANSITIONS[from]?.includes(to) ?? false;\n}\n\n/**\n * Get allowed transitions from a status\n */\nexport function getAllowedTransitions(status: MedicalServiceStatus): MedicalServiceStatus[] {\n  return MEDICAL_SERVICE_STATUS_TRANSITIONS[status] ?? [];\n}\n"]}
|
|
@@ -0,0 +1,36 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Shared status types for all status modules
|
|
3
|
+
* Provides common interfaces and types used across status definitions
|
|
4
|
+
*/
|
|
5
|
+
import type { Locale } from '../operations/labels';
|
|
6
|
+
/**
|
|
7
|
+
* Status metadata interface
|
|
8
|
+
* Defines the structure for all status metadata including icons, colors, and translations
|
|
9
|
+
*/
|
|
10
|
+
export interface StatusMetadata {
|
|
11
|
+
icon: string;
|
|
12
|
+
color: string;
|
|
13
|
+
label: {
|
|
14
|
+
short: {
|
|
15
|
+
'us-EN': string;
|
|
16
|
+
'fr-FR': string;
|
|
17
|
+
};
|
|
18
|
+
long: {
|
|
19
|
+
'us-EN': string;
|
|
20
|
+
'fr-FR': string;
|
|
21
|
+
};
|
|
22
|
+
};
|
|
23
|
+
description: {
|
|
24
|
+
'us-EN': string;
|
|
25
|
+
'fr-FR': string;
|
|
26
|
+
};
|
|
27
|
+
}
|
|
28
|
+
/**
|
|
29
|
+
* Generic status configuration type
|
|
30
|
+
* Used to define metadata for any enum-based status
|
|
31
|
+
*/
|
|
32
|
+
export type StatusConfiguration<T extends string | number> = Record<T, StatusMetadata>;
|
|
33
|
+
/**
|
|
34
|
+
* Utility type for locale parameter
|
|
35
|
+
*/
|
|
36
|
+
export type { Locale };
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
/**
|
|
3
|
+
* Shared status types for all status modules
|
|
4
|
+
* Provides common interfaces and types used across status definitions
|
|
5
|
+
*/
|
|
6
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
7
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHlwZXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvc3RhdHVzL3R5cGVzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQTs7O0dBR0ciLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIFNoYXJlZCBzdGF0dXMgdHlwZXMgZm9yIGFsbCBzdGF0dXMgbW9kdWxlc1xuICogUHJvdmlkZXMgY29tbW9uIGludGVyZmFjZXMgYW5kIHR5cGVzIHVzZWQgYWNyb3NzIHN0YXR1cyBkZWZpbml0aW9uc1xuICovXG5cbmltcG9ydCB0eXBlIHsgTG9jYWxlIH0gZnJvbSAnLi4vb3BlcmF0aW9ucy9sYWJlbHMnO1xuXG4vKipcbiAqIFN0YXR1cyBtZXRhZGF0YSBpbnRlcmZhY2VcbiAqIERlZmluZXMgdGhlIHN0cnVjdHVyZSBmb3IgYWxsIHN0YXR1cyBtZXRhZGF0YSBpbmNsdWRpbmcgaWNvbnMsIGNvbG9ycywgYW5kIHRyYW5zbGF0aW9uc1xuICovXG5leHBvcnQgaW50ZXJmYWNlIFN0YXR1c01ldGFkYXRhIHtcbiAgaWNvbjogc3RyaW5nOyAvLyBNYXRlcmlhbCBpY29uIG5hbWVcbiAgY29sb3I6IHN0cmluZzsgLy8gSGV4IGNvbG9yIG9yIENTUyBjb2xvciBuYW1lXG4gIGxhYmVsOiB7XG4gICAgc2hvcnQ6IHtcbiAgICAgICd1cy1FTic6IHN0cmluZztcbiAgICAgICdmci1GUic6IHN0cmluZztcbiAgICB9O1xuICAgIGxvbmc6IHtcbiAgICAgICd1cy1FTic6IHN0cmluZztcbiAgICAgICdmci1GUic6IHN0cmluZztcbiAgICB9O1xuICB9O1xuICBkZXNjcmlwdGlvbjoge1xuICAgICd1cy1FTic6IHN0cmluZztcbiAgICAnZnItRlInOiBzdHJpbmc7XG4gIH07XG59XG5cbi8qKlxuICogR2VuZXJpYyBzdGF0dXMgY29uZmlndXJhdGlvbiB0eXBlXG4gKiBVc2VkIHRvIGRlZmluZSBtZXRhZGF0YSBmb3IgYW55IGVudW0tYmFzZWQgc3RhdHVzXG4gKi9cbmV4cG9ydCB0eXBlIFN0YXR1c0NvbmZpZ3VyYXRpb248VCBleHRlbmRzIHN0cmluZyB8IG51bWJlcj4gPSBSZWNvcmQ8VCwgU3RhdHVzTWV0YWRhdGE+O1xuXG4vKipcbiAqIFV0aWxpdHkgdHlwZSBmb3IgbG9jYWxlIHBhcmFtZXRlclxuICovXG5leHBvcnQgdHlwZSB7IExvY2FsZSB9O1xuIl19
|
|
@@ -0,0 +1,118 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Status utilities for extracting and querying status metadata
|
|
3
|
+
* Provides common functions to work with status configurations
|
|
4
|
+
*/
|
|
5
|
+
import type { AccountLocationStatus } from './account-location-status';
|
|
6
|
+
import type { MedicalHistoryStatus } from './medical-history-status';
|
|
7
|
+
import type { MedicalServiceStatus } from './medical-service-status';
|
|
8
|
+
import type { StatusMetadata, Locale } from './types';
|
|
9
|
+
/**
|
|
10
|
+
* Feature type for status selection
|
|
11
|
+
*/
|
|
12
|
+
export type StatusFeature = 'medicalService' | 'accountLocation' | 'medicalHistory';
|
|
13
|
+
/**
|
|
14
|
+
* Status type mapping for each feature
|
|
15
|
+
*/
|
|
16
|
+
export type StatusTypeMap = {
|
|
17
|
+
medicalService: MedicalServiceStatus;
|
|
18
|
+
accountLocation: AccountLocationStatus;
|
|
19
|
+
medicalHistory: MedicalHistoryStatus;
|
|
20
|
+
};
|
|
21
|
+
/**
|
|
22
|
+
* Get status metadata for a specific feature and status
|
|
23
|
+
* @param feature - The feature name (e.g., 'medicalService', 'accountLocation')
|
|
24
|
+
* @param status - The status value
|
|
25
|
+
* @returns The complete StatusMetadata for the given feature and status
|
|
26
|
+
* @throws Error if feature or status is not found
|
|
27
|
+
*/
|
|
28
|
+
export declare function getStatusMetadataForFeature<T extends StatusFeature>(feature: T, status: StatusTypeMap[T]): StatusMetadata;
|
|
29
|
+
/**
|
|
30
|
+
* Get status icon for a specific feature and status
|
|
31
|
+
* @param feature - The feature name
|
|
32
|
+
* @param status - The status value
|
|
33
|
+
* @returns The Material icon name
|
|
34
|
+
*/
|
|
35
|
+
export declare function getStatusIconForFeature<T extends StatusFeature>(feature: T, status: StatusTypeMap[T]): string;
|
|
36
|
+
/**
|
|
37
|
+
* Get status color for a specific feature and status
|
|
38
|
+
* @param feature - The feature name
|
|
39
|
+
* @param status - The status value
|
|
40
|
+
* @returns The hex color code
|
|
41
|
+
*/
|
|
42
|
+
export declare function getStatusColorForFeature<T extends StatusFeature>(feature: T, status: StatusTypeMap[T]): string;
|
|
43
|
+
/**
|
|
44
|
+
* Get status label for a specific feature and status
|
|
45
|
+
* @param feature - The feature name
|
|
46
|
+
* @param status - The status value
|
|
47
|
+
* @param locale - The language locale (default: 'us-EN')
|
|
48
|
+
* @param format - Label format: 'short' or 'long' (default: 'short')
|
|
49
|
+
* @returns The translated label
|
|
50
|
+
*/
|
|
51
|
+
export declare function getStatusLabelForFeature<T extends StatusFeature>(feature: T, status: StatusTypeMap[T], locale?: Locale, format?: 'short' | 'long'): string;
|
|
52
|
+
/**
|
|
53
|
+
* Get status description for a specific feature and status
|
|
54
|
+
* @param feature - The feature name
|
|
55
|
+
* @param status - The status value
|
|
56
|
+
* @param locale - The language locale (default: 'us-EN')
|
|
57
|
+
* @returns The translated description
|
|
58
|
+
*/
|
|
59
|
+
export declare function getStatusDescriptionForFeature<T extends StatusFeature>(feature: T, status: StatusTypeMap[T], locale?: Locale): string;
|
|
60
|
+
/**
|
|
61
|
+
* Get all metadata for a specific feature
|
|
62
|
+
* @param feature - The feature name
|
|
63
|
+
* @returns Record of all statuses and their metadata for the feature
|
|
64
|
+
*/
|
|
65
|
+
export declare function getAllStatusMetadataForFeature<T extends StatusFeature>(feature: T): Record<StatusTypeMap[T], StatusMetadata>;
|
|
66
|
+
/**
|
|
67
|
+
* Get all statuses for a specific feature
|
|
68
|
+
* @param feature - The feature name
|
|
69
|
+
* @returns Array of all status values for the feature
|
|
70
|
+
*/
|
|
71
|
+
export declare function getAllStatusesForFeature<T extends StatusFeature>(feature: T): StatusTypeMap[T][];
|
|
72
|
+
/**
|
|
73
|
+
* Filter statuses by criteria
|
|
74
|
+
* @param feature - The feature name
|
|
75
|
+
* @param predicate - Function to test each status metadata
|
|
76
|
+
* @returns Array of statuses that match the predicate
|
|
77
|
+
*/
|
|
78
|
+
export declare function filterStatusesByFeature<T extends StatusFeature>(feature: T, predicate: (metadata: StatusMetadata, status: StatusTypeMap[T]) => boolean): StatusTypeMap[T][];
|
|
79
|
+
/**
|
|
80
|
+
* Map statuses to a specific value using a transform function
|
|
81
|
+
* @param feature - The feature name
|
|
82
|
+
* @param transform - Function to transform each status metadata
|
|
83
|
+
* @returns Record of statuses mapped to the transformed values
|
|
84
|
+
*/
|
|
85
|
+
export declare function mapStatusesByFeature<T extends StatusFeature, U>(feature: T, transform: (metadata: StatusMetadata, status: StatusTypeMap[T]) => U): Record<StatusTypeMap[T], U>;
|
|
86
|
+
/**
|
|
87
|
+
* Get status metadata with computed properties
|
|
88
|
+
* @param feature - The feature name
|
|
89
|
+
* @param status - The status value
|
|
90
|
+
* @param locale - The language locale
|
|
91
|
+
* @returns Extended metadata with computed labels and description
|
|
92
|
+
*/
|
|
93
|
+
export interface ExtendedStatusMetadata extends Omit<StatusMetadata, 'description'> {
|
|
94
|
+
shortLabel: string;
|
|
95
|
+
longLabel: string;
|
|
96
|
+
description: string;
|
|
97
|
+
}
|
|
98
|
+
export declare function getExtendedStatusMetadataForFeature<T extends StatusFeature>(feature: T, status: StatusTypeMap[T], locale?: Locale): ExtendedStatusMetadata;
|
|
99
|
+
/**
|
|
100
|
+
* Search statuses by label
|
|
101
|
+
* @param feature - The feature name
|
|
102
|
+
* @param searchTerm - The search term (case-insensitive)
|
|
103
|
+
* @param locale - The language locale
|
|
104
|
+
* @returns Array of statuses matching the search term
|
|
105
|
+
*/
|
|
106
|
+
export declare function searchStatusesByFeature<T extends StatusFeature>(feature: T, searchTerm: string, locale?: Locale): StatusTypeMap[T][];
|
|
107
|
+
/**
|
|
108
|
+
* Get status metadata grouped by color
|
|
109
|
+
* @param feature - The feature name
|
|
110
|
+
* @returns Record of colors mapped to arrays of statuses
|
|
111
|
+
*/
|
|
112
|
+
export declare function groupStatusesByColorForFeature<T extends StatusFeature>(feature: T): Record<string, StatusTypeMap[T][]>;
|
|
113
|
+
/**
|
|
114
|
+
* Get status metadata grouped by icon
|
|
115
|
+
* @param feature - The feature name
|
|
116
|
+
* @returns Record of icons mapped to arrays of statuses
|
|
117
|
+
*/
|
|
118
|
+
export declare function groupStatusesByIconForFeature<T extends StatusFeature>(feature: T): Record<string, StatusTypeMap[T][]>;
|
|
@@ -0,0 +1,197 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
/**
|
|
3
|
+
* Status utilities for extracting and querying status metadata
|
|
4
|
+
* Provides common functions to work with status configurations
|
|
5
|
+
*/
|
|
6
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
7
|
+
exports.getStatusMetadataForFeature = getStatusMetadataForFeature;
|
|
8
|
+
exports.getStatusIconForFeature = getStatusIconForFeature;
|
|
9
|
+
exports.getStatusColorForFeature = getStatusColorForFeature;
|
|
10
|
+
exports.getStatusLabelForFeature = getStatusLabelForFeature;
|
|
11
|
+
exports.getStatusDescriptionForFeature = getStatusDescriptionForFeature;
|
|
12
|
+
exports.getAllStatusMetadataForFeature = getAllStatusMetadataForFeature;
|
|
13
|
+
exports.getAllStatusesForFeature = getAllStatusesForFeature;
|
|
14
|
+
exports.filterStatusesByFeature = filterStatusesByFeature;
|
|
15
|
+
exports.mapStatusesByFeature = mapStatusesByFeature;
|
|
16
|
+
exports.getExtendedStatusMetadataForFeature = getExtendedStatusMetadataForFeature;
|
|
17
|
+
exports.searchStatusesByFeature = searchStatusesByFeature;
|
|
18
|
+
exports.groupStatusesByColorForFeature = groupStatusesByColorForFeature;
|
|
19
|
+
exports.groupStatusesByIconForFeature = groupStatusesByIconForFeature;
|
|
20
|
+
const account_location_status_1 = require("./account-location-status");
|
|
21
|
+
const medical_history_status_1 = require("./medical-history-status");
|
|
22
|
+
const medical_service_status_1 = require("./medical-service-status");
|
|
23
|
+
/**
|
|
24
|
+
* Metadata registry mapping features to their status configurations
|
|
25
|
+
*/
|
|
26
|
+
const METADATA_REGISTRY = {
|
|
27
|
+
medicalService: medical_service_status_1.MEDICAL_SERVICE_STATUS_METADATA,
|
|
28
|
+
accountLocation: account_location_status_1.ACCOUNT_LOCATION_STATUS_METADATA,
|
|
29
|
+
medicalHistory: medical_history_status_1.MEDICAL_HISTORY_STATUS_METADATA,
|
|
30
|
+
};
|
|
31
|
+
/**
|
|
32
|
+
* Get status metadata for a specific feature and status
|
|
33
|
+
* @param feature - The feature name (e.g., 'medicalService', 'accountLocation')
|
|
34
|
+
* @param status - The status value
|
|
35
|
+
* @returns The complete StatusMetadata for the given feature and status
|
|
36
|
+
* @throws Error if feature or status is not found
|
|
37
|
+
*/
|
|
38
|
+
function getStatusMetadataForFeature(feature, status) {
|
|
39
|
+
const registry = METADATA_REGISTRY[feature];
|
|
40
|
+
if (!registry) {
|
|
41
|
+
throw new Error(`Unknown status feature: ${feature}`);
|
|
42
|
+
}
|
|
43
|
+
const metadata = registry[status];
|
|
44
|
+
if (!metadata) {
|
|
45
|
+
throw new Error(`Unknown status for feature ${feature}: ${status}`);
|
|
46
|
+
}
|
|
47
|
+
return metadata;
|
|
48
|
+
}
|
|
49
|
+
/**
|
|
50
|
+
* Get status icon for a specific feature and status
|
|
51
|
+
* @param feature - The feature name
|
|
52
|
+
* @param status - The status value
|
|
53
|
+
* @returns The Material icon name
|
|
54
|
+
*/
|
|
55
|
+
function getStatusIconForFeature(feature, status) {
|
|
56
|
+
return getStatusMetadataForFeature(feature, status).icon;
|
|
57
|
+
}
|
|
58
|
+
/**
|
|
59
|
+
* Get status color for a specific feature and status
|
|
60
|
+
* @param feature - The feature name
|
|
61
|
+
* @param status - The status value
|
|
62
|
+
* @returns The hex color code
|
|
63
|
+
*/
|
|
64
|
+
function getStatusColorForFeature(feature, status) {
|
|
65
|
+
return getStatusMetadataForFeature(feature, status).color;
|
|
66
|
+
}
|
|
67
|
+
/**
|
|
68
|
+
* Get status label for a specific feature and status
|
|
69
|
+
* @param feature - The feature name
|
|
70
|
+
* @param status - The status value
|
|
71
|
+
* @param locale - The language locale (default: 'us-EN')
|
|
72
|
+
* @param format - Label format: 'short' or 'long' (default: 'short')
|
|
73
|
+
* @returns The translated label
|
|
74
|
+
*/
|
|
75
|
+
function getStatusLabelForFeature(feature, status, locale = 'us-EN', format = 'short') {
|
|
76
|
+
const metadata = getStatusMetadataForFeature(feature, status);
|
|
77
|
+
return metadata.label[format][locale];
|
|
78
|
+
}
|
|
79
|
+
/**
|
|
80
|
+
* Get status description for a specific feature and status
|
|
81
|
+
* @param feature - The feature name
|
|
82
|
+
* @param status - The status value
|
|
83
|
+
* @param locale - The language locale (default: 'us-EN')
|
|
84
|
+
* @returns The translated description
|
|
85
|
+
*/
|
|
86
|
+
function getStatusDescriptionForFeature(feature, status, locale = 'us-EN') {
|
|
87
|
+
return getStatusMetadataForFeature(feature, status).description[locale];
|
|
88
|
+
}
|
|
89
|
+
/**
|
|
90
|
+
* Get all metadata for a specific feature
|
|
91
|
+
* @param feature - The feature name
|
|
92
|
+
* @returns Record of all statuses and their metadata for the feature
|
|
93
|
+
*/
|
|
94
|
+
function getAllStatusMetadataForFeature(feature) {
|
|
95
|
+
const registry = METADATA_REGISTRY[feature];
|
|
96
|
+
if (!registry) {
|
|
97
|
+
throw new Error(`Unknown status feature: ${feature}`);
|
|
98
|
+
}
|
|
99
|
+
return registry;
|
|
100
|
+
}
|
|
101
|
+
/**
|
|
102
|
+
* Get all statuses for a specific feature
|
|
103
|
+
* @param feature - The feature name
|
|
104
|
+
* @returns Array of all status values for the feature
|
|
105
|
+
*/
|
|
106
|
+
function getAllStatusesForFeature(feature) {
|
|
107
|
+
const metadata = getAllStatusMetadataForFeature(feature);
|
|
108
|
+
return Object.keys(metadata);
|
|
109
|
+
}
|
|
110
|
+
/**
|
|
111
|
+
* Filter statuses by criteria
|
|
112
|
+
* @param feature - The feature name
|
|
113
|
+
* @param predicate - Function to test each status metadata
|
|
114
|
+
* @returns Array of statuses that match the predicate
|
|
115
|
+
*/
|
|
116
|
+
function filterStatusesByFeature(feature, predicate) {
|
|
117
|
+
const metadata = getAllStatusMetadataForFeature(feature);
|
|
118
|
+
return Object.entries(metadata)
|
|
119
|
+
.filter(([status, meta]) => predicate(meta, status))
|
|
120
|
+
.map(([status]) => status);
|
|
121
|
+
}
|
|
122
|
+
/**
|
|
123
|
+
* Map statuses to a specific value using a transform function
|
|
124
|
+
* @param feature - The feature name
|
|
125
|
+
* @param transform - Function to transform each status metadata
|
|
126
|
+
* @returns Record of statuses mapped to the transformed values
|
|
127
|
+
*/
|
|
128
|
+
function mapStatusesByFeature(feature, transform) {
|
|
129
|
+
const metadata = getAllStatusMetadataForFeature(feature);
|
|
130
|
+
const result = {};
|
|
131
|
+
Object.entries(metadata).forEach(([status, meta]) => {
|
|
132
|
+
result[status] = transform(meta, status);
|
|
133
|
+
});
|
|
134
|
+
return result;
|
|
135
|
+
}
|
|
136
|
+
function getExtendedStatusMetadataForFeature(feature, status, locale = 'us-EN') {
|
|
137
|
+
const metadata = getStatusMetadataForFeature(feature, status);
|
|
138
|
+
return {
|
|
139
|
+
icon: metadata.icon,
|
|
140
|
+
color: metadata.color,
|
|
141
|
+
label: metadata.label,
|
|
142
|
+
shortLabel: metadata.label.short[locale],
|
|
143
|
+
longLabel: metadata.label.long[locale],
|
|
144
|
+
description: metadata.description[locale],
|
|
145
|
+
};
|
|
146
|
+
}
|
|
147
|
+
/**
|
|
148
|
+
* Search statuses by label
|
|
149
|
+
* @param feature - The feature name
|
|
150
|
+
* @param searchTerm - The search term (case-insensitive)
|
|
151
|
+
* @param locale - The language locale
|
|
152
|
+
* @returns Array of statuses matching the search term
|
|
153
|
+
*/
|
|
154
|
+
function searchStatusesByFeature(feature, searchTerm, locale = 'us-EN') {
|
|
155
|
+
const lowerSearch = searchTerm.toLowerCase();
|
|
156
|
+
return filterStatusesByFeature(feature, (metadata) => {
|
|
157
|
+
const shortLabel = metadata.label.short[locale].toLowerCase();
|
|
158
|
+
const longLabel = metadata.label.long[locale].toLowerCase();
|
|
159
|
+
const description = metadata.description[locale].toLowerCase();
|
|
160
|
+
return shortLabel.includes(lowerSearch) || longLabel.includes(lowerSearch) || description.includes(lowerSearch);
|
|
161
|
+
});
|
|
162
|
+
}
|
|
163
|
+
/**
|
|
164
|
+
* Get status metadata grouped by color
|
|
165
|
+
* @param feature - The feature name
|
|
166
|
+
* @returns Record of colors mapped to arrays of statuses
|
|
167
|
+
*/
|
|
168
|
+
function groupStatusesByColorForFeature(feature) {
|
|
169
|
+
const metadata = getAllStatusMetadataForFeature(feature);
|
|
170
|
+
const grouped = {};
|
|
171
|
+
Object.entries(metadata).forEach(([status, meta]) => {
|
|
172
|
+
const metaTyped = meta;
|
|
173
|
+
if (!grouped[metaTyped.color]) {
|
|
174
|
+
grouped[metaTyped.color] = [];
|
|
175
|
+
}
|
|
176
|
+
grouped[metaTyped.color].push(status);
|
|
177
|
+
});
|
|
178
|
+
return grouped;
|
|
179
|
+
}
|
|
180
|
+
/**
|
|
181
|
+
* Get status metadata grouped by icon
|
|
182
|
+
* @param feature - The feature name
|
|
183
|
+
* @returns Record of icons mapped to arrays of statuses
|
|
184
|
+
*/
|
|
185
|
+
function groupStatusesByIconForFeature(feature) {
|
|
186
|
+
const metadata = getAllStatusMetadataForFeature(feature);
|
|
187
|
+
const grouped = {};
|
|
188
|
+
Object.entries(metadata).forEach(([status, meta]) => {
|
|
189
|
+
const metaTyped = meta;
|
|
190
|
+
if (!grouped[metaTyped.icon]) {
|
|
191
|
+
grouped[metaTyped.icon] = [];
|
|
192
|
+
}
|
|
193
|
+
grouped[metaTyped.icon].push(status);
|
|
194
|
+
});
|
|
195
|
+
return grouped;
|
|
196
|
+
}
|
|
197
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"utils.js","sourceRoot":"","sources":["../../src/status/utils.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * Status utilities for extracting and querying status metadata\n * Provides common functions to work with status configurations\n */\n\nimport type { AccountLocationStatus } from './account-location-status';\nimport type { MedicalHistoryStatus } from './medical-history-status';\nimport type { MedicalServiceStatus } from './medical-service-status';\nimport type { StatusMetadata, Locale } from './types';\nimport { ACCOUNT_LOCATION_STATUS_METADATA } from './account-location-status';\nimport { MEDICAL_HISTORY_STATUS_METADATA } from './medical-history-status';\nimport { MEDICAL_SERVICE_STATUS_METADATA } from './medical-service-status';\n\n/**\n * Feature type for status selection\n */\nexport type StatusFeature = 'medicalService' | 'accountLocation' | 'medicalHistory';\n\n/**\n * Status type mapping for each feature\n */\nexport type StatusTypeMap = {\n  medicalService: MedicalServiceStatus;\n  accountLocation: AccountLocationStatus;\n  medicalHistory: MedicalHistoryStatus;\n};\n\n/**\n * Metadata registry mapping features to their status configurations\n */\nconst METADATA_REGISTRY: Record<StatusFeature, Record<string | number, StatusMetadata>> = {\n  medicalService: MEDICAL_SERVICE_STATUS_METADATA,\n  accountLocation: ACCOUNT_LOCATION_STATUS_METADATA,\n  medicalHistory: MEDICAL_HISTORY_STATUS_METADATA,\n};\n\n/**\n * Get status metadata for a specific feature and status\n * @param feature - The feature name (e.g., 'medicalService', 'accountLocation')\n * @param status - The status value\n * @returns The complete StatusMetadata for the given feature and status\n * @throws Error if feature or status is not found\n */\nexport function getStatusMetadataForFeature<T extends StatusFeature>(\n  feature: T,\n  status: StatusTypeMap[T],\n): StatusMetadata {\n  const registry = METADATA_REGISTRY[feature];\n  if (!registry) {\n    throw new Error(`Unknown status feature: ${feature}`);\n  }\n\n  const metadata = registry[status];\n  if (!metadata) {\n    throw new Error(`Unknown status for feature ${feature}: ${status}`);\n  }\n\n  return metadata;\n}\n\n/**\n * Get status icon for a specific feature and status\n * @param feature - The feature name\n * @param status - The status value\n * @returns The Material icon name\n */\nexport function getStatusIconForFeature<T extends StatusFeature>(feature: T, status: StatusTypeMap[T]): string {\n  return getStatusMetadataForFeature(feature, status).icon;\n}\n\n/**\n * Get status color for a specific feature and status\n * @param feature - The feature name\n * @param status - The status value\n * @returns The hex color code\n */\nexport function getStatusColorForFeature<T extends StatusFeature>(feature: T, status: StatusTypeMap[T]): string {\n  return getStatusMetadataForFeature(feature, status).color;\n}\n\n/**\n * Get status label for a specific feature and status\n * @param feature - The feature name\n * @param status - The status value\n * @param locale - The language locale (default: 'us-EN')\n * @param format - Label format: 'short' or 'long' (default: 'short')\n * @returns The translated label\n */\nexport function getStatusLabelForFeature<T extends StatusFeature>(\n  feature: T,\n  status: StatusTypeMap[T],\n  locale: Locale = 'us-EN',\n  format: 'short' | 'long' = 'short',\n): string {\n  const metadata = getStatusMetadataForFeature(feature, status);\n  return metadata.label[format][locale];\n}\n\n/**\n * Get status description for a specific feature and status\n * @param feature - The feature name\n * @param status - The status value\n * @param locale - The language locale (default: 'us-EN')\n * @returns The translated description\n */\nexport function getStatusDescriptionForFeature<T extends StatusFeature>(\n  feature: T,\n  status: StatusTypeMap[T],\n  locale: Locale = 'us-EN',\n): string {\n  return getStatusMetadataForFeature(feature, status).description[locale];\n}\n\n/**\n * Get all metadata for a specific feature\n * @param feature - The feature name\n * @returns Record of all statuses and their metadata for the feature\n */\nexport function getAllStatusMetadataForFeature<T extends StatusFeature>(\n  feature: T,\n): Record<StatusTypeMap[T], StatusMetadata> {\n  const registry = METADATA_REGISTRY[feature];\n  if (!registry) {\n    throw new Error(`Unknown status feature: ${feature}`);\n  }\n  return registry as Record<StatusTypeMap[T], StatusMetadata>;\n}\n\n/**\n * Get all statuses for a specific feature\n * @param feature - The feature name\n * @returns Array of all status values for the feature\n */\nexport function getAllStatusesForFeature<T extends StatusFeature>(feature: T): StatusTypeMap[T][] {\n  const metadata = getAllStatusMetadataForFeature(feature);\n  return Object.keys(metadata) as StatusTypeMap[T][];\n}\n\n/**\n * Filter statuses by criteria\n * @param feature - The feature name\n * @param predicate - Function to test each status metadata\n * @returns Array of statuses that match the predicate\n */\nexport function filterStatusesByFeature<T extends StatusFeature>(\n  feature: T,\n  predicate: (metadata: StatusMetadata, status: StatusTypeMap[T]) => boolean,\n): StatusTypeMap[T][] {\n  const metadata = getAllStatusMetadataForFeature(feature);\n  return Object.entries(metadata)\n    .filter(([status, meta]) => predicate(meta as StatusMetadata, status as StatusTypeMap[T]))\n    .map(([status]) => status as StatusTypeMap[T]);\n}\n\n/**\n * Map statuses to a specific value using a transform function\n * @param feature - The feature name\n * @param transform - Function to transform each status metadata\n * @returns Record of statuses mapped to the transformed values\n */\nexport function mapStatusesByFeature<T extends StatusFeature, U>(\n  feature: T,\n  transform: (metadata: StatusMetadata, status: StatusTypeMap[T]) => U,\n): Record<StatusTypeMap[T], U> {\n  const metadata = getAllStatusMetadataForFeature(feature);\n  const result: Record<string, U> = {};\n\n  Object.entries(metadata).forEach(([status, meta]) => {\n    result[status] = transform(meta as StatusMetadata, status as StatusTypeMap[T]);\n  });\n\n  return result as Record<StatusTypeMap[T], U>;\n}\n\n/**\n * Get status metadata with computed properties\n * @param feature - The feature name\n * @param status - The status value\n * @param locale - The language locale\n * @returns Extended metadata with computed labels and description\n */\nexport interface ExtendedStatusMetadata extends Omit<StatusMetadata, 'description'> {\n  shortLabel: string;\n  longLabel: string;\n  description: string;\n}\n\nexport function getExtendedStatusMetadataForFeature<T extends StatusFeature>(\n  feature: T,\n  status: StatusTypeMap[T],\n  locale: Locale = 'us-EN',\n): ExtendedStatusMetadata {\n  const metadata = getStatusMetadataForFeature(feature, status);\n\n  return {\n    icon: metadata.icon,\n    color: metadata.color,\n    label: metadata.label,\n    shortLabel: metadata.label.short[locale],\n    longLabel: metadata.label.long[locale],\n    description: metadata.description[locale],\n  };\n}\n\n/**\n * Search statuses by label\n * @param feature - The feature name\n * @param searchTerm - The search term (case-insensitive)\n * @param locale - The language locale\n * @returns Array of statuses matching the search term\n */\nexport function searchStatusesByFeature<T extends StatusFeature>(\n  feature: T,\n  searchTerm: string,\n  locale: Locale = 'us-EN',\n): StatusTypeMap[T][] {\n  const lowerSearch = searchTerm.toLowerCase();\n\n  return filterStatusesByFeature(feature, (metadata) => {\n    const shortLabel = metadata.label.short[locale].toLowerCase();\n    const longLabel = metadata.label.long[locale].toLowerCase();\n    const description = metadata.description[locale].toLowerCase();\n\n    return shortLabel.includes(lowerSearch) || longLabel.includes(lowerSearch) || description.includes(lowerSearch);\n  });\n}\n\n/**\n * Get status metadata grouped by color\n * @param feature - The feature name\n * @returns Record of colors mapped to arrays of statuses\n */\nexport function groupStatusesByColorForFeature<T extends StatusFeature>(\n  feature: T,\n): Record<string, StatusTypeMap[T][]> {\n  const metadata = getAllStatusMetadataForFeature(feature);\n  const grouped: Record<string, StatusTypeMap[T][]> = {};\n\n  Object.entries(metadata).forEach(([status, meta]) => {\n    const metaTyped = meta as StatusMetadata;\n    if (!grouped[metaTyped.color]) {\n      grouped[metaTyped.color] = [];\n    }\n    grouped[metaTyped.color].push(status as StatusTypeMap[T]);\n  });\n\n  return grouped;\n}\n\n/**\n * Get status metadata grouped by icon\n * @param feature - The feature name\n * @returns Record of icons mapped to arrays of statuses\n */\nexport function groupStatusesByIconForFeature<T extends StatusFeature>(feature: T): Record<string, StatusTypeMap[T][]> {\n  const metadata = getAllStatusMetadataForFeature(feature);\n  const grouped: Record<string, StatusTypeMap[T][]> = {};\n\n  Object.entries(metadata).forEach(([status, meta]) => {\n    const metaTyped = meta as StatusMetadata;\n    if (!grouped[metaTyped.icon]) {\n      grouped[metaTyped.icon] = [];\n    }\n    grouped[metaTyped.icon].push(status as StatusTypeMap[T]);\n  });\n\n  return grouped;\n}\n"]}
|