Transform your career journey with intelligent resume insights. Get instant ATS scores, personalized feedback, and optimization tips powered by advanced AI.
Scanara is an AI-powered resume analysis platform designed to help job seekers optimize their resumes for Applicant Tracking Systems (ATS) and improve their chances of landing interviews.
The application analyzes your resume against specific job descriptions, providing detailed feedback on:
- ATS Compatibility Score - How well your resume performs with automated screening systems
- Content Quality - Assessment of your resume's relevance and impact
- Structure & Formatting - Evaluation of organization and readability
- Skills Alignment - How well your skills match job requirements
- Tone & Style - Professional language and presentation analysis
scanara/
β
βββ app/ # Application source code
β βββ components/ # Reusable React components
β β βββ Accordion.tsx # Expandable feedback sections
β β βββ ATS.tsx # ATS score display
β β βββ Details.tsx # Detailed feedback sections
β β βββ FileUploader.tsx # Drag-and-drop upload
β β βββ Logo.tsx # Brand logo component
β β βββ Navbar.tsx # Navigation bar
β β βββ ResumeCard.tsx # Resume preview cards
β β βββ ScoreBadge.tsx # Score status indicators
β β βββ ScoreCircle.tsx # Circular score display
β β βββ ScoreGauge.tsx # Score gauge visualization
β β βββ Summary.tsx # Score summary section
β β
β βββ lib/ # Utility functions & libraries
β β βββ pdf2img.ts # PDF to image conversion
β β βββ puter.ts # Puter.js integration
β β βββ utils.ts # Helper functions
β β
β βββ routes/ # Page components (routes)
β β βββ auth.tsx # Authentication/login page
β β βββ home.tsx # Dashboard/home page
β β βββ resume.tsx # Resume review/results page
β β βββ upload.tsx # Upload & analysis page
β β βββ wipe.tsx # Data management utility
β β
β βββ app.css # Global styles & Tailwind
β βββ root.tsx # Root layout component
β βββ routes.ts # Route configuration
β
βββ public/ # Static assets
β βββ icons/ # SVG icons
β βββ images/ # Project images
β β βββ login-signup.png # Authentication screen
β β βββ upload-resume.png # Home dashboard
β β βββ upload-screen-form.png # Upload form
β β βββ upload-for-jackmayers.png # Sample upload
β β βββ analyzing-progress.png # Loading/analysis screen
β β βββ analysis-results.png # Final results page
β βββ favicon.ico
β
βββ constants/ # Application constants
β βββ index.ts
β
βββ types/ # TypeScript type definitions
β βββ index.d.ts
β βββ puter.d.ts
β
βββ package.json # Dependencies & scripts
βββ tsconfig.json # TypeScript configuration
βββ vite.config.ts # Vite build configuration
βββ react-router.config.ts # Router configuration
βββ Dockerfile # Docker configuration
βββ .gitignore # Git ignore rules
βββ README.md # Documentation
When you first visit Scanara, you're greeted with a secure authentication screen. Here's how it works:
Left Panel (Blue Gradient Background):
- Scanara logo and branding
- Application tagline and description
- Key features highlighted with badges:
- β ATS Optimization
- β AI Feedback
- β Instant Results
- Visual preview of the application
Right Panel (Sign-In Section):
- Welcome message: "Welcome Back"
- Sign-in button powered by secure Puter.js authentication
- Security notice explaining the authentication system
- Easy account creation or sign-in with existing credentials
What Happens:
- Click the "Sign In to Continue" button
- Secure authentication modal appears
- Sign in with your credentials or create a new account
- Once authenticated, you're redirected to your dashboard
After successful authentication, you land on your personalized dashboard.
Dashboard Features:
- Navigation Bar: Scanara logo (clickable link to home) and "Upload Your Resume" button
- Hero Section: Welcoming headline and motivational subtitle
- Resume Cards Grid: All your previously analyzed resumes displayed as interactive cards, each showing:
- Resume thumbnail preview
- Company name and job title
- Overall score with color-coded badge:
- π’ Green (70-100): Excellent
- π‘ Yellow (50-69): Good, needs improvement
- π΄ Red (0-49): Needs significant work
- Upload date
- "View Details" button to access full analysis
Empty State:
- If you're new, a friendly message prompts you to upload your first resume
- Large "Upload Your Resume" button to get started
Quick Actions:
- Click any resume card to view detailed analysis
- Click "Upload Your Resume" to analyze a new resume
- All resumes are automatically saved and organized by date
This is where you provide the context for analysis. The form has four main sections:
Section 1: Company Name
- Text input field
- Enter the company you're applying to
- Example: "Google", "Microsoft", "Tech Startup Inc."
Section 2: Job Title
- Text input field
- Enter the specific position title
- Example: "Senior Frontend Developer", "Product Manager"
Section 3: Job Description
- Large text area for the complete job posting
- Copy and paste the entire job description
- Include all requirements, responsibilities, and qualifications
- More detail = Better AI analysis
Section 4: Resume Upload
- Drag-and-drop zone with visual gradient border
- Click to upload or drag your PDF file
- Supports PDF files up to 20MB
- After upload, you see a preview showing:
- PDF icon
- File name
- File size
- Remove/replace option
Analyze Button:
- Large blue gradient button at bottom
- Activated only when all fields are filled with valid data
- Click to start the AI analysis process
Best Practices for Uploading:
- Use the exact job title from the posting
- Include complete job description with all sections
- Ensure your resume PDF is not password-protected
- Double-check company name and job details for accuracy
Once you click "Analyze Resume", the system springs into action with multiple processing stages:
What Happens Behind the Scenes:
-
Uploading the File (2-3 seconds)
- Your resume PDF is securely uploaded to cloud storage
- File validation ensures integrity
- Progress indicator updates in real-time
-
Converting to Image (3-5 seconds)
- PDF is converted to a high-quality image
- This allows the AI to analyze your resume's visual layout
- Formatting and design elements are preserved
-
Uploading the Image (2-3 seconds)
- Converted image is uploaded to secure storage
- Ready for AI analysis and processing
-
Preparing Data (1-2 seconds)
- Your job description and resume information are formatted
- Data is organized for AI processing
- System prepares the analysis context
-
Analyzing (10-30 seconds)
- Claude 3.7 Sonnet AI analyzes your resume
- AI compares your experience against job requirements
- AI evaluates content, structure, tone, and skills
- ATS compatibility is assessed
- Detailed feedback is generated
-
Analysis Complete
- System generates your detailed results report
- Page automatically redirects to results screen
- Your analysis is saved to your dashboard
Technical Details:
- Uses advanced AI (Claude 3.7 Sonnet from Anthropic)
- Analyzes content relevance, keywords, and ATS compatibility
- Evaluates professional tone and presentation
- Assesses skills alignment with job requirements
- All processing is secure and private
The results page is your comprehensive feedback report with actionable insights.
Layout: Split-Screen Design
Left Panel (Resume Preview):
- Full visual preview of your uploaded resume
- Sticky position - stays visible while scrolling
- Click to open full PDF in new tab
- Gradient border for visual appeal
Right Panel (Detailed Analysis & Feedback):
A. Overall Score Card
- Large circular gauge showing your overall score (0-100)
- Color-coded performance indicator
- "Your Resume Score" heading with explanation
- This score represents your resume's overall performance
B. Category Scores (Four Key Areas)
-
Tone & Style Score (0-100)
- Professional language and consistency
- Action verb strength and clarity
- Overall voice and presentation
-
Content Score (0-100)
- Relevance to job description
- Achievement quantification and impact
- Keyword optimization
-
Structure Score (0-100)
- Section organization and flow
- Visual hierarchy and readability
- Formatting consistency
-
Skills Score (0-100)
- Alignment with job requirements
- Technical proficiency demonstration
- Soft skills presentation
C. ATS Compatibility Score
- Dedicated score for Applicant Tracking System compatibility
- Critical for getting past automated screening
- Actionable tips for improvement, such as:
- Adding relevant keywords from job description
- Using standard section headings
- Avoiding complex formatting and tables
- Including both acronyms and full terms
- Using standard fonts without graphics
D. Detailed Feedback Sections (Expandable)
Each category includes:
- Strengths: What you're doing well
- Areas for Improvement: Specific issues identified
- Recommendations: Actionable steps to enhance your resume
- Examples: Before/after suggestions with concrete improvements
- Keywords: Terms from the job description you should add
How to Use These Results:
- Review your overall score to understand your resume's current state
- Identify which categories need the most improvement
- Prioritize ATS fixes first (most critical for screening)
- Read through all detailed feedback sections
- Take notes on specific recommendations
- Reference your resume on the left to match feedback to sections
- Make improvements to your resume
- Re-upload to track progress and improvements
Navigation Options:
- Back button to return to dashboard
- Click resume preview to open full PDF
- Save or export your analysis
- Compare with previous versions
- Browser-based authentication via Puter.js
- Privacy-first approach - your data stays secure
- No passwords stored locally
- Quick and seamless sign-in
- Simple drag-and-drop interface
- PDF support up to 20MB
- Instant file validation and preview
- Visual confirmation before analysis
- Advanced AI evaluation using Claude 3.7 Sonnet
- Job-specific feedback tailored to your target role
- Comprehensive scoring across multiple categories
- Contextual recommendations
- Overall score (0-100) with visual indicators
- Four category-specific scores
- ATS compatibility assessment with improvement tips
- Actionable recommendations for each section
- Strengths and weaknesses clearly identified
- Store all analyzed resumes in one place
- Track improvements over time
- Easy access to previous analyses
- Compare multiple versions
- Works seamlessly on desktop, tablet, and mobile
- Modern, intuitive user interface
- Fast and smooth experience
- Optimized for all screen sizes
- React 19 - Modern UI framework
- React Router v7 - Client-side routing
- TypeScript - Type-safe code
- Tailwind CSS - Utility-first styling
- Vite - Fast build tool and dev server
- Puter.js - Serverless backend infrastructure
- Authentication system
- Cloud file storage
- Key-value database
- AI integration
- Claude 3.7 Sonnet (Anthropic) - Advanced AI analysis
- PDF.js - PDF rendering and conversion
- Zustand - Lightweight state management
- TypeScript - Type checking and safety
- ESLint - Code quality
- Prettier - Code formatting
Before you begin, ensure you have:
- Node.js v18 or higher - Download here
- npm or yarn (comes with Node.js)
- Git - Download here
- A modern web browser
Step 1: Clone the Repository
git clone https://github.com/Maxmilla-code/Ai-resume-generator.git
cd ai-resume-analyzerStep 2: Install Dependencies
npm installStep 3: Start Development Server
npm run devStep 4: Open in Browser
Navigate to: http://localhost:5173
# Create optimized production build
npm run build
# Preview production build locally
npm run preview# Build Docker image
docker build -t scanara .
# Run container
docker run -p 5173:5173 scanara- Color Scheme: Modern blue gradients with supporting status colors
- Typography: Clean, readable fonts with clear hierarchy
- User Experience: Intuitive flow from authentication β upload β analysis β results
- Visual Feedback: Real-time progress indicators and status updates
- Accessibility: High contrast, semantic markup, keyboard navigation
- Encrypted Cloud Storage - All resumes stored securely
- Secure Authentication - Browser-based with Puter.js
- User Data Control - You own your data, not us
- No Data Selling - Your information is never sold
- Private AI Analysis - Processing is secure and confidential
We welcome contributions! Here's how you can help:
- Report bugs via GitHub Issues
- Suggest features and improvements
- Submit pull requests with enhancements
- Improve documentation and examples
- Check our documentation for detailed guides
- Review the FAQ section
- Open an issue on GitHub for bugs
- Contact us for feature requests
Made with β€οΈ by maxmilla
Helping job seekers land their dream jobs, one resume at a time.





