-
Notifications
You must be signed in to change notification settings - Fork 522
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
Camera Preset Not Resetting on Re-selection Bug #9186
Camera Preset Not Resetting on Re-selection Bug #9186
Conversation
WalkthroughThe changes introduce a new state variable, Changes
Assessment against linked issues
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? 🪧 TipsChatThere are 3 ways to chat with CodeRabbit:
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)
Other keywords and placeholders
CodeRabbit Configuration File (
|
✅ Deploy Preview for care-ohc ready!
To edit notification comments on pull requests, go to your Netlify site configuration. |
There was a problem hiding this 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
🧹 Outside diff range and nitpick comments (3)
src/components/Facility/ConsultationDetails/ConsultationFeedTab.tsx (3)
103-103
: Remove debug console.log statementDebug logging should be removed before production deployment.
- console.log({ preset, presets });
Line range hint
188-197
: Consider documenting the timeout usageThe 3-second delay in updating session storage after camera movement isn't immediately obvious. Consider adding a comment explaining why this delay is necessary.
setSelectedPreset(undefined); setHasMoved(true); + // Allow time for camera movement to complete before capturing final position setTimeout(async () => {
Line range hint
226-236
: Fix analytics event parameterWhile the preset selection handling is correct, the analytics event uses the wrong preset name.
onChange={(value) => { triggerGoal("Camera Preset Clicked", { - presetName: preset?.name, + presetName: value.name, consultationId: props.consultationId, userId: authUser.id, result: "success", });
📜 Review details
Configuration used: CodeRabbit UI
Review profile: CHILL
📒 Files selected for processing (1)
src/components/Facility/ConsultationDetails/ConsultationFeedTab.tsx
(7 hunks)
🔇 Additional comments (5)
src/components/Facility/ConsultationDetails/ConsultationFeedTab.tsx (5)
37-37
: LGTM: Good separation of concerns
The introduction of selectedPreset
state properly separates the selection state from the active preset state, which is essential for handling preset re-selection correctly.
104-104
: LGTM: Proper state initialization
The initialization of selectedPreset
alongside preset
ensures consistent initial state.
131-134
: LGTM: Comprehensive preset update handling
The update logic properly maintains consistency between preset
and selectedPreset
states while handling all necessary cleanup operations.
186-186
: LGTM: Correct preset position binding
Using selectedPreset?.position
ensures the camera properly responds to preset re-selection, fixing the core issue.
37-37
: Verify the complete preset selection workflow
The implementation looks correct, but please verify these scenarios:
- Selecting a preset moves camera to correct position
- Manual camera movement clears selected preset
- Re-selecting the same preset restores the original position
- Saving a new position updates the preset correctly
Also applies to: 186-186, 188-188, 226-226, 236-236
✅ Verification successful
Based on the search results, I can now verify the implementation. The code shows:
- Proper state management for preset selection:
const [selectedPreset, setSelectedPreset] = useState<CameraPreset>();
- Clearing selection on manual movement:
setSelectedPreset(undefined);
setHasMoved(true);
- Position update handling:
setSelectedPreset(updated);
setHasMoved(false);
- Preset selection and restoration:
onChange={(value) => {
setSelectedPreset(value);
}}
Implementation correctly handles all preset selection scenarios
The code properly implements:
- Preset selection state management
- Clearing selection on manual camera movement
- Position restoration on preset selection
- Position updates for existing presets
🏁 Scripts executed
The following scripts were executed for the analysis:
Script:
#!/bin/bash
# Description: Check for any other camera position handling in the codebase
# Look for other camera position handling
rg -A 5 "position.*preset" --type typescript
# Check for other preset selection handling
ast-grep --pattern 'onChange($param) {
$$$
setSelectedPreset($$$)
$$$
}'
Length of output: 163
Script:
#!/bin/bash
# Search for camera position and preset handling with correct file extensions
rg -A 5 "position.*preset" -t ts -t tsx
# Look for preset selection state updates
rg -A 5 "setSelectedPreset" -t ts -t tsx
# Find camera movement handlers
rg -A 5 "(onCameraMove|handleCameraMove)" -t ts -t tsx
# Search for preset selection handlers
rg -A 5 "(onPresetSelect|handlePresetSelect)" -t ts -t tsx
Length of output: 312
Script:
#!/bin/bash
# Search for files first
fd "\.(ts|tsx)$"
# Then search with just extension
rg -A 5 "position.*preset" --type-add 'ts:*.{ts,tsx}'
# Look for preset selection state updates
rg -A 5 "setSelectedPreset" --type-add 'ts:*.{ts,tsx}'
# Find camera movement handlers
rg -A 5 "(onCameraMove|handleCameraMove)" --type-add 'ts:*.{ts,tsx}'
# Search for preset selection handlers
rg -A 5 "(onPresetSelect|handlePresetSelect)" --type-add 'ts:*.{ts,tsx}'
Length of output: 30801
@nihal467 Try testing with presets present in the configuration page (in the drop down in the feed page); those should be working. You will notice that those presets (Bed 6, switches etc) don't show up on the configuration page (talking to Rithvik about what's happening here). |
Opened issue on BE for this: ohcnetwork/care#2619 |
LGTM |
const [preset, setPreset] = useState<CameraPreset>(); | ||
const [selectedPreset, setSelectedPreset] = useState<CameraPreset>(); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
this is now confusing... so what does preset
state store?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
this is now confusing... so what does
preset
state store?
selectedPreset specifically stores user's explicit selection, whereas preset is tied to the asset object.
const asset = preset?.asset_bed.asset_object; |
src/components/Facility/ConsultationDetails/ConsultationFeedTab.tsx
Outdated
Show resolved
Hide resolved
There was a problem hiding this 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
🧹 Outside diff range and nitpick comments (2)
src/components/Facility/ConsultationDetails/ConsultationFeedTab.tsx (2)
37-37
: Document the dual state management patternWhile the separation between
selectedPreset
(user's explicit selection) andpreset
(asset-tied state) is logical, adding JSDoc comments would improve code maintainability and prevent future confusion.+ // Tracks the currently selected preset by the user const [selectedPreset, setSelectedPreset] = useState<CameraPreset>(); + // Tracks the preset tied to the asset object const [preset, setPreset] = useState<CameraPreset>();
171-173
: Add error handling for preset position changesWhile the camera feed integration works correctly, consider adding error handling for cases where the position change fails:
<CameraFeed key={key} asset={asset} preset={selectedPreset?.position} - onMove={() => { + onMove={async () => { setSelectedPreset(undefined); setHasMoved(true); + try { setTimeout(async () => { const { data } = await operate({ type: "get_status" }); if (data) { sessionStorage.setItem( feedStateSessionKey, JSON.stringify({ type: "position", value: (data as GetStatusResponse).result.position, } satisfies LastAccessedPosition), ); } }, 3000); + } catch (error) { + console.error('Failed to update camera position:', error); + // Consider showing a user-friendly error notification + } }}
📜 Review details
Configuration used: CodeRabbit UI
Review profile: CHILL
📒 Files selected for processing (2)
public/locale/en.json
(2 hunks)src/components/Facility/ConsultationDetails/ConsultationFeedTab.tsx
(6 hunks)
🔇 Additional comments (3)
src/components/Facility/ConsultationDetails/ConsultationFeedTab.tsx (2)
82-89
: LGTM: Consistent state initialization
The initialization logic correctly maintains consistency between preset
and selectedPreset
states.
116-116
: LGTM: Atomic state updates
The update logic maintains consistency between states and handles the update operation atomically.
public/locale/en.json (1)
901-901
: LGTM: Consistent localization entries
The new localization entries are properly formatted and align with the component changes.
Also applies to: 1287-1287
@Jacobjeevan Your efforts have helped advance digital healthcare and TeleICU systems. 🚀 Thank you for taking the time out to make CARE better. We hope you continue to innovate and contribute; your impact is immense! 🙌 |
Proposed Changes
@ohcnetwork/care-fe-code-reviewers
Merge Checklist
Summary by CodeRabbit
New Features
Bug Fixes