Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

noUncheckedIndexedAccess in tsconfig #9880

Closed
wants to merge 15 commits into from

Conversation

Rishith25
Copy link
Contributor

@Rishith25 Rishith25 commented Jan 10, 2025

Proposed Changes

@ohcnetwork/care-fe-code-reviewers

Merge Checklist

  • Add specs that demonstrate bug / test a new feature.
  • Update product documentation.
  • Ensure that UI text is kept in I18n files.
  • Prep screenshot or demo video for changelog entry, and attach it to issue.
  • Request for Peer Reviews
  • Completion of QA

Summary by CodeRabbit

Based on the comprehensive summary of changes, here are the release notes:

Release Notes

  • Robustness Improvements

    • Enhanced error handling across multiple components by adding optional chaining and nullish coalescing operators
    • Improved type safety for parameter and property access
    • Added fallback mechanisms to prevent runtime errors
  • Type Safety Enhancements

    • Updated TypeScript configuration to enable stricter type checking
    • Refined type definitions for various components and functions
  • Routing and Navigation

    • Improved route parameter handling to manage undefined or null values
    • Added default values for route parameters to prevent potential errors
  • Performance and Stability

    • Implemented safer data access patterns in components and utility functions
    • Added checks to prevent accessing undefined properties

These changes collectively improve the application's reliability and type safety, reducing potential runtime errors and enhancing overall user experience.

@Rishith25 Rishith25 requested a review from a team as a code owner January 10, 2025 11:50
Copy link
Contributor

coderabbitai bot commented Jan 10, 2025

Walkthrough

This pull request focuses on enhancing code robustness across multiple components and files by implementing optional chaining, nullish coalescing, and adding safeguards against undefined values. The changes span various parts of the application, including routing, component logic, hooks, and utility functions. The primary goal is to improve error handling and prevent potential runtime errors by ensuring that code can gracefully handle scenarios where data might be undefined or null.

Changes

