Commit Graph

105 Commits

Author SHA1 Message Date
Jose Olarte III
07b538cadc feat: implement member visibility dialog with checkbox selection and refresh
- Add "Set Visibility" dialog for meeting members who need visibility settings
- Filter members to show only those not in contacts or without seesMe set
- Implement checkbox selection with "Select All" functionality
- Add reactive checkbox behavior with proper state management
- Default all checkboxes to checked when dialog opens
- Implement "Set Visibility" action to add contacts and set seesMe property
- Add success notifications with count of affected members
- Disable "Set Visibility" button when no members are selected
- Use notification callbacks for data refresh
- Hide "Set Visibility" buttons when no members need visibility settings
- Add proper dialog state management and cleanup
- Ensure dialog closes before triggering data refresh to prevent stale states

The implementation provides a smooth user experience for managing member visibility settings with proper state synchronization between components.
2025-10-14 21:21:35 +08:00
ee587ac3fc fix: remaining starred-project issues, plus better Error logging and user verbiage 2025-09-28 19:07:48 -06:00
Jose Olarte III
c9082fa57b refactor: remove single-use notification constant
- Replace constant usage with direct message string in ImportDerivedAccountView.vue
- Clean up import statement to remove unused import
- Remove unused constant from notifications.ts
2025-09-01 16:02:48 +08:00
Jose Olarte III
c4f2bb5e3a refactor: move duplicate account import warnings to notification constants
- Add NOTIFY_DUPLICATE_ACCOUNT_IMPORT constant for import warnings
- Add NOTIFY_DUPLICATE_DERIVED_ACCOUNT constant for derived account warnings
- Update ImportAccountView.vue to use notification constants
- Update ImportDerivedAccountView.vue to use notification constants
- Update test file to use notification constants for assertions

Centralizes notification messages for better maintainability and consistency
with the existing notification system.

Files modified:
- src/constants/notifications.ts: Add new notification constants
- src/views/ImportAccountView.vue: Replace hardcoded messages with constants
- src/views/ImportDerivedAccountView.vue: Replace hardcoded messages with constants
- test-playwright/duplicate-import-test.spec.ts: Update test assertions
2025-08-28 16:44:17 +08:00
Jose Olarte III
ec53452220 Chore: lint fix 2025-08-26 16:52:32 +08:00
Jose Olarte III
ec326495b2 Merge branch 'master' into contact-gifting-current-user 2025-08-26 16:51:09 +08:00
Jose Olarte III
cc50c38d13 Chore: simplify wording for person entities
- Replaced all instances of "Unnamed Member" with "Someone Unnamed"
- Removed unused UNNAMED_MEMBER constant
- Renamed UNNAMED_PERSON to THAT_UNNAMED_PERSON to match its value
- Renamed UNNAMED_USER to UNNAMED_PERSON and changed the value to "unnamed person"
2025-08-26 16:32:57 +08:00
Jose Olarte III
eb44e7b51e Chore: convert "unnamed" into constant
- "Unnamed/Unknown" simplified into just "Unnamed"
- Phrase variations have their own constants
2025-08-18 20:33:19 +08:00
Matthew Raymer
215c37f00a Merge branch 'master' into ask-for-contacts-export 2025-08-17 02:36:57 +00:00
Matthew Raymer
379056aae1 feat(typescript): resolve Priority 2 type safety issues across components
- Eliminate all remaining any types in Priority 2 components (activity, gifts, usage limits, QR scanning, discovery, meetings)
- Implement proper TypeScript types using existing interfaces (GiveActionClaim, EndorserRateLimits, ImageRateLimits)
- Replace any types with unknown + proper type guards for error handling
- Fix type assertions for external library integrations (QR scanning, mapping)
- Maintain backward compatibility while improving type safety

Resolves 7 Priority 2 type safety warnings, achieving 100% type safety for critical user-facing functionality.
2025-08-16 14:13:36 +00:00
1f1739f00c fix: Fix messaging on the info-circles by givers & receivers in gifting details. 2025-08-06 20:54:34 -06:00
Matthew Raymer
aed16ebe94 Remove PROD_SHARE_DOMAIN constant and unify domain configuration
- Remove hard-coded PROD_SHARE_DOMAIN from src/constants/app.ts
- Update all sharing functionality to use environment-specific APP_SERVER
- Rewrite domain configuration documentation to reflect unified approach
- Simplify domain management with single APP_SERVER constant
- Update README.md examples to use APP_SERVER for all URL generation

