@doctorus/common 0.0.17 → 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.
@@ -5,3 +5,4 @@ export * from './types';
5
5
  export * from './medical-service-status';
6
6
  export * as AccountLocationStatus from './account-location-status';
7
7
  export * as MedicalHistoryStatus from './medical-history-status';
8
+ export * from './utils';
@@ -44,4 +44,5 @@ __exportStar(require("./types"), exports);
44
44
  __exportStar(require("./medical-service-status"), exports);
45
45
  exports.AccountLocationStatus = __importStar(require("./account-location-status"));
46
46
  exports.MedicalHistoryStatus = __importStar(require("./medical-history-status"));
47
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvc3RhdHVzL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztBQUFBOztHQUVHO0FBQ0gsMENBQXdCO0FBQ3hCLDJEQUF5QztBQUN6QyxtRkFBbUU7QUFDbkUsaUZBQWlFIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBTdGF0dXMgbW9kdWxlIGV4cG9ydHNcbiAqL1xuZXhwb3J0ICogZnJvbSAnLi90eXBlcyc7XG5leHBvcnQgKiBmcm9tICcuL21lZGljYWwtc2VydmljZS1zdGF0dXMnO1xuZXhwb3J0ICogYXMgQWNjb3VudExvY2F0aW9uU3RhdHVzIGZyb20gJy4vYWNjb3VudC1sb2NhdGlvbi1zdGF0dXMnO1xuZXhwb3J0ICogYXMgTWVkaWNhbEhpc3RvcnlTdGF0dXMgZnJvbSAnLi9tZWRpY2FsLWhpc3Rvcnktc3RhdHVzJztcbiJdfQ==
47
+ __exportStar(require("./utils"), exports);
48
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvc3RhdHVzL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztBQUFBOztHQUVHO0FBQ0gsMENBQXdCO0FBQ3hCLDJEQUF5QztBQUN6QyxtRkFBbUU7QUFDbkUsaUZBQWlFO0FBQ2pFLDBDQUF3QiIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogU3RhdHVzIG1vZHVsZSBleHBvcnRzXG4gKi9cbmV4cG9ydCAqIGZyb20gJy4vdHlwZXMnO1xuZXhwb3J0ICogZnJvbSAnLi9tZWRpY2FsLXNlcnZpY2Utc3RhdHVzJztcbmV4cG9ydCAqIGFzIEFjY291bnRMb2NhdGlvblN0YXR1cyBmcm9tICcuL2FjY291bnQtbG9jYXRpb24tc3RhdHVzJztcbmV4cG9ydCAqIGFzIE1lZGljYWxIaXN0b3J5U3RhdHVzIGZyb20gJy4vbWVkaWNhbC1oaXN0b3J5LXN0YXR1cyc7XG5leHBvcnQgKiBmcm9tICcuL3V0aWxzJztcbiJdfQ==
@@ -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"]}
package/package.json CHANGED
@@ -32,7 +32,7 @@
32
32
  "publishConfig": {
33
33
  "access": "public"
34
34
  },
35
- "version": "0.0.17",
35
+ "version": "0.0.18",
36
36
  "jest": {
37
37
  "coverageProvider": "v8",
38
38
  "testMatch": [