{% extends "base.html" %} {% from "components/ui.html" import page_header, breadcrumb_nav, button, filter_badge, empty_state, loading_spinner, progress_indicator %} {% block content %} {% set breadcrumbs = [ {'text': 'Projects'} ] %} {{ page_header( icon_class='fas fa-folder', title_text='Projects', subtitle_text='Manage your projects here', breadcrumbs=breadcrumbs, actions_html='Create Project' if (current_user.is_admin or has_permission('create_projects')) else None ) }}
| {% endif %} | Name | Client | Status | Billable | Rate | Budget | Actions | |
|---|---|---|---|---|---|---|---|---|
| {% endif %} | {% set is_fav = favorite_project_ids and project.id in favorite_project_ids %} | {{ project.name }} | {% if project.client_id %} {{ project.client }} {% else %} {{ project.client }} {% endif %} | {% if project.status == 'active' %} Active {% elif project.status == 'inactive' %} Inactive {% else %} Archived {% endif %} | {% if project.billable %} Billable {% else %} Non-billable {% endif %} | {% if project.hourly_rate %} {{ '%.2f'|format(project.hourly_rate|float) }}/h {% else %} — {% endif %} | {% if project.budget_amount %} {% set consumed = (project.budget_consumed_amount or 0.0) %} {% set total = project.budget_amount|float %} {% set pct = (consumed / total * 100) if total > 0 else 0 %} {% if pct >= 90 %} {% set badge_classes = 'bg-red-100 text-red-700 dark:bg-red-900/30 dark:text-red-300' %} {% elif pct >= 70 %} {% set badge_classes = 'bg-amber-100 text-amber-700 dark:bg-amber-900/30 dark:text-amber-300' %} {% else %} {% set badge_classes = 'bg-green-100 text-green-700 dark:bg-green-900/30 dark:text-green-300' %} {% endif %} {{ pct|round(0) }}% {% else %} — {% endif %} | View |