File Path Change Summary
tsconfig.json Added "noUncheckedIndexedAccess": true compiler option
src/Routers/*Routes.tsx Added nullish coalescing and optional chaining for route parameter handling
src/components/Common/* Enhanced error handling with optional chaining and null checks
src/hooks/* Improved file and data processing with safer property access
src/Utils/* Added safeguards for property access and state updates

Assessment against linked issues

Objective Addressed Explanation
Enable noUncheckedIndexedAccess

Possibly related PRs

Suggested labels

needs testing, needs review

Suggested reviewers

  • rithviknishad
  • Jacobjeevan

Poem

🐰 Debugging Bunny's Ballad 🐰

With optional chains, we hop and we dance,
Preventing errors with each careful glance,
No more undefined fears, our code stands tall,
Safe and robust, we conquer it all!

TypeScript magic, our guardian bright! 🌟


📜 Recent review details

Configuration used: CodeRabbit UI
Review profile: CHILL
Plan: Pro

📥 Commits

Reviewing files that changed from the base of the PR and between c667672 and 321c635.

📒 Files selected for processing (3)
  • src/Routers/routes/ConsultationRoutes.tsx (2 hunks)
  • src/Utils/utils.ts (2 hunks)
  • src/components/Questionnaire/QuestionnaireForm.tsx (1 hunks)
🚧 Files skipped from review as they are similar to previous changes (3)
  • src/components/Questionnaire/QuestionnaireForm.tsx
  • src/Utils/utils.ts
  • src/Routers/routes/ConsultationRoutes.tsx
⏰ Context from checks skipped due to timeout of 90000ms (3)
  • GitHub Check: Redirect rules - care-ohc
  • GitHub Check: Header rules - care-ohc
  • GitHub Check: Pages changed - care-ohc

Thank you for using CodeRabbit. We offer it for free to the OSS community and would appreciate your support in helping us grow. If you find it useful, would you consider giving us a shout-out on your favorite social media?

❤️ Share
🪧 Tips

Chat

There are 3 ways to chat with CodeRabbit:

  • Review comments: Directly reply to a review comment made by CodeRabbit. Example:
    • I pushed a fix in commit <commit_id>, please review it.
    • Generate unit testing code for this file.
    • Open a follow-up GitHub issue for this discussion.
  • Files and specific lines of code (under the "Files changed" tab): Tag @coderabbitai in a new review comment at the desired location with your query. Examples:
    • @coderabbitai generate unit testing code for this file.
    • @coderabbitai modularize this function.
  • PR comments: Tag @coderabbitai in a new PR comment to ask questions about the PR branch. For the best results, please provide a very specific query, as very limited context is provided in this mode. Examples:
    • @coderabbitai gather interesting stats about this repository and render them as a table. Additionally, render a pie chart showing the language distribution in the codebase.
    • @coderabbitai read src/utils.ts and generate unit testing code.
    • @coderabbitai read the files in the src/scheduler package and generate a class diagram using mermaid and a README in the markdown format.
    • @coderabbitai help me debug CodeRabbit configuration file.

Note: Be mindful of the bot's finite context window. It's strongly recommended to break down tasks such as reading entire modules into smaller chunks. For a focused discussion, use review comments to chat about specific files and their changes, instead of using the PR comments.

CodeRabbit Commands (Invoked using PR comments)

  • @coderabbitai pause to pause the reviews on a PR.
  • @coderabbitai resume to resume the paused reviews.
  • @coderabbitai review to trigger an incremental review. This is useful when automatic reviews are disabled for the repository.
  • @coderabbitai full review to do a full review from scratch and review all the files again.
  • @coderabbitai summary to regenerate the summary of the PR.
  • @coderabbitai generate docstrings to generate docstrings for this PR. (Beta)
  • @coderabbitai resolve resolve all the CodeRabbit review comments.
  • @coderabbitai configuration to show the current CodeRabbit configuration for the repository.
  • @coderabbitai help to get help.

Other keywords and placeholders

  • Add @coderabbitai ignore anywhere in the PR description to prevent this PR from being reviewed.
  • Add @coderabbitai summary to generate the high-level summary at a specific location in the PR description.
  • Add @coderabbitai anywhere in the PR title to generate the title automatically.

CodeRabbit Configuration File (.coderabbit.yaml)

  • You can programmatically configure CodeRabbit by adding a .coderabbit.yaml file to the root of your repository.
  • Please see the configuration documentation for more information.
  • If your editor has YAML language server enabled, you can add the path at the top of this file to enable auto-completion and validation: # yaml-language-server: $schema=https://coderabbit.ai/integrations/schema.v2.json

Documentation and Community

  • Visit our Documentation for detailed information on how to use CodeRabbit.
  • Join our Discord Community to get help, request features, and share feedback.
  • Follow us on X/Twitter for updates and announcements.

Copy link

netlify bot commented Jan 10, 2025

Deploy Preview for care-ohc ready!

Name Link
🔨 Latest commit c667672
🔍 Latest deploy log https://app.netlify.com/sites/care-ohc/deploys/67828da7b1a1890008d46590
😎 Deploy Preview https://deploy-preview-9880--care-ohc.netlify.app
📱 Preview on mobile
Toggle QR Code...

QR Code

Use your smartphone camera to open QR code link.

To edit notification comments on pull requests, go to your Netlify site configuration.

Copy link
Contributor

@coderabbitai coderabbitai bot left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Actionable comments posted: 9

🧹 Nitpick comments (16)
src/Routers/routes/PatientRoutes.tsx (1)

13-13: Consider using nullish coalescing (??) instead of logical OR (||)

While adding default values for route parameters is correct, using the logical OR operator (||) will convert any falsy value (including empty string) to the default. Consider using the nullish coalescing operator (??) which only defaults for null or undefined.

Example fix:

- facilityId={facilityId || ""}
+ facilityId={facilityId ?? ""}

Also applies to: 19-19, 21-21, 23-23, 26-26, 33-33, 38-38, 45-46

src/service-worker.ts (1)

38-38: Consider adding error handling for postMessage

While the optional chaining operator correctly handles undefined clients, consider adding error handling for the postMessage operation itself.

- clients[0]?.postMessage(data);
+ try {
+   clients[0]?.postMessage(data);
+ } catch (error) {
+   console.error('Failed to post message to client:', error);
+ }
src/components/Common/Avatar.tsx (1)

33-33: The default color might be unnecessary

The modulo operation stringToInt(name) % colors.length ensures the index is always within bounds of the non-empty colors array. The default color would only be used if the colors array is empty. Consider adding an assertion or check for non-empty colors array instead.

- const backgroundColor = colors[index] || "#FFFFFF"; // Default to white if undefined
+ if (colors.length === 0) {
+   throw new Error("Colors array must not be empty");
+ }
+ const backgroundColor = colors[index];
src/Routers/routes/ConsultationRoutes.tsx (1)

16-17: Consider using nullish coalescing for route parameters.

While using || works, the nullish coalescing operator (??) would be more appropriate here as it only replaces null or undefined values, not all falsy values like empty strings.

Example refactor:

-      facilityId={facilityId || ""}
+      facilityId={facilityId ?? ""}

Also applies to: 26-27, 36-37, 44-47, 55-56, 63-65, 71-74, 80-81, 87-89, 98-99

src/components/Common/AudioPlayer.tsx (1)

94-99: Simplify the conditional checks.

The current implementation has duplicate conditions checking the same value. This can be simplified while maintaining type safety.

-      if (value[0] !== undefined) {
-        audioRef.current.currentTime = value[0];
-      }
-      if (value[0] !== undefined) {
-        setCurrentTime(value[0]);
-      }
+      const time = value[0];
+      if (time !== undefined) {
+        audioRef.current.currentTime = time;
+        setCurrentTime(time);
+      }
src/components/Common/Export.tsx (1)

65-73: Remove unnecessary non-null assertion and improve code organization.

The non-null assertion (!) on item.route is redundant since we've already checked its existence. Also, consider extracting the action logic for better readability.

-          let action = item?.action;
-          if (item?.route) {
-            action = async () => {
-              const { data } = await request(item.route!);
-              return data ?? null;
-            };
-          }
-          if (action) {
-            exportFile(action, item?.filePrefix, item?.type, item?.parse);
-          }
+          const getDataFromRoute = async (route: Route<string | { results: object[] }, unknown>) => {
+            const { data } = await request(route);
+            return data ?? null;
+          };
+          
+          const exportAction = item?.route 
+            ? () => getDataFromRoute(item.route)
+            : item?.action;
+            
+          if (exportAction) {
+            exportFile(exportAction, item?.filePrefix, item?.type, item?.parse);
+          }
src/common/schemaParser.ts (2)

94-97: Improve type safety and make the fallback more explicit.

The empty object fallback could be more explicit using nullish coalescing, and type safety could be improved.

-      const { value, error } =
-        validateAndParse(key, item[key], schema[key] as SingleKeySchema)[key] ||
-        {};
+      const result = validateAndParse(key, item[key], schema[key] as SingleKeySchema)[key] ?? {
+        value: undefined,
+        error: undefined,
+      };
+      const { value, error } = result;

186-189: Remove unnecessary optional chaining and improve type safety.

The optional chaining on Object.values() is unnecessary as it always returns an array. Consider adding type guards instead.

-    return (
-      dataWithErrors[index] &&
-      !Object.values(dataWithErrors[index])?.some((item) => item.error)
-    );
+    const record = dataWithErrors[index];
+    return record ? !Object.values(record).some((item) => item.error) : false;
src/Utils/AutoSave.tsx (2)

184-186: Simplify the draft selection logic.

The draft selection logic can be simplified by using array indexing.

-          (draftStarted
-            ? drafts[0]?.draft
-            : drafts[drafts.length - 1]?.draft) || {},
+          drafts[draftStarted ? 0 : drafts.length - 1]?.draft ?? {},

196-197: Simplify the timestamp selection logic.

The timestamp selection logic can be simplified similar to the draft selection.

-            ? drafts[0]?.timestamp
-            : drafts[drafts.length - 1]?.timestamp,
+            drafts[draftStarted ? 0 : drafts.length - 1]?.timestamp,
src/components/Common/Charts/ObservationChart.tsx (1)

354-357: LGTM! Good use of optional chaining.

The addition of optional chaining operators for accessing details.enteredBy improves the code's robustness by safely handling cases where observations[0] might be undefined.

Consider extracting the first observation's details into a constant for better readability:

+              const firstObservation = observations[0]?.details;
               <Avatar
-                name={observations[0]?.details.enteredBy}
+                name={firstObservation?.enteredBy}
                 className="h-6 w-6"
               />
-              <span>{observations[0]?.details.enteredBy}</span>
+              <span>{firstObservation?.enteredBy}</span>
src/components/Questionnaire/QuestionnaireForm.tsx (1)

150-156: LGTM! Improved error handling for form updates.

The changes enhance the robustness of error handling by safely accessing form?.errors and conditionally updating the form array.

Consider using nullish coalescing to provide a default empty array for errors:

-            form?.errors.push({
+            (form?.errors ?? []).push({
               question_id: error.question_id,
               error: error.error ?? error.msg,
             } as QuestionValidationError);
src/Utils/utils.ts (1)

313-316: LGTM! Safe country code handling.

Good use of optional chaining and nullish coalescing for handling potentially undefined country codes and their properties.

Consider extracting the country code access into a helper function to reduce repetition:

const getCountryCodeFromPhoneCodes = (code: string) => 
  phoneCodes[code as string]?.code.replaceAll("-", "") ?? "";
tsconfig.json (1)

25-26: LGTM! Important type safety enhancement.

The addition of noUncheckedIndexedAccess is a valuable improvement that will help catch potential runtime errors by making array and object property access stricter.

This change will require careful handling of array indices and object properties throughout the codebase, as TypeScript will now treat them as potentially undefined. This aligns well with defensive programming practices.

src/pages/Encounters/EncounterShow.tsx (1)

169-169: Consider logging invalid tab selections

While the fallback to EncounterUpdatesTab prevents runtime errors, it might be helpful to log when invalid tabs are selected to track potential routing or navigation issues.

Consider adding error logging:

-  const SelectedTab = tabs[props.tab] || EncounterUpdatesTab;
+  const SelectedTab = tabs[props.tab] || (() => {
+    console.warn(`Invalid tab selected: ${props.tab}`);
+    return EncounterUpdatesTab;
+  })();
src/hooks/useFileManager.tsx (1)

84-86: LGTM! Robust handling of optional array access.

The changes properly handle potential undefined values when accessing array indices, which aligns with the noUncheckedIndexedAccess TypeScript option. The implementation includes:

  • Fallback to empty array if split fails
  • Optional chaining for array access
  • Nullish coalescing to provide empty string default

However, consider extracting the extension logic into a reusable utility function since URL parsing is a common operation.

+// In src/Utils/files.ts
+export const getFileExtension = (url: string): string => {
+  const div1 = url.split("?")?.[0]?.split(".") ?? [];
+  return div1.length > 0 ? (div1[div1.length - 1]?.toLowerCase() ?? "") : "";
+};

-const getExtension = (url: string) => {
-  const div1 = url.split("?")[0]?.split(".") || [];
-  const ext: string =
-    div1.length > 0 ? (div1[div1.length - 1]?.toLowerCase() ?? "") : "";
-  return ext;
-};
+const getExtension = getFileExtension;
📜 Review details

Configuration used: CodeRabbit UI
Review profile: CHILL
Plan: Pro

📥 Commits

Reviewing files that changed from the base of the PR and between 63d1385 and 356f18a.

📒 Files selected for processing (47)
  • src/CAREUI/interactive/HumanChart.tsx (1 hunks)
  • src/Providers/PatientUserProvider.tsx (1 hunks)
  • src/Routers/AppRouter.tsx (1 hunks)
  • src/Routers/routes/ConsultationRoutes.tsx (3 hunks)
  • src/Routers/routes/FacilityRoutes.tsx (1 hunks)
  • src/Routers/routes/OrganizationRoutes.tsx (1 hunks)
  • src/Routers/routes/PatientRoutes.tsx (1 hunks)
  • src/Routers/routes/ResourceRoutes.tsx (1 hunks)
  • src/Routers/routes/UserRoutes.tsx (1 hunks)
  • src/Routers/routes/questionnaireRoutes.tsx (1 hunks)
  • src/Utils/AutoSave.tsx (3 hunks)
  • src/Utils/utils.ts (2 hunks)
  • src/common/schemaParser.ts (2 hunks)
  • src/common/utils.tsx (1 hunks)
  • src/components/Common/AudioPlayer.tsx (1 hunks)
  • src/components/Common/Avatar.tsx (1 hunks)
  • src/components/Common/Charts/ObservationChart.tsx (1 hunks)
  • src/components/Common/DateTextInput.tsx (1 hunks)
  • src/components/Common/ExcelFIleDragAndDrop.tsx (3 hunks)
  • src/components/Common/Export.tsx (1 hunks)
  • src/components/Common/GLocationPicker.tsx (3 hunks)
  • src/components/Common/SearchByMultipleFields.tsx (6 hunks)
  • src/components/Facility/DuplicatePatientDialog.tsx (1 hunks)
  • src/components/Form/FormFields/PhoneNumberFormField.tsx (2 hunks)
  • src/components/Patient/PatientRegistration.tsx (1 hunks)
  • src/components/Questionnaire/QuestionTypes/DateTimeQuestion.tsx (1 hunks)
  • src/components/Questionnaire/QuestionTypes/FollowUpAppointmentQuestion.tsx (1 hunks)
  • src/components/Questionnaire/QuestionnaireEditor.tsx (2 hunks)
  • src/components/Questionnaire/QuestionnaireForm.tsx (1 hunks)
  • src/components/Questionnaire/structured/handlers.ts (1 hunks)
  • src/components/Schedule/Appointments/utils.ts (1 hunks)
  • src/components/Schedule/ScheduleTemplatesList.tsx (1 hunks)
  • src/components/Schedule/routes.tsx (1 hunks)
  • src/components/Users/UserAvailabilityTab.tsx (2 hunks)
  • src/components/ui/chart.tsx (1 hunks)
  • src/components/ui/input-otp.tsx (1 hunks)
  • src/hooks/useAppHistory.ts (1 hunks)
  • src/hooks/useFileManager.tsx (1 hunks)
  • src/hooks/useFileUpload.tsx (1 hunks)
  • src/hooks/useFilters.tsx (2 hunks)
  • src/pages/Encounters/EncounterShow.tsx (1 hunks)
  • src/pages/Encounters/PrintPrescription.tsx (1 hunks)
  • src/pages/Encounters/tabs/EncounterNotesTab.tsx (1 hunks)
  • src/pages/Encounters/tabs/EncounterPlotsTab.tsx (1 hunks)
  • src/pages/FacilityOrganization/components/FacilityOrganizationSelector.tsx (1 hunks)
  • src/service-worker.ts (1 hunks)
  • tsconfig.json (1 hunks)
🧰 Additional context used
🪛 Biome (1.9.4)
src/components/Questionnaire/QuestionTypes/DateTimeQuestion.tsx

[error] 60-60: isNaN is unsafe. It attempts a type coercion. Use Number.isNaN instead.

See the MDN documentation for more details.
Unsafe fix: Use Number.isNaN instead.

(lint/suspicious/noGlobalIsNan)

src/components/Patient/PatientRegistration.tsx

[error] 474-474: Missing key property for this element in iterable.

The order of the items may change, and having a key can help React identify which item was moved.
Check the React documentation.

(lint/correctness/useJsxKeyInIterable)

🔇 Additional comments (40)
src/Routers/routes/questionnaireRoutes.tsx (1)

9-10: LGTM! Consistent handling of route parameters.

The addition of || "" fallback ensures type safety by preventing undefined values from being passed to the components, aligning with the noUncheckedIndexedAccess requirements.

src/Routers/routes/UserRoutes.tsx (1)

13-15: LGTM! Consistent handling of tab parameters.

The addition of || "" fallback ensures type safety by preventing undefined values from being passed to the UserHome component, aligning with the noUncheckedIndexedAccess requirements.

Also applies to: 20-20, 22-22

src/Routers/routes/ResourceRoutes.tsx (1)

17-18: LGTM! Consistent handling of resource IDs.

The addition of || "" fallback ensures type safety by preventing undefined values from being passed to the ResourceDetails and ResourceDetailsUpdate components, aligning with the noUncheckedIndexedAccess requirements.

src/common/utils.tsx (1)

39-39: Verify all callers handle undefined return value

The return type change from string to string | undefined is correct for noUncheckedIndexedAccess, but could break existing code that expects a string.

src/pages/Encounters/tabs/EncounterPlotsTab.tsx (1)

33-34: LGTM! Consider additional type safety improvements

The optional chaining operator for data[0]?.id correctly handles the case when data is empty. However, consider adding type assertions or runtime checks for the entire data structure to ensure type safety.

✅ Verification successful

The code is already type-safe and well-structured

The codebase shows proper type safety measures:

  • Null checking with if (isLoading || !data)
  • Optional chaining with data[0]?.id
  • Handling undefined find() result
  • Safe array mapping in JSX
🏁 Scripts executed

The following scripts were executed for the analysis:

Script:

#!/bin/bash
# Check if there are any other array accesses in the file that might need similar treatment
rg -U '\[\d+\][^?]' src/pages/Encounters/tabs/EncounterPlotsTab.tsx

Length of output: 69


Script:

#!/bin/bash
# Get the complete file content
cat src/pages/Encounters/tabs/EncounterPlotsTab.tsx

# Also search for any array operations on data
rg -U "data\." src/pages/Encounters/tabs/EncounterPlotsTab.tsx

Length of output: 2105

src/Routers/AppRouter.tsx (1)

68-69: LGTM! Good error handling.

The conditional rendering with fallback to ErrorPage is a clean way to handle undefined route parameters.

src/components/Schedule/ScheduleTemplatesList.tsx (1)

110-111: Extract magic strings as named constants.

The default time values should be defined as constants at the module level for better maintainability and reusability.

+const DEFAULT_START_TIME = "00:00";
+const DEFAULT_END_TIME = "23:59";
+
 // ... rest of the code ...
-                            slot.availability[0]?.start_time ?? "00:00",
-                            slot.availability[0]?.end_time ?? "23:59",
+                            slot.availability[0]?.start_time ?? DEFAULT_START_TIME,
+                            slot.availability[0]?.end_time ?? DEFAULT_END_TIME,

Also, verify if these default values are appropriate for your use case, as they span the entire day.

src/pages/FacilityOrganization/components/FacilityOrganizationSelector.tsx (1)

103-108: LGTM! Proper null checks added.

The added null checks for lastOrg and lastOrg.id improve type safety by preventing potential undefined access.

src/components/Common/DateTextInput.tsx (1)

65-65: LGTM! Added safe array access.

The nullish coalescing operator ensures safe array access by providing a default value of 0 when maxMap[index] is undefined.

src/components/Questionnaire/QuestionTypes/FollowUpAppointmentQuestion.tsx (1)

53-56: LGTM! Added proper default values.

The nullish coalescing operator ensures that value is always a valid FollowUpAppointmentRequest object with default values, preventing potential undefined access.

src/components/Common/GLocationPicker.tsx (2)

140-140: LGTM! Safe access to map controls.

The optional chaining operators ensure safe access to Google Maps controls, which may be undefined during initialization.

Also applies to: 171-171, 179-179


159-159: LGTM! Safe access to places data.

The optional chaining operator ensures safe access to potentially undefined places data, preventing runtime errors.

src/hooks/useFilters.tsx (2)

97-99: LGTM! Safe handling of potentially undefined values.

The addition of || "" ensures that the value will always be a string, preventing potential undefined values from propagating.


133-133: LGTM! Safe array index access.

Adding || "" as a fallback when accessing array indices aligns with the noUncheckedIndexedAccess TypeScript option.

src/components/Common/SearchByMultipleFields.tsx (3)

72-72: LGTM! Safe initialization and type checking.

The addition of optional chaining (?.) ensures safe access to selectedOption properties during initialization and type checking.

Also applies to: 79-80


98-106: LGTM! Robust error handling in handleOptionChange.

The changes ensure safe handling of potentially undefined values:

  • Added fallbacks for option values
  • Added null check before calling onFieldChange

162-165: LGTM! Consistent null-safe property access.

Optional chaining has been added consistently across the component for accessing selectedOption properties.

Also applies to: 183-183, 188-188, 202-202

src/hooks/useFileUpload.tsx (1)

108-108: LGTM! Safe file extension extraction.

Adding || "" as a fallback ensures that the extension will always be a string, even if the filename doesn't contain a period.

src/components/Form/FormFields/PhoneNumberFormField.tsx (2)

107-113: LGTM! Robust country code handling.

The changes add proper null checks when looking up country data:

  1. Check if countryCode exists
  2. Check if countryData exists for the code

195-195: LGTM! Safe phone code conditioning.

Adding || "" ensures that the code is always a string before attempting to split it.

src/components/Common/ExcelFIleDragAndDrop.tsx (4)

66-71: LGTM! Good error handling.

The addition of the worksheet existence check with proper error handling improves the robustness of the code.


127-127: LGTM! Safe property access.

The addition of optional chaining for accessing the file type property improves type safety.


132-134: LGTM! Proper null check.

The addition of the null check before calling onSelectFile prevents potential runtime errors.


189-191: LGTM! Safe file handling.

The addition of the null check before calling onSelectFile ensures safe file handling.

src/components/ui/chart.tsx (1)

140-140: LGTM! Safe property access.

The addition of optional chaining for accessing dataKey and name properties improves type safety.

src/components/Users/UserAvailabilityTab.tsx (3)

203-204: LGTM! Safe time handling with defaults.

The addition of optional chaining and default values for time properties ensures safe access and valid time values.


302-302: LGTM! Safe start time handling.

The addition of optional chaining and default value for start_time ensures safe access and a valid time value.


303-303: LGTM! Safe end time handling.

The addition of optional chaining and default value for end_time ensures safe access and a valid time value.

src/pages/Encounters/PrintPrescription.tsx (2)

197-197: LGTM! Safe code property access.

The addition of optional chaining for accessing the code property improves type safety.


200-200: LGTM! Safe meaning property access.

The addition of optional chaining for accessing the meaning property improves type safety.

src/components/Schedule/Appointments/utils.ts (1)

55-58: LGTM! Good error handling for sorting.

The addition of optional chaining (?.) and nullish coalescing (??) operators improves the code's robustness by providing a sensible default value when sorting slots with potentially undefined values.

src/Utils/utils.ts (2)

290-292: LGTM! Safe property access in phone formatting.

Good use of optional chaining and nullish coalescing to handle potentially undefined country codes.


307-309: LGTM! Improved phone code validation.

The changes enhance the robustness of phone code validation by safely handling undefined values and providing an empty string fallback.

src/Providers/PatientUserProvider.tsx (1)

53-55: LGTM! Proper null check added.

The addition of the null check before setting the selected patient is a good defensive programming practice that aligns with the new TypeScript configuration.

src/pages/Encounters/tabs/EncounterNotesTab.tsx (1)

334-334: LGTM! Safe array access implemented.

The use of optional chaining and nullish coalescing (threadsData?.results[0]?.id ?? null) is the correct way to handle potentially undefined values when accessing array elements.

src/components/Questionnaire/QuestionnaireEditor.tsx (2)

134-136: LGTM! Safe array manipulation in drag handler.

The null check before splicing the reordered item is a good safety measure that aligns with the new TypeScript configuration.


1154-1156: LGTM! Consistent null checking pattern.

The same safety pattern is correctly applied to the sub-questions drag handler, maintaining consistency throughout the codebase.

src/components/ui/input-otp.tsx (1)

36-37: LGTM! Improved null safety handling

The changes enhance type safety by safely accessing and destructuring the slot object with a fallback to an empty object.

src/CAREUI/interactive/HumanChart.tsx (1)

39-39: LGTM! Added safety check for RegExp construction

The addition of the || "" fallback prevents potential runtime errors when constructing a RegExp with an undefined value.

src/components/Questionnaire/structured/handlers.ts (1)

152-152: LGTM! Enhanced null safety in follow-up appointment handling

The changes improve robustness by safely destructuring values with appropriate defaults, preventing potential runtime errors when handling empty or undefined follow-up appointments.

src/components/Patient/PatientRegistration.tsx Outdated Show resolved Hide resolved
src/hooks/useAppHistory.ts Outdated Show resolved Hide resolved
src/components/Schedule/routes.tsx Outdated Show resolved Hide resolved
src/components/Schedule/routes.tsx Outdated Show resolved Hide resolved
src/Routers/routes/FacilityRoutes.tsx Outdated Show resolved Hide resolved
src/Routers/routes/OrganizationRoutes.tsx Outdated Show resolved Hide resolved
src/Utils/AutoSave.tsx Show resolved Hide resolved
Copy link
Contributor

@coderabbitai coderabbitai bot left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Actionable comments posted: 0

🧹 Nitpick comments (1)
src/components/Facility/DuplicatePatientDialog.tsx (1)

42-45: Simplify null check and add default value.

The current implementation has redundant null checking. Since TypeScript's optional chaining (?.) already handles null/undefined values, the additional && operator is unnecessary.

Consider this improvement:

-            <span className="font-bold">
-              {patientList[0] && patientList[0]?.phone_number}
-            </span>
+            <span className="font-bold">
+              {patientList[0]?.phone_number ?? '-'}
+            </span>

This change:

  • Simplifies the null check using optional chaining
  • Adds a default value for better user experience when no phone number is available
🧰 Tools
🪛 Biome (1.9.4)

[error] 43-43: Change to an optional chain.

Unsafe fix: Change to an optional chain.

(lint/complexity/useOptionalChain)

📜 Review details

Configuration used: CodeRabbit UI
Review profile: CHILL
Plan: Pro

📥 Commits

Reviewing files that changed from the base of the PR and between 2f356a2 and 260e7fd.

📒 Files selected for processing (10)
  • src/Routers/routes/ConsultationRoutes.tsx (3 hunks)
  • src/Routers/routes/FacilityRoutes.tsx (1 hunks)
  • src/Routers/routes/PatientRoutes.tsx (1 hunks)
  • src/Routers/routes/ResourceRoutes.tsx (1 hunks)
  • src/Routers/routes/UserRoutes.tsx (1 hunks)
  • src/Routers/routes/questionnaireRoutes.tsx (1 hunks)
  • src/components/Facility/DuplicatePatientDialog.tsx (1 hunks)
  • src/components/Questionnaire/QuestionTypes/DateTimeQuestion.tsx (1 hunks)
  • src/components/Schedule/routes.tsx (1 hunks)
  • src/hooks/useAppHistory.ts (1 hunks)
🚧 Files skipped from review as they are similar to previous changes (9)
  • src/components/Questionnaire/QuestionTypes/DateTimeQuestion.tsx
  • src/hooks/useAppHistory.ts
  • src/Routers/routes/questionnaireRoutes.tsx
  • src/components/Schedule/routes.tsx
  • src/Routers/routes/PatientRoutes.tsx
  • src/Routers/routes/ConsultationRoutes.tsx
  • src/Routers/routes/ResourceRoutes.tsx
  • src/Routers/routes/UserRoutes.tsx
  • src/Routers/routes/FacilityRoutes.tsx
🧰 Additional context used
🪛 Biome (1.9.4)
src/components/Facility/DuplicatePatientDialog.tsx

[error] 43-43: Change to an optional chain.

Unsafe fix: Change to an optional chain.

(lint/complexity/useOptionalChain)

⏰ Context from checks skipped due to timeout of 90000ms (1)
  • GitHub Check: OSSAR-Scan

Copy link
Contributor

@coderabbitai coderabbitai bot left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Actionable comments posted: 1

🧹 Nitpick comments (3)
src/common/utils.tsx (1)

40-49: Consider optimizing the array operations.

The implementation is correct and safely handles undefined values with the nullish coalescing operator. However, we can optimize the array operations by combining filter and map into a single reduce operation.

Consider this optimization:

  return (
    humanizeStrings(
-     options
-       .filter((option) => {
-         return id instanceof Array
-           ? id.map((i) => String(i)).includes(String(option.id))
-           : String(option.id) === String(id);
-       })
-       .map((option) => option.text),
+     options.reduce((acc: string[], option) => {
+       const shouldInclude = Array.isArray(id)
+         ? id.map(String).includes(String(option.id))
+         : String(option.id) === String(id);
+       return shouldInclude ? [...acc, option.text] : acc;
+     }, []),
    ) ?? ""
  );
🧰 Tools
🪛 Biome (1.9.4)

[error] 44-44: Use Array.isArray() instead of instanceof Array.

instanceof Array returns false for array-like objects and arrays from other execution contexts.
Unsafe fix: Use Array.isArray() instead.

(lint/suspicious/useIsArray)

src/common/schemaParser.ts (2)

101-101: Remove redundant variable assignment.

The prop variable is only used once and duplicates the expression from line 97. Consider removing this assignment and using the expression directly where needed.

-      const prop = schema[key]?.prop ?? key;

       if (schema[key]?.parent) {
         const indexKey = schema[key].parent || key;
         acc[indexKey] = acc[indexKey] || {};
-        acc[indexKey][prop] = { value, error };
+        acc[indexKey][schema[key]?.prop ?? key] = { value, error };

186-189: Remove unnecessary null checks.

The current implementation has redundant safety checks:

  1. The dataWithErrors[index] check is unnecessary as dataWithErrors is created from the same array as parsedData, so the indices will always match.
  2. The optional chaining on Object.values() is redundant as it always returns an array with the some() method.
     return (
-      dataWithErrors[index] &&
-      !Object.values(dataWithErrors[index])?.some((item) => item.error)
+      !Object.values(dataWithErrors[index]).some((item) => item.error)
    );
📜 Review details

Configuration used: CodeRabbit UI
Review profile: CHILL
Plan: Pro

📥 Commits

Reviewing files that changed from the base of the PR and between 260e7fd and 7e25a9b.

📒 Files selected for processing (20)
  • src/CAREUI/interactive/HumanChart.tsx (1 hunks)
  • src/Routers/routes/FacilityRoutes.tsx (1 hunks)
  • src/Utils/AutoSave.tsx (3 hunks)
  • src/common/schemaParser.ts (2 hunks)
  • src/common/utils.tsx (1 hunks)
  • src/components/Common/AudioPlayer.tsx (1 hunks)
  • src/components/Common/Avatar.tsx (1 hunks)
  • src/components/Common/DateTextInput.tsx (1 hunks)
  • src/components/Common/ExcelFIleDragAndDrop.tsx (3 hunks)
  • src/components/Common/SearchByMultipleFields.tsx (6 hunks)
  • src/components/Form/FormFields/PhoneNumberFormField.tsx (2 hunks)
  • src/components/Questionnaire/QuestionnaireForm.tsx (1 hunks)
  • src/components/Questionnaire/structured/handlers.ts (1 hunks)
  • src/components/Schedule/routes.tsx (1 hunks)
  • src/components/Users/UserAvailabilityTab.tsx (2 hunks)
  • src/components/ui/input-otp.tsx (1 hunks)
  • src/hooks/useAppHistory.ts (1 hunks)
  • src/hooks/useFileUpload.tsx (1 hunks)
  • src/hooks/useFilters.tsx (2 hunks)
  • src/pages/FacilityOrganization/components/FacilityOrganizationSelector.tsx (1 hunks)
🚧 Files skipped from review as they are similar to previous changes (18)
  • src/components/Schedule/routes.tsx
  • src/hooks/useAppHistory.ts
  • src/components/ui/input-otp.tsx
  • src/CAREUI/interactive/HumanChart.tsx
  • src/hooks/useFileUpload.tsx
  • src/Utils/AutoSave.tsx
  • src/components/Common/Avatar.tsx
  • src/components/Questionnaire/structured/handlers.ts
  • src/components/Common/AudioPlayer.tsx
  • src/components/Common/ExcelFIleDragAndDrop.tsx
  • src/pages/FacilityOrganization/components/FacilityOrganizationSelector.tsx
  • src/components/Common/DateTextInput.tsx
  • src/hooks/useFilters.tsx
  • src/components/Questionnaire/QuestionnaireForm.tsx
  • src/components/Users/UserAvailabilityTab.tsx
  • src/Routers/routes/FacilityRoutes.tsx
  • src/components/Common/SearchByMultipleFields.tsx
  • src/components/Form/FormFields/PhoneNumberFormField.tsx
🧰 Additional context used
🪛 Biome (1.9.4)
src/common/utils.tsx

[error] 44-44: Use Array.isArray() instead of instanceof Array.

instanceof Array returns false for array-like objects and arrays from other execution contexts.
Unsafe fix: Use Array.isArray() instead.

(lint/suspicious/useIsArray)

🔇 Additional comments (1)
src/common/schemaParser.ts (1)

94-96: LGTM! Good use of optional chaining and nullish coalescing.

The changes improve type safety by properly handling potentially undefined values from validateAndParse.

src/common/utils.tsx Outdated Show resolved Hide resolved
Copy link

👋 Hi, @Rishith25,
Conflicts have been detected against the base branch. Please rebase your branch against the base branch.


This message is automatically generated by prince-chrismc/label-merge-conflicts-action so don't hesitate to report issues/improvements there.

@github-actions github-actions bot added the merge conflict pull requests with merge conflict label Jan 10, 2025
@github-actions github-actions bot added the Deploy-Failed Deplyment is not showing preview label Jan 10, 2025
Copy link
Contributor

@coderabbitai coderabbitai bot left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Actionable comments posted: 1

🧹 Nitpick comments (2)
src/components/Questionnaire/QuestionTypes/AppointmentQuestion.tsx (1)

53-56: Consider these type-safety and maintainability improvements.

While the current changes are good, consider these enhancements:

  1. Extract default values to a named constant for reusability
  2. Add JSDoc to document the initialization
  3. Improve the type casting above this code
+ /** Default values for a new appointment question */
+ const DEFAULT_APPOINTMENT: CreateAppointmentQuestion = {
+   reason_for_visit: "",
+   slot_id: "",
+ } as const;

