forked from FrederikBaerentsen/BrickTracker
Basic wishlist feature
This commit is contained in:
parent
baf5841502
commit
608681f4bc
72
app.py
72
app.py
@ -494,46 +494,56 @@ def wishlist():
|
|||||||
input_value = 'None'
|
input_value = 'None'
|
||||||
|
|
||||||
if request.method == 'POST':
|
if request.method == 'POST':
|
||||||
input_value = request.form.get('inputField')
|
if 'create_submit' in request.form:
|
||||||
print(input_value)
|
input_value = request.form.get('inputField')
|
||||||
|
print(input_value)
|
||||||
|
|
||||||
|
|
||||||
input_value = input_value.replace(" ","")
|
input_value = input_value.replace(" ","")
|
||||||
if '-' not in input_value:
|
if '-' not in input_value:
|
||||||
input_value = input_value + '-1'
|
input_value = input_value + '-1'
|
||||||
|
|
||||||
total_set_file = np.genfromtxt("sets.csv",delimiter=",",dtype="str",usecols=(0))
|
total_set_file = np.genfromtxt("sets.csv",delimiter=",",dtype="str",usecols=(0))
|
||||||
if input_value not in total_set_file:
|
if input_value not in total_set_file:
|
||||||
print('ERROR: ' + input_value)
|
print('ERROR: ' + input_value)
|
||||||
#return render_template('wishlist.html',error=input_value)
|
#return render_template('wishlist.html',error=input_value)
|
||||||
|
|
||||||
else:
|
else:
|
||||||
set_num = input_value
|
set_num = input_value
|
||||||
|
|
||||||
input_value = 'None'
|
input_value = 'None'
|
||||||
|
conn = sqlite3.connect('app.db')
|
||||||
|
cursor = conn.cursor()
|
||||||
|
rb = rebrick.init(os.getenv("REBRICKABLE_API_KEY"))
|
||||||
|
response = json.loads(rebrick.lego.get_set(set_num).read())
|
||||||
|
cursor.execute('''INSERT INTO wishlist (
|
||||||
|
set_num,
|
||||||
|
name,
|
||||||
|
year,
|
||||||
|
theme_id,
|
||||||
|
num_parts,
|
||||||
|
set_img_url,
|
||||||
|
set_url,
|
||||||
|
last_modified_dt
|
||||||
|
) VALUES (?, ?, ?, ?, ?, ?, ?, ?) ''', (response['set_num'], response['name'], response['year'], response['theme_id'], response['num_parts'],response['set_img_url'],response['set_url'],response['last_modified_dt']))
|
||||||
|
set_img_url = response["set_img_url"]
|
||||||
|
res = requests.get(set_img_url, stream = True)
|
||||||
|
if res.status_code == 200:
|
||||||
|
with open("./static/sets/"+set_num+".jpg",'wb') as f:
|
||||||
|
shutil.copyfileobj(res.raw, f)
|
||||||
|
else:
|
||||||
|
logging.error('set_img_url: ' + set_num)
|
||||||
|
|
||||||
|
conn.commit()
|
||||||
|
conn.close()
|
||||||
|
elif 'add_to_list' in request.form:
|
||||||
|
set_num = request.form.get('set_num')
|
||||||
conn = sqlite3.connect('app.db')
|
conn = sqlite3.connect('app.db')
|
||||||
cursor = conn.cursor()
|
cursor = conn.cursor()
|
||||||
rb = rebrick.init(os.getenv("REBRICKABLE_API_KEY"))
|
|
||||||
response = json.loads(rebrick.lego.get_set(set_num).read())
|
|
||||||
cursor.execute('''INSERT INTO wishlist (
|
|
||||||
set_num,
|
|
||||||
name,
|
|
||||||
year,
|
|
||||||
theme_id,
|
|
||||||
num_parts,
|
|
||||||
set_img_url,
|
|
||||||
set_url,
|
|
||||||
last_modified_dt
|
|
||||||
) VALUES (?, ?, ?, ?, ?, ?, ?, ?) ''', (response['set_num'], response['name'], response['year'], response['theme_id'], response['num_parts'],response['set_img_url'],response['set_url'],response['last_modified_dt']))
|
|
||||||
set_img_url = response["set_img_url"]
|
|
||||||
res = requests.get(set_img_url, stream = True)
|
|
||||||
if res.status_code == 200:
|
|
||||||
with open("./static/sets/"+set_num+".jpg",'wb') as f:
|
|
||||||
shutil.copyfileobj(res.raw, f)
|
|
||||||
else:
|
|
||||||
logging.error('set_img_url: ' + set_num)
|
|
||||||
|
|
||||||
|
cursor.execute('DELETE FROM wishlist where set_num="' +set_num+ '";')
|
||||||
conn.commit()
|
conn.commit()
|
||||||
|
cursor.close()
|
||||||
conn.close()
|
conn.close()
|
||||||
|
|
||||||
conn = sqlite3.connect('app.db')
|
conn = sqlite3.connect('app.db')
|
||||||
|
@ -123,6 +123,9 @@ display: none !important;
|
|||||||
<a class="navbar-item hidden-mobile" href="/minifigs">
|
<a class="navbar-item hidden-mobile" href="/minifigs">
|
||||||
Minifigs
|
Minifigs
|
||||||
</a>
|
</a>
|
||||||
|
<a class="navbar-item hidden-mobile" href="/wishlist">
|
||||||
|
Wishlist
|
||||||
|
</a>
|
||||||
<a class="navbar-item hidden-mobile" href="/config">
|
<a class="navbar-item hidden-mobile" href="/config">
|
||||||
Config
|
Config
|
||||||
</a>
|
</a>
|
||||||
|
@ -3,7 +3,7 @@
|
|||||||
|
|
||||||
|
|
||||||
<head>
|
<head>
|
||||||
<title>{{ tmp }} - {{ title }}</title>
|
<title>Withlist</title>
|
||||||
<meta name="viewport" content="width=device-width, minimum-scale=1.0, maximum-scale=1.0, user-scalable=no, initial-scale=1.0"> <!-- CSS Reset -->
|
<meta name="viewport" content="width=device-width, minimum-scale=1.0, maximum-scale=1.0, user-scalable=no, initial-scale=1.0"> <!-- CSS Reset -->
|
||||||
<link
|
<link
|
||||||
rel="stylesheet"
|
rel="stylesheet"
|
||||||
@ -217,7 +217,7 @@ background-color: white;
|
|||||||
</div>
|
</div>
|
||||||
<div class="field">
|
<div class="field">
|
||||||
<div class="control">
|
<div class="control">
|
||||||
<button id="submitButton" class="button is-primary" type="submit">Submit</button>
|
<button id="submitButton" class="button is-primary" type="submit" name="create_submit">Submit</button>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</form>
|
</form>
|
||||||
@ -229,11 +229,12 @@ background-color: white;
|
|||||||
<table id="data" class="table tablemobile sortable">
|
<table id="data" class="table tablemobile sortable">
|
||||||
<thead>
|
<thead>
|
||||||
<tr>
|
<tr>
|
||||||
<th></th>
|
<th class="fixed-width sorttable_nosort"></th>
|
||||||
<th style="text-align:center;margin:0px;" class="fixed-width hidden-mobile">ID</th>
|
<th style="text-align:center;margin:0px;" class="fixed-width">ID</th>
|
||||||
<th class="fixed-width hidden-mobile">Name</th>
|
<th class="fixed-width">Name</th>
|
||||||
<th style="text-align: center;" class="fixed-width">Year</th>
|
<th style="text-align: center;" class="fixed-width hidden-mobile">Year</th>
|
||||||
<th style="text-align: center;" class="fixed-width">Parts</th>
|
<th style="text-align: center;" class="fixed-width hidden-mobile">Parts</th>
|
||||||
|
<th style="text-align: center;" class="sorttable_nosort">Delete</th>
|
||||||
</tr>
|
</tr>
|
||||||
</thead>
|
</thead>
|
||||||
<tbody> <!-- set_num|name|year|theme_id|num_parts|set_img_url|set_url|last_modified_dt -->
|
<tbody> <!-- set_num|name|year|theme_id|num_parts|set_img_url|set_url|last_modified_dt -->
|
||||||
@ -242,8 +243,14 @@ background-color: white;
|
|||||||
<td><img src="{{ '/static/sets/' + sets[0] + '.jpg' }}" class="lightbox-trigger" style="height: 50px; width: auto;"></td>
|
<td><img src="{{ '/static/sets/' + sets[0] + '.jpg' }}" class="lightbox-trigger" style="height: 50px; width: auto;"></td>
|
||||||
<td style="text-align:center;margin:0px;">{{ sets[0] }}</td>
|
<td style="text-align:center;margin:0px;">{{ sets[0] }}</td>
|
||||||
<td>{{ sets[1] }}</td>
|
<td>{{ sets[1] }}</td>
|
||||||
<td style="text-align:center;">{{ sets[2] }}</td>
|
<td style="text-align:center;" class="hidden-mobile">{{ sets[2] }}</td>
|
||||||
<td style="text-align:center;">{{ sets[4] }}</td>
|
<td style="text-align:center;" class="hidden-mobile">{{ sets[4] }}</td>
|
||||||
|
<td style="text-align:center;">
|
||||||
|
<form method="POST" style="margin:0">
|
||||||
|
<input type="hidden" name="set_num" value="{{ sets[0] }}">
|
||||||
|
<button type="submit" class="btn btn-primary" name="add_to_list">Delete</button>
|
||||||
|
</form>
|
||||||
|
</td>
|
||||||
</tr>
|
</tr>
|
||||||
{% endfor %}
|
{% endfor %}
|
||||||
</tbody>
|
</tbody>
|
||||||
|
Loading…
Reference in New Issue
Block a user