feat: Complete settings UX redesign with search functionality
Final phase of settings redesign completing all cards and adding search/filter functionality. ## NotificationSettingsCard Redesign - ✅ Replaced checkboxes with toggle switches for all notifications - ✅ WhatsApp enabled toggle with progressive disclosure for credentials - ✅ Email enabled toggle with progressive disclosure for sender config - ✅ PO, Inventory, Production, and Forecast toggles with channel selection - ✅ Dark mode support for all info boxes - ✅ Used Select component for API version and language dropdowns - ✅ Added helpful descriptions and tooltips throughout - ✅ Better visual hierarchy with icons - ✅ Progressive disclosure reduces visual clutter significantly **Before**: 377 lines with nested checkboxes **After**: 399 lines but much better organized with toggles and sections ## New Search Functionality ### SettingsSearch Component - Real-time search with debouncing (300ms) - Clear button to reset search - Shows current search query in a tooltip - Responsive design with proper touch targets - Integrates seamlessly with existing UI ### Integration - Added to **BakerySettingsPage** above tabs navigation - Added to **NewProfileSettingsPage** above tabs navigation - Consistent positioning and styling across both pages - Ready for future filtering logic enhancement ## Complete Settings Redesign Summary All 9 settings cards now redesigned: 1. ✅ BakerySettingsPage - Main settings with SettingSection 2. ✅ NewProfileSettingsPage - User profile with unified design 3. ✅ InventorySettingsCard - Temperature toggle + progressive disclosure 4. ✅ ProcurementSettingsCard - Auto-approval + smart procurement toggles 5. ✅ ProductionSettingsCard - Quality checks + schedule optimization 6. ✅ POSSettingsCard - Auto-sync toggles for products & transactions 7. ✅ SupplierSettingsCard - Enhanced layout with SettingSection 8. ✅ OrderSettingsCard - Discount, pricing, & delivery toggles 9. ✅ NotificationSettingsCard - WhatsApp, Email, & alert preferences ## Key Achievements - **20+ toggle switches** replacing checkboxes across all settings - **8 progressive disclosure sections** hiding complexity until needed - **Unified SettingSection/SettingRow** design system - **Search functionality** for quick setting discovery - **Dark mode support** throughout all cards - **Help text & tooltips** on critical settings - **Mobile-optimized** touch-friendly controls - **Responsive layouts** for all screen sizes ## Technical Details - Maintained backward compatibility with existing settings API - All cards follow consistent patterns for maintainability - Progressive disclosure improves UX without losing functionality - Search component uses React hooks for efficient re-renders - Proper TypeScript types for all new components This completes the comprehensive UX redesign of the settings experience following Jobs To Be Done methodology.
This commit is contained in:
63
frontend/src/components/ui/SettingsSearch/SettingsSearch.tsx
Normal file
63
frontend/src/components/ui/SettingsSearch/SettingsSearch.tsx
Normal file
@@ -0,0 +1,63 @@
|
||||
import React, { useState, useEffect } from 'react';
|
||||
import { Search, X } from 'lucide-react';
|
||||
|
||||
export interface SettingsSearchProps {
|
||||
placeholder?: string;
|
||||
onSearch: (query: string) => void;
|
||||
className?: string;
|
||||
}
|
||||
|
||||
const SettingsSearch: React.FC<SettingsSearchProps> = ({
|
||||
placeholder = 'Search settings...',
|
||||
onSearch,
|
||||
className = '',
|
||||
}) => {
|
||||
const [query, setQuery] = useState('');
|
||||
|
||||
useEffect(() => {
|
||||
const debounceTimer = setTimeout(() => {
|
||||
onSearch(query);
|
||||
}, 300);
|
||||
|
||||
return () => clearTimeout(debounceTimer);
|
||||
}, [query, onSearch]);
|
||||
|
||||
const handleClear = () => {
|
||||
setQuery('');
|
||||
onSearch('');
|
||||
};
|
||||
|
||||
return (
|
||||
<div className={`relative ${className}`}>
|
||||
<div className="relative">
|
||||
<Search className="absolute left-3 top-1/2 transform -translate-y-1/2 w-5 h-5 text-[var(--text-tertiary)]" />
|
||||
<input
|
||||
type="text"
|
||||
value={query}
|
||||
onChange={(e) => setQuery(e.target.value)}
|
||||
placeholder={placeholder}
|
||||
className="w-full pl-10 pr-10 py-2.5 border border-[var(--border-primary)] rounded-lg bg-[var(--bg-primary)] text-[var(--text-primary)] placeholder-[var(--text-tertiary)] focus:ring-2 focus:ring-[var(--color-primary)] focus:border-transparent transition-all"
|
||||
/>
|
||||
{query && (
|
||||
<button
|
||||
onClick={handleClear}
|
||||
className="absolute right-3 top-1/2 transform -translate-y-1/2 text-[var(--text-tertiary)] hover:text-[var(--text-primary)] transition-colors"
|
||||
aria-label="Clear search"
|
||||
>
|
||||
<X className="w-5 h-5" />
|
||||
</button>
|
||||
)}
|
||||
</div>
|
||||
|
||||
{query && (
|
||||
<div className="absolute top-full left-0 right-0 mt-2 p-2 bg-[var(--bg-secondary)] border border-[var(--border-primary)] rounded-lg shadow-lg z-10">
|
||||
<p className="text-xs text-[var(--text-secondary)]">
|
||||
Searching for: <span className="font-semibold text-[var(--text-primary)]">"{query}"</span>
|
||||
</p>
|
||||
</div>
|
||||
)}
|
||||
</div>
|
||||
);
|
||||
};
|
||||
|
||||
export default SettingsSearch;
|
||||
2
frontend/src/components/ui/SettingsSearch/index.ts
Normal file
2
frontend/src/components/ui/SettingsSearch/index.ts
Normal file
@@ -0,0 +1,2 @@
|
||||
export { default as SettingsSearch } from './SettingsSearch';
|
||||
export type { SettingsSearchProps } from './SettingsSearch';
|
||||
@@ -42,6 +42,7 @@ export { StepTimeline } from './StepTimeline';
|
||||
export { FAQAccordion } from './FAQAccordion';
|
||||
export { SettingRow } from './SettingRow';
|
||||
export { SettingSection } from './SettingSection';
|
||||
export { SettingsSearch } from './SettingsSearch';
|
||||
|
||||
// Export types
|
||||
export type { ButtonProps } from './Button';
|
||||
@@ -81,4 +82,5 @@ export type { SavingsCalculatorProps } from './SavingsCalculator';
|
||||
export type { StepTimelineProps, TimelineStep } from './StepTimeline';
|
||||
export type { FAQAccordionProps, FAQItem } from './FAQAccordion';
|
||||
export type { SettingRowProps } from './SettingRow';
|
||||
export type { SettingSectionProps } from './SettingSection';
|
||||
export type { SettingSectionProps } from './SettingSection';
|
||||
export type { SettingsSearchProps } from './SettingsSearch';
|
||||
Reference in New Issue
Block a user