This change eliminates the complexity of separate constants for different
URL types and provides consistent environment-specific configuration for
all functionality including sharing.
2025-08-04 03:52:21 +00:00
e5e01040b2 chore: Restore the dev setting for a variable. 2025-08-02 00:59:35 -06:00
Matthew Raymer
6007bc34e4 refactor: centralize QR navigation logic and add export prompt after contact addition
- Create QRNavigationService to handle platform-specific QR routing
- Remove direct Capacitor imports from ContactsView, ProjectsView, HelpView
- Replace duplicated QR routing logic with centralized service calls
- Update HelpView template to use platform service methods (isCapacitor, capabilities)
- Add export data prompt after successfully adding a contact
- Add NOTIFY_EXPORT_DATA_PROMPT notification constant
- Implement exportContactData() method with platform service integration
- Fix TypeScript compatibility for Vue Router route parameters
- Maintain consistent QR navigation behavior across all views

Eliminates code duplication and improves platform abstraction by using
PlatformService instead of direct Capacitor references. Enhances user
experience with automatic export prompts for data backup.
2025-07-30 12:47:55 +00:00
005bdcf0f4 remove logic that made no difference 2025-07-23 19:06:33 -06:00
Matthew Raymer
7ab595cb60 Implement configurable domain names for all copy link functionality
- Add PROD_SHARE_DOMAIN constant using existing AppString.PROD_PUSH_SERVER
- Update all 9 components/services to use configurable domain instead of hardcoded URLs
- Fix localhost issues in development mode for all sharing functionality
- Ensure all copy link buttons generate production URLs regardless of environment
- Add proper TypeScript imports and component properties for template access
- Maintain existing functionality while improving maintainability and consistency

Files updated:
- src/constants/app.ts (new constant)
- src/views/ClaimView.vue (claim + certificate links)
- src/views/ProjectViewView.vue (project links)
- src/views/ConfirmGiftView.vue (confirm gift links)
- src/components/HiddenDidDialog.vue (hidden DID links)
- src/views/UserProfileView.vue (profile links)
- src/views/InviteOneView.vue (invite links)
- src/views/ContactsView.vue (contact import links)
- src/views/OnboardMeetingSetupView.vue (meeting links)
- src/libs/endorserServer.ts (contact import confirm links)

Documentation added:
- docs/domain-configuration.md (comprehensive guide)
- README.md (quick reference section)

Security audit:  All changes maintain existing security model
Testing:  All linting errors resolved, only warnings remain
Performance:  No performance impact, improves user experience
2025-07-21 07:47:34 +00:00
Matthew Raymer
99e366d491 Complete UserNameDialog Enhanced Triple Migration Pattern (1 minute)
- Replace PlatformServiceFactory with PlatformServiceMixin methods
- Extract button styling classes to computed properties
- Add comprehensive documentation and error handling
- 87% faster than estimated migration time
2025-07-21 05:39:31 +00:00
Matthew Raymer
051fdd5681 fix: check limits message 2025-07-19 02:04:59 +00:00
f35155acdb fix: capitalize the beginning of a message 2025-07-17 19:41:53 -06:00
Matthew Raymer
d355d51ea3 feat: centralize identity creation with router navigation guard
Migrate automatic identity creation from scattered view components to centralized
router navigation guard for consistent behavior across all entry points.

**Key Changes:**
- Add global beforeEach navigation guard in router/index.ts
- Remove automatic identity creation from HomeView, ContactsView, InviteOneAcceptView,
  and OnboardMeetingMembersView
- Keep minimal fallback logic in deep link scenarios with logging
- Exclude manual identity creation routes (/start, /new-identifier, /import-account)

**Benefits:**
- Eliminates code duplication and race conditions
- Ensures consistent identity creation regardless of entry point
- Centralizes error handling with fallback to manual creation
- Improves maintainability with single point of change

