Skip to content

upload only mode for sync#264

Merged
Ethran merged 4 commits into
mainfrom
dev
May 24, 2026
Merged

upload only mode for sync#264
Ethran merged 4 commits into
mainfrom
dev

Conversation

@Ethran

@Ethran Ethran commented May 24, 2026

Copy link
Copy Markdown
Owner

No description provided.

Ethran added 4 commits May 24, 2026 12:49
### Build
- **app/build.gradle**: Excluded `com.tencent:mmkv` from both `onyxsdk-pen` and `onyxsdk-base` dependencies.
### UI & UX
- **LastSyncInfo**: Refactored to use `LocalConfiguration.current.locales` for localized date formatting instead of the default locale.
- Cleaned up trailing whitespace and improved indentation across multiple composable functions for better readability.
- Reorganized parameters and line breaks in `EInkActionButton`, `EInkSection`, and various `Text` components to comply with standard formatting guidelines.
### UI & UX
- **SyncSettingsTab**:
    - Externalized hardcoded strings in the experimental sync warning dialog to `strings.xml`.
    - Added vertical scrolling to the sync settings layout.
    - Removed redundant comments.

### Localization
- **Strings (English & Polish)**:
    - Added new strings for experimental sync warnings and export errors.
    - Fixed a typo in the Polish translation for Onyx device instructions ("Odmrizić" to "Odmrozić").
### Sync & Core
- **SyncSettings**: Added `uploadOnly` boolean property to manage the new sync mode.
- **SyncOrchestrator**:
    - Updated sync logic to skip remote deletions and new notebook downloads when `uploadOnly` is enabled.
    - Introduced `finalizeSyncResult` to handle non-critical `SyncUploadOnlySkip` errors.
- **NotebookReconciliationService**: Modified `syncNotebook` to return a `SyncUploadOnlySkip` error instead of downloading when remote changes are detected in upload-only mode.
- **FolderSyncService**: Updated `syncFolders` to skip applying remote folder changes to the local database when `uploadOnly` is active.
- **DomainError**: Added `SyncUploadOnlySkip` error type and `isOnlyUploadSkip()` helper to identify non-critical upload skips.

### UI & Resources
- **Strings**: Added labels for the "Upload only" setting in English and Polish; shortened existing WebDAV labels.
- **SyncSettingsTab**: Added a toggle for the `uploadOnly` setting.

### Testing
- **SyncOrchestratorTest**: Added unit tests for `finalizeSyncResult` to ensure upload-only skips are treated as successful syncs.
@Ethran Ethran merged commit 86db16a into main May 24, 2026
6 checks passed
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

None yet

Projects

None yet

Development

Successfully merging this pull request may close these issues.

1 participant