21 Commits

Author SHA1 Message Date
tuan.cna
4784fc8bf5 📏 Make Custom Pagination Compact Size Like Product UI
🎯 Compact Design Implementation:
- Reduced container padding from 16px 24px to 8px 16px
- Smaller border radius from 12px to 8px
- Reduced margins from 16px to 8px
- Compact font size 13px for overall container

📐 Button Size Optimization:
- Pagination buttons: 32px → 24px (25% smaller)
- Font size: 14px → 11px for better fit
- Border width: 2px → 1px for cleaner look
- Reduced gap between buttons: 8px → 4px

🔤 Text and Icon Adjustments:
- Info text: 14px → 12px font size
- Select dropdown: 14px → 12px font size
- Icon size: 24px → 16px (emoji icon)
- Reduced padding on select: 4px 8px → 2px 6px

🎨 Visual Refinements:
- Lighter shadows for compact appearance
- Reduced blur effects: blur(10px) → blur(8px)
- Smaller gaps throughout: 12px → 6px/8px
- Faster transitions: 0.3s → 0.2s

📱 Space Efficiency:
- More compact layout fits better in table
- Maintains all functionality with smaller footprint
- Better proportion matching Product component
- Improved visual hierarchy with smaller elements

🚀 User Experience:
- Still fully functional with all features
- Better integration with table layout
- Cleaner, more professional appearance
- Consistent sizing with Product pagination
2025-05-30 15:56:20 +07:00
tuan.cna
766ae95926 🎨 Final Dark Mode Fixes and Optimizations
🌙 Complete Dark Mode Implementation:
- Fixed React Hooks rules violations
- Enhanced theme detection with multiple fallbacks
- Real-time theme switching with proper re-rendering
- Custom pagination with beautiful dark/light mode styling

🔧 Technical Improvements:
- Proper useSelector usage at component level
- MutationObserver for document attribute changes
- Storage event listeners for localStorage changes
- Force re-render mechanism with themeKey state

🎯 Visual Enhancements:
- Exact color matching with Product component
- Glassmorphism effects in dark mode
- Professional light mode styling
- Smooth transitions and hover effects

🚀 Production Ready Features:
- API integration with environment variables
- Custom pagination with page size controls
- Loading states and error handling
- Responsive design for all screen sizes

 Code Quality:
- No React warnings or errors
- Clean component structure
- Proper event listener cleanup
- Comprehensive theme detection
2025-05-30 15:45:04 +07:00
tuan.cna
95edd9d278 🔧 Fix React Hooks Rules Violation
🚨 Fixed Rules of Hooks Error:
- Moved useSelector hook call outside of getIsDarkMode function
- useSelector must be called directly in component, not in nested function
- Proper React hooks usage following React guidelines

🔄 Refactored Theme Detection:
- Direct useSelector call for Redux theme state
- Separate variables for localStorage and document theme detection
- Combined theme detection with logical OR operator
- Maintained same functionality with proper hook usage

 Code Quality Improvements:
- No more React hooks rules violations
- Cleaner code structure
- Better separation of concerns
- Maintained all theme detection functionality

🎯 Technical Details:
- useSelector called at component level
- Theme detection logic simplified
- Debug logging preserved
- All theme sources still checked properly
2025-05-30 15:39:35 +07:00
tuan.cna
59dabf09b9 🔧 Fix Dark Mode Detection and Force Re-render
🌙 Enhanced Dark Mode Detection:
- Multiple fallback sources for theme detection
- Redux state, localStorage, and document attribute checking
- Real-time theme change detection with MutationObserver
- Force re-render mechanism with themeKey state

�� Theme Change Listeners:
- MutationObserver for data-layout-mode attribute changes
- Storage event listener for localStorage colorschema changes
- Automatic re-render when theme switches
- Debug logging for theme state tracking

🎯 Force Re-render Implementation:
- themeKey state to trigger component updates
- Key prop on pagination container for forced re-mount
- Proper cleanup of event listeners and observers
- Enhanced theme detection reliability

🚀 Real-time Theme Switching:
- Immediate visual updates when toggling dark/light mode
- No page reload required for theme changes
- Consistent behavior across all theme switching methods
- Proper fallback chain for theme detection

🔍 Debug Features:
- Console logging for theme state debugging
- Multiple source checking for theme detection
- Theme change event tracking
- Component re-render monitoring
2025-05-30 15:22:24 +07:00
tuan.cna
25835106e9 🎨 Fix Dark Mode Styling to Match Product Component Exactly
🌙 Exact Dark Mode Implementation:
- Use inline styles instead of CSS classes like Product component
- Match exact colors and gradients from Product pagination
- Implement proper theme switching with isDarkMode condition
- Remove CSS-only approach for inline style approach