- const values =
-   (questionnaireResponse.values?.[0]
-     ?.value as unknown as CreateAppointmentQuestion[]) || [];
+ const values = questionnaireResponse.values?.[0]?.value as
+   | CreateAppointmentQuestion[]
+   | undefined
+   ?? [];

- const value: CreateAppointmentQuestion = values[0] ?? {
-   reason_for_visit: "",
-   slot_id: "",
- };
+ const value: CreateAppointmentQuestion = values[0] ?? DEFAULT_APPOINTMENT;
src/pages/Appointments/utils.ts (1)

55-58: Consider adding validation for empty arrays before sorting.

While the current changes handle undefined array access safely, consider adding a guard clause to handle empty arrays explicitly. This would make the code more maintainable and prevent potential edge cases.

 result.sort((a, b) =>
+  // Handle empty arrays
+  !a.slots.length || !b.slots.length
+    ? 0
+    :
     compareAsc(
       a.slots[0]?.start_datetime ?? "00:00",
       b.slots[0]?.start_datetime ?? "00:00",
     ),
 );
📜 Review details

Configuration used: CodeRabbit UI
Review profile: CHILL
Plan: Pro

📥 Commits

Reviewing files that changed from the base of the PR and between 57c8e5a and 2e4e860.

📒 Files selected for processing (7)
  • src/Routers/AppRouter.tsx (1 hunks)
  • src/Routers/routes/ScheduleRoutes.tsx (1 hunks)
  • src/components/Questionnaire/QuestionTypes/AppointmentQuestion.tsx (1 hunks)
  • src/components/Questionnaire/QuestionnaireEditor.tsx (2 hunks)
  • src/components/Questionnaire/structured/handlers.ts (1 hunks)
  • src/components/Users/UserAvailabilityTab.tsx (2 hunks)
  • src/pages/Appointments/utils.ts (1 hunks)