**Files Modified:**
- src/router/index.ts: Add navigation guard with identity creation logic
- src/views/HomeView.vue: Remove automatic creation, simplify initializeIdentity()
- src/views/ContactsView.vue: Add fallback with logging
- src/views/InviteOneAcceptView.vue: Add fallback with logging
- src/views/OnboardMeetingMembersView.vue: Add fallback with logging

**Testing:**
- Verified first-time user navigation creates identity automatically
- Confirmed existing users bypass creation logic
- Validated manual creation routes remain unaffected
- Tested deep link scenarios with fallback logic

**Documentation:**
- Created docs/identity-creation-migration.md with comprehensive details
- Includes migration rationale, implementation details, testing scenarios
- Documents security considerations and rollback plan

Resolves inconsistent identity creation behavior across different app entry points.
2025-07-17 04:03:05 +00:00
Matthew Raymer
8dd73950f5 Fix duplicate export declarations and migrate ContactsView with sub-components
- Remove duplicate NOTIFY_INVITE_MISSING and NOTIFY_INVITE_PROCESSING_ERROR exports
- Update InviteOneAcceptView.vue to use correct NOTIFY_INVITE_TRUNCATED_DATA constant
- Migrate ContactsView to PlatformServiceMixin and extract into modular sub-components
- Resolves TypeScript compilation errors preventing web build
2025-07-16 08:03:26 +00:00
Matthew Raymer
f79454c8b5 Migrate endorserServer.ts to Enhanced Triple Migration Pattern
- Remove databaseUtil import, replace with logger.error
- Migrate $notify to modern notify pattern with createNotifyHelpers
- Add NOTIFY_PERSONAL_DATA_ERROR constant for error messages
- Use NOTIFICATION_TIMEOUTS.STANDARD for timeouts
- All phases complete: database, SQL, notification migration
- 35 minutes, 1510 lines, high complexity service file
- Linting passes with no errors
2025-07-09 09:40:25 +00:00
Matthew Raymer
702fff236f feat: Complete NewEditProjectView.vue Enhanced Triple Migration Pattern and ImageMethodDialog improvements
- Complete all 4 phases of Enhanced Triple Migration Pattern for NewEditProjectView.vue
- Replace databaseUtil calls with PlatformServiceMixin methods
- Standardize notification calls using constants and timeout helpers
- Extract 12 computed properties for template streamlining
- Add notification constants and helper functions to notifications.ts
- Extract long CSS classes to computed properties in ImageMethodDialog.vue
- Fix platformService conflict in ImageMethodDialog.vue
- Complete PushNotificationPermission.vue migration with all phases
- Update migration tracking documentation
- Migration completed in 11m 30s (74% faster than estimate)
2025-07-09 07:22:58 +00:00
Matthew Raymer
9ee9855c68 Migrate HelpView.vue to PlatformServiceMixin - extract 7 inline handlers to methods
- Replace databaseUtil calls with PlatformServiceMixin for settings operations
- Extract toggleAlpha/Group/Community/Verifiable/Governance/Basics methods
- Add copyBitcoinAddress method with clipboard feedback
- Enhance onboarding reset with error handling and logging
- Human tested: all help sections, clipboard ops, platform navigation work
- 6 minutes (3x faster than estimate), technically compliant
2025-07-09 04:56:31 +00:00
Matthew Raymer
b1435b0c42 Enhance migration templates with critical omission prevention
Add comprehensive guidance to prevent common migration oversights:
- Remove unused notification imports
- Replace hardcoded timeout values with constants
- Remove legacy wrapper functions
- Extract long class attributes to computed properties
- Replace literal strings with constants

Based on lessons learned from ContactQRScanShowView.vue migration.
Includes validation commands and specific examples for each pattern.
2025-07-09 04:42:05 +00:00
Matthew Raymer
6210a088dd Migrate InviteOneAcceptView and QuickActionBvcBeginView to Enhanced Triple Migration Pattern
- Complete database migration from databaseUtil to PlatformServiceMixin
- Migrate all notifications to helper methods + centralized constants
- Extract inline template handlers to documented methods
- Add comprehensive logging and error handling
- Add migration documentation for InviteOneAcceptView
2025-07-09 03:59:37 +00:00
Matthew Raymer
4f92656b7f feat: migrate QuickActionBvcBeginView to Enhanced Triple Migration Pattern
- Database: Replace databaseUtil with PlatformServiceMixin
- Notifications: Add BVC constants and helper system
- Template: Extract computed properties and goBack method
- Enhanced logging and comprehensive documentation
- All BVC meeting functionality preserved
2025-07-09 03:18:50 +00:00
Matthew Raymer
a2c1afd119 feat(migration): Complete SearchAreaView.vue Enhanced Triple Migration Pattern
Migrate geographic search area management from databaseUtil to modern architecture.

 Database Migration: Replace databaseUtil with PlatformServiceMixin
 Notification Migration: Add 4 constants + helper system integration
 Template Streamlining: Add actionButtonClass computed property + goBack() method
 SQL Abstraction: Verified service layer compliance

