add group page
This commit is contained in:
38
app.py
38
app.py
@@ -30,7 +30,6 @@ login_manager.login_view = 'login'
|
|||||||
|
|
||||||
migrate = Migrate(app, db)
|
migrate = Migrate(app, db)
|
||||||
|
|
||||||
|
|
||||||
@login_manager.user_loader
|
@login_manager.user_loader
|
||||||
def load_user(user_id):
|
def load_user(user_id):
|
||||||
return User.query.get(int(user_id))
|
return User.query.get(int(user_id))
|
||||||
@@ -264,6 +263,43 @@ def create_user():
|
|||||||
db.session.commit()
|
db.session.commit()
|
||||||
return redirect(url_for('admin'))
|
return redirect(url_for('admin'))
|
||||||
|
|
||||||
|
@app.route('/group/<int:group_id>/manage')
|
||||||
|
@login_required
|
||||||
|
@admin_required
|
||||||
|
def manage_group(group_id):
|
||||||
|
group = Group.query.get_or_404(group_id)
|
||||||
|
available_players = Player.query.filter(~Player.groups.any(Group.id == group_id)).all()
|
||||||
|
return render_template('manage_group.html', group=group, available_players=available_players)
|
||||||
|
|
||||||
|
@app.route('/group/<int:group_id>/add_player', methods=['POST'])
|
||||||
|
@login_required
|
||||||
|
@admin_required
|
||||||
|
def add_player_to_group(group_id):
|
||||||
|
group = Group.query.get_or_404(group_id)
|
||||||
|
player_id = request.form['player_id']
|
||||||
|
player = Player.query.get_or_404(player_id)
|
||||||
|
group.players.append(player)
|
||||||
|
db.session.commit()
|
||||||
|
return redirect(url_for('manage_group', group_id=group_id))
|
||||||
|
|
||||||
|
@app.route('/group/<int:group_id>/upload', methods=['POST'])
|
||||||
|
@login_required
|
||||||
|
@admin_required
|
||||||
|
def upload_content_to_group(group_id):
|
||||||
|
group = Group.query.get_or_404(group_id)
|
||||||
|
files = request.files.getlist('files')
|
||||||
|
duration = int(request.form['duration'])
|
||||||
|
|
||||||
|
for file in files:
|
||||||
|
filename = secure_filename(file.filename)
|
||||||
|
file_path = os.path.join(app.config['UPLOAD_FOLDER'], filename)
|
||||||
|
file.save(file_path)
|
||||||
|
new_content = Content(file_name=filename, duration=duration, group_id=group_id)
|
||||||
|
db.session.add(new_content)
|
||||||
|
|
||||||
|
db.session.commit()
|
||||||
|
return redirect(url_for('manage_group', group_id=group_id))
|
||||||
|
|
||||||
if __name__ == '__main__':
|
if __name__ == '__main__':
|
||||||
with app.app_context():
|
with app.app_context():
|
||||||
db.create_all() # Creează toate tabelele
|
db.create_all() # Creează toate tabelele
|
||||||
|
|||||||
Binary file not shown.
@@ -62,13 +62,25 @@
|
|||||||
<!-- Groups Section -->
|
<!-- Groups Section -->
|
||||||
<div class="card mb-4">
|
<div class="card mb-4">
|
||||||
<div class="card-header bg-success text-white">
|
<div class="card-header bg-success text-white">
|
||||||
<h2>Groups</h2>
|
<h2>Player Groups</h2>
|
||||||
</div>
|
</div>
|
||||||
<div class="card-body">
|
<div class="card-body">
|
||||||
<ul class="list-group">
|
<ul class="list-group">
|
||||||
{% for group in groups %}
|
{% for group in groups %}
|
||||||
<li class="list-group-item">
|
<li class="list-group-item d-flex justify-content-between align-items-center">
|
||||||
<strong>{{ group.name }}</strong> ({{ group.players | length }} players)
|
<div>
|
||||||
|
<strong>{{ group.name }}</strong> ({{ group.players | length }} players)
|
||||||
|
<ul class="list-group mt-2">
|
||||||
|
{% for player in group.players %}
|
||||||
|
<li class="list-group-item">
|
||||||
|
{{ player.username }} ({{ player.ip }})
|
||||||
|
</li>
|
||||||
|
{% endfor %}
|
||||||
|
</ul>
|
||||||
|
</div>
|
||||||
|
<div>
|
||||||
|
<a href="{{ url_for('manage_group', group_id=group.id) }}" class="btn btn-sm btn-secondary">Manage Group</a>
|
||||||
|
</div>
|
||||||
</li>
|
</li>
|
||||||
{% endfor %}
|
{% endfor %}
|
||||||
</ul>
|
</ul>
|
||||||
|
|||||||
56
templates/manage_group.html
Normal file
56
templates/manage_group.html
Normal file
@@ -0,0 +1,56 @@
|
|||||||
|
<!DOCTYPE html>
|
||||||
|
<html>
|
||||||
|
<head>
|
||||||
|
<title>Manage Group</title>
|
||||||
|
<link href="https://cdn.jsdelivr.net/npm/bootstrap@5.3.0-alpha3/dist/css/bootstrap.min.css" rel="stylesheet">
|
||||||
|
</head>
|
||||||
|
<body>
|
||||||
|
<div class="container py-5">
|
||||||
|
<h1 class="text-center mb-4">Manage Group: {{ group.name }}</h1>
|
||||||
|
|
||||||
|
<!-- Add Players to Group Section -->
|
||||||
|
<div class="card mb-4">
|
||||||
|
<div class="card-header bg-primary text-white">
|
||||||
|
<h2>Add Players to Group</h2>
|
||||||
|
</div>
|
||||||
|
<div class="card-body">
|
||||||
|
<form action="{{ url_for('add_player_to_group', group_id=group.id) }}" method="post">
|
||||||
|
<div class="mb-3">
|
||||||
|
<label for="player_id" class="form-label">Select Player</label>
|
||||||
|
<select class="form-select" id="player_id" name="player_id" required>
|
||||||
|
{% for player in available_players %}
|
||||||
|
<option value="{{ player.id }}">{{ player.username }} ({{ player.ip }})</option>
|
||||||
|
{% endfor %}
|
||||||
|
</select>
|
||||||
|
</div>
|
||||||
|
<button type="submit" class="btn btn-primary">Add Player</button>
|
||||||
|
</form>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<!-- Upload Content Section -->
|
||||||
|
<div class="card mb-4">
|
||||||
|
<div class="card-header bg-success text-white">
|
||||||
|
<h2>Upload Content for Group</h2>
|
||||||
|
</div>
|
||||||
|
<div class="card-body">
|
||||||
|
<form action="{{ url_for('upload_content_to_group', group_id=group.id) }}" method="post" enctype="multipart/form-data">
|
||||||
|
<div class="mb-3">
|
||||||
|
<label for="files" class="form-label">Select Images</label>
|
||||||
|
<input type="file" class="form-control" id="files" name="files" multiple required>
|
||||||
|
</div>
|
||||||
|
<div class="mb-3">
|
||||||
|
<label for="duration" class="form-label">Display Duration (seconds)</label>
|
||||||
|
<input type="number" class="form-control" id="duration" name="duration" required>
|
||||||
|
</div>
|
||||||
|
<button type="submit" class="btn btn-primary">Upload</button>
|
||||||
|
</form>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<a href="{{ url_for('dashboard') }}" class="btn btn-secondary">Back to Dashboard</a>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<script src="https://cdn.jsdelivr.net/npm/bootstrap@5.3.0-alpha3/dist/js/bootstrap.bundle.min.js"></script>
|
||||||
|
</body>
|
||||||
|
</html>
|
||||||
@@ -8,6 +8,20 @@
|
|||||||
<div class="container py-5">
|
<div class="container py-5">
|
||||||
<h1 class="text-center mb-4">Player Schedule for {{ player.username }}</h1>
|
<h1 class="text-center mb-4">Player Schedule for {{ player.username }}</h1>
|
||||||
|
|
||||||
|
<!-- Group Membership Section -->
|
||||||
|
<div class="mb-4">
|
||||||
|
{% if player.groups %}
|
||||||
|
<h4 class="text-center">Member of Group(s):</h4>
|
||||||
|
<ul class="list-group">
|
||||||
|
{% for group in player.groups %}
|
||||||
|
<li class="list-group-item">{{ group.name }}</li>
|
||||||
|
{% endfor %}
|
||||||
|
</ul>
|
||||||
|
{% else %}
|
||||||
|
<h4 class="text-center">Not a member of any group</h4>
|
||||||
|
{% endif %}
|
||||||
|
</div>
|
||||||
|
|
||||||
<!-- Schedule Section -->
|
<!-- Schedule Section -->
|
||||||
<div class="card mb-4">
|
<div class="card mb-4">
|
||||||
<div class="card-header bg-primary text-white">
|
<div class="card-header bg-primary text-white">
|
||||||
|
|||||||
Reference in New Issue
Block a user