Files
fabdash/backend/app/routes/projects.py

56 lines
1.8 KiB
Python
Raw Normal View History

2026-03-05 12:13:22 -06:00
from flask import Blueprint, jsonify, request
from ..models import Project, Deliverable
from ..extensions import db
from datetime import date
projects_bp = Blueprint('projects', __name__)
@projects_bp.route('/projects', methods=['GET'])
def get_projects():
projects = Project.query.order_by(Project.created_at.desc()).all()
return jsonify([p.to_dict() for p in projects])
@projects_bp.route('/projects/<int:id>', methods=['GET'])
def get_project(id):
project = Project.query.get_or_404(id)
return jsonify(project.to_dict())
@projects_bp.route('/projects', methods=['POST'])
def create_project():
data = request.get_json()
project = Project(
name=data['name'],
color=data.get('color', '#C9A84C'),
description=data.get('description', ''),
2026-03-05 13:28:07 -06:00
drive_url=data.get('drive_url', ''),
2026-03-05 12:13:22 -06:00
)
db.session.add(project)
db.session.flush()
for d in data.get('deliverables', []):
if d.get('title') and d.get('due_date'):
db.session.add(Deliverable(
project_id=project.id,
title=d['title'],
due_date=date.fromisoformat(d['due_date']),
status=d.get('status', 'upcoming'),
))
db.session.commit()
return jsonify(project.to_dict()), 201
@projects_bp.route('/projects/<int:id>', methods=['PATCH'])
def update_project(id):
project = Project.query.get_or_404(id)
data = request.get_json()
2026-03-05 13:28:07 -06:00
for field in ('name', 'color', 'description', 'drive_url'):
2026-03-05 12:13:22 -06:00
if field in data:
setattr(project, field, data[field])
db.session.commit()
return jsonify(project.to_dict())
@projects_bp.route('/projects/<int:id>', methods=['DELETE'])
def delete_project(id):
project = Project.query.get_or_404(id)
db.session.delete(project)
db.session.commit()
return jsonify({'message': 'Project deleted'}), 200