Compare commits
2 Commits
60f746b2ee
...
347f467735
| Author | SHA1 | Date | |
|---|---|---|---|
| 347f467735 | |||
| de3e20e0cb |
98
app.py
@@ -1,78 +1,96 @@
|
||||
# -*- coding: utf-8 -*-
|
||||
from flask import Flask, render_template, request, flash, redirect, url_for
|
||||
from flask import Flask, render_template, request, flash, redirect, url_for, send_file
|
||||
from werkzeug.utils import secure_filename
|
||||
import os
|
||||
from models import db
|
||||
from models import PrintedDetal
|
||||
import secrets
|
||||
from models import db, PrintedDetal
|
||||
import logging
|
||||
from models import PrintedDetal
|
||||
|
||||
logging.basicConfig(filename='app.log', encoding='utf-8', level=logging.DEBUG)
|
||||
|
||||
|
||||
UPLOAD_IMG_FOLDER = os.path.join('static', 'img', 'uploads')
|
||||
UPLOAD_STL_FOLDER = os.path.join('static', 'stl')
|
||||
ALLOWED_EXTENSIONS = {'png', 'jpg', 'jpeg', 'stl'}
|
||||
|
||||
app = Flask(__name__)
|
||||
app.config['SQLALCHEMY_DATABASE_URI'] = 'sqlite:///app.db'
|
||||
app.config['UPLOAD_FOLDER'] = UPLOAD_IMG_FOLDER
|
||||
app.config['UPLOAD_FOLDER2'] = UPLOAD_STL_FOLDER
|
||||
app.config['UPLOAD_IMG_FOLDER'] = os.path.join('static', 'uploads', 'img')
|
||||
app.config['UPLOAD_STL_FOLDER'] = os.path.join('static', 'uploads', 'stl')
|
||||
app.config['UPLOAD_SRC_FOLDER'] = os.path.join('static', 'uploads', 'src')
|
||||
|
||||
db.init_app(app)
|
||||
db.init_app(app)
|
||||
|
||||
|
||||
@app.route("/")
|
||||
def index():
|
||||
#detals = PrintedDetal.query.all()
|
||||
|
||||
return render_template("index.html") # , detals=detals)
|
||||
allDetals = {}
|
||||
|
||||
detalsQuery = PrintedDetal.query.all()
|
||||
|
||||
for detal in detalsQuery:
|
||||
detals = {}
|
||||
detals['img'] = detal.img
|
||||
detals['stl'] = detal.stl
|
||||
detals['src'] = detal.src
|
||||
detals['isprinted'] = detal.isprinted
|
||||
|
||||
allDetals[detal.id] = detals
|
||||
|
||||
logging.debug(allDetals)
|
||||
|
||||
return render_template("index.html", detals=allDetals)
|
||||
|
||||
|
||||
@app.route("/admin", methods=['GET', 'POST'])
|
||||
def admipage():
|
||||
logging.debug("adminpage loaded")
|
||||
|
||||
return render_template("adminpage.html")
|
||||
|
||||
|
||||
@app.route('/uploader', methods=['GET', 'POST'])
|
||||
def upload_file():
|
||||
if request.method == 'POST':
|
||||
logging.debug("POST QUERY loaded")
|
||||
image_file = request.files['img']
|
||||
stl_file = request.files['stl']
|
||||
src_file = request.files['src']
|
||||
|
||||
image_file = request.files['imgfile']
|
||||
stl_file = request.files['stlfile']
|
||||
if len(image_file.filename) > 0:
|
||||
filename = image_file.filename.split('.')
|
||||
image_file.filename = secrets.token_hex(15) + '.' + filename[-1]
|
||||
image_file.save(os.path.join(
|
||||
app.config['UPLOAD_IMG_FOLDER'], image_file.filename))
|
||||
|
||||
logging.debug(image_file)
|
||||
logging.debug(stl_file)
|
||||
if len(stl_file.filename) > 0:
|
||||
filename = stl_file.filename.split('.')
|
||||
stl_file.filename = secrets.token_hex(15) + '.' + filename[-1]
|
||||
stl_file.save(os.path.join(app.config['UPLOAD_STL_FOLDER'],stl_file.filename))
|
||||
|
||||
image_file.save(os.path.join(
|
||||
app.config['UPLOAD_FOLDER'], image_file.filename))
|
||||
stl_file.save(os.path.join(
|
||||
app.config['UPLOAD_FOLDER2'], stl_file.filename))
|
||||
if len(src_file.filename) > 0:
|
||||
filename = src_file.filename.split('.')
|
||||
src_file.filename = secrets.token_hex(15) + '.' + filename[-1]
|
||||
src_file.save(os.path.join(app.config['UPLOAD_SRC_FOLDER'], src_file.filename))
|
||||
|
||||
if request.form.get('isprinted') == 'on':
|
||||
isprinered = True
|
||||
else:
|
||||
isprinered = False
|
||||
|
||||
logging.debug(image_file)
|
||||
logging.debug(stl_file)
|
||||
logging.debug(image_file.filename)
|
||||
logging.debug(stl_file.filename)
|
||||
logging.debug(src_file.filename)
|
||||
logging.debug(isprinered)
|
||||
|
||||
# detal = PrintedDetal(imgpath=image_file.filename,
|
||||
# stlpath=stl_file.filename,
|
||||
# isprinted=isprinered)
|
||||
# db.session.add(detal)
|
||||
# db.session.commit()
|
||||
detal = PrintedDetal(img=image_file.filename,
|
||||
stl=stl_file.filename,
|
||||
src=src_file.filename,
|
||||
isprinted=isprinered)
|
||||
db.session.add(detal)
|
||||
db.session.commit()
|
||||
|
||||
return render_template("adminpage.html")
|
||||
return redirect(url_for('admipage'))
|
||||
|
||||
else:
|
||||
return render_template("adminpage.html")
|
||||
|
||||
|
||||
@app.route('/uploader', methods=['GET', 'POST'])
|
||||
def upload_file():
|
||||
if request.method == 'POST':
|
||||
f = request.files['file']
|
||||
f.save(secure_filename(f.filename))
|
||||
return 'file uploaded successfully'
|
||||
@app.route('/download/<filename>', methods=['GET', 'POST'])
|
||||
def download(filename):
|
||||
return send_file(app.config['UPLOAD_SRC_FOLDER']+'/'+ filename, as_attachment=True)
|
||||
|
||||
|
||||
if __name__ == "__main__":
|
||||
|
||||
@@ -6,7 +6,7 @@ db = SQLAlchemy()
|
||||
|
||||
class PrintedDetal(db.Model):
|
||||
id = db.Column(db.Integer, primary_key=True, autoincrement=True)
|
||||
imgpath = db.Column(db.String(3000))
|
||||
stlpath = db.Column(db.String(3000))
|
||||
srcpath = db.Column(db.String(3000))
|
||||
img = db.Column(db.String(3000))
|
||||
stl = db.Column(db.String(3000))
|
||||
src = db.Column(db.String(3000))
|
||||
isprinted = db.Column(db.Boolean())
|
||||
@@ -4,7 +4,7 @@ body {
|
||||
background-color: #dcf3d0;
|
||||
}
|
||||
|
||||
header{
|
||||
header {
|
||||
box-shadow: 0px 5px 10px 2px rgba(34, 60, 80, 0.2);
|
||||
}
|
||||
|
||||
@@ -15,14 +15,14 @@ header{
|
||||
line-height: 100px;
|
||||
text-align: center;
|
||||
color: #034956;
|
||||
|
||||
|
||||
}
|
||||
|
||||
.row {
|
||||
margin-top: 20px;
|
||||
}
|
||||
|
||||
.col-md-4{
|
||||
.col-md-4 {
|
||||
margin-bottom: 25px;
|
||||
}
|
||||
|
||||
@@ -30,8 +30,13 @@ header{
|
||||
background-color: #fef6dd;
|
||||
border-radius: 12px;
|
||||
box-shadow: 0px 5px 10px 2px rgba(34, 60, 80, 0.2);
|
||||
height: 450px;
|
||||
}
|
||||
|
||||
.card-img-top{
|
||||
|
||||
height: 250px;
|
||||
}
|
||||
|
||||
.btn {
|
||||
|
||||
@@ -50,19 +55,18 @@ header{
|
||||
|
||||
}
|
||||
|
||||
.card-img-top{
|
||||
.card-img-top {
|
||||
padding: 10px;
|
||||
border-radius: 18px;
|
||||
}
|
||||
|
||||
h5{
|
||||
h5 {
|
||||
font-size: 17px;
|
||||
}
|
||||
|
||||
|
||||
|
||||
.mobile-margin{
|
||||
.mobile-margin {
|
||||
margin-bottom: 10px;
|
||||
padding: 10px;
|
||||
}
|
||||
|
||||
}
|
||||
BIN
static/img/uploads/13c3a23110f9ae0a8c6c2eaf153ce3.jpg
Normal file
|
After Width: | Height: | Size: 26 KiB |
BIN
static/img/uploads/1a47072defc8d6e06c5432bfa94ff9.jpg
Normal file
|
After Width: | Height: | Size: 225 KiB |
BIN
static/img/uploads/1e6372b9451aa8d5325b295ac64d40.jpg
Normal file
|
After Width: | Height: | Size: 26 KiB |
BIN
static/img/uploads/280c7fe9388d4f445100acc1b7b1ac.jpg
Normal file
|
After Width: | Height: | Size: 26 KiB |
BIN
static/img/uploads/4fb140f1adecd3aae5e697ed2b3107.png
Normal file
|
After Width: | Height: | Size: 15 KiB |
BIN
static/img/uploads/73e726fde93f0c81141140007e2f6a.jpg
Normal file
|
After Width: | Height: | Size: 225 KiB |
BIN
static/img/uploads/8907a42ceb726bc28f1f254323d291.png
Normal file
|
After Width: | Height: | Size: 14 KiB |
BIN
static/img/uploads/a8839944bcde4fb39480a891338293.png
Normal file
|
After Width: | Height: | Size: 15 KiB |
BIN
static/img/uploads/b0ba34fd7f2cb29f16d22cdf64f3cd.png
Normal file
|
After Width: | Height: | Size: 15 KiB |
BIN
static/img/uploads/d85d9441ce77db404a7a3624c6a4c5.png
Normal file
|
After Width: | Height: | Size: 14 KiB |
BIN
static/img/uploads/de2b9c1eb3aa4b51d8b904c2eb9ebd.jpg
Normal file
|
After Width: | Height: | Size: 225 KiB |
BIN
static/img/uploads/f5daf4603ed462e2093415fce3c357.png
Normal file
|
After Width: | Height: | Size: 65 KiB |
0
static/src/c642733f147aec6642e3e2130f6f84.png
Normal file
|
After Width: | Height: | Size: 225 KiB |
|
After Width: | Height: | Size: 26 KiB |
|
After Width: | Height: | Size: 14 KiB |
BIN
static/uploads/img/39336ea1bd63cd729256a4840f58eb.jpg
Normal file
|
After Width: | Height: | Size: 26 KiB |
BIN
static/uploads/img/47f8eaffbd6afb256d0c30d4537755.jpg
Normal file
|
After Width: | Height: | Size: 225 KiB |
BIN
static/uploads/img/52d8fefb9d1ffed4b85b0a4dc09365.jpg
Normal file
|
After Width: | Height: | Size: 26 KiB |
BIN
static/uploads/img/5e616db251a1f79f500d9a88a6c524.jpg
Normal file
|
After Width: | Height: | Size: 225 KiB |
BIN
static/uploads/img/6adf0d6e7152f32e26cac5dc8d9bf1.png
Normal file
|
After Width: | Height: | Size: 65 KiB |
BIN
static/uploads/img/780bc1f4b169cb3cb4b0b5817152cb.png
Normal file
|
After Width: | Height: | Size: 15 KiB |
BIN
static/uploads/img/7f77be274a610e1110778492813e58.png
Normal file
|
After Width: | Height: | Size: 14 KiB |
BIN
static/uploads/img/a8972714142d6ce089a7748a52d176.jpg
Normal file
|
After Width: | Height: | Size: 26 KiB |
BIN
static/uploads/src/070105ef12aa09da5f8745b26c1b00.jpg
Normal file
|
After Width: | Height: | Size: 26 KiB |
BIN
static/uploads/src/366d577969a8f6c3d3dcde95b7c36e.png
Normal file
|
After Width: | Height: | Size: 65 KiB |
BIN
static/uploads/src/54a029e3d30e2d293935d561284604.png
Normal file
|
After Width: | Height: | Size: 14 KiB |
BIN
static/uploads/src/95442dae6cdf2be5c7bb883ec460ff.jpg
Normal file
|
After Width: | Height: | Size: 225 KiB |
BIN
static/uploads/src/a13c81558c5484445cf9dc33a0a4f3.jpg
Normal file
|
After Width: | Height: | Size: 26 KiB |
BIN
static/uploads/src/ad33b76d2e6d1ee725c95b4b8eba4d.png
Normal file
|
After Width: | Height: | Size: 15 KiB |
|
After Width: | Height: | Size: 26 KiB |
BIN
static/uploads/src/f5abf0156af9fafeb560caee9d8dd2.jpg
Normal file
|
After Width: | Height: | Size: 225 KiB |
BIN
static/uploads/stl/5043eb896ce1a9e7a1a12a1e1a9d63.jpg
Normal file
|
After Width: | Height: | Size: 26 KiB |
BIN
static/uploads/stl/8a9ac33bb865b3a4c5a9b2b538f01a.png
Normal file
|
After Width: | Height: | Size: 14 KiB |
BIN
static/uploads/stl/a483b6fdc21ef3796c843c137b561c.jpg
Normal file
|
After Width: | Height: | Size: 225 KiB |
BIN
static/uploads/stl/cbd9ac8333684dea75d102d5ae9a9e.png
Normal file
|
After Width: | Height: | Size: 15 KiB |
BIN
static/uploads/stl/cf89b089ff7ccd15a42086824df9ab.jpg
Normal file
|
After Width: | Height: | Size: 225 KiB |
BIN
static/uploads/stl/d38ff410af2bf8f2da14fbc8afc4c9.png
Normal file
|
After Width: | Height: | Size: 65 KiB |
@@ -8,7 +8,7 @@
|
||||
<link href="https://cdn.jsdelivr.net/npm/bootstrap@5.2.2/dist/css/bootstrap.min.css" rel="stylesheet"
|
||||
integrity="sha384-Zenh87qX5JnK2Jl0vWa8Ck2rdkQ2Bzep5IDxbcnCeuOxjzrPF/et3URy9Bv1WTRi" crossorigin="anonymous">
|
||||
<link rel="stylesheet" href="{{ url_for('static', filename='css/adminpage.css')}}">
|
||||
<title>3d Detals</title>
|
||||
<title>3d Detals adminka</title>
|
||||
</head>
|
||||
|
||||
<body>
|
||||
@@ -18,13 +18,13 @@
|
||||
<div class="container">
|
||||
|
||||
<div class="row ">
|
||||
<form method="post" enctype=multipart/form-data>
|
||||
<form method="post" enctype=multipart/form-data action="/uploader">
|
||||
<label class=" d-block p-2">Выберите изображение </label>
|
||||
<input class=" formblock d-block p-2" type="file" name="imgfile" />
|
||||
<input class=" formblock d-block p-2" type="file" name="img" />
|
||||
<label class=" d-block p-2">Выберите исходный file </label>
|
||||
<input class=" formblock d-block p-2" type="file" name="origfile" />
|
||||
<input class=" formblock d-block p-2" type="file" name="src" />
|
||||
<label class=" d-block p-2">Выберите stl file </label>
|
||||
<input class=" formblock d-block p-2" type="file" name="stlfile" />
|
||||
<input class=" formblock d-block p-2" type="file" name="stl" />
|
||||
<label > Напечатано </label>
|
||||
<input type="checkbox" class="bxigchekcbox" id="printed" name="isprinted">
|
||||
<input class="btn d-block p-2" type="submit" value="Upload">
|
||||
|
||||
@@ -17,25 +17,24 @@
|
||||
<div class="container">
|
||||
<div class="row">
|
||||
|
||||
{% for i in range(10) %}
|
||||
{% for key, value in detals.items() %}
|
||||
|
||||
<div class="col-md-4">
|
||||
<div class="card mobile-margin">
|
||||
<img class="card-img-top" src="{{url_for('static', filename='img/1.jpg')}}" alt="1 image">
|
||||
<img class="card-img-top" src="{{url_for('static', filename='uploads/img/' + value['img'])}}">
|
||||
|
||||
<div class="card-body">
|
||||
<dv class="row">
|
||||
<div class="col">
|
||||
<button class="btn btn-block mobile-margin">Скачать исходник</button>
|
||||
<a href="{{url_for('static', filename='uploads/src/' + value['src'])}}" class="btn btn-block mobile-margin" download >Скачать исходник</a>
|
||||
</div>
|
||||
<div class="col">
|
||||
<button class="btn btn-block mobile-margin">Скачать stl </button>
|
||||
<a href="{{url_for('static', filename='uploads/stl/' + value['stl'])}}" class="btn btn-block mobile-margin" download>Скачать stl </a>
|
||||
</div>
|
||||
<div class="row">
|
||||
<div class="col d-flex justify-content-center">
|
||||
<input class="form-check-input" type="checkbox" value="" id="flexCheckDefault" disabled>
|
||||
<label class="form-check-label" for="flexCheckDefault">
|
||||
Напечатано
|
||||
</label>
|
||||
<label> Напечатано </label>
|
||||
</div>
|
||||
<div class="col d-flex justify-content-center">
|
||||
<h5> 22.10.2022</h5>
|
||||
|
||||