delete item, remove from list fix + restore history
This commit is contained in:
parent
960fbf80fb
commit
b363c5d752
33
src/db.py
33
src/db.py
@ -212,6 +212,11 @@ def delete_item(uuid):
|
|||||||
""", (uuid,))
|
""", (uuid,))
|
||||||
cursor.execute("""
|
cursor.execute("""
|
||||||
DELETE
|
DELETE
|
||||||
|
FROM listcontent
|
||||||
|
WHERE item_uuid = %s
|
||||||
|
""", (uuid,))
|
||||||
|
cursor.execute("""
|
||||||
|
DELETE
|
||||||
FROM item
|
FROM item
|
||||||
WHERE uuid = %s
|
WHERE uuid = %s
|
||||||
""", (uuid,))
|
""", (uuid,))
|
||||||
@ -387,6 +392,12 @@ def fetch_all():
|
|||||||
converted_row = (row[0], row[1], str(row[2]), row[3], row[4], row[5], row[6])
|
converted_row = (row[0], row[1], str(row[2]), row[3], row[4], row[5], row[6])
|
||||||
converted_rows.append(converted_row)
|
converted_rows.append(converted_row)
|
||||||
results[0] = converted_rows
|
results[0] = converted_rows
|
||||||
|
# timestamp fix in table history
|
||||||
|
converted_rows = []
|
||||||
|
for row in results[3]:
|
||||||
|
converted_row = (row[0], row[1], row[2], row[3], row[4], f'{row[5]}')
|
||||||
|
converted_rows.append(converted_row)
|
||||||
|
results[3] = converted_rows
|
||||||
return results
|
return results
|
||||||
|
|
||||||
def restore_db(data):
|
def restore_db(data):
|
||||||
@ -394,18 +405,34 @@ def restore_db(data):
|
|||||||
tables = ["item", "itemlist", "listcontent", "history"]
|
tables = ["item", "itemlist", "listcontent", "history"]
|
||||||
connection = connect_db()
|
connection = connect_db()
|
||||||
cursor = connection.cursor()
|
cursor = connection.cursor()
|
||||||
|
item_uuid = {}
|
||||||
for elem in data["item"]:
|
for elem in data["item"]:
|
||||||
# check if item already exists
|
# check if item already exists
|
||||||
query = f'SELECT * FROM item WHERE itemid={str(elem["itemid"])} and skuid={str(elem["skuid"])}'
|
query = f'SELECT * FROM item WHERE itemid={str(elem["itemid"])} and skuid={str(elem["skuid"])}'
|
||||||
cursor.execute(query)
|
cursor.execute(query)
|
||||||
result = cursor.rowcount
|
result = cursor.rowcount
|
||||||
|
# complete item uuid dict
|
||||||
|
item_uuid[elem["uuid"]] = (elem["itemid"], elem["skuid"])
|
||||||
if result == 0:
|
if result == 0:
|
||||||
|
# if item doesn't already exist, insert it in database
|
||||||
attributes = str(elem["attributes"]).split(',') if len(str(elem["attributes"]))>0 else "[]::text[]"
|
attributes = str(elem["attributes"]).split(',') if len(str(elem["attributes"]))>0 else "[]::text[]"
|
||||||
query = f'INSERT INTO item (uuid, itemid, skuid, choice, attributes, image, show) VALUES (nextval(\'uuid_sequence\'), {str(elem["itemid"])}, {str(elem["skuid"])}, {str(elem["choice"])}, ARRAY{attributes}, \'{str(elem["image"])}\', {str(elem["show"])})'
|
query = f'INSERT INTO item (uuid, itemid, skuid, choice, attributes, image, show) VALUES (nextval(\'uuid_sequence\'), {str(elem["itemid"])}, {str(elem["skuid"])}, {str(elem["choice"])}, ARRAY{attributes}, \'{str(elem["image"])}\', {str(elem["show"])})'
|
||||||
cursor.execute(query)
|
cursor.execute(query)
|
||||||
for table in tables:
|
for elem in data["history"]:
|
||||||
for elem in data[table]:
|
# check if history entry already exists
|
||||||
print(elem)
|
query = f'SELECT * FROM history WHERE h_timestamp=\'{elem["h_timestamp"]}\''
|
||||||
|
cursor.execute(query)
|
||||||
|
result = cursor.rowcount
|
||||||
|
if result == 0:
|
||||||
|
# find related item
|
||||||
|
(rel_itemid, rel_skuid) = item_uuid[elem["uuid"]]
|
||||||
|
query = f'SELECT uuid FROM item WHERE itemid={rel_itemid} and skuid={rel_skuid}'
|
||||||
|
cursor.execute(query)
|
||||||
|
uuid = cursor.fetchall()[0][0]
|
||||||
|
# insert history entry
|
||||||
|
query = f'INSERT INTO history (uuid, price, currency, quantity, discount_percentage, h_timestamp) VALUES ({uuid}, \'{elem["price"]}\', \'{elem["currency"]}\', {elem["quantity"]}, {elem["discount_percentage"]}, \'{elem["h_timestamp"]}\')'
|
||||||
|
cursor.execute(query)
|
||||||
|
|
||||||
cursor.close()
|
cursor.close()
|
||||||
connection.commit()
|
connection.commit()
|
||||||
connection.close()
|
connection.close()
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
function handleFileUpload(event) {
|
function handleFileUpload() {
|
||||||
const file = document.getElementById('inputGroupFile01').files[0];
|
const file = document.getElementById('inputGroupFile01').files[0];
|
||||||
const reader = new FileReader();
|
const reader = new FileReader();
|
||||||
|
|
||||||
@ -6,7 +6,6 @@ function handleFileUpload(event) {
|
|||||||
const rawData = e.target.result;
|
const rawData = e.target.result;
|
||||||
var blocks = rawData.split('#####');
|
var blocks = rawData.split('#####');
|
||||||
blocks.shift() // 1st element is empty
|
blocks.shift() // 1st element is empty
|
||||||
console.log(blocks);
|
|
||||||
var data = {};
|
var data = {};
|
||||||
blocks.forEach(function (block) {
|
blocks.forEach(function (block) {
|
||||||
const split = block.indexOf('\n');
|
const split = block.indexOf('\n');
|
||||||
|
Loading…
x
Reference in New Issue
Block a user