Commit graph

18253 commits

Author SHA1 Message Date
Johannes Millan
25767261dd test(cloudflare): add test comment for Cloudflare Pages preview 2026-01-22 15:34:33 +01:00
Johannes Millan
cbeef2feb4 feat(supersync): add EU data hosting badge to login page
Add a trust badge displaying EU flag stars and "Data hosted in EU" text to the SuperSync server login/register page. The badge uses official EU flag colors (blue #039 and gold #fc0) with the circle of 12 stars from public domain SVG.
2026-01-22 15:33:02 +01:00
Johannes Millan
3b33f9bb85 chore: remove internal GDPR compliance documentation
Internal compliance documentation has been moved to a private location.
These documents contain sensitive operational procedures and security
analysis that should not be public.

Files moved:
- GDPR compliance analysis
- Incident response playbooks
- Data subject request procedures
- DPIA screening decisions
- Records of processing activities
- Infrastructure verification documents
2026-01-22 15:05:53 +01:00
Johannes Millan
16c5f0817f fix(mobile): increase dialog content max-height to 90vh on mobile
Increases max-height of mat-mdc-dialog-content from default to 90vh on
mobile viewports (≤599px) to better utilize available screen space and
reduce unnecessary scrolling in dialogs like the schedule task dialog.
2026-01-22 14:55:46 +01:00
Johannes Millan
b47772f30e docs(compliance): update operational procedures for encryption disclosure
Update incident response, data subject request, and DPIA procedures to
accurately reflect that database encryption at rest is NOT implemented
for non-E2EE users.

Changes:
- INCIDENT-RESPONSE-PLAYBOOK.md: Clarify E2EE is optional throughout,
  add physical server compromise scenarios, update risk assessments to
  differentiate E2EE vs non-E2EE users, document encryption gap in
  prevention measures
- DATA-SUBJECT-REQUEST-PROCEDURES.md: Add encryption status disclosure
  to access responses, clarify data export formats, add security notice
  about unencrypted storage for non-E2EE users
- DPIA-SCREENING-DECISION.md: Document encryption gap as additional
  consideration, update risk level to LOW-MEDIUM, add encryption gap
  to conclusion and re-assessment triggers

All procedures now consistently acknowledge 85% compliance score and
risk variance based on E2EE usage, while maintaining that DPIA is not
required per Art. 35.
2026-01-22 14:10:44 +01:00
Johannes Millan
300be32fdf feat: update wording 2026-01-22 13:37:58 +01:00
Johannes Millan
eb1bee33d7 docs(security): add SuperSync encryption at rest implementation plan
Add comprehensive plan for implementing LUKS volume encryption to meet
GDPR compliance requirements. Includes:

- Dual-key LUKS setup (operational + emergency recovery)
- Encrypted backup procedures with GPG
- Complete migration runbook with rollback procedures
- Key management and rotation procedures
- Audit logging for GDPR compliance
- Performance benchmarking criteria

Addresses primary GDPR compliance gap (database encryption at rest).
Reviewed by technical and security agents with 85% confidence level.
2026-01-22 13:34:54 +01:00
Johannes Millan
0bbced2b08 docs(compliance): document encryption risk and update privacy policy
Update GDPR compliance documentation to accurately reflect that database
encryption at rest is NOT implemented for non-E2EE users. This critical
finding required:

- Update compliance score from 92% to 85% (10% deduction for encryption gap)
- Add comprehensive encryption disclosure to privacy policies (German & English)
- Document risk: unencrypted PostgreSQL data on disk
- Update GDPR analysis with compensating controls (optional E2EE)
- Revise Records of Processing Activities with encryption status
- Add context to Alfahosting verification tracker

Changes prioritize GDPR transparency by honestly documenting security
limitations rather than overstating compliance.
2026-01-22 13:34:54 +01:00
Johannes Millan
11d6dc1738 docs(compliance): remove outdated VPS verification files 2026-01-22 13:34:54 +01:00
Johannes Millan
e93760dfb8 refactor(tasks): simplify template conditionals with @if/@else patterns
- Convert sequential @if blocks to @if/@else for mutually exclusive conditions
- Remove redundant nested repeatCfgId check (parent already guarantees condition)
- Remove redundant nested subTasks?.length checks (parent already guarantees condition)

Improves template readability without changing behavior.
2026-01-22 13:34:54 +01:00
Johannes Millan
32eca5a326 fix(e2e): resolve timing issues in 4 failing tests
- Fix tag assignment by waiting for tag to appear on task after assignment
- Fix project/tag dialog forms by adding initialization delay (300ms)
- Fix issue provider panel by handling auto-closing dialogs
- Replace arbitrary timeouts with proper element visibility checks

All 4 previously failing tests now pass consistently:
- menu-touch-submenu: tag toggling via submenu
- context-switching: project navigation and TODAY tag switching
- issue-provider-panel: dialog opening without errors

Test results: 191 passed, 0 failed (previously 4 failed)
2026-01-22 13:34:54 +01:00
Johannes Millan
b46688c553 feat: update icons 2026-01-22 13:34:54 +01:00
Johannes Millan
e5ca294680 refactor(schedule): extract magic numbers to named constants
Create schedule.constants.ts and schedule-constants.scss with named
constants for viewport thresholds, breakpoints, column widths, and
scrollbar dimensions. Update components to use constants for better
maintainability and documentation.
2026-01-22 13:34:54 +01:00
Johannes Millan
527bb229ac test(sync): add integration test for entity extraction from DELETE payload
Add integration test verifying that when a remote DELETE is applied first
but a local UPDATE wins LWW conflict resolution, the entity can be
extracted from the DELETE payload and the UPDATE applied on top of it.
2026-01-22 13:34:54 +01:00
Johannes Millan
13d3f5e96b feat(mobile-bottom-nav): add active route styling for Today and Planner buttons
- Add active state CSS reusing magic side nav theme variables
- Switch to routerLinkActive directive for declarative route matching
- Remove manual currentRoute signal tracking
2026-01-22 13:34:54 +01:00
Johannes Millan
631659de2e
Merge pull request #6103 from steindvart/make-close-buttons
Fix unlocalization text and 'Close' for single buttons
2026-01-22 13:34:48 +01:00
Johannes Millan
072b6e9674
Merge pull request #6104 from zenoprax/docs/configure-actions
docs(ci): Exclude docs/wiki/** from some actions
2026-01-22 13:33:26 +01:00
Johannes Millan
cd8faafe6d
Merge pull request #6100 from super-productivity/dependabot/npm_and_yarn/packages/plugin-dev/ai-productivity-prompts/npm_and_yarn-8567b85e05
chore(deps): bump the npm_and_yarn group across 5 directories with 1 update
2026-01-22 13:30:43 +01:00
Johannes Millan
4eef92a28e
Merge pull request #6101 from super-productivity/dependabot/npm_and_yarn/npm_and_yarn-f3562b46b9
chore(deps): bump lodash from 4.17.21 to 4.17.23 in the npm_and_yarn group across 1 directory
2026-01-22 13:30:33 +01:00
Johannes Millan
e509685c81
Merge pull request #6108 from steindvart/advanced-issue-types
Advanced issue types
2026-01-22 13:23:32 +01:00
Ivan Kalashnikov
05282e157c fix(issue-templates): standardize type casing for bug report templates 2026-01-22 16:26:21 +07:00
Ivan Kalashnikov
7bab29940c feat(issue-templates): add improved internal app error report template 2026-01-22 15:37:18 +07:00
Ivan Kalashnikov
4e4f784f2a feat(issue-templates): type instead tag, better formatting. 2026-01-22 15:14:03 +07:00
Corey Newton
ababd99b57
docs(ci): Exclude docs/wiki/** from some actions
There is no reason to run certain checks on simple documentation
updates. These Actions showed up during the initial v0.1 PR and added
noise to the PR process.
2026-01-21 20:04:16 -08:00
Ivan Kalashnikov
ea5eb6be7d fix: import TranslatePipe in dialog share component 2026-01-22 08:35:59 +07:00
Ivan Kalashnikov
0a8fe0a243 Merge remote-tracking branch 'origin/master' into adbanced-issue-types 2026-01-22 08:27:10 +07:00
Ivan Kalashnikov
5b070a395c fix: import translation constants in dialog share component 2026-01-22 08:23:55 +07:00
Ivan Kalashnikov
0c73198a71 fix: translate close button text in share and productivity breakdown dialogs 2026-01-22 08:10:03 +07:00
dependabot[bot]
3e5b7c601a
chore(deps): bump lodash in the npm_and_yarn group across 1 directory
Bumps the npm_and_yarn group with 1 update in the / directory: [lodash](https://github.com/lodash/lodash).


Updates `lodash` from 4.17.21 to 4.17.23
- [Release notes](https://github.com/lodash/lodash/releases)
- [Commits](https://github.com/lodash/lodash/compare/4.17.21...4.17.23)

---
updated-dependencies:
- dependency-name: lodash
  dependency-version: 4.17.23
  dependency-type: indirect
  dependency-group: npm_and_yarn
...

Signed-off-by: dependabot[bot] <support@github.com>
2026-01-21 23:25:58 +00:00
dependabot[bot]
89236bc50d
chore(deps): bump the npm_and_yarn group across 5 directories with 1 update
Bumps the npm_and_yarn group with 1 update in the /packages/plugin-dev/ai-productivity-prompts directory: [lodash](https://github.com/lodash/lodash).
Bumps the npm_and_yarn group with 1 update in the /packages/plugin-dev/automations directory: [lodash](https://github.com/lodash/lodash).
Bumps the npm_and_yarn group with 1 update in the /packages/plugin-dev/boilerplate-solid-js directory: [lodash](https://github.com/lodash/lodash).
Bumps the npm_and_yarn group with 1 update in the /packages/plugin-dev/procrastination-buster directory: [lodash](https://github.com/lodash/lodash).
Bumps the npm_and_yarn group with 1 update in the /packages/plugin-dev/sync-md directory: [lodash](https://github.com/lodash/lodash).


Updates `lodash` from 4.17.21 to 4.17.23
- [Release notes](https://github.com/lodash/lodash/releases)
- [Commits](https://github.com/lodash/lodash/compare/4.17.21...4.17.23)

Updates `lodash` from 4.17.21 to 4.17.23
- [Release notes](https://github.com/lodash/lodash/releases)
- [Commits](https://github.com/lodash/lodash/compare/4.17.21...4.17.23)

Updates `lodash` from 4.17.21 to 4.17.23
- [Release notes](https://github.com/lodash/lodash/releases)
- [Commits](https://github.com/lodash/lodash/compare/4.17.21...4.17.23)

Updates `lodash` from 4.17.21 to 4.17.23
- [Release notes](https://github.com/lodash/lodash/releases)
- [Commits](https://github.com/lodash/lodash/compare/4.17.21...4.17.23)

Updates `lodash` from 4.17.21 to 4.17.23
- [Release notes](https://github.com/lodash/lodash/releases)
- [Commits](https://github.com/lodash/lodash/compare/4.17.21...4.17.23)

---
updated-dependencies:
- dependency-name: lodash
  dependency-version: 4.17.23
  dependency-type: indirect
  dependency-group: npm_and_yarn
- dependency-name: lodash
  dependency-version: 4.17.23
  dependency-type: indirect
  dependency-group: npm_and_yarn
- dependency-name: lodash
  dependency-version: 4.17.23
  dependency-type: indirect
  dependency-group: npm_and_yarn
- dependency-name: lodash
  dependency-version: 4.17.23
  dependency-type: indirect
  dependency-group: npm_and_yarn
- dependency-name: lodash
  dependency-version: 4.17.23
  dependency-type: indirect
  dependency-group: npm_and_yarn
...

Signed-off-by: dependabot[bot] <support@github.com>
2026-01-21 23:25:54 +00:00
Johannes Millan
14f4ed233e
Merge pull request #6099 from super-productivity/claude/evaluate-actions-workflow-4c4ZB
fix(lighthouse): increase font budget for Material Symbols upgrade
2026-01-22 00:22:17 +01:00
Claude
47001a1228
fix(lighthouse): increase font budget for Material Symbols upgrade
The font budget was set to 260KB before the Material Icons to Material
Symbols upgrade. Material Symbols font is ~456KB, causing Lighthouse CI
to fail. Increase budget to 520KB to accommodate the larger font with
headroom for future updates.
2026-01-21 23:18:58 +00:00
Johannes Millan
0775650e6e 17.0.0-RC.13 2026-01-21 22:12:01 +01:00
Johannes Millan
86850c711a fix(sync): restore entity from DELETE payload when UPDATE wins LWW conflict
When a remote DELETE is applied before LWW resolution and the local UPDATE
wins (newer timestamp), extract the entity from the DELETE operation payload
to recreate it, preventing data loss from the race condition.
2026-01-21 21:36:26 +01:00
Johannes Millan
cfb1c656dd feat: change bottom nav order again 2026-01-21 21:19:56 +01:00
Johannes Millan
d13701e071 test(performance): add stress tests for bulk hydration and adjust timeout values 2026-01-21 21:06:19 +01:00
Johannes Millan
ff0acbdd37 fix(gitignore): correct screenshots directory path in .gitignore 2026-01-21 21:05:29 +01:00
Johannes Millan
a35331f4ff feat(schedule): restore always 7 days with horizontal scroll for week view 2026-01-21 21:00:37 +01:00
Johannes Millan
dee9faad4f fix(icons): add missing calendar icon for ICAL provider
- Created calendar.svg icon for ICAL issue provider
- Registered calendar icon in global theme service
- Updated ISSUE_PROVIDER_ICON_MAP to use 'calendar' instead of 'calendar_month'
- Fixes error: "Unable to find icon with the name :calendar_month"
2026-01-21 20:50:15 +01:00
Johannes Millan
d578beb52b style(electron): make custom window title bar fully transparent 2026-01-21 20:45:52 +01:00
Johannes Millan
cd5151f4f7 fix(ci): exclude WebDAV and SuperSync tests from build workflow
WebDAV and SuperSync E2E tests require dedicated server infrastructure
and should only run in the scheduled E2E workflow or manually. This
prevents build failures when the required servers are not available.

- Added @webdav tag to all WebDAV test files for consistent filtering
- Updated build.yml to exclude @webdav and @supersync tagged tests
2026-01-21 20:42:50 +01:00
Johannes Millan
94e1550227 fix(tasks): hide close button in bottom panel on mobile
Prevents the task close button from appearing on mobile screens (≤600px) where task details are shown in the bottom panel, improving UX by avoiding redundant UI elements.
2026-01-21 20:10:38 +01:00
Johannes Millan
3d430c154c docs(readme): update sponsor from LambdaTest to TestMu AI
Replace LambdaTest sponsor with TestMu AI in the sponsor section.
Add theme-aware logos using picture element for automatic dark/light mode support.
2026-01-21 19:54:47 +01:00
Johannes Millan
054acbdf63 fix(e2e): resolve test failures and improve encryption UX
- Fix snackbar selector in supersync edge cases test
- Add polling for plugin navigation stability
- Show error snackbar and status icon on decryption failure
- All 5 failing tests now passing consistently
2026-01-21 19:53:00 +01:00
Johannes Millan
337afed482 fix(task-view-customizer): persist sort, group, and filter settings to localStorage
Resolves issue #6095 where Task View Customizer settings (sort, group, filter)
were being reset on app restart or day change.

Changes:
- Add localStorage keys for sort/group/filter settings
- Initialize signals from localStorage with default fallbacks
- Add effects to auto-persist signal changes to localStorage
- Add 7 comprehensive unit tests for persistence behavior

Settings now persist across app restarts, work context changes, and day boundaries.
Invalid localStorage data gracefully falls back to defaults.
2026-01-21 19:41:43 +01:00
Johannes Millan
623971eacd fix(ci): allow external contributors to trigger Claude Code review workflow
Add allowed_non_write_users parameter to bypass actor permission check for PRs from external contributors. This enables automated code reviews for all PRs, including those from forks, while maintaining security through pull_request_target context.
2026-01-21 19:23:27 +01:00
Johannes Millan
4661b19f7a style(icons): change Material Icons to outlined style
Changes FILL variation setting from 1 (filled) to 0 (outlined) to render all Material Symbol icons in outlined style throughout the app.
2026-01-21 19:18:40 +01:00
Johannes Millan
867b708413 perf(e2e): cache WebDAV health checks at worker level
Optimize WebDAV E2E test startup by caching health checks at the
worker level instead of checking in each test file's beforeAll hook.

Changes:
- Create webdav.fixture.ts with worker-level health check caching
- Update 12 WebDAV test files to use new fixture
- Remove redundant beforeAll health check blocks

Impact:
- Reduces health check overhead from ~8s to ~2s when WebDAV unavailable
- Saves ~6 seconds on PR/build CI runs (combined with existing SuperSync optimization)
- Tests automatically skip when WebDAV server is not reachable
2026-01-21 19:16:58 +01:00
Johannes Millan
3a9d35149d feat(e2e): enable SuperSync tests in e2e:docker:all script
Modify e2e:docker:all to run all 360+ E2E tests including @supersync tests.

- Start all required services (app, webdav, db, supersync)
- Add wait-for-supersync.sh for SuperSync health check
- Execute tests in two phases:
  - Phase 1: Non-supersync tests (default workers)
  - Phase 2: SuperSync tests (3 workers to avoid server overload)
- Both phases run independently; exit code reflects first failure
- Previously skipped 131 @supersync tests now included

Resolves complete E2E test coverage for all sync providers.
2026-01-21 19:04:57 +01:00
Johannes Millan
73c1848ba9 fix(docs): resolve markdown linting errors in all wiki files
- Add top-level headings to all wiki files (MD041)
- Fix heading spacing and blank line issues (MD022, MD012)
- Convert HTML badges to markdown format (MD033)
- Add alt text to images (MD045)
- Fix list indentation and numbering (MD005, MD029, MD032)
- Remove trailing punctuation from headings (MD026)
- Convert emphasis to proper headings (MD036)
- Fix heading level increments (MD001)
- Add trailing newlines to all files (MD047)

This ensures the wiki-sync.yml GitHub Action will pass linting.
All changes maintain the same visual appearance and functionality.

Fixes the lint failures reported in GitHub Action run #21212863659
2026-01-21 18:03:05 +01:00