🚧 Files skipped from review as they are similar to previous changes (4)
  • src/components/Questionnaire/structured/handlers.ts
  • src/components/Questionnaire/QuestionnaireEditor.tsx
  • src/Routers/AppRouter.tsx
  • src/components/Users/UserAvailabilityTab.tsx
🔇 Additional comments (2)
src/components/Questionnaire/QuestionTypes/AppointmentQuestion.tsx (1)

53-56: LGTM! Good type safety improvements.

The explicit type annotation and default values effectively address the noUncheckedIndexedAccess requirements while preventing potential runtime errors.

src/Routers/routes/ScheduleRoutes.tsx (1)

39-40: Maintain consistency in default value handling across components.

The same feedback applies here. Consider implementing a consistent strategy for handling undefined route parameters across all components.

src/Routers/routes/ScheduleRoutes.tsx Show resolved Hide resolved
@Rishith25
Copy link
Contributor Author

Hi @amjithtitus09 @rithviknishad @Jacobjeevan
Can you please review the PR. Let me know if any changes are required.

Copy link
Member

@rithviknishad rithviknishad left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

only did a quick pass. take inspiration from this review to make edits beyond what's reviewed.

Comment on lines +14 to +19
}) => (
<PrintPrescription
facilityId={facilityId ?? ""}
encounterId={encounterId ?? ""}
/>
),
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

would the component work with "" being passed to the id fields?

i mean, the whole reason for adding this strict check is so that it's super safe. i don't see much advantage in enabling this check when we are anyways gonna fallback to empty string.

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@rithviknishad you are right. Falling back to an empty string defeats the purpose of strict checks.

I’m planning to display the ErrorPage when the parameters are undefined or invalid:

  "/facility/:facilityId/encounter/:encounterId/prescriptions/print": ({
    facilityId,
    encounterId,
  }) => (
    facilityId && encounterId ? (
      <PrintPrescription facilityId={facilityId} encounterId={encounterId} />
    ) : (
      <ErrorPage />
    )
  ),

Does this approach align with what you had in mind?

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

the root issue seems to be with the implementation of AppRoutes type itself. It should've inferred type as string automatically instead, hence these checks wouldn't be needed in the first place.

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

what we have now:

image

what's expected:
image

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

We won't need these checks with #9890 i believe

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

i did check after enabling this config in that branch, it still gives string | undefined after enabling it. (atleast it's not never)

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

  "/facility/:facilityId/encounter/:encounterId/prescriptions/print": ({
    facilityId,
    encounterId,
  }) => (
    facilityId && encounterId ? (
      <PrintPrescription facilityId={facilityId} encounterId={encounterId} />
    ) : (
      <ErrorPage />
    )
  ),

@rithviknishad So should i follow this approach to handle the undefined right?

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

we'll need a better solution than that 😅 this approach is not maintainable. with too many routes, repeating this logic is quite cumbersome.

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

(there's a reason for the issue being 6 story points) 🙂

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@rithviknishad I have found two methods

  1. Using the non-null assertion operator (!)
/facility/:facilityId/encounter/:encounterId/prescriptions/print": ({
    facilityId,
    encounterId,
  }) => (
    <PrintPrescription facilityId={facilityId!} encounterId={encounterId!} />
  ),
  1. I have modified AppRoutes type in AppRoute.tsx
export type AppRoutes = {
  [K in keyof RouteFunction<K>]: RouteFunction<K>;
};

by 2nd method params are of type any and if we declare the param types as string

"/facility/:facilityId/encounter/:encounterId/prescriptions/print": ({
    facilityId,
    encounterId,
  }: {
    facilityId: string;
    encounterId: string;
  }) => <PrintPrescription facilityId={facilityId} encounterId={encounterId} />,

image

Currently trying to finding more methods to infer params as directly string instead of string | undefind or never

src/components/Facility/DuplicatePatientDialog.tsx Outdated Show resolved Hide resolved
src/components/Patient/PatientRegistration.tsx Outdated Show resolved Hide resolved
src/components/Questionnaire/structured/handlers.ts Outdated Show resolved Hide resolved
src/components/Users/UserAvailabilityTab.tsx Outdated Show resolved Hide resolved
src/pages/Appointments/utils.ts Outdated Show resolved Hide resolved
src/CAREUI/interactive/HumanChart.tsx Outdated Show resolved Hide resolved
@rithviknishad rithviknishad removed Deploy-Failed Deplyment is not showing preview merge conflict pull requests with merge conflict labels Jan 10, 2025
@Rishith25
Copy link
Contributor Author

Rishith25 commented Jan 10, 2025

@rithviknishad I have done all suggested changes and more relevant changes.
Please let me know if any further changes are required.

Copy link
Contributor

@coderabbitai coderabbitai bot left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Actionable comments posted: 1

♻️ Duplicate comments (1)
src/components/Questionnaire/QuestionTypes/DateTimeQuestion.tsx (1)

62-62: ⚠️ Potential issue

Replace isNaN with Number.isNaN for safer type checking

The global isNaN performs type coercion which can lead to unexpected results.

Apply this diff to improve type safety:

-    if (isNaN(hours) || isNaN(minutes)) {
+    if (Number.isNaN(hours) || Number.isNaN(minutes)) {
🧰 Tools
🪛 Biome (1.9.4)

[error] 62-62: isNaN is unsafe. It attempts a type coercion. Use Number.isNaN instead.

See the MDN documentation for more details.
Unsafe fix: Use Number.isNaN instead.

(lint/suspicious/noGlobalIsNan)


[error] 62-62: isNaN is unsafe. It attempts a type coercion. Use Number.isNaN instead.

See the MDN documentation for more details.
Unsafe fix: Use Number.isNaN instead.

(lint/suspicious/noGlobalIsNan)

🧹 Nitpick comments (2)
src/pages/Scheduling/components/EditScheduleTemplateSheet.tsx (1)

437-454: Optimize the null checks for better readability.

While the implementation is safe, the double optional chaining after the null check is redundant.

Consider simplifying the code:

  {Object.entries(availabilitiesByDay).map(([day, times]) => {
    const dayofWeek = DayOfWeek[parseInt(day)];
    if (!dayofWeek) return;
-   const formattedDay =
-     dayofWeek?.charAt(0) + dayofWeek?.slice(1).toLowerCase();
+   const formattedDay =
+     dayofWeek.charAt(0) + dayofWeek.slice(1).toLowerCase();
    return (
      <p key={day} className="flex items-center gap-2 text-sm">
src/components/Questionnaire/QuestionTypes/DateTimeQuestion.tsx (1)

58-64: Consider adding error feedback for invalid time input

Currently, the function silently returns on invalid input. Consider providing feedback to the user when they enter invalid time values.

+    const showError = (message: string) => {
+      // You can integrate this with your existing error handling system
+      console.error(message);
+    };
+
     const parts = event.target.value.split(":");
-    if (parts.length !== 2) return;
+    if (parts.length !== 2) {
+      showError("Invalid time format");
+      return;
+    }
     const [hoursStr, minutesStr] = parts;
     const hours = Number(hoursStr);
     const minutes = Number(minutesStr);

     if (Number.isNaN(hours) || Number.isNaN(minutes)) {
+      showError("Invalid time values");
       return;
     }
     if (hours < 0 || hours > 23 || minutes < 0 || minutes > 59) {
+      showError("Time values out of range");
       return;
     }
🧰 Tools
🪛 Biome (1.9.4)

[error] 62-62: isNaN is unsafe. It attempts a type coercion. Use Number.isNaN instead.

See the MDN documentation for more details.
Unsafe fix: Use Number.isNaN instead.

(lint/suspicious/noGlobalIsNan)


[error] 62-62: isNaN is unsafe. It attempts a type coercion. Use Number.isNaN instead.

See the MDN documentation for more details.
Unsafe fix: Use Number.isNaN instead.

(lint/suspicious/noGlobalIsNan)

📜 Review details

Configuration used: CodeRabbit UI
Review profile: CHILL
Plan: Pro

📥 Commits

Reviewing files that changed from the base of the PR and between 2e4e860 and 8671dfd.

📒 Files selected for processing (22)
  • src/CAREUI/interactive/HumanChart.tsx (0 hunks)
  • src/Utils/AutoSave.tsx (2 hunks)
  • src/Utils/utils.ts (2 hunks)
  • src/common/schemaParser.ts (2 hunks)
  • src/components/Common/Avatar.tsx (2 hunks)
  • src/components/Common/DateTextInput.tsx (1 hunks)
  • src/components/Common/GLocationPicker.tsx (3 hunks)
  • src/components/Common/SearchByMultipleFields.tsx (6 hunks)
  • src/components/Facility/DuplicatePatientDialog.tsx (1 hunks)
  • src/components/Patient/PatientRegistration.tsx (1 hunks)
  • src/components/Questionnaire/QuestionTypes/AppointmentQuestion.tsx (1 hunks)
  • src/components/Questionnaire/QuestionTypes/DateTimeQuestion.tsx (1 hunks)
  • src/components/Questionnaire/QuestionnaireForm.tsx (1 hunks)
  • src/components/Questionnaire/structured/handlers.ts (1 hunks)
  • src/components/Users/UserAvailabilityTab.tsx (2 hunks)
  • src/components/ui/input-otp.tsx (1 hunks)
  • src/hooks/useAppHistory.ts (1 hunks)
  • src/hooks/useFilters.tsx (2 hunks)
  • src/pages/Appointments/utils.ts (1 hunks)
  • src/pages/Encounters/tabs/EncounterNotesTab.tsx (1 hunks)
  • src/pages/Scheduling/ScheduleTemplates.tsx (1 hunks)
  • src/pages/Scheduling/components/EditScheduleTemplateSheet.tsx (2 hunks)
💤 Files with no reviewable changes (1)
  • src/CAREUI/interactive/HumanChart.tsx
🚧 Files skipped from review as they are similar to previous changes (18)
  • src/components/ui/input-otp.tsx
  • src/components/Questionnaire/QuestionTypes/AppointmentQuestion.tsx
  • src/Utils/utils.ts
  • src/components/Questionnaire/QuestionnaireForm.tsx
  • src/components/Common/Avatar.tsx
  • src/components/Common/GLocationPicker.tsx
  • src/components/Patient/PatientRegistration.tsx
  • src/components/Users/UserAvailabilityTab.tsx
  • src/pages/Encounters/tabs/EncounterNotesTab.tsx
  • src/hooks/useAppHistory.ts
  • src/components/Facility/DuplicatePatientDialog.tsx
  • src/components/Questionnaire/structured/handlers.ts
  • src/common/schemaParser.ts
  • src/pages/Appointments/utils.ts
  • src/components/Common/DateTextInput.tsx
  • src/Utils/AutoSave.tsx
  • src/hooks/useFilters.tsx
  • src/components/Common/SearchByMultipleFields.tsx
🧰 Additional context used
🪛 Biome (1.9.4)
src/components/Questionnaire/QuestionTypes/DateTimeQuestion.tsx

[error] 62-62: isNaN is unsafe. It attempts a type coercion. Use Number.isNaN instead.

See the MDN documentation for more details.
Unsafe fix: Use Number.isNaN instead.

(lint/suspicious/noGlobalIsNan)


[error] 62-62: isNaN is unsafe. It attempts a type coercion. Use Number.isNaN instead.

See the MDN documentation for more details.
Unsafe fix: Use Number.isNaN instead.

(lint/suspicious/noGlobalIsNan)

🔇 Additional comments (3)
src/pages/Scheduling/ScheduleTemplates.tsx (1)

128-135: LGTM! Robust null-safety implementation.

The addition of optional chaining and nullish coalescing operators effectively prevents potential runtime errors when accessing array elements and calculating slots.

src/pages/Scheduling/components/EditScheduleTemplateSheet.tsx (2)

333-341: LGTM! Consistent null-safety pattern.

The implementation maintains consistency with ScheduleTemplates.tsx in handling potential null values during slot calculations.


Line range hint 128-135: Well-structured implementation of null safety.

The consistent pattern of null checks and optional chaining across components demonstrates a thorough approach to preventing runtime errors and improving type safety.

Also applies to: 333-341, 437-454

@github-actions github-actions bot added the Deploy-Failed Deplyment is not showing preview label Jan 11, 2025
@github-actions github-actions bot added the merge conflict pull requests with merge conflict label Jan 12, 2025
Copy link

👋 Hi, @Rishith25,
Conflicts have been detected against the base branch. Please rebase your branch against the base branch.


This message is automatically generated by prince-chrismc/label-merge-conflicts-action so don't hesitate to report issues/improvements there.

@rithviknishad rithviknishad removed the Deploy-Failed Deplyment is not showing preview label Jan 12, 2025
Copy link

netlify bot commented Jan 12, 2025

Deploy Preview for care-ohc ready!

Name Link
🔨 Latest commit 321c635
🔍 Latest deploy log https://app.netlify.com/sites/care-ohc/deploys/67839fdee862350008bf919d
😎 Deploy Preview https://deploy-preview-9880--care-ohc.netlify.app
📱 Preview on mobile
Toggle QR Code...

QR Code

Use your smartphone camera to open QR code link.

To edit notification comments on pull requests, go to your Netlify site configuration.

@github-actions github-actions bot added merge conflict pull requests with merge conflict and removed merge conflict pull requests with merge conflict labels Jan 12, 2025
Copy link

👋 Hi, @Rishith25,
Conflicts have been detected against the base branch. Please rebase your branch against the base branch.


This message is automatically generated by prince-chrismc/label-merge-conflicts-action so don't hesitate to report issues/improvements there.

@Rishith25
Copy link
Contributor Author

@rithviknishad Is this my PR is still valid or not?

@rithviknishad
Copy link
Member

#9878 (comment)

@Rishith25
Copy link
Contributor Author

Rishith25 commented Jan 23, 2025

#9878 (comment)

@rithviknishad Should i raise a new PR for that or should I update this PR ?
Because i almost handled all undefined cases in all the files except the route files

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
merge conflict pull requests with merge conflict needs review needs testing needs-triage question Further information is requested
Projects
None yet
Development

Successfully merging this pull request may close these issues.

Enable noUncheckedIndexedAccess in tsconfig
3 participants