Geographic Features Preserved:
- Interactive Leaflet maps with bounding box calculation
- Privacy-preserving local storage (no server transmission)
- Real-time map interactions with visual feedback

Performance: 8 minutes (50% faster than estimate)
Testing:  Human tested - all functionality verified
Security:  Privacy protections maintained

Files: SearchAreaView.vue, constants/notifications.ts, migration docs

Migration Status: 55% complete (51/92 components)
2025-07-09 02:44:19 +00:00
Matthew Raymer
53f5b2ce4b feat: migrate HelpNotificationsView.vue to Enhanced Triple Migration Pattern
- Add PlatformServiceMixin for modern database operations
- Replace databaseUtil.updateDefaultSettings() with $updateSettings()
- Migrate 5 notifications to helper system with centralized constants
- Extract repeated CSS classes to computed properties
- Add comprehensive documentation for user support component
- Fix duplicate NOTIFY_UNCONFIRMED_HOURS export in constants
- Maintain all existing functionality and visual styling

Migration completed in 7 minutes (53% faster than estimate)
All validation checks passed, human tested successfully
Project progress: 54% (50/92 components)
2025-07-09 02:17:50 +00:00
Matthew Raymer
5ae93d70f5 SeedBackupView: Complete Enhanced Triple Migration Pattern (4 min)
- Database: Replace databaseUtil with PlatformServiceMixin
- Notifications: Add NOTIFY_PROFILE_SEED_LOAD_ERROR constant, migrate to helper system
- Template: Extract CSS classes to computed properties (copiedFeedbackClass, revealButtonClass, copyIconClass)
- Security: Enhanced documentation for critical seed backup component

Time: 4 minutes | Complexity: Simple | Quality: EXCELLENT (2.5x faster than estimate)
Human Testing: Pending | Migration Progress: 53% (49/92 components)
2025-07-09 01:17:49 +00:00
Matthew Raymer
d43d3ade34 Complete GiftedDetailsView Enhanced Triple Migration Pattern + Mixin Enhancement (10 minutes)
 Database Migration: Replaced databaseUtil.retrieveSettingsForActiveAccount() with $accountSettings()
 SQL Abstraction: Replaced PlatformServiceFactory.getInstance() with mixin methods
 Notification Migration: Added comprehensive notification system with constants
 Error Handling: Enhanced with success/error notifications for user feedback
 Mixin Enhancement: Added $mapQueryResultToValues and $mapColumnsToValues methods
 Code Quality: Eliminated databaseUtil dependency completely

- Added NOTIFY_GIFTED_DETAILS_* constants for all user-facing messages
- Replaced all direct $notify calls with notification helpers and constants
- Enhanced PlatformServiceMixin with mapping utilities to eliminate legacy dependencies
- Updated interface definitions for new mixin methods
- All linting passed, validation shows technically compliant
- EXCELLENT execution: 50% faster than estimated (10 min vs 20 min)

Migration Status: 52% complete (48/92 components, 5 human tested)
Next: Human testing to verify gift recording workflow
2025-07-08 13:14:26 +00:00
Matthew Raymer
2c7fb8be8f Complete ImportDerivedAccountView Enhanced Triple Migration Pattern (3 minutes)
 Database Migration: Replaced databaseUtil.updateDidSpecificSettings() with $saveUserSettings()
 SQL Abstraction: Replaced raw SQL with $saveSettings({ activeDid: newId.did })
 Notification Migration: Added comprehensive notification system with constants
 Error Handling: Enhanced with success/error notifications for user feedback
 Code Quality: Added proper TypeScript types and documentation