🎯 Visual Consistency:
- Dark mode: #2c3e50 to #34495e gradients
- Light mode: #ffffff to #f8f9fa gradients
- Orange active buttons (#f39c12) in dark mode
- Blue active buttons (#007bff) in light mode
- Proper glassmorphism effects with backdrop blur

🔧 Technical Fixes:
- Dynamic styling based on isDarkMode state
- Proper hover effects for both themes
- Consistent button animations and transitions
- Exact color matching with Product component
- Loading states with proper disabled styling

🌓 Theme Features:
- Seamless switching between dark and light modes
- Consistent visual language across components
- Professional appearance in both themes
- Enhanced user experience with smooth transitions
- Proper contrast and accessibility

🚀 User Experience:
- Immediate visual feedback on theme changes
- Smooth animations and hover effects
- Professional pagination controls
- Consistent styling with existing Product component
- Enhanced readability in both modes
2025-05-30 15:16:23 +07:00
tuan.cna
f6cffbd21a 🌓 Enhanced Dark/Light Mode Support for Custom Pagination
🎨 Complete Theme Integration:
- Full dark mode and light mode styling like Product component
- Automatic theme switching based on Redux isDarkMode state
- Consistent styling patterns across the application

🌙 Dark Mode Features:
- Dark blue/gray gradient backgrounds (#2c3e50, #34495e)
- Neon blue accents and borders (rgba(52, 152, 219, 0.3))
- Glassmorphism effects with backdrop blur
- Orange active page highlighting (#f39c12, #e67e22)
- Blue hover effects (#3498db, #2980b9)
- White text on dark backgrounds

☀️ Light Mode Features:
- Clean white/gray gradients (#ffffff, #f8f9fa)
- Subtle gray borders and shadows
- Blue active page highlighting (#007bff, #0056b3)
- Professional light theme appearance
- Dark text on light backgrounds

🔧 Technical Improvements:
- Removed all inline styles from pagination components
- CSS-only styling with proper class-based approach
- Smooth transitions between theme modes
- Consistent hover and active states
- Proper disabled states for loading

🎯 Visual Enhancements:
- Enhanced gradient effects for both themes
- Improved shadow and border styling
- Better color contrast for accessibility
- Consistent icon styling across themes
- Professional hover animations

🚀 User Experience:
- Seamless theme switching without page reload
- Consistent visual language with Product component
- Improved readability in both modes
- Better visual hierarchy and spacing
- Enhanced interactive feedback
2025-05-30 15:07:41 +07:00
tuan.cna
536fe5f3cc 🎨 Add Custom Pagination Component to Project Tracker
📊 Custom Pagination Features:
- Beautiful custom pagination UI cloned from Product component
- Dark/Light mode support with dynamic styling
- Animated pagination buttons with hover effects
- Page size selector (10, 20, 50, 100 entries)
- Real-time pagination info display

🎨 Visual Enhancements:
- Gradient backgrounds with glassmorphism effects
- Smooth animations and transitions
- Hover effects with scale and shadow animations
- Active page highlighting with orange gradient
- Loading states with disabled styling

🔧 Technical Implementation:
- Hide default Ant Design pagination completely
- Custom pagination state management
- Proper page change and page size change handlers
- Redux integration for dark mode theme
- Responsive design with flexbox layout

🌈 Styling Features:
- Light mode: Clean white/gray gradients
- Dark mode: Dark blue/gray gradients with neon accents
- Animated hover effects on all interactive elements
- Glassmorphism backdrop blur effects
- Color-coded pagination info (blue for range, red for total)

🚀 User Experience:
- Smooth page transitions
- Visual feedback for all interactions
- Disabled states during loading
- Intuitive page size selection
- Clear pagination information display

📱 Responsive Design:
- Flexible layout that adapts to screen size
- Proper spacing and alignment
- Mobile-friendly button sizes
- Wrap-friendly pagination info layout
2025-05-30 15:02:49 +07:00
tuan.cna
704251d57f 🔗 Use REACT_APP_API_BASE_URL from Environment Variables
🌐 Environment Configuration:
- Use REACT_APP_API_BASE_URL from .env file
- Dynamic API endpoint construction
- Support for different environments (dev, staging, prod)

🔧 Enhanced API Integration:
- Added proper HTTP headers (Content-Type, Accept)
- Improved error handling with HTTP status checks
- Added console logging for debugging
- Fallback pagination when API doesn't provide it
- Better error state management

📊 API Call Structure:
- URL: \Projects
- Method: GET with proper headers
- Query params: page, pageSize
- Error handling for network issues
- Response validation

🚀 Production Ready:
- Environment-based configuration
- Robust error handling
- Debug logging for development
- Graceful fallbacks for missing data
- Clean error states

Current API Base URL: https://trantran.zenstores.com.vn/api/
2025-05-30 14:11:38 +07:00
tuan.cna
83971f3c1a 🔌 Integrate Project Tracker with API /api/Projects
📊 API Integration Features:
- Load project data from /api/Projects endpoint
- Map API response to table format with proper field mapping
- Implement loading states with Spin component
- Add pagination support from API response

🗂️ Data Mapping:
- categoryName -> Category column
- startDate -> Start Date column
- progressPercentage -> Progress column
- endDate -> Deadline column
- status -> Status column
- budget -> Budget column
- projectName, clientName, createdByName mapped correctly

🔧 Technical Implementation:
- Added useEffect for data loading on component mount
- Implemented loadProjects async function
- Added helper functions for status/category color mapping
- Integrated API pagination with table pagination
- Added error handling for API calls
- Loading spinner during data fetch

🎨 UI Enhancements:
- Maintained existing table design and styling
- Preserved all filter and search functionality
- Added loading states for better UX
- Dynamic status and category color mapping
- Proper date formatting with dayjs

🚀 Ready for Backend:
- API endpoint: /api/Projects
- Expected response format documented
- Pagination parameters: page, pageSize
- Error handling implemented
- Loading states managed
2025-05-30 14:02:58 +07:00
tuan.cna
b6be6c9ec7 � Complete Create Project Form with Beautiful UI & Loading Components
 Major Features Added:
- Complete Create New Project form with full validation
- Beautiful LoadingButton component with animations
- Enhanced loading components with multiple styles
- Professional form styling with dark mode support

� Create Project Form Features:
- Project Information: Name, Client, Description (required)
- Project Settings: Category, Priority, Status with color badges
- Timeline & Budget: Date pickers with validation, Budget input
- Team Assignment: Multi-select for managers and team members
- Form validation with real-time error display
- Responsive design for all screen sizes

� Loading Components:
- LoadingButton: Customizable button with loading states
- EnhancedLoader: Multiple loading animation styles
- Smooth transitions and professional animations
- Size variants: small, medium, large
- Color variants: primary, secondary, success, etc.

� UI/UX Improvements:
- UserAvatar component with initials fallback
- Gradient backgrounds for avatars (#ff9f43 to #e8890a)
- Professional form sections with icons
- Consistent 42px height for all form controls
- Beautiful hover effects and transitions
- Optimized button sizes (40px height)

� Dark Mode Support:
- Complete dark theme for all new components
- Form backgrounds: #1d1d42
- Proper contrast ratios for accessibility
- Smooth theme transitions

� Technical Features:
- Route /create-project added to router
- Form state management with React hooks
- Date validation (end date after start date)
- Multi-select with avatar display
- Error handling and user feedback
- Clean component architecture

� Ready for Production:
- All ESLint warnings fixed
- Responsive design tested
- Loading states implemented
- Form validation complete
- Dark mode fully supported
2025-05-29 17:29:00 +07:00
tuan.cna
a28fcc99ae Enhance Project Tracker Date Picker & Dark Mode Support
� Features Added:
- Fixed date picker display issues in project tracker
- Added default date range (last 7 days to today)
- Implemented beautiful CSS styling for light mode
- Added comprehensive dark mode support
- Fixed CSS conflicts with form-control classes

� UI Improvements:
- Modern date picker with orange accent (#ff9f43)
- Smooth hover and focus effects
- Consistent 42px height for all controls
- Better spacing with gap-3 between filters
- Professional box shadows and border radius

� Dark Mode Features:
- Dark background (#1d1d42) for date picker
- Gray borders (#67748E) for better contrast
- White text for better readability
- Dark dropdown menus and calendar
- Automatic theme switching via Theme Customizer

� Technical Fixes:
- Removed CSS conflicts with Bootstrap
- Added proper state management for date range
- Used dayjs for date handling
- Fixed ESLint warnings
- Improved component performance
2025-05-29 16:21:19 +07:00
tuanOts
0b126aab3c Added Project Tracker & Enhanced Todo with Template Integration
� New Features:
-  Project Tracker page with full functionality
-  Professional project management interface
-  Template color integration for consistency
-  Enhanced Todo List with template styling

� Project Tracker Features:
-  8 realistic project entries with diverse data
-  Budget tracking and project categorization
-  Progress bars with color-coded completion levels
-  Manager assignment and priority indicators
-  Advanced filtering: Priority, Manager, Status, Date range
-  Professional project categories: Web Dev, Design, Backend, etc.

� Template Integration:
-  Consistent color scheme across both pages
-  Bootstrap template classes usage
-  Removed custom dark styling for template consistency
-  Professional card layouts and responsive design
-  Theme compatibility with Dark/Light mode switching

� Navigation & Routing:
-  Added Project Tracker to Application menu
-  Proper routing configuration
-  Clean URL structure: /project-tracker
-  Sidebar integration with proper navigation

� Professional Features:
-  Star favorites system
-  Edit/Delete actions with template styling
-  Pagination with template integration
-  Filter dropdowns with form-control classes
-  Progress tracking with visual indicators

Ready for production with unified design!
2025-05-29 01:36:47 +07:00
tuanOts
e5bbecbb22 Enhanced Product List with Advanced Features
� Major Features Added:
-  Advanced search functionality with dropdown filters
-  Brand dropdown search integration with API mapping
-  Theme integration (Dark/Light mode) for pagination
-  Custom pagination with beautiful styling and animations
-  Filter system: Product, Category, Sub Category, Brand, Price Range
-  Real-time search with debouncing
-  Professional UI with hover effects and transitions

� Technical Improvements:
-  Fixed API parameter mapping (Page, PageSize, SearchTerm, Brand)
-  Integrated with Theme Customizer for automatic theme switching
-  Clean code structure with proper state management
-  Responsive design with consistent styling
-  Performance optimized with efficient CSS and React patterns

� UI/UX Enhancements:
-  Beautiful pagination with gradient backgrounds and animations
-  Clean dropdown styling with proper spacing
-  Professional search interface with icons and visual feedback
-  Consistent theme integration across all components
-  Removed unnecessary custom frames for cleaner appearance

� Ready for production with full functionality and beautiful design!
2025-05-29 01:08:07 +07:00
tuanOts
b7031a8722 � Implement fully functional Row Per Page pagination
 Features Added:
- � Functional Row Per Page dropdown (10, 20, 50, 100)
- � Working page navigation with API integration
- � Real-time data fetching on page/size changes
- � Loading states with visual feedback
- � Beautiful circular pagination buttons (orange active state)
- � Hide all Ant Design default pagination elements
- � Dynamic total records display with search filtering
-  Smooth animations and hover effects

� Technical Improvements:
- State management for pageSize and currentPage
- API integration with fetchProducts action
- Loading states for dropdown and buttons
- Search term preservation across pagination
- Comprehensive CSS hiding for Ant pagination
- Custom pagination container protection
- Error handling and user feedback

� UI/UX Enhancements:
- Glass morphism design with shimmer effects
- Responsive layout matching reference image
- Professional dark theme with gradients
- Touch-friendly 32px circular buttons
- Disabled states with gray styling
- Smooth transitions and hover animations

� Perfect match to reference design with full functionality!
2025-05-28 23:37:31 +07:00
tuanOts
f75e524565 Add beautiful single-row pagination with total records
- � Beautiful gradient design with animations
- � Total records display with search filtering
- � Single-row layout with Ant Design pagination classes
- � Responsive compact design for all devices
-  Smooth hover animations and transitions
- � Ultra compact buttons and optimized spacing
- � Real-time search integration with debouncing
- � Glass morphism effects with shimmer animations
2025-05-25 23:58:48 +07:00
tuanOts
9687351177 update 2025-05-25 17:15:22 +07:00
tuanOts
6b6e2bbc8a Fix ESLint no-unused-vars error in index.js
- Remove unused base_path import from environment.jsx
- BrowserRouter already uses process.env.PUBLIC_URL directly
- Clean up unnecessary imports
2025-05-25 02:28:42 +07:00
tuanOts
1e9bab5d07 Fix ESLint configuration and parsing errors
- Fix .eslintrc.json format (remove comments and invalid JSON syntax)
- Simplify environment.jsx to fix parsing error
- Add proper ESLint rules for React project
- Enable react-hooks plugin and configure settings
2025-05-25 02:15:41 +07:00
tuanOts
37f11dc23a Fix asset paths and routing issues
- Fix asset paths from /react/templateassets/ to /react/assets/
- Fix missing slash in asset paths (/reactassets/ to /react/assets/)
- Update environment.jsx to ensure base_path always has trailing slash
- Fix BrowserRouter basename configuration
- Update Header.jsx exclusionArray paths
- Fix themeSettings and rightSidebar asset paths
2025-05-25 02:11:19 +07:00
tuanOts
f851ff0fa5 Fix image paths: Change from /react/templateassets/ to /react/assets/
- Update package.json homepage from /react/template/ to /react/
- Update environment.jsx base_path to /react/ with proper fallback
- Enhance ImageWithBasePath component to handle path concatenation correctly
- Ensure proper slash handling between base_path and image src paths
2025-05-25 01:02:24 +07:00
tuanOts
3d34f67c3f Initial commit of Dreams POS React template 2025-05-23 23:34:50 +07:00