Version: 1.1.0Documentation Index
Fetch the complete documentation index at: https://docs.encoreos.io/llms.txt
Use this file to discover all available pages before exploring further.
Module: FA (Finance & Revenue)
Status: Active
Purpose: This guide helps users understand how to work with tax forms, review them, and track distributions.
Table of Contents
- Overview
- Quick Reference
- Decision Tree
- Prerequisites
- Pre-Flight Checklist
- Getting Started
- Common Tasks
- Advanced Features
- Pattern Library
- Common Mistakes
- API Examples
- Tips and Best Practices
- Troubleshooting
- Related Documentation
Overview
The Tax Reporting module helps your organization manage federal tax forms (1099-NEC, W-2, Form 941, Form 940) and state tax filings. Users with appropriate permissions can view, review, and approve tax forms for filing, as well as track document distribution to vendors and employees.Key Capabilities
- View tax years and their filing status
- Review generated tax forms (1099, W-2, quarterly reports)
- Approve forms for filing to IRS
- Track document distribution and delivery status
- Export forms for records and audit purposes
Who Should Use This Guide
| Role | Use Case |
|---|---|
| Accountant | Review generated forms, approve for filing |
| Tax Reviewer | Audit form data before distribution |
| Finance Staff | Monitor tax year progress and deadlines |
| Payroll Manager | Verify W-2 data before distribution |
Quick Reference
| Action | Where | Permission Required | Key Deadline |
|---|---|---|---|
| View tax years | Finance > Tax Compliance > Tax Years | fa.tax.view | — |
| Review 1099 forms | Finance > Tax Compliance > 1099 Forms | fa.tax.view | Jan 31 |
| Review W-2 forms | Finance > Tax Compliance > W-2 Forms | fa.tax.view | Jan 31 |
| Approve forms for filing | Form detail page > Approve | fa.tax.generate | Before filing deadline |
| Generate tax reports | Finance > Tax Compliance > Tax Reports | fa.tax.generate | Quarterly (941) / Annual (940) |
| Send distributions | Finance > Tax Compliance > Distributions | fa.tax.distribute | Jan 31 (W-2/1099) |
| Resend failed deliveries | Distributions > Failed > Resend | fa.tax.distribute | Within 48 hours |
| Export/download PDF | Form detail page > Download PDF | fa.tax.view | As needed |
Decision Tree
Use this flow to determine the right action for common scenarios: I need to…- Check filing status → Go to Tax Years → Click year → View status cards
- Review a form before filing → Go to 1099 or W-2 Forms → Click form → Verify data → Click Approve
- Resend a failed distribution → Go to Distributions → Filter by “Failed” → Verify email → Click Resend
- Regenerate a form with updated data → Contact Admin (requires
fa.tax.admin) → Admin regenerates from updated payroll/AP data - File a quarterly report → Go to Tax Reports → Select report → Verify data → Click “Mark as Filed”
- Export a form for records → Open form detail page → Click “Download PDF”
Prerequisites
Permissions Required
To use Tax Reporting, you need:| Permission | Description |
|---|---|
fa.tax.view | View tax years, forms, reports, and distributions |
fa.tax.generate | Generate 1099, W-2, and quarterly/annual tax reports (for admins) |
fa.tax.distribute | Send tax documents to recipients |
Note: Contact your organization administrator if you don’t have the required permissions.
Pre-Flight Checklist
Before starting any tax reporting workflow, verify:- You have the required permissions (
fa.tax.viewat minimum) - You know the tax year you’re working with (e.g., 2025)
- You have access to vendor and employee master records
- You understand your organization’s tax filing timeline
- Payroll data is finalized for the relevant period (for W-2s)
- Vendor payment records are complete (for 1099s)
- Email addresses are verified for distribution recipients
Getting Started
Accessing Tax Reporting
- Navigate to Finance & Revenue in the main menu
- Click Tax Compliance
- You’ll see the Tax Compliance Dashboard with all active tax years
Understanding the Dashboard
The dashboard displays Status Cards for:| Card | Shows |
|---|---|
| Tax Years | Current and historical years; count of forms per year |
| 1099 Forms | Vendor tax forms; generation and filing status |
| W-2 Forms | Employee tax forms; ready-to-file count |
| Tax Reports | Quarterly (941) and annual (940) reports |
| Distributions | Email delivery tracking; sent and failed counts |
Common Tasks
Task 1: View a Tax Year
When to use: Check the status of a specific tax year and see all forms within it. Steps:- On the Dashboard, click Tax Years
- Find the tax year you want (e.g., 2025)
- Click on the year to open the Tax Year Detail page
- You’ll see:
- Year: Tax year (e.g., 2025)
- Status: Active, In Review, or Closed
- Progress: Number of forms generated, reviewed, ready to file
- Forms Generated: Count of 1099s, W-2s, and reports
- Use the Filters to find years by status
- Closed tax years are read-only; historical forms remain accessible for audit
Task 2: Review 1099-NEC Forms (Vendors)
When to use: Verify vendor information and payment totals before filing with the IRS. Steps:- Navigate to 1099 Forms
- Select the tax year
-
You’ll see a list of generated forms:
- Vendor: Company name
- EIN: Employer Identification Number
- Gross Payments: Total amount paid during the year
- Status: Pending Review, Ready to File
-
Click on a form to see details:
- Vendor Address
- Payment Breakdown (by month or category)
- Form Type (1099-NEC default)
-
Verify the data:
- Confirm vendor name and address are correct
- Check that gross payments match your records
- Review any notes or exceptions
- Click Approved to mark the form Ready to File
- Use Filter by Status to focus on pending forms
- Compare gross payments with your Accounts Payable records
- If data is incorrect, contact your Administrator to regenerate the form
Task 3: Review W-2 Forms (Employees)
When to use: Verify employee wage and tax data before distribution. Steps:- Navigate to W-2 Forms
- Select the tax year
-
You’ll see a list of generated forms:
- Employee: Name (SSN masked for security)
- Wages, Tips, and Compensation: Year-to-date gross
- Federal Tax Withheld: Total federal income tax
- Status: Pending Review, Ready to Distribute
-
Click on a form to see details:
- Employee Address
- Year-to-Date Totals: Wages, other income, deductions
- Tax Withholdings: Federal, state, Social Security
- Box 12 Codes (401k, health insurance, etc.)
-
Verify the data:
- Check gross wages against payroll records
- Confirm tax withholdings are accurate
- Review deductions and special codes
- Click Approved to mark the form Ready to Distribute
- SSN is encrypted and only visible to tax admins (for security)
- Coordinate with Payroll if you see discrepancies
- Employee W-2s are typically distributed by January 31st
Task 4: Review and File Tax Reports (941 / 940)
When to use: Verify payroll tax liability and confirm filing with the IRS. Steps:- Navigate to Tax Reports
- Select the tax year
-
You’ll see quarterly (941) and annual (940) reports:
- Report Type: 941 or 940
- Filing Period: Q1, Q2, Q3, Q4, or Annual
- Filing Status: Draft, Ready to File, Filed
- Filed Date: When the form was submitted to IRS
-
Click on a report to see details:
- Calculation Summary: Calculated tax liability
- Quarterly Breakdown (for 941): Liability by quarter
- Supporting Documentation: Links to payroll data
-
Verify the data:
- Cross-check tax liability with your payroll system
- Confirm filing period is correct
- Ensure any adjustments are documented
- Click Mark as Filed once IRS filing is confirmed
- 941 deadlines: Q1 (Apr 30), Q2 (Jul 31), Q3 (Oct 31), Q4 (Jan 31 next year)
- 940 deadline: January 31st (annual)
- Contact your tax accountant if liability seems unusual
Task 5: Track Tax Document Distribution
When to use: Monitor email delivery of tax forms to vendors and employees. Steps:- Navigate to Distributions
-
You’ll see all sent forms:
- Form Type: 1099, W-2, etc.
- Recipient: Vendor or employee name and email
- Sent Date: When the form was emailed
- Status: Sent, Read, Failed
-
Check Status:
- Sent: Email delivered; waiting for recipient to open
- Read: Recipient opened the email
- Failed: Delivery error (e.g., invalid email address)
-
For Failed deliveries:
- Verify the email address in Contacts or Payroll
- Click Resend to retry delivery
- If still failing, contact your Administrator
- Track Read status to confirm recipients received forms
- Resend failed distributions within 48 hours
- Use Filters to find forms by status or recipient type
Advanced Features
Exporting Forms for Records
- Open a specific form detail page (1099, W-2, or tax report)
- Click Download PDF (or Export)
- The form downloads as a PDF for your records or archival
- Print for filing cabinet backup
- Email to external tax accountant or CPA
- Archive for audit purposes
Filtering and Searching
On any list page (Tax Years, 1099 Forms, W-2 Forms, etc.), use:| Filter | Purpose |
|---|---|
| Status | Filter by Pending Review, Ready to File, Filed, etc. |
| Tax Year | Show forms for a specific year |
| Date Range | Filter by creation or filing date |
| Recipient | Search by vendor or employee name |
Pattern Library
UI Patterns and Expected States
| Pattern | Location | Expected Behavior |
|---|---|---|
| Dashboard Cards | Tax Compliance Dashboard | Each card shows count + status; clickable for detail |
| Forms List | 1099/W-2 Forms pages | Table with vendor/employee, amount, status; row-click for detail |
| Form Detail | Form detail page | Read-only fields with Approve/Download actions |
| Distribution Tracker | Distributions page | Table with recipient, sent date, status; Resend action for failed |
| Status Badges | All list pages | Color-coded: Draft (gray), Pending Review (yellow), Ready to File (blue), Filed (green), Failed (red) |
| Loading State | All pages | Skeleton loaders while data loads; never blank screen |
| Empty State | Forms list with no data | ”No forms generated yet” message with CTA to generate |
| Error State | On query failure | User-friendly message with Retry button; raw errors never shown |
Common Mistakes
| Symptom | Likely Cause | Fix |
|---|---|---|
| ”Approve” button is disabled | Missing fa.tax.generate permission | Contact admin to grant permission |
| Form shows incorrect wages | Payroll data not finalized | Coordinate with Payroll; admin regenerates form |
| Distribution shows “Failed” | Invalid or outdated email address | Verify email in Contacts; click Resend |
| Cannot find a tax year | Year not yet created | Contact admin to create the tax year |
| Report shows $0 liability | No payroll data for the period | Verify payroll was processed for the quarter |
| PDF download does nothing | Feature not yet enabled | Check with admin; button shows “Coming soon” tooltip if unavailable |
| Duplicate forms appear | Form was regenerated without archiving old | Contact admin to clean up duplicates |
| Cannot close tax year | Outstanding forms or distributions | Complete all pending forms and distributions first |
API Examples
Fetching Tax Years (for Developers)
The following example shows how to query tax years using the Supabase client. This is useful for building custom integrations or scripts:
Note: Always include .eq('organization_id', organizationId) for multi-tenant isolation.
Tips and Best Practices
Do’s
✅ Review all form data thoroughly before approving✅ Verify vendor EINs and employee SSNs against master records
✅ Coordinate with Payroll (HR-07) for W-2 data discrepancies
✅ Confirm email addresses are correct before distribution
✅ Track distribution status and resend failed deliveries promptly
✅ Archive completed forms and proofs of filing for your records
Don’ts
❌ Don’t approve forms without verifying data accuracy❌ Don’t change tax year status without admin approval
❌ Don’t forward unencrypted tax forms via email
❌ Don’t rely solely on email delivery; verify receipt by recipients
Troubleshooting
Issue: Form Data Looks Incorrect
Symptoms: Gross payments, wages, or tax amounts don’t match your records Cause: Source data (Payroll or Accounts Payable) may be outdated Solution:- Check HR Payroll (for W-2) or Accounts Payable (for 1099) for the correct data
- Contact your Administrator to regenerate the form with updated data
- If still incorrect, escalate to your Finance Manager
Issue: Email Not Received by Recipient
Symptoms: Recipient didn’t receive the tax form email Causes:- Email address is invalid or outdated
- Email ended up in spam folder
- Email server delivery failure
- Verify the email address in Contacts or Payroll
- Correct the address if needed
- Click Resend on the Distribution page
- Ask the recipient to check spam/junk folder
- If still failing, contact your Administrator
Issue: Cannot Approve a Form
Symptoms: “Approve” button is disabled Causes:- You don’t have
fa.tax.generatepermission - Form is already approved or filed
- System is still processing form data
- Contact your Administrator to grant the
fa.tax.generatepermission - Check the form status; if already filed, no approval needed
- Wait a few moments and refresh if the form is still loading
Related Documentation
- Admin Guide:
docs/fa/tax-reporting-admin-guide.md- For managing tax years and settings - Specification:
specs/fa/specs/FA-10-tax-reporting-compliance.md- Technical details - Integration Guide:
docs/architecture/integrations/FA-10-tax-reporting-INTEGRATION.md- How other modules connect
Last Updated: 2026-02-13
Questions? Contact your Finance Manager or Organization Administrator.