- Added NOTIFY_ACCOUNT_DERIVATION_SUCCESS/ERROR constants
- Replaced PlatformServiceFactory.getInstance() with mixin methods
- Enhanced user experience with proper success/error feedback
- All linting passed, validation shows technically compliant
- EXCELLENT execution: 85% faster than estimated (3 min vs 20 min)

Migration Status: 51% complete (47/92 components)
Next: Human testing to verify account derivation workflow
2025-07-08 12:43:52 +00:00
Matthew Raymer
af35a3055c Migrate ClaimCertificateView.vue to Enhanced Triple Migration Pattern
- Replaced all databaseUtil and direct PlatformServiceFactory usage with PlatformServiceMixin methods
- Removed all raw SQL queries from the component
- Centralized notification message in src/constants/notifications.ts
- Replaced direct $notify call with notification helper and TIMEOUTS constant
- Updated migration documentation and security audit
- Ran lint-fix; no migration-specific errors remain

Ready for human testing and validation.
2025-07-08 12:32:05 +00:00
Matthew Raymer
0d75dd6262 Migrate DiscoverView.vue to Enhanced Triple Migration Pattern
- Replaced all databaseUtil and direct PlatformServiceFactory usage with PlatformServiceMixin methods
- Removed all raw SQL queries from the component
- Centralized all notification messages in src/constants/notifications.ts
- Replaced direct $notify calls with notification helpers and TIMEOUTS constants
- Streamlined template logic (tab classes via computed properties)
- Updated migration documentation and security audit
- Ran lint-fix; no errors remain

Ready for human testing and validation.
2025-07-08 12:19:09 +00:00
Matthew Raymer
6857cb02b5 Migrate ConfirmGiftView.vue and ClaimReportCertificateView.vue to PlatformServiceMixin
- ConfirmGiftView.vue: Complete triple migration (11 minutes, EXCELLENT execution)
  - Replaced databaseUtil and PlatformServiceFactory with PlatformServiceMixin methods
  - Migrated 6 notification calls to helper methods with centralized constants
  - Added 5 new notification constants for gift confirmation workflow
  - All linting errors resolved, human tested and validated

- ClaimReportCertificateView.vue: Already migrated, marked as human tested
  - Component was already fully compliant with modern patterns
  - Human testing completed and documented
  - No additional migration work required

- Updated migration status: 47% complete (43/92 components)
- Enhanced notification constants with proper message extraction
- All components follow Enhanced Triple Migration Pattern
- Security audit: SQL injection prevention, standardized error handling
- Performance: Migration time reduced by 20% through improved processes

Migration progress: 47% complete with perfect human testing record (4/4 components)
2025-07-08 12:10:19 +00:00
Matthew Raymer
52ed8bfd4b Migrate OfferDetailsView.vue to PlatformServiceMixin, notification constants, and template streamlining
- Replaced all databaseUtil and direct PlatformServiceFactory usage with PlatformServiceMixin methods
- Abstracted all notification messages to src/constants/notifications.ts and migrated to notify helper
- Added computed properties for assignment labels to streamline template logic
- Removed unused imports and resolved all linter errors
- Updated migration documentation and ensured security audit compliance
- All changes validated with lint-fix and ready for human testing
2025-07-08 11:54:50 +00:00
Matthew Raymer
698bee6a27 ClaimReportCertificateView 2025-07-08 11:41:13 +00:00
Matthew Raymer
06c071a912 feat: migrate QuickActionBvcEndView.vue to PlatformServiceMixin and notification helpers
- Replace databaseUtil.retrieveSettingsForActiveAccount() with $settings()
- Replace raw SQL "SELECT * FROM contacts" with $getAllContacts()
- Remove databaseUtil.mapQueryResultToValues() dependency
- Extract 6 notification messages to constants in notifications.ts
- Replace all $notify() calls with notify helper methods
- Add computed properties for template optimization (hasSelectedClaims, canSubmit, claimCountText)
- Add PlatformServiceMixin as mixin
- Update template to use computed properties for cleaner logic
- Add notification templates for confirmation success messages
- All linter errors resolved; only existing warnings remain

Migration: Database + SQL + Notifications + Template streamlining
Time: 45 minutes | Complexity: Medium | Issues: None
Human Testing: Pending

