diff options
| author | Alex Yatskov <alex@foosoft.net> | 2020-05-22 17:46:16 -0700 | 
|---|---|---|
| committer | Alex Yatskov <alex@foosoft.net> | 2020-05-22 17:46:16 -0700 | 
| commit | 1480288561cb8b9fb87ad711d970c548329fea98 (patch) | |
| tree | 87c2247f6d144407afcc6de316bbacc264582248 /ext/bg/js/database.js | |
| parent | f2186c51e4ef219d158735d30a32bbf3e49c4e1a (diff) | |
| parent | d0dcff765f740bf6f0f6523b09cb8b21eb85cd93 (diff) | |
Merge branch 'master' into testing
Diffstat (limited to 'ext/bg/js/database.js')
| -rw-r--r-- | ext/bg/js/database.js | 47 | 
1 files changed, 44 insertions, 3 deletions
| diff --git a/ext/bg/js/database.js b/ext/bg/js/database.js index 260c815a..930cd0d0 100644 --- a/ext/bg/js/database.js +++ b/ext/bg/js/database.js @@ -33,7 +33,7 @@ class Database {          }          try { -            this.db = await Database._open('dict', 5, (db, transaction, oldVersion) => { +            this.db = await Database._open('dict', 6, (db, transaction, oldVersion) => {                  Database._upgrade(db, transaction, oldVersion, [                      {                          version: 2, @@ -90,12 +90,21 @@ class Database {                                  indices: ['dictionary', 'expression', 'reading', 'sequence', 'expressionReverse', 'readingReverse']                              }                          } +                    }, +                    { +                        version: 6, +                        stores: { +                            media: { +                                primaryKey: {keyPath: 'id', autoIncrement: true}, +                                indices: ['dictionary', 'path'] +                            } +                        }                      }                  ]);              });              return true;          } catch (e) { -            logError(e); +            yomichan.logError(e);              return false;          }      } @@ -120,7 +129,7 @@ class Database {          await this.prepare();      } -    async deleteDictionary(dictionaryName, onProgress, progressSettings) { +    async deleteDictionary(dictionaryName, progressSettings, onProgress) {          this._validate();          const targets = [ @@ -268,6 +277,34 @@ class Database {          return result;      } +    async getMedia(targets) { +        this._validate(); + +        const count = targets.length; +        const promises = []; +        const results = new Array(count).fill(null); +        const createResult = Database._createMedia; +        const processRow = (row, [index, dictionaryName]) => { +            if (row.dictionary === dictionaryName) { +                results[index] = createResult(row, index); +            } +        }; + +        const transaction = this.db.transaction(['media'], 'readonly'); +        const objectStore = transaction.objectStore('media'); +        const index = objectStore.index('path'); + +        for (let i = 0; i < count; ++i) { +            const {path, dictionaryName} = targets[i]; +            const only = IDBKeyRange.only(path); +            promises.push(Database._getAll(index, only, [i, dictionaryName], processRow)); +        } + +        await Promise.all(promises); + +        return results; +    } +      async getDictionaryInfo() {          this._validate(); @@ -432,6 +469,10 @@ class Database {          return {character, mode, data, dictionary, index};      } +    static _createMedia(row, index) { +        return Object.assign({}, row, {index}); +    } +      static _getAll(dbIndex, query, context, processRow) {          const fn = typeof dbIndex.getAll === 'function' ? Database._getAllFast : Database._getAllUsingCursor;          return fn(dbIndex, query, context, processRow); |