- fix Indexdb:
1) ReadAllData 'GET' : OK 2) InsertTodo 'POST' : OK 3) DeleteItem 'DELETE': OK 4) Modify 'PATCH' : OK
This commit is contained in:
@@ -333,13 +333,15 @@ export default class Todo extends Vue {
|
||||
|
||||
await globalroutines(this, 'write', 'todos', objtodo)
|
||||
.then((id) => {
|
||||
console.log('*** IDNEW (2) = ', id)
|
||||
console.log('*** IDNEW (3) = ', id)
|
||||
|
||||
// update also the last elem
|
||||
if (lastelem !== null) {
|
||||
lastelem.id_next = id
|
||||
lastelem.modified = true
|
||||
console.log('calling MODIFY 4', lastelem)
|
||||
}
|
||||
|
||||
this.modify(lastelem, false)
|
||||
.then(ris => {
|
||||
console.log('END calling MODIFY 4')
|
||||
@@ -348,10 +350,7 @@ export default class Todo extends Vue {
|
||||
this.updatetable(false)
|
||||
|
||||
})
|
||||
} else {
|
||||
this.saveItemToSyncAndDb(rescodes.DB.TABLE_SYNC_TODOS, 'POST', objtodo)
|
||||
this.updatetable(false)
|
||||
}
|
||||
|
||||
|
||||
}).catch(err => {
|
||||
console.log('Errore: ' + err.message)
|
||||
@@ -369,7 +368,7 @@ export default class Todo extends Vue {
|
||||
console.log('cmdToSyncAndDb', cmd, table, method, item, id, msg)
|
||||
|
||||
const mythis = this
|
||||
if ('serviceWorker' in navigator && 'SyncManager' in window) {
|
||||
if (false && ('serviceWorker' in navigator && 'SyncManager' in window)) {
|
||||
await navigator.serviceWorker.ready
|
||||
.then(function (sw) {
|
||||
// _id: new Date().toISOString(),
|
||||
@@ -395,9 +394,12 @@ export default class Todo extends Vue {
|
||||
})
|
||||
})
|
||||
} else {
|
||||
if (cmd === rescodes.DB.CMD_SYNC_TODOS)
|
||||
if (cmd === rescodes.DB.CMD_SYNC_TODOS) {
|
||||
if (method === 'POST')
|
||||
Todos.actions.dbInsertTodo(item)
|
||||
else if (method === 'PATCH')
|
||||
Todos.actions.dbSaveTodo(item)
|
||||
else if (cmd === rescodes.DB.CMD_DELETE_TODOS)
|
||||
} else if (cmd === rescodes.DB.CMD_DELETE_TODOS)
|
||||
Todos.actions.dbDeleteTodo(id)
|
||||
}
|
||||
}
|
||||
@@ -633,6 +635,10 @@ export default class Todo extends Vue {
|
||||
|
||||
|
||||
async modify(myobj: ITodo, update: boolean) {
|
||||
if (myobj === null)
|
||||
return new Promise(function (resolve, reject) {
|
||||
resolve()
|
||||
})
|
||||
await globalroutines(this, 'read', 'todos', null, myobj._id)
|
||||
.then(miorec => {
|
||||
console.log('ArrTodos: ', myobj.descr, '[', myobj._id, ']')
|
||||
|
||||
@@ -64,26 +64,20 @@ export let idbKeyval = (() => {
|
||||
return req.result;
|
||||
},
|
||||
async set(key, value) {
|
||||
return await withStore('readwrite', 'keyval', store => {
|
||||
store.put(value, key);
|
||||
let req;
|
||||
await withStore('readwrite', 'keyval', store => {
|
||||
req = store.put(value, key);
|
||||
});
|
||||
return req.result;
|
||||
},
|
||||
async setdata(table, valuekey) {
|
||||
|
||||
// set only the ID, because it need to delete it
|
||||
let value = []
|
||||
if (table === 'delete_todos') {
|
||||
value['_id'] = valuekey
|
||||
value['value'] = valuekey
|
||||
}else {
|
||||
value = valuekey
|
||||
}
|
||||
|
||||
async setdata(table, value) {
|
||||
let req;
|
||||
console.log('setdata', table, value)
|
||||
|
||||
return await withStore('readwrite', table, store => {
|
||||
store.put(value);
|
||||
await withStore('readwrite', table, store => {
|
||||
req = store.put(value);
|
||||
});
|
||||
return req.result;
|
||||
},
|
||||
async delete(key) {
|
||||
return await withStore('readwrite', 'keyval', store => {
|
||||
|
||||
@@ -1,4 +1,4 @@
|
||||
let idbKeyval = (() => {
|
||||
let let idbKeyval = (() => {
|
||||
let db;
|
||||
|
||||
function getDB() {
|
||||
@@ -47,6 +47,7 @@ let idbKeyval = (() => {
|
||||
},
|
||||
async getdata(table, key) {
|
||||
let req;
|
||||
|
||||
await withStore('readonly', table, store => {
|
||||
console.log('store', store, 'key', key)
|
||||
req = store.get(key);
|
||||
@@ -62,24 +63,20 @@ let idbKeyval = (() => {
|
||||
return req.result;
|
||||
},
|
||||
async set(key, value) {
|
||||
return await withStore('readwrite', 'keyval', store => {
|
||||
store.put(value, key);
|
||||
let req;
|
||||
await withStore('readwrite', 'keyval', store => {
|
||||
req = store.put(value, key);
|
||||
});
|
||||
return req.result;
|
||||
},
|
||||
async setdata(table, valuekey) {
|
||||
|
||||
let value = []
|
||||
if (table === 'delete_todos') {
|
||||
value['_id'] = valuekey
|
||||
}else {
|
||||
value = valuekey
|
||||
}
|
||||
|
||||
async setdata(table, value) {
|
||||
let req;
|
||||
console.log('setdata', table, value)
|
||||
|
||||
return await withStore('readwrite', table, store => {
|
||||
store.put(value);
|
||||
await withStore('readwrite', table, store => {
|
||||
req = store.put(value);
|
||||
});
|
||||
return req.result;
|
||||
},
|
||||
async delete(key) {
|
||||
return await withStore('readwrite', 'keyval', store => {
|
||||
|
||||
@@ -18,6 +18,12 @@ async function sendRequest (url: string, lang: string, mytok: string, method: st
|
||||
cache: 'no-cache',
|
||||
headers: authHeader
|
||||
}
|
||||
} else if (method === 'DELETE') {
|
||||
configInit = {
|
||||
method: method,
|
||||
cache: 'no-cache',
|
||||
headers: authHeader
|
||||
}
|
||||
} else {
|
||||
configInit = {
|
||||
method: method,
|
||||
|
||||
@@ -77,12 +77,20 @@ namespace Actions {
|
||||
}
|
||||
|
||||
async function dbSaveTodo(context, itemtodo: ITodo) {
|
||||
console.log('dbSaveTodo', itemtodo)
|
||||
return await dbInsertSaveTodo(context, itemtodo, 'PATCH')
|
||||
}
|
||||
|
||||
async function dbInsertTodo(context, itemtodo: ITodo) {
|
||||
return await dbInsertSaveTodo(context, itemtodo, 'POST')
|
||||
}
|
||||
|
||||
async function dbInsertSaveTodo(context, itemtodo: ITodo, method) {
|
||||
console.log('dbInsertSaveTodo', itemtodo, method)
|
||||
let call = process.env.MONGODB_HOST + '/todos/' + itemtodo._id
|
||||
|
||||
const token = UserStore.state.idToken
|
||||
|
||||
let res = await Api.SendReq(call, UserStore.state.lang, token, 'PATCH', itemtodo)
|
||||
let res = await Api.SendReq(call, UserStore.state.lang, token, method, itemtodo)
|
||||
.then(function (res) {
|
||||
return rescodes.OK
|
||||
})
|
||||
@@ -127,6 +135,7 @@ namespace Actions {
|
||||
}
|
||||
|
||||
export const actions = {
|
||||
dbInsertTodo: b.dispatch(dbInsertTodo),
|
||||
dbSaveTodo: b.dispatch(dbSaveTodo),
|
||||
dbLoadTodo: b.dispatch(dbLoadTodo),
|
||||
dbDeleteTodo: b.dispatch(dbDeleteTodo),
|
||||
|
||||
Reference in New Issue
Block a user