Security: Eliminates raw SQL queries, standardizes error handling
Performance: Optimized contact retrieval, reduced template complexity
2025-07-08 11:15:11 +00:00
Matthew Raymer
562740ef5b Complete InviteOneView.vue Enhanced Triple Migration Pattern with human validation
- Database migration: databaseUtil → PlatformServiceMixin methods
- SQL abstraction: Raw contact insertion → $insertContact() service method
- Notification migration: 7 patterns → helper system + constants
- Template streamlining: 5 computed properties + helper methods added
- Human testing: Complete invitation lifecycle validated
- Time: 9m 5s (50% faster than estimate)
- Project: 43% complete (40/92 components migrated)
2025-07-08 10:37:05 +00:00
Matthew Raymer
bebc32047b Complete TestView.vue Enhanced Triple Migration Pattern with human validation
- Database migration: databaseUtil → PlatformServiceMixin methods
- SQL abstraction: Raw temp table queries → service methods
- Notification migration: $notify → helper system + constants
- Template streamlining: 75% reduction via computed properties
- Human testing: All 8 notification buttons + SQL interface validated
- Time: 8m 26s (3.6x faster than estimate)
- Project: 42% complete (39/92 components migrated)
2025-07-08 10:13:35 +00:00
Matthew Raymer
cc26d5161b git commit -m "feat: migrate IdentitySwitcherView.vue to Enhanced Triple Migration Pattern
- Replace databaseUtil/PlatformServiceFactory with PlatformServiceMixin
- Add notification helpers + centralized constants for identity management
- Extract button styling and account formatting to computed properties
- Improve TypeScript typing (Account interface)
- 6-minute migration achieving technical compliance
- All identity switching and deletion features preserved"
2025-07-08 08:46:38 +00:00
Matthew Raymer
277c3e79ab Complete GiftedPrompts.vue Enhanced Triple Migration Pattern (4 minutes)
Database Migration:
- Replace PlatformServiceFactory + databaseUtil with PlatformServiceMixin
- Eliminate 2 raw SQL queries (SELECT COUNT, SELECT with OFFSET)
- Use cached this.$contacts() for efficient contact access

Template Streamlining:
- Add buttonClasses computed property for consistent styling
- Add displayContactName computed property for contact fallback logic
- Add routerConfig computed property for cleaner navigation code

Performance: 75% faster than estimated (4 min vs 15-20 min)
Validation: Component now technically compliant, 0 legacy patterns
Code Quality: Enhanced maintainability with computed properties
2025-07-08 08:31:17 +00:00
Matthew Raymer
7a2f29dcd3 Replace notification literal strings with constants and add usage documentation
- Migrate remaining ContactsView.vue literal strings to centralized constants
- Add missing constants: NOTIFY_BLANK_INVITE, NOTIFY_REGISTRATION_ERROR_FALLBACK, etc.
- Create composite message functions: getRegisterPersonSuccessMessage(), getVisibilitySuccessMessage()
- Document all notification constants with usage locations in comments
- Fix scattered hardcoded notification messages preventing translation
- 0 linter errors, ContactsView.vue now fully notification-compliant
2025-07-08 08:08:46 +00:00
Matthew Raymer
7d0486a4cf Complete OnboardingDialog.vue Enhanced Triple Migration Pattern (3.5 minutes)
• Database Migration: Replace databaseUtil with PlatformServiceMixin methods
• SQL Abstraction: Replace raw SQL with $getAllContacts() and $accountSettings()
• Template Streamlining: Add 5 computed properties for consistent styling
• Vue Syntax Fix: Correct vue-facing-decorator mixin and computed property syntax

Migration Details:
- Removed: databaseUtil imports and PlatformServiceFactory usage
- Added: PlatformServiceMixin with $accountSettings(), $getAllContacts(), $updateSettings()
- Created: 5 computed properties (primaryButtonClasses, secondaryButtonClasses, etc.)
- Fixed: Proper @Component mixin declaration and class getter syntax
- Quality: Zero linting errors, full TypeScript compliance

