55 lines
1.8 KiB
Python
55 lines
1.8 KiB
Python
|
|
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', ''),
|
||
|
|
)
|
||
|
|
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()
|
||
|
|
for field in ('name', 'color', 'description'):
|
||
|
|
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
|