mirror of
https://github.com/discourse/discourse.git
synced 2024-11-30 20:25:26 +08:00
Notifications cache should use localStorage
wrapper
This commit is contained in:
parent
bf2c18fddb
commit
6fb69d4434
|
@ -46,4 +46,12 @@ KeyValueStore.prototype = {
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
// API compatibility with `localStorage`
|
||||||
|
KeyValueStore.prototype.getItem = KeyValueStore.prototype.get;
|
||||||
|
KeyValueStore.prototype.removeItem = KeyValueStore.prototype.remove;
|
||||||
|
KeyValueStore.prototype.setItem = function(key, value) {
|
||||||
|
this.set({ key, value });
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
export default KeyValueStore;
|
export default KeyValueStore;
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
import StaleResult from 'discourse/lib/stale-result';
|
import StaleResult from 'discourse/lib/stale-result';
|
||||||
import { hashString } from 'discourse/lib/hash';
|
import { hashString } from 'discourse/lib/hash';
|
||||||
|
|
||||||
// Mix this in to an adapter to provide stale caching in localStorage
|
// Mix this in to an adapter to provide stale caching in our key value store
|
||||||
export default {
|
export default {
|
||||||
storageKey(type, findArgs) {
|
storageKey(type, findArgs) {
|
||||||
const hashedArgs = Math.abs(hashString(JSON.stringify(findArgs)));
|
const hashedArgs = Math.abs(hashString(JSON.stringify(findArgs)));
|
||||||
|
@ -11,12 +11,11 @@ export default {
|
||||||
findStale(store, type, findArgs) {
|
findStale(store, type, findArgs) {
|
||||||
const staleResult = new StaleResult();
|
const staleResult = new StaleResult();
|
||||||
try {
|
try {
|
||||||
const stored = localStorage.getItem(this.storageKey(type, findArgs));
|
const stored = this.keyValueStore.getItem(this.storageKey(type, findArgs));
|
||||||
if (stored) {
|
if (stored) {
|
||||||
const parsed = JSON.parse(stored);
|
const parsed = JSON.parse(stored);
|
||||||
staleResult.setResults(parsed);
|
staleResult.setResults(parsed);
|
||||||
}
|
}
|
||||||
|
|
||||||
} catch(e) {
|
} catch(e) {
|
||||||
// JSON parsing error
|
// JSON parsing error
|
||||||
}
|
}
|
||||||
|
@ -25,7 +24,7 @@ export default {
|
||||||
|
|
||||||
find(store, type, findArgs) {
|
find(store, type, findArgs) {
|
||||||
return this._super(store, type, findArgs).then((results) => {
|
return this._super(store, type, findArgs).then((results) => {
|
||||||
localStorage.setItem(this.storageKey(type, findArgs), JSON.stringify(results));
|
this.keyValueStore.setItem(this.storageKey(type, findArgs), JSON.stringify(results));
|
||||||
return results;
|
return results;
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
|
@ -15,7 +15,7 @@ function inject() {
|
||||||
}
|
}
|
||||||
|
|
||||||
function injectAll(app, name) {
|
function injectAll(app, name) {
|
||||||
inject(app, name, 'controller', 'component', 'route', 'view', 'model');
|
inject(app, name, 'controller', 'component', 'route', 'view', 'model', 'adapter');
|
||||||
}
|
}
|
||||||
|
|
||||||
export default {
|
export default {
|
||||||
|
|
Loading…
Reference in New Issue
Block a user