Component provides 3-page onboarding flow (Home, Discover, Create) with
dynamic content based on user registration and contact status.
Ready for human testing across all platforms.
2025-07-08 02:32:15 +00:00
Matthew Raymer
48be4ece65 docs: Update migration status after ContactAmountsView human testing
- Update CURRENT_MIGRATION_STATUS.md with latest progress (35% complete)
- Add ContactAmountsView.vue to human testing completion list
- Update migration-time-tracker.md with testing metrics and progress
- Document 8 components now human tested, 25 ready for testing
- Update realistic estimates for remaining 59 components

Migration Progress: 33/92 components (35%) | Human Tested: 8 components
2025-07-07 13:23:30 +00:00
Matthew Raymer
6a2bc798cd docs: Update migration status after ContactEditView human testing
- Update CURRENT_MIGRATION_STATUS.md with latest progress (34% complete)
- Add ContactEditView.vue to human testing completion list
- Update migration-time-tracker.md with testing metrics and progress
- Document 7 components now human tested, 25 ready for testing
- Update realistic estimates for remaining 60 components

Migration Progress: 32/92 components (34%) | Human Tested: 7 components
2025-07-07 13:06:58 +00:00
Matthew Raymer
524c1d91be Refactor ContactsView.vue to use notification constants
- Extracted all inline notification and danger messages to src/constants/notifications.ts
- Added 20+ new notification constants and 2 template functions for dynamic messages
- Replaced all notify and danger calls with references to new constants/templates
- Updated imports for notification constants/templates and removed unused imports
- Fixed all linter errors - all notification messages now use single source of truth
- All $notify calls now use constants (remaining 3 are complex modals requiring raw calls)
2025-07-07 12:30:18 +00:00
Matthew Raymer
93a166b2b6 Complete SharedPhotoView.vue Enhanced Triple Migration Pattern (6 minutes)
Database Migration: Replace databaseUtil + PlatformServiceFactory with PlatformServiceMixin
SQL Abstraction: Use $first<Temp>(), $dbQuery(), $dbExec(), $accountSettings(), $updateSettings()
Notification Migration: Add 2 constants, migrate 3 $notify calls to helper methods
Documentation: Add comprehensive file and method-level documentation

Time: 6 minutes | Complexity: Medium | Issues: Linting fixed
Testing: Manual required | Validation: Full Enhanced Triple Migration Pattern

Component Features:
- External image sharing from device apps via deep linking
- Image upload to server with JWT authentication
- Convert images to gifts (GiveAction) or profile pictures
- Temporary storage management and cleanup
- Integration with PhotoDialog for profile image cropping
- Comprehensive error handling for upload scenarios

Technical Updates:
- Type-safe database operations with proper result mapping
- Centralized notification constants for consistency
- Enhanced error handling with detailed logging
- Clean separation of concerns between data access and UI
2025-07-07 10:38:36 +00:00
Matthew Raymer
17e30762bd Complete Enhanced Triple Migration Pattern for PhotoDialog and OfferDialog components
- Implement 4-phase migration pattern: Database + SQL + Notifications + Template Streamlining
- PhotoDialog.vue: Replace databaseUtil with PlatformServiceMixin, add 8 notification constants, extract 11 computed properties
- OfferDialog.vue: Replace databaseUtil with PlatformServiceMixin, add 7 notification constants, extract CSS classes to computed properties
- Update migration template with Phase 4 (Template Streamlining) and Phase 5 (Code Quality Review)
- Add 15 centralized notification constants to src/constants/notifications.ts

Migration validation: 25/27 components complete (93% success rate)
2025-07-07 09:56:40 +00:00
Matthew Raymer
d8fbed3873 Complete ProjectsView.vue Triple Migration Pattern with literal extraction
Apply full database migration (databaseUtil → PlatformServiceMixin), replace
raw SQL with service methods, migrate 3 notifications to helper methods.
Preserve 1 complex modal for advanced routing features while extracting
all literal strings to NOTIFY_CAMERA_SHARE_METHOD constant.

Add computed properties (offerTabClasses, projectTabClasses) to streamline
template logic and comprehensive JSDoc documentation for all methods.
Update migration templates to mandate literal extraction from complex modals.

ProjectsView.vue now appropriately incomplete: helper methods for simple
notifications, raw $notify preserved only where advanced features required.
2025-07-07 08:00:25 +00:00