@blackcode_sa/metaestetics-api 1.12.62 → 1.12.64
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/dist/admin/index.d.mts +4 -2
- package/dist/admin/index.d.ts +4 -2
- package/dist/admin/index.js +4 -45
- package/dist/admin/index.mjs +4 -45
- package/dist/backoffice/index.d.mts +86 -1
- package/dist/backoffice/index.d.ts +86 -1
- package/dist/backoffice/index.js +308 -0
- package/dist/backoffice/index.mjs +306 -0
- package/dist/index.d.mts +99 -3
- package/dist/index.d.ts +99 -3
- package/dist/index.js +545 -281
- package/dist/index.mjs +867 -603
- package/package.json +119 -119
- package/src/__mocks__/firstore.ts +10 -10
- package/src/admin/aggregation/README.md +79 -79
- package/src/admin/aggregation/appointment/README.md +128 -128
- package/src/admin/aggregation/appointment/appointment.aggregation.service.ts +1844 -1844
- package/src/admin/aggregation/appointment/index.ts +1 -1
- package/src/admin/aggregation/clinic/README.md +52 -52
- package/src/admin/aggregation/clinic/clinic.aggregation.service.ts +703 -703
- package/src/admin/aggregation/clinic/index.ts +1 -1
- package/src/admin/aggregation/forms/README.md +13 -13
- package/src/admin/aggregation/forms/filled-forms.aggregation.service.ts +322 -322
- package/src/admin/aggregation/forms/index.ts +1 -1
- package/src/admin/aggregation/index.ts +8 -8
- package/src/admin/aggregation/patient/README.md +27 -27
- package/src/admin/aggregation/patient/index.ts +1 -1
- package/src/admin/aggregation/patient/patient.aggregation.service.ts +141 -141
- package/src/admin/aggregation/practitioner/README.md +42 -42
- package/src/admin/aggregation/practitioner/index.ts +1 -1
- package/src/admin/aggregation/practitioner/practitioner.aggregation.service.ts +433 -433
- package/src/admin/aggregation/practitioner-invite/index.ts +1 -1
- package/src/admin/aggregation/practitioner-invite/practitioner-invite.aggregation.service.ts +961 -961
- package/src/admin/aggregation/procedure/README.md +43 -43
- package/src/admin/aggregation/procedure/index.ts +1 -1
- package/src/admin/aggregation/procedure/procedure.aggregation.service.ts +702 -702
- package/src/admin/aggregation/reviews/index.ts +1 -1
- package/src/admin/aggregation/reviews/reviews.aggregation.service.ts +641 -689
- package/src/admin/booking/README.md +125 -125
- package/src/admin/booking/booking.admin.ts +1037 -1037
- package/src/admin/booking/booking.calculator.ts +712 -712
- package/src/admin/booking/booking.types.ts +59 -59
- package/src/admin/booking/index.ts +3 -3
- package/src/admin/booking/timezones-problem.md +185 -185
- package/src/admin/calendar/README.md +7 -7
- package/src/admin/calendar/calendar.admin.service.ts +345 -345
- package/src/admin/calendar/index.ts +1 -1
- package/src/admin/documentation-templates/document-manager.admin.ts +260 -260
- package/src/admin/documentation-templates/index.ts +1 -1
- package/src/admin/free-consultation/free-consultation-utils.admin.ts +148 -148
- package/src/admin/free-consultation/index.ts +1 -1
- package/src/admin/index.ts +75 -75
- package/src/admin/logger/index.ts +78 -78
- package/src/admin/mailing/README.md +95 -95
- package/src/admin/mailing/appointment/appointment.mailing.service.ts +732 -732
- package/src/admin/mailing/appointment/index.ts +1 -1
- package/src/admin/mailing/appointment/templates/patient/appointment-confirmed.html +40 -40
- package/src/admin/mailing/base.mailing.service.ts +208 -208
- package/src/admin/mailing/index.ts +3 -3
- package/src/admin/mailing/practitionerInvite/existing-practitioner-invite.mailing.ts +611 -611
- package/src/admin/mailing/practitionerInvite/index.ts +2 -2
- package/src/admin/mailing/practitionerInvite/practitionerInvite.mailing.ts +395 -395
- package/src/admin/mailing/practitionerInvite/templates/existing-practitioner-invitation.template.ts +155 -155
- package/src/admin/mailing/practitionerInvite/templates/invitation.template.ts +101 -101
- package/src/admin/mailing/practitionerInvite/templates/invite-accepted-notification.template.ts +228 -228
- package/src/admin/mailing/practitionerInvite/templates/invite-rejected-notification.template.ts +242 -242
- package/src/admin/notifications/index.ts +1 -1
- package/src/admin/notifications/notifications.admin.ts +710 -710
- package/src/admin/requirements/README.md +128 -128
- package/src/admin/requirements/index.ts +1 -1
- package/src/admin/requirements/patient-requirements.admin.service.ts +475 -475
- package/src/admin/users/index.ts +1 -1
- package/src/admin/users/user-profile.admin.ts +405 -405
- package/src/backoffice/constants/certification.constants.ts +13 -13
- package/src/backoffice/constants/index.ts +1 -1
- package/src/backoffice/errors/backoffice.errors.ts +181 -181
- package/src/backoffice/errors/index.ts +1 -1
- package/src/backoffice/expo-safe/README.md +26 -26
- package/src/backoffice/expo-safe/index.ts +41 -41
- package/src/backoffice/index.ts +5 -5
- package/src/backoffice/services/FIXES_README.md +102 -102
- package/src/backoffice/services/README.md +40 -40
- package/src/backoffice/services/brand.service.ts +256 -256
- package/src/backoffice/services/category.service.ts +318 -318
- package/src/backoffice/services/constants.service.ts +385 -385
- package/src/backoffice/services/documentation-template.service.ts +202 -202
- package/src/backoffice/services/index.ts +11 -8
- package/src/backoffice/services/migrate-products.ts +116 -116
- package/src/backoffice/services/product.service.ts +553 -553
- package/src/backoffice/services/requirement.service.ts +235 -235
- package/src/backoffice/services/subcategory.service.ts +395 -395
- package/src/backoffice/services/technology.service.ts +1083 -1070
- package/src/backoffice/types/README.md +12 -12
- package/src/backoffice/types/admin-constants.types.ts +69 -69
- package/src/backoffice/types/brand.types.ts +29 -29
- package/src/backoffice/types/category.types.ts +62 -62
- package/src/backoffice/types/documentation-templates.types.ts +28 -28
- package/src/backoffice/types/index.ts +10 -10
- package/src/backoffice/types/procedure-product.types.ts +38 -38
- package/src/backoffice/types/product.types.ts +240 -240
- package/src/backoffice/types/requirement.types.ts +63 -63
- package/src/backoffice/types/static/README.md +18 -18
- package/src/backoffice/types/static/blocking-condition.types.ts +21 -21
- package/src/backoffice/types/static/certification.types.ts +37 -37
- package/src/backoffice/types/static/contraindication.types.ts +19 -19
- package/src/backoffice/types/static/index.ts +6 -6
- package/src/backoffice/types/static/pricing.types.ts +16 -16
- package/src/backoffice/types/static/procedure-family.types.ts +14 -14
- package/src/backoffice/types/static/treatment-benefit.types.ts +22 -22
- package/src/backoffice/types/subcategory.types.ts +34 -34
- package/src/backoffice/types/technology.types.ts +163 -161
- package/src/backoffice/validations/index.ts +1 -1
- package/src/backoffice/validations/schemas.ts +164 -163
- package/src/config/__mocks__/firebase.ts +99 -99
- package/src/config/firebase.ts +78 -78
- package/src/config/index.ts +9 -9
- package/src/errors/auth.error.ts +6 -6
- package/src/errors/auth.errors.ts +200 -200
- package/src/errors/clinic.errors.ts +32 -32
- package/src/errors/firebase.errors.ts +47 -47
- package/src/errors/user.errors.ts +99 -99
- package/src/index.backup.ts +407 -407
- package/src/index.ts +6 -6
- package/src/locales/en.ts +31 -31
- package/src/recommender/admin/index.ts +1 -1
- package/src/recommender/admin/services/recommender.service.admin.ts +5 -5
- package/src/recommender/front/index.ts +1 -1
- package/src/recommender/front/services/onboarding.service.ts +5 -5
- package/src/recommender/front/services/recommender.service.ts +3 -3
- package/src/recommender/index.ts +1 -1
- package/src/services/PATIENTAUTH.MD +197 -197
- package/src/services/README.md +106 -106
- package/src/services/__tests__/auth/auth.mock.test.ts +17 -17
- package/src/services/__tests__/auth/auth.setup.ts +293 -293
- package/src/services/__tests__/auth.service.test.ts +346 -346
- package/src/services/__tests__/base.service.test.ts +77 -77
- package/src/services/__tests__/user.service.test.ts +528 -528
- package/src/services/appointment/README.md +17 -17
- package/src/services/appointment/appointment.service.ts +2505 -2082
- package/src/services/appointment/index.ts +1 -1
- package/src/services/appointment/utils/appointment.utils.ts +552 -552
- package/src/services/appointment/utils/extended-procedure.utils.ts +314 -314
- package/src/services/appointment/utils/form-initialization.utils.ts +225 -225
- package/src/services/appointment/utils/recommended-procedure.utils.ts +195 -195
- package/src/services/appointment/utils/zone-management.utils.ts +353 -353
- package/src/services/appointment/utils/zone-photo.utils.ts +152 -152
- package/src/services/auth/auth.service.ts +989 -989
- package/src/services/auth/auth.v2.service.ts +961 -961
- package/src/services/auth/index.ts +7 -7
- package/src/services/auth/utils/error.utils.ts +90 -90
- package/src/services/auth/utils/firebase.utils.ts +49 -49
- package/src/services/auth/utils/index.ts +21 -21
- package/src/services/auth/utils/practitioner.utils.ts +125 -125
- package/src/services/base.service.ts +41 -41
- package/src/services/calendar/calendar.service.ts +1077 -1077
- package/src/services/calendar/calendar.v2.service.ts +1683 -1683
- package/src/services/calendar/calendar.v3.service.ts +313 -313
- package/src/services/calendar/externalCalendar.service.ts +178 -178
- package/src/services/calendar/index.ts +5 -5
- package/src/services/calendar/synced-calendars.service.ts +743 -743
- package/src/services/calendar/utils/appointment.utils.ts +265 -265
- package/src/services/calendar/utils/calendar-event.utils.ts +646 -646
- package/src/services/calendar/utils/clinic.utils.ts +237 -237
- package/src/services/calendar/utils/docs.utils.ts +157 -157
- package/src/services/calendar/utils/google-calendar.utils.ts +697 -697
- package/src/services/calendar/utils/index.ts +8 -8
- package/src/services/calendar/utils/patient.utils.ts +198 -198
- package/src/services/calendar/utils/practitioner.utils.ts +221 -221
- package/src/services/calendar/utils/synced-calendar.utils.ts +472 -472
- package/src/services/clinic/README.md +204 -204
- package/src/services/clinic/__tests__/clinic-admin.service.test.ts +287 -287
- package/src/services/clinic/__tests__/clinic-group.service.test.ts +352 -352
- package/src/services/clinic/__tests__/clinic.service.test.ts +354 -354
- package/src/services/clinic/billing-transactions.service.ts +217 -217
- package/src/services/clinic/clinic-admin.service.ts +202 -202
- package/src/services/clinic/clinic-group.service.ts +310 -310
- package/src/services/clinic/clinic.service.ts +708 -708
- package/src/services/clinic/index.ts +5 -5
- package/src/services/clinic/practitioner-invite.service.ts +519 -519
- package/src/services/clinic/utils/admin.utils.ts +551 -551
- package/src/services/clinic/utils/clinic-group.utils.ts +646 -646
- package/src/services/clinic/utils/clinic.utils.ts +949 -949
- package/src/services/clinic/utils/filter.utils.d.ts +23 -23
- package/src/services/clinic/utils/filter.utils.ts +446 -446
- package/src/services/clinic/utils/index.ts +11 -11
- package/src/services/clinic/utils/photos.utils.ts +188 -188
- package/src/services/clinic/utils/search.utils.ts +84 -84
- package/src/services/clinic/utils/tag.utils.ts +124 -124
- package/src/services/documentation-templates/documentation-template.service.ts +537 -537
- package/src/services/documentation-templates/filled-document.service.ts +587 -587
- package/src/services/documentation-templates/index.ts +2 -2
- package/src/services/index.ts +13 -13
- package/src/services/media/index.ts +1 -1
- package/src/services/media/media.service.ts +418 -418
- package/src/services/notifications/__tests__/notification.service.test.ts +242 -242
- package/src/services/notifications/index.ts +1 -1
- package/src/services/notifications/notification.service.ts +215 -215
- package/src/services/patient/README.md +48 -48
- package/src/services/patient/To-Do.md +43 -43
- package/src/services/patient/__tests__/patient.service.test.ts +294 -294
- package/src/services/patient/index.ts +2 -2
- package/src/services/patient/patient.service.ts +883 -883
- package/src/services/patient/patientRequirements.service.ts +285 -285
- package/src/services/patient/utils/aesthetic-analysis.utils.ts +176 -176
- package/src/services/patient/utils/clinic.utils.ts +80 -80
- package/src/services/patient/utils/docs.utils.ts +142 -142
- package/src/services/patient/utils/index.ts +9 -9
- package/src/services/patient/utils/location.utils.ts +126 -126
- package/src/services/patient/utils/medical-stuff.utils.ts +143 -143
- package/src/services/patient/utils/medical.utils.ts +458 -458
- package/src/services/patient/utils/practitioner.utils.ts +260 -260
- package/src/services/patient/utils/profile.utils.ts +510 -510
- package/src/services/patient/utils/sensitive.utils.ts +260 -260
- package/src/services/patient/utils/token.utils.ts +211 -211
- package/src/services/practitioner/README.md +145 -145
- package/src/services/practitioner/index.ts +1 -1
- package/src/services/practitioner/practitioner.service.ts +1742 -1742
- package/src/services/procedure/README.md +163 -163
- package/src/services/procedure/index.ts +1 -1
- package/src/services/procedure/procedure.service.ts +1682 -1682
- package/src/services/reviews/index.ts +1 -1
- package/src/services/reviews/reviews.service.ts +636 -683
- package/src/services/user/index.ts +1 -1
- package/src/services/user/user.service.ts +489 -489
- package/src/services/user/user.v2.service.ts +466 -466
- package/src/types/appointment/index.ts +481 -453
- package/src/types/calendar/index.ts +258 -258
- package/src/types/calendar/synced-calendar.types.ts +66 -66
- package/src/types/clinic/index.ts +489 -489
- package/src/types/clinic/practitioner-invite.types.ts +91 -91
- package/src/types/clinic/preferences.types.ts +159 -159
- package/src/types/clinic/to-do +3 -3
- package/src/types/documentation-templates/index.ts +308 -308
- package/src/types/index.ts +44 -44
- package/src/types/notifications/README.md +77 -77
- package/src/types/notifications/index.ts +265 -265
- package/src/types/patient/aesthetic-analysis.types.ts +66 -66
- package/src/types/patient/allergies.ts +58 -58
- package/src/types/patient/index.ts +275 -273
- package/src/types/patient/medical-info.types.ts +152 -152
- package/src/types/patient/patient-requirements.ts +92 -92
- package/src/types/patient/token.types.ts +61 -61
- package/src/types/practitioner/index.ts +206 -206
- package/src/types/procedure/index.ts +181 -181
- package/src/types/profile/index.ts +39 -39
- package/src/types/reviews/index.ts +130 -132
- package/src/types/tz-lookup.d.ts +4 -4
- package/src/types/user/index.ts +38 -38
- package/src/utils/TIMESTAMPS.md +176 -176
- package/src/utils/TimestampUtils.ts +241 -241
- package/src/utils/index.ts +1 -1
- package/src/validations/appointment.schema.ts +574 -574
- package/src/validations/calendar.schema.ts +225 -225
- package/src/validations/clinic.schema.ts +493 -493
- package/src/validations/common.schema.ts +25 -25
- package/src/validations/documentation-templates/index.ts +1 -1
- package/src/validations/documentation-templates/template.schema.ts +220 -220
- package/src/validations/documentation-templates.schema.ts +10 -10
- package/src/validations/index.ts +20 -20
- package/src/validations/media.schema.ts +10 -10
- package/src/validations/notification.schema.ts +90 -90
- package/src/validations/patient/aesthetic-analysis.schema.ts +55 -55
- package/src/validations/patient/medical-info.schema.ts +125 -125
- package/src/validations/patient/patient-requirements.schema.ts +84 -84
- package/src/validations/patient/token.schema.ts +29 -29
- package/src/validations/patient.schema.ts +217 -216
- package/src/validations/practitioner.schema.ts +222 -222
- package/src/validations/procedure-product.schema.ts +41 -41
- package/src/validations/procedure.schema.ts +124 -124
- package/src/validations/profile-info.schema.ts +41 -41
- package/src/validations/reviews.schema.ts +189 -195
- package/src/validations/schemas.ts +104 -104
- package/src/validations/shared.schema.ts +78 -78
|
@@ -1,204 +1,204 @@
|
|
|
1
|
-
# Clinic Service
|
|
2
|
-
|
|
3
|
-
This service manages clinic data within the Firestore database. It provides methods for creating, reading, updating, and managing clinics, their branches, and associated data like tags and administrators.
|
|
4
|
-
|
|
5
|
-
**Note:** This service relies on helper functions defined in the `./utils` directory for specific operations like photo uploads, geo-queries, and data fetching. Cloud Functions handle data aggregation into related entities (Practitioners, Procedures, ClinicGroups).
|
|
6
|
-
|
|
7
|
-
## `ClinicService` Class
|
|
8
|
-
|
|
9
|
-
Extends `BaseService`.
|
|
10
|
-
|
|
11
|
-
### Constructor
|
|
12
|
-
|
|
13
|
-
```typescript
|
|
14
|
-
constructor(
|
|
15
|
-
db: Firestore,
|
|
16
|
-
auth: Auth,
|
|
17
|
-
app: FirebaseApp,
|
|
18
|
-
clinicGroupService: ClinicGroupService,
|
|
19
|
-
clinicAdminService: ClinicAdminService
|
|
20
|
-
)
|
|
21
|
-
```
|
|
22
|
-
|
|
23
|
-
Initializes the service with Firestore, Auth, App instances, and required dependency services (`ClinicGroupService`, `ClinicAdminService`).
|
|
24
|
-
|
|
25
|
-
### Core Methods
|
|
26
|
-
|
|
27
|
-
- **`createClinic(data: CreateClinicData, creatorAdminId: string): Promise<Clinic>`**
|
|
28
|
-
- Creates a new clinic document in Firestore.
|
|
29
|
-
- Validates input data using `createClinicSchema`.
|
|
30
|
-
- Verifies the `creatorAdminId` and their association with the specified `clinicGroupId`.
|
|
31
|
-
- Calculates the geohash for the clinic's location.
|
|
32
|
-
- Initializes default review information.
|
|
33
|
-
- Handles photo uploads for logo, cover photo, featured photos, and photos with tags using utility functions.
|
|
34
|
-
- Updates the creator admin's `clinicsManaged` list.
|
|
35
|
-
- **Aggregation Note:** Adding the clinic to the `ClinicGroup` is handled by Cloud Functions.
|
|
36
|
-
- **`updateClinic(clinicId: string, data: Partial<Omit<Clinic, \"id\" | \"createdAt\" | \"clinicGroupId\">>, adminId: string): Promise<Clinic>`**
|
|
37
|
-
- Updates an existing clinic document.
|
|
38
|
-
- Fetches the current clinic data.
|
|
39
|
-
- Validates the partial update data against the `clinicSchema` after merging with existing data.
|
|
40
|
-
- Updates the geohash if the location is changed.
|
|
41
|
-
- Handles photo updates/uploads if necessary.
|
|
42
|
-
- **Aggregation Note:** Aggregation updates in related entities (Practitioners, Procedures, ClinicGroup) are handled by Cloud Functions.
|
|
43
|
-
- **`deactivateClinic(clinicId: string, adminId: string): Promise<void>`**
|
|
44
|
-
- Sets the `isActive` flag of a clinic to `false`.
|
|
45
|
-
- Requires admin permission (verification logic might be in the calling function or assumed).
|
|
46
|
-
- **Aggregation Note:** Aggregation updates (e.g., removing from active lists, updating related entities) are handled by Cloud Functions.
|
|
47
|
-
- **`getClinic(clinicId: string): Promise<Clinic | null>`**
|
|
48
|
-
- Retrieves a single clinic document by its ID using `ClinicUtils.getClinic`.
|
|
49
|
-
- **`getClinicsByGroup(groupId: string): Promise<Clinic[]>`**
|
|
50
|
-
- Retrieves all clinic documents belonging to a specific `clinicGroupId` using `ClinicUtils.getClinicsByGroup`.
|
|
51
|
-
- **`findClinicsInRadius(center: { latitude: number; longitude: number }, radiusInKm: number, filters?: { procedures?: string[]; tags?: ClinicTag[] }): Promise<Clinic[]>`**
|
|
52
|
-
- Finds active clinics within a specified radius using geohash queries.
|
|
53
|
-
- Leverages `SearchUtils.findClinicsInRadius`.
|
|
54
|
-
- Optionally filters results by procedure IDs (services) and tags.
|
|
55
|
-
- **`addTags(clinicId: string, adminId: string, newTags: { tags?: ClinicTag[] }): Promise<Clinic>`**
|
|
56
|
-
- Adds specified tags to a clinic's `tags` array using `TagUtils.addTags`.
|
|
57
|
-
- Ensures the admin has permission. Prevents duplicates.
|
|
58
|
-
- **`removeTags(clinicId: string, adminId: string, tagsToRemove: { tags?: ClinicTag[] }): Promise<Clinic>`**
|
|
59
|
-
- Removes specified tags from a clinic's `tags` array using `TagUtils.removeTags`.
|
|
60
|
-
- Ensures the admin has permission.
|
|
61
|
-
- **`getClinicsByAdmin(adminId: string, options?: { isActive?: boolean; includeGroupClinics?: boolean }): Promise<Clinic[]>`**
|
|
62
|
-
- Retrieves clinics associated with a specific admin using `ClinicUtils.getClinicsByAdmin`.
|
|
63
|
-
- Handles options for filtering by `isActive` and including all group clinics for owners.
|
|
64
|
-
- **`getActiveClinicsByAdmin(adminId: string): Promise<Clinic[]>`**
|
|
65
|
-
- Retrieves only the active clinics associated with a specific admin using `ClinicUtils.getActiveClinicsByAdmin`.
|
|
66
|
-
- **`createClinicBranch(clinicGroupId: string, setupData: ClinicBranchSetupData, adminId: string): Promise<Clinic>`**
|
|
67
|
-
- Creates a new clinic (branch) within an existing `clinicGroupId`.
|
|
68
|
-
- Validates group existence. Uses `createClinic` internally.
|
|
69
|
-
- **`getClinicById(clinicId: string): Promise<Clinic | null>`**
|
|
70
|
-
- Retrieves a single clinic document by its ID using `ClinicUtils.getClinicById`.
|
|
71
|
-
- **`getAllClinics(pagination?: number, lastDoc?: any): Promise<{ clinics: Clinic[]; lastDoc: any }>`**
|
|
72
|
-
- Retrieves all clinics, ordered by ID, optionally with pagination, using `ClinicUtils.getAllClinics`.
|
|
73
|
-
- **`getAllClinicsInRange(center: { latitude: number; longitude: number }, rangeInKm: number, pagination?: number, lastDoc?: any): Promise<{ clinics: (Clinic & { distance: number })[]; lastDoc: any }>`**
|
|
74
|
-
- Retrieves all clinics within a range, sorted by distance, optionally with pagination, using `ClinicUtils.getAllClinicsInRange`.
|
|
75
|
-
- **`getClinicsByFilters(filters: { ... }): Promise<{ clinics: (Clinic & { distance?: number })[]; lastDoc: any }>`**
|
|
76
|
-
- Retrieves clinics based on complex filters (location, tags, procedures, rating, etc.).
|
|
77
|
-
- Uses `FilterUtils.getClinicsByFilters` for combined query and in-memory filtering.
|
|
78
|
-
|
|
79
|
-
### Utility Functions (`./utils`)
|
|
80
|
-
|
|
81
|
-
- **`clinic.utils.ts`**: Core fetching (`getClinic`, `getClinicsByGroup`, etc.), create/update/deactivate logic wrappers, admin checks.
|
|
82
|
-
- **`filter.utils.ts`**: Complex filtering logic (`getClinicsByFilters`), including geo-queries.
|
|
83
|
-
- **`clinic-group.utils.ts`**: Helpers for clinic group interactions (used by `ClinicGroupService`).
|
|
84
|
-
- **`tag.utils.ts`**: Logic for adding/removing tags (`addTags`, `removeTags`).
|
|
85
|
-
- **`photos.utils.ts`**: Firebase Storage interactions (`uploadPhoto`, `uploadMultiplePhotos`, `deletePhoto`).
|
|
86
|
-
- **`admin.utils.ts`**: Helpers for clinic admin interactions (used by `ClinicAdminService`).
|
|
87
|
-
- **`search.utils.ts`**: Geo-radius search logic (`findClinicsInRadius`).
|
|
88
|
-
|
|
89
|
-
# Clinic Services
|
|
90
|
-
|
|
91
|
-
This directory contains services related to clinic operations.
|
|
92
|
-
|
|
93
|
-
## Services
|
|
94
|
-
|
|
95
|
-
### ClinicService
|
|
96
|
-
|
|
97
|
-
Handles clinic CRUD operations, searching, and management.
|
|
98
|
-
|
|
99
|
-
### ClinicGroupService
|
|
100
|
-
|
|
101
|
-
Manages clinic groups and their operations.
|
|
102
|
-
|
|
103
|
-
### ClinicAdminService
|
|
104
|
-
|
|
105
|
-
Handles clinic administrator operations.
|
|
106
|
-
|
|
107
|
-
### PractitionerInviteService
|
|
108
|
-
|
|
109
|
-
Manages the practitioner invitation system for clinics.
|
|
110
|
-
|
|
111
|
-
## PractitionerInviteService
|
|
112
|
-
|
|
113
|
-
The `PractitionerInviteService` handles the complete flow of inviting practitioners to join clinics.
|
|
114
|
-
|
|
115
|
-
### Flow
|
|
116
|
-
|
|
117
|
-
1. Clinic searches for active practitioners by name or email (using existing practitioner search services)
|
|
118
|
-
2. Clinic creates an invite request with proposed working hours
|
|
119
|
-
3. Practitioner receives the invite and can accept or reject it
|
|
120
|
-
4. Admins can cancel pending invites if needed
|
|
121
|
-
5. Connection between practitioner and clinic is handled by aggregation side-effects
|
|
122
|
-
|
|
123
|
-
### Methods
|
|
124
|
-
|
|
125
|
-
#### Core Invite Methods
|
|
126
|
-
|
|
127
|
-
- `createInviteAdmin(practitionerId, clinicId, proposedWorkingHours, invitedBy, message?)` - Create a new invite
|
|
128
|
-
- `acceptInviteDoctor(inviteId)` - Doctor accepts an invite
|
|
129
|
-
- `rejectInviteDoctor(inviteId, rejectionReason?)` - Doctor rejects an invite
|
|
130
|
-
- `cancelInviteAdmin(inviteId, cancelReason?)` - Admin cancels a pending invite
|
|
131
|
-
|
|
132
|
-
#### Retrieval Methods
|
|
133
|
-
|
|
134
|
-
- `getAllInvitesDoctor(practitionerId, statusFilter?)` - Get all invites for a practitioner
|
|
135
|
-
- `getAllInvitesClinic(clinicId, statusFilter?)` - Get all invites for a clinic
|
|
136
|
-
- `getInviteById(inviteId)` - Get a specific invite
|
|
137
|
-
- `getInvitesWithFilters(filters)` - Advanced filtering
|
|
138
|
-
|
|
139
|
-
#### Admin Methods
|
|
140
|
-
|
|
141
|
-
- `deleteInvite(inviteId)` - Delete an invite (admin only)
|
|
142
|
-
|
|
143
|
-
### Status Filtering
|
|
144
|
-
|
|
145
|
-
All retrieval methods support filtering by invite status:
|
|
146
|
-
|
|
147
|
-
- `PENDING` - Invite has been sent but not responded to
|
|
148
|
-
- `ACCEPTED` - Practitioner has accepted the invite
|
|
149
|
-
- `REJECTED` - Practitioner has rejected the invite
|
|
150
|
-
- `CANCELLED` - Admin has cancelled the invite
|
|
151
|
-
|
|
152
|
-
### Usage Example
|
|
153
|
-
|
|
154
|
-
```typescript
|
|
155
|
-
// Create service instance
|
|
156
|
-
const practitionerInviteService = new PractitionerInviteService(db, auth, app);
|
|
157
|
-
|
|
158
|
-
// Create an invite
|
|
159
|
-
const invite = await practitionerInviteService.createInviteAdmin(
|
|
160
|
-
"practitioner123",
|
|
161
|
-
"clinic456",
|
|
162
|
-
proposedHours,
|
|
163
|
-
"admin789",
|
|
164
|
-
"We'd love to have you join our team!"
|
|
165
|
-
);
|
|
166
|
-
|
|
167
|
-
// Get clinic's invites
|
|
168
|
-
const clinicInvites = await practitionerInviteService.getAllInvitesClinic(
|
|
169
|
-
"clinic456",
|
|
170
|
-
[PractitionerInviteStatus.PENDING]
|
|
171
|
-
);
|
|
172
|
-
|
|
173
|
-
// Doctor accepts invite
|
|
174
|
-
const acceptedInvite = await practitionerInviteService.acceptInviteDoctor(
|
|
175
|
-
invite.id
|
|
176
|
-
);
|
|
177
|
-
|
|
178
|
-
// Admin cancels pending invite
|
|
179
|
-
const cancelledInvite = await practitionerInviteService.cancelInviteAdmin(
|
|
180
|
-
invite.id,
|
|
181
|
-
"Position no longer available"
|
|
182
|
-
);
|
|
183
|
-
```
|
|
184
|
-
|
|
185
|
-
### Data Structure
|
|
186
|
-
|
|
187
|
-
The service uses existing aggregation types from the profile module:
|
|
188
|
-
|
|
189
|
-
- `PractitionerProfileInfo` - Complete practitioner information including certification
|
|
190
|
-
- `ClinicInfo` - Complete clinic information including location and contact details
|
|
191
|
-
|
|
192
|
-
### Error Handling
|
|
193
|
-
|
|
194
|
-
All methods include proper error handling and logging. Common errors:
|
|
195
|
-
|
|
196
|
-
- Practitioner/Clinic not found
|
|
197
|
-
- Duplicate pending invites
|
|
198
|
-
- Invalid status transitions (only pending invites can be accepted/rejected/cancelled)
|
|
199
|
-
- Permission issues
|
|
200
|
-
|
|
201
|
-
### Firestore Collections
|
|
202
|
-
|
|
203
|
-
- Collection: `practitioner-invites`
|
|
204
|
-
- Documents contain complete invite information with embedded practitioner and clinic details
|
|
1
|
+
# Clinic Service
|
|
2
|
+
|
|
3
|
+
This service manages clinic data within the Firestore database. It provides methods for creating, reading, updating, and managing clinics, their branches, and associated data like tags and administrators.
|
|
4
|
+
|
|
5
|
+
**Note:** This service relies on helper functions defined in the `./utils` directory for specific operations like photo uploads, geo-queries, and data fetching. Cloud Functions handle data aggregation into related entities (Practitioners, Procedures, ClinicGroups).
|
|
6
|
+
|
|
7
|
+
## `ClinicService` Class
|
|
8
|
+
|
|
9
|
+
Extends `BaseService`.
|
|
10
|
+
|
|
11
|
+
### Constructor
|
|
12
|
+
|
|
13
|
+
```typescript
|
|
14
|
+
constructor(
|
|
15
|
+
db: Firestore,
|
|
16
|
+
auth: Auth,
|
|
17
|
+
app: FirebaseApp,
|
|
18
|
+
clinicGroupService: ClinicGroupService,
|
|
19
|
+
clinicAdminService: ClinicAdminService
|
|
20
|
+
)
|
|
21
|
+
```
|
|
22
|
+
|
|
23
|
+
Initializes the service with Firestore, Auth, App instances, and required dependency services (`ClinicGroupService`, `ClinicAdminService`).
|
|
24
|
+
|
|
25
|
+
### Core Methods
|
|
26
|
+
|
|
27
|
+
- **`createClinic(data: CreateClinicData, creatorAdminId: string): Promise<Clinic>`**
|
|
28
|
+
- Creates a new clinic document in Firestore.
|
|
29
|
+
- Validates input data using `createClinicSchema`.
|
|
30
|
+
- Verifies the `creatorAdminId` and their association with the specified `clinicGroupId`.
|
|
31
|
+
- Calculates the geohash for the clinic's location.
|
|
32
|
+
- Initializes default review information.
|
|
33
|
+
- Handles photo uploads for logo, cover photo, featured photos, and photos with tags using utility functions.
|
|
34
|
+
- Updates the creator admin's `clinicsManaged` list.
|
|
35
|
+
- **Aggregation Note:** Adding the clinic to the `ClinicGroup` is handled by Cloud Functions.
|
|
36
|
+
- **`updateClinic(clinicId: string, data: Partial<Omit<Clinic, \"id\" | \"createdAt\" | \"clinicGroupId\">>, adminId: string): Promise<Clinic>`**
|
|
37
|
+
- Updates an existing clinic document.
|
|
38
|
+
- Fetches the current clinic data.
|
|
39
|
+
- Validates the partial update data against the `clinicSchema` after merging with existing data.
|
|
40
|
+
- Updates the geohash if the location is changed.
|
|
41
|
+
- Handles photo updates/uploads if necessary.
|
|
42
|
+
- **Aggregation Note:** Aggregation updates in related entities (Practitioners, Procedures, ClinicGroup) are handled by Cloud Functions.
|
|
43
|
+
- **`deactivateClinic(clinicId: string, adminId: string): Promise<void>`**
|
|
44
|
+
- Sets the `isActive` flag of a clinic to `false`.
|
|
45
|
+
- Requires admin permission (verification logic might be in the calling function or assumed).
|
|
46
|
+
- **Aggregation Note:** Aggregation updates (e.g., removing from active lists, updating related entities) are handled by Cloud Functions.
|
|
47
|
+
- **`getClinic(clinicId: string): Promise<Clinic | null>`**
|
|
48
|
+
- Retrieves a single clinic document by its ID using `ClinicUtils.getClinic`.
|
|
49
|
+
- **`getClinicsByGroup(groupId: string): Promise<Clinic[]>`**
|
|
50
|
+
- Retrieves all clinic documents belonging to a specific `clinicGroupId` using `ClinicUtils.getClinicsByGroup`.
|
|
51
|
+
- **`findClinicsInRadius(center: { latitude: number; longitude: number }, radiusInKm: number, filters?: { procedures?: string[]; tags?: ClinicTag[] }): Promise<Clinic[]>`**
|
|
52
|
+
- Finds active clinics within a specified radius using geohash queries.
|
|
53
|
+
- Leverages `SearchUtils.findClinicsInRadius`.
|
|
54
|
+
- Optionally filters results by procedure IDs (services) and tags.
|
|
55
|
+
- **`addTags(clinicId: string, adminId: string, newTags: { tags?: ClinicTag[] }): Promise<Clinic>`**
|
|
56
|
+
- Adds specified tags to a clinic's `tags` array using `TagUtils.addTags`.
|
|
57
|
+
- Ensures the admin has permission. Prevents duplicates.
|
|
58
|
+
- **`removeTags(clinicId: string, adminId: string, tagsToRemove: { tags?: ClinicTag[] }): Promise<Clinic>`**
|
|
59
|
+
- Removes specified tags from a clinic's `tags` array using `TagUtils.removeTags`.
|
|
60
|
+
- Ensures the admin has permission.
|
|
61
|
+
- **`getClinicsByAdmin(adminId: string, options?: { isActive?: boolean; includeGroupClinics?: boolean }): Promise<Clinic[]>`**
|
|
62
|
+
- Retrieves clinics associated with a specific admin using `ClinicUtils.getClinicsByAdmin`.
|
|
63
|
+
- Handles options for filtering by `isActive` and including all group clinics for owners.
|
|
64
|
+
- **`getActiveClinicsByAdmin(adminId: string): Promise<Clinic[]>`**
|
|
65
|
+
- Retrieves only the active clinics associated with a specific admin using `ClinicUtils.getActiveClinicsByAdmin`.
|
|
66
|
+
- **`createClinicBranch(clinicGroupId: string, setupData: ClinicBranchSetupData, adminId: string): Promise<Clinic>`**
|
|
67
|
+
- Creates a new clinic (branch) within an existing `clinicGroupId`.
|
|
68
|
+
- Validates group existence. Uses `createClinic` internally.
|
|
69
|
+
- **`getClinicById(clinicId: string): Promise<Clinic | null>`**
|
|
70
|
+
- Retrieves a single clinic document by its ID using `ClinicUtils.getClinicById`.
|
|
71
|
+
- **`getAllClinics(pagination?: number, lastDoc?: any): Promise<{ clinics: Clinic[]; lastDoc: any }>`**
|
|
72
|
+
- Retrieves all clinics, ordered by ID, optionally with pagination, using `ClinicUtils.getAllClinics`.
|
|
73
|
+
- **`getAllClinicsInRange(center: { latitude: number; longitude: number }, rangeInKm: number, pagination?: number, lastDoc?: any): Promise<{ clinics: (Clinic & { distance: number })[]; lastDoc: any }>`**
|
|
74
|
+
- Retrieves all clinics within a range, sorted by distance, optionally with pagination, using `ClinicUtils.getAllClinicsInRange`.
|
|
75
|
+
- **`getClinicsByFilters(filters: { ... }): Promise<{ clinics: (Clinic & { distance?: number })[]; lastDoc: any }>`**
|
|
76
|
+
- Retrieves clinics based on complex filters (location, tags, procedures, rating, etc.).
|
|
77
|
+
- Uses `FilterUtils.getClinicsByFilters` for combined query and in-memory filtering.
|
|
78
|
+
|
|
79
|
+
### Utility Functions (`./utils`)
|
|
80
|
+
|
|
81
|
+
- **`clinic.utils.ts`**: Core fetching (`getClinic`, `getClinicsByGroup`, etc.), create/update/deactivate logic wrappers, admin checks.
|
|
82
|
+
- **`filter.utils.ts`**: Complex filtering logic (`getClinicsByFilters`), including geo-queries.
|
|
83
|
+
- **`clinic-group.utils.ts`**: Helpers for clinic group interactions (used by `ClinicGroupService`).
|
|
84
|
+
- **`tag.utils.ts`**: Logic for adding/removing tags (`addTags`, `removeTags`).
|
|
85
|
+
- **`photos.utils.ts`**: Firebase Storage interactions (`uploadPhoto`, `uploadMultiplePhotos`, `deletePhoto`).
|
|
86
|
+
- **`admin.utils.ts`**: Helpers for clinic admin interactions (used by `ClinicAdminService`).
|
|
87
|
+
- **`search.utils.ts`**: Geo-radius search logic (`findClinicsInRadius`).
|
|
88
|
+
|
|
89
|
+
# Clinic Services
|
|
90
|
+
|
|
91
|
+
This directory contains services related to clinic operations.
|
|
92
|
+
|
|
93
|
+
## Services
|
|
94
|
+
|
|
95
|
+
### ClinicService
|
|
96
|
+
|
|
97
|
+
Handles clinic CRUD operations, searching, and management.
|
|
98
|
+
|
|
99
|
+
### ClinicGroupService
|
|
100
|
+
|
|
101
|
+
Manages clinic groups and their operations.
|
|
102
|
+
|
|
103
|
+
### ClinicAdminService
|
|
104
|
+
|
|
105
|
+
Handles clinic administrator operations.
|
|
106
|
+
|
|
107
|
+
### PractitionerInviteService
|
|
108
|
+
|
|
109
|
+
Manages the practitioner invitation system for clinics.
|
|
110
|
+
|
|
111
|
+
## PractitionerInviteService
|
|
112
|
+
|
|
113
|
+
The `PractitionerInviteService` handles the complete flow of inviting practitioners to join clinics.
|
|
114
|
+
|
|
115
|
+
### Flow
|
|
116
|
+
|
|
117
|
+
1. Clinic searches for active practitioners by name or email (using existing practitioner search services)
|
|
118
|
+
2. Clinic creates an invite request with proposed working hours
|
|
119
|
+
3. Practitioner receives the invite and can accept or reject it
|
|
120
|
+
4. Admins can cancel pending invites if needed
|
|
121
|
+
5. Connection between practitioner and clinic is handled by aggregation side-effects
|
|
122
|
+
|
|
123
|
+
### Methods
|
|
124
|
+
|
|
125
|
+
#### Core Invite Methods
|
|
126
|
+
|
|
127
|
+
- `createInviteAdmin(practitionerId, clinicId, proposedWorkingHours, invitedBy, message?)` - Create a new invite
|
|
128
|
+
- `acceptInviteDoctor(inviteId)` - Doctor accepts an invite
|
|
129
|
+
- `rejectInviteDoctor(inviteId, rejectionReason?)` - Doctor rejects an invite
|
|
130
|
+
- `cancelInviteAdmin(inviteId, cancelReason?)` - Admin cancels a pending invite
|
|
131
|
+
|
|
132
|
+
#### Retrieval Methods
|
|
133
|
+
|
|
134
|
+
- `getAllInvitesDoctor(practitionerId, statusFilter?)` - Get all invites for a practitioner
|
|
135
|
+
- `getAllInvitesClinic(clinicId, statusFilter?)` - Get all invites for a clinic
|
|
136
|
+
- `getInviteById(inviteId)` - Get a specific invite
|
|
137
|
+
- `getInvitesWithFilters(filters)` - Advanced filtering
|
|
138
|
+
|
|
139
|
+
#### Admin Methods
|
|
140
|
+
|
|
141
|
+
- `deleteInvite(inviteId)` - Delete an invite (admin only)
|
|
142
|
+
|
|
143
|
+
### Status Filtering
|
|
144
|
+
|
|
145
|
+
All retrieval methods support filtering by invite status:
|
|
146
|
+
|
|
147
|
+
- `PENDING` - Invite has been sent but not responded to
|
|
148
|
+
- `ACCEPTED` - Practitioner has accepted the invite
|
|
149
|
+
- `REJECTED` - Practitioner has rejected the invite
|
|
150
|
+
- `CANCELLED` - Admin has cancelled the invite
|
|
151
|
+
|
|
152
|
+
### Usage Example
|
|
153
|
+
|
|
154
|
+
```typescript
|
|
155
|
+
// Create service instance
|
|
156
|
+
const practitionerInviteService = new PractitionerInviteService(db, auth, app);
|
|
157
|
+
|
|
158
|
+
// Create an invite
|
|
159
|
+
const invite = await practitionerInviteService.createInviteAdmin(
|
|
160
|
+
"practitioner123",
|
|
161
|
+
"clinic456",
|
|
162
|
+
proposedHours,
|
|
163
|
+
"admin789",
|
|
164
|
+
"We'd love to have you join our team!"
|
|
165
|
+
);
|
|
166
|
+
|
|
167
|
+
// Get clinic's invites
|
|
168
|
+
const clinicInvites = await practitionerInviteService.getAllInvitesClinic(
|
|
169
|
+
"clinic456",
|
|
170
|
+
[PractitionerInviteStatus.PENDING]
|
|
171
|
+
);
|
|
172
|
+
|
|
173
|
+
// Doctor accepts invite
|
|
174
|
+
const acceptedInvite = await practitionerInviteService.acceptInviteDoctor(
|
|
175
|
+
invite.id
|
|
176
|
+
);
|
|
177
|
+
|
|
178
|
+
// Admin cancels pending invite
|
|
179
|
+
const cancelledInvite = await practitionerInviteService.cancelInviteAdmin(
|
|
180
|
+
invite.id,
|
|
181
|
+
"Position no longer available"
|
|
182
|
+
);
|
|
183
|
+
```
|
|
184
|
+
|
|
185
|
+
### Data Structure
|
|
186
|
+
|
|
187
|
+
The service uses existing aggregation types from the profile module:
|
|
188
|
+
|
|
189
|
+
- `PractitionerProfileInfo` - Complete practitioner information including certification
|
|
190
|
+
- `ClinicInfo` - Complete clinic information including location and contact details
|
|
191
|
+
|
|
192
|
+
### Error Handling
|
|
193
|
+
|
|
194
|
+
All methods include proper error handling and logging. Common errors:
|
|
195
|
+
|
|
196
|
+
- Practitioner/Clinic not found
|
|
197
|
+
- Duplicate pending invites
|
|
198
|
+
- Invalid status transitions (only pending invites can be accepted/rejected/cancelled)
|
|
199
|
+
- Permission issues
|
|
200
|
+
|
|
201
|
+
### Firestore Collections
|
|
202
|
+
|
|
203
|
+
- Collection: `practitioner-invites`
|
|
204
|
+
- Documents contain complete invite information with embedded practitioner and clinic details
|