Compare commits
5 Commits
2c557818f7
...
c945a2adb6
Author | SHA1 | Date | |
---|---|---|---|
c945a2adb6 | |||
f6ba77e533 | |||
a7ed4d06fb | |||
e30a0a6f9b | |||
43f53fe79b |
3
.gitignore
vendored
3
.gitignore
vendored
@ -1 +1,2 @@
|
||||
develop.md
|
||||
develop.md
|
||||
.env
|
@ -1 +0,0 @@
|
||||
|
@ -3,8 +3,8 @@
|
||||
|
||||
技術スタックは以下の通り
|
||||
|
||||
- Go
|
||||
- Gin
|
||||
- Python
|
||||
- Flask
|
||||
- JavaScript
|
||||
- Bootstrap or Tailwind テンプレート(未定)
|
||||
- MySQL
|
||||
|
25
app/__init__.py
Normal file
25
app/__init__.py
Normal file
@ -0,0 +1,25 @@
|
||||
from flask import Flask
|
||||
from flask_sqlalchemy import SQLAlchemy
|
||||
from flask_login import LoginManager
|
||||
import os
|
||||
|
||||
# db = SQLAlchemy()
|
||||
login_manager = LoginManager()
|
||||
#login_manager.login_view = 'auth.login'
|
||||
login_manager.login_message_category = 'info'
|
||||
|
||||
# TODO:DB設定などのコードを書く
|
||||
def create_app():
|
||||
app = Flask(__name__)
|
||||
# TODO:シークレットキーは設定ファイルで管理
|
||||
app.config['SECRET_KEY'] = 'secret'
|
||||
app.config['SQLALCHEMY_DATABASE_URI'] = 'mysql+pymysql://root:password@localhost/workout'
|
||||
app.config['SQLALCHEMY_TRACK_MODIFICATIONS'] = False
|
||||
|
||||
#db.init_app(app)
|
||||
#login_manager.init_app(app)
|
||||
|
||||
#with app.app_context():
|
||||
#db.create_all()
|
||||
|
||||
return app
|
0
app/models/__init__.py
Normal file
0
app/models/__init__.py
Normal file
65
app/models/workout.py
Normal file
65
app/models/workout.py
Normal file
@ -0,0 +1,65 @@
|
||||
from . import db
|
||||
from datetime import datetime, date
|
||||
|
||||
class User(db.Model):
|
||||
__tablename__ = 'users'
|
||||
|
||||
id = db.Column(db.Integer, primary_key=True)
|
||||
username = db.Column(db.String(80), unique=True, nullable=False)
|
||||
email = db.Column(db.String(120), unique=True, nullable=True)
|
||||
password_hash = db.Column(db.String(128), nullable=False)
|
||||
profile_image_url = db.Column(db.String(255), nullable=True)
|
||||
bio = db.Column(db.Text, nullable=True)
|
||||
created_at = db.Column(db.DateTime, nullable=False, default=datetime.utcnow)
|
||||
updated_at = db.Column(db.DateTime, nullable=False, default=datetime.utcnow, onupdate=datetime.utcnow)
|
||||
|
||||
workouts = db.relationship('Workout', backref='user', lazy=True, cascade="all, delete-orphan")
|
||||
|
||||
def __repr__(self):
|
||||
return f'<User {self.username}>'
|
||||
|
||||
class Workout(db.Model):
|
||||
__tablename__ = 'workouts'
|
||||
|
||||
id = db.Column(db.Integer, primary_key=True)
|
||||
user_id = db.Column(db.Integer, db.ForeignKey('users.id'), nullable=False)
|
||||
title = db.Column(db.String(120), nullable=False)
|
||||
workout_date = db.Column(db.Date, nullable=False, default=date.today)
|
||||
memo = db.Column(db.Text, nullable=True)
|
||||
created_at = db.Column(db.DateTime, nullable=False, default=datetime.utcnow)
|
||||
updated_at = db.Column(db.DateTime, nullable=False, default=datetime.utcnow, onupdate=datetime.utcnow)
|
||||
|
||||
logs = db.relationship('WorkoutLog', backref='workout', lazy=True, cascade="all, delete-orphan")
|
||||
|
||||
def __repr__(self):
|
||||
return f'<Workout {self.title} on {self.workout_date}>'
|
||||
|
||||
class Exercise(db.Model):
|
||||
__tablename__ = 'exercises'
|
||||
|
||||
id = db.Column(db.Integer, primary_key=True)
|
||||
name = db.Column(db.String(120), unique=True, nullable=False)
|
||||
target_muscle_group = db.Column(db.String(80), nullable=True)
|
||||
description = db.Column(db.Text, nullable=True)
|
||||
image_url = db.Column(db.String(255), nullable=True)
|
||||
|
||||
logs = db.relationship('WorkoutLog', backref='exercise', lazy=True)
|
||||
|
||||
def __repr__(self):
|
||||
return f'<Exercise {self.name}>'
|
||||
|
||||
class WorkoutLog(db.Model):
|
||||
__tablename__ = 'workout_logs'
|
||||
|
||||
id = db.Column(db.Integer, primary_key=True)
|
||||
workout_id = db.Column(db.Integer, db.ForeignKey('workouts.id'), nullable=False)
|
||||
exercise_id = db.Column(db.Integer, db.ForeignKey('exercises.id'), nullable=False)
|
||||
set_number = db.Column(db.Integer, nullable=False)
|
||||
weight = db.Column(db.Float, nullable=False)
|
||||
reps = db.Column(db.Integer, nullable=False)
|
||||
unit = db.Column(db.String(10), nullable=False, default='kg')
|
||||
created_at = db.Column(db.DateTime, nullable=False, default=datetime.utcnow)
|
||||
updated_at = db.Column(db.DateTime, nullable=False, default=datetime.utcnow, onupdate=datetime.utcnow)
|
||||
|
||||
def __repr__(self):
|
||||
return f'<Log: Set {self.set_number} of {self.exercise.name}>'
|
0
app/repositories/__init__.py
Normal file
0
app/repositories/__init__.py
Normal file
0
app/repositories/workout_repository.py
Normal file
0
app/repositories/workout_repository.py
Normal file
0
app/routes/__init__.py
Normal file
0
app/routes/__init__.py
Normal file
0
app/routes/workout_routes.py
Normal file
0
app/routes/workout_routes.py
Normal file
0
app/services/__init__.py
Normal file
0
app/services/__init__.py
Normal file
0
app/services/workout_service.py
Normal file
0
app/services/workout_service.py
Normal file
0
app/static/css/bootstrap.min.css
vendored
Normal file
0
app/static/css/bootstrap.min.css
vendored
Normal file
0
app/static/js/bootstrap.bundle.min.js
vendored
Normal file
0
app/static/js/bootstrap.bundle.min.js
vendored
Normal file
0
app/templates/dashboard.html
Normal file
0
app/templates/dashboard.html
Normal file
0
app/templates/layouts/base.html
Normal file
0
app/templates/layouts/base.html
Normal file
@ -1 +0,0 @@
|
||||
|
@ -1 +0,0 @@
|
||||
|
@ -1 +0,0 @@
|
||||
|
@ -1 +0,0 @@
|
||||
|
@ -1 +0,0 @@
|
||||
|
@ -1 +0,0 @@
|
||||
|
@ -1 +0,0 @@
|
||||
|
@ -1 +0,0 @@
|
||||
|
@ -1 +0,0 @@
|
||||
|
@ -1 +0,0 @@
|
||||
|
@ -1 +0,0 @@
|
||||
|
@ -1 +0,0 @@
|
||||
|
@ -1 +0,0 @@
|
||||
|
@ -1 +0,0 @@
|
||||
|
@ -1 +0,0 @@
|
||||
|
@ -1 +0,0 @@
|
||||
|
@ -1 +0,0 @@
|
||||
|
@ -1 +0,0 @@
|
||||
|
@ -1 +0,0 @@
|
||||
|
@ -1 +0,0 @@
|
||||
|
@ -1 +0,0 @@
|
||||
|
5
requirements.txt
Normal file
5
requirements.txt
Normal file
@ -0,0 +1,5 @@
|
||||
Flask
|
||||
Flask-SQLAlchemy
|
||||
PyMySQL
|
||||
python-dotenv
|
||||
gunicorn
|
Loading…
x
Reference in New Issue
Block a user