From b4b0e8a7be8a9cd515cd0044b222c071ae8e9fb3 Mon Sep 17 00:00:00 2001
From: temi
Date: Wed, 31 May 2023 21:53:40 +1000
Subject: [PATCH 01/47] AtlasOfLivingAustralia/biocollect#1532 - offline
capability - species generation via admin tools - offline map
---
build.gradle | 12 +-
gradle.properties | 2 +-
.../assets/javascripts/biocollect-utils.js | 43 +
.../assets/javascripts/database-schema.js | 51 +
.../javascripts/enterBioActivityData.js | 70 +-
grails-app/assets/javascripts/entities.js | 838 +++
.../assets/javascripts/forms-manifest.js | 7 +
grails-app/assets/javascripts/images.js | 99 +-
.../javascripts/knockout-custom-bindings.js | 4 +-
grails-app/assets/javascripts/offline-list.js | 365 ++
grails-app/assets/javascripts/outputs.js | 86 +-
.../javascripts/project-activity-index.js | 99 +
grails-app/assets/javascripts/pwa-cache.js | 65 +
.../pwa-form-initialisation-script.js | 43 +
grails-app/assets/javascripts/pwa-index.js | 511 ++
grails-app/assets/javascripts/pwa-messages.js | 24 +
grails-app/assets/javascripts/sw.js | 69 +
grails-app/assets/vendor/dexiejs/dexie.js | 5719 +++++++++++++++++
grails-app/assets/vendor/dexiejs/dexie.js.map | 1 +
grails-app/assets/vendor/dexiejs/dexie.min.js | 2 +
.../assets/vendor/dexiejs/dexie.min.js.map | 1 +
grails-app/conf/application.yml | 41 +-
.../biocollect/BioActivityController.groovy | 261 +-
.../ala/biocollect/DocumentController.groovy | 16 +
.../ProjectActivityController.groovy | 4 +-
.../au/org/ala/biocollect/UrlMappings.groovy | 53 +
.../biocollect/merit/ProjectController.groovy | 26 +-
.../biocollect/merit/SearchController.groovy | 19 +-
.../biocollect/merit/SiteController.groovy | 26 +-
.../biocollect/merit/SpeciesController.groovy | 33 +
grails-app/i18n/messages.properties | 49 +
.../biocollect/ProjectActivityService.groovy | 4 +-
.../biocollect/merit/SpeciesService.groovy | 255 +-
grails-app/views/admin/tools.gsp | 19 +
.../_activityInitialisationJavaScript.gsp | 136 +
..._asyncActivityInitialisationJavaScript.gsp | 152 +
.../bioActivity/_createEditActivityBody.gsp | 142 +-
grails-app/views/bioActivity/create.gsp | 5 +-
grails-app/views/bioActivity/createOrEdit.gsp | 86 +
.../bioActivity/createOrEditFragment.gsp | 2 +
grails-app/views/bioActivity/edit.gsp | 5 +-
grails-app/views/bioActivity/index.gsp | 2 +-
grails-app/views/bioActivity/offlineList.gsp | 93 +
.../views/bioActivity/previewActivity.gsp | 5 +-
grails-app/views/bioActivity/pwaIndex.gsp | 252 +
.../views/bioActivity/pwaIndexFragment.gsp | 34 +
grails-app/views/layouts/pwa.gsp | 18 +
grails-app/views/pwa/index.gsp | 297 +
settings.gradle | 4 +-
.../org/ala/biocollect/StubbedCasSpec.groovy | 21 +
.../resources/wiremock/mappings/jwks.json | 23 +
.../mappings/webServiceAccessToken.json | 20 +
src/test/js/spec/ProjectActivitySpec.js | 10 +-
53 files changed, 10026 insertions(+), 198 deletions(-)
create mode 100644 grails-app/assets/javascripts/biocollect-utils.js
create mode 100644 grails-app/assets/javascripts/database-schema.js
create mode 100644 grails-app/assets/javascripts/entities.js
create mode 100644 grails-app/assets/javascripts/offline-list.js
create mode 100644 grails-app/assets/javascripts/project-activity-index.js
create mode 100644 grails-app/assets/javascripts/pwa-cache.js
create mode 100644 grails-app/assets/javascripts/pwa-form-initialisation-script.js
create mode 100644 grails-app/assets/javascripts/pwa-index.js
create mode 100644 grails-app/assets/javascripts/pwa-messages.js
create mode 100644 grails-app/assets/javascripts/sw.js
create mode 100644 grails-app/assets/vendor/dexiejs/dexie.js
create mode 100644 grails-app/assets/vendor/dexiejs/dexie.js.map
create mode 100644 grails-app/assets/vendor/dexiejs/dexie.min.js
create mode 100644 grails-app/assets/vendor/dexiejs/dexie.min.js.map
create mode 100644 grails-app/views/bioActivity/_activityInitialisationJavaScript.gsp
create mode 100644 grails-app/views/bioActivity/_asyncActivityInitialisationJavaScript.gsp
create mode 100644 grails-app/views/bioActivity/createOrEdit.gsp
create mode 100644 grails-app/views/bioActivity/createOrEditFragment.gsp
create mode 100644 grails-app/views/bioActivity/offlineList.gsp
create mode 100644 grails-app/views/bioActivity/pwaIndex.gsp
create mode 100644 grails-app/views/bioActivity/pwaIndexFragment.gsp
create mode 100644 grails-app/views/layouts/pwa.gsp
create mode 100644 grails-app/views/pwa/index.gsp
create mode 100644 src/integration-test/resources/wiremock/mappings/jwks.json
create mode 100644 src/integration-test/resources/wiremock/mappings/webServiceAccessToken.json
diff --git a/build.gradle b/build.gradle
index b19c731dd..631fc587d 100644
--- a/build.gradle
+++ b/build.gradle
@@ -111,6 +111,8 @@ dependencies {
implementation('org.grails.plugins:http-builder-helper:1.1.0') {
exclude group: 'org.apache.httpcomponents', module: 'httpclient'
}
+
+ implementation 'com.opencsv:opencsv:5.7.0'
implementation "org.apache.httpcomponents:httpclient:4.5.7"
runtimeOnly 'org.webjars:jquery:1.12.4'
implementation 'dk.glasius:external-config:3.0.0'
@@ -151,10 +153,14 @@ dependencies {
runtimeOnly 'com.bertramlabs.plugins:less-asset-pipeline:3.3.1'
implementation 'com.bertramlabs.plugins:sass-asset-pipeline:3.2.5'
implementation 'org.codehaus.groovy:groovy-dateutil:2.5.0'
-
+ implementation "org.grails.plugins:ala-map-plugin:3.0.1"
+ implementation "com.nimbusds:nimbus-jose-jwt:9.25.6"
+ implementation "io.jsonwebtoken:jjwt-impl:0.11.5"
+ implementation "io.jsonwebtoken:jjwt-jackson:0.11.5"
+ implementation "io.jsonwebtoken:jjwt-api:0.11.5"
if (!Boolean.valueOf(inplace)) {
implementation "org.grails.plugins:ala-map-plugin:3.0.1"
- implementation "org.grails.plugins:ecodata-client-plugin:6.1-COGNITO-SNAPSHOT"
+ implementation "org.grails.plugins:ecodata-client-plugin:6.1-PWA-SNAPSHOT"
}
testCompileOnly "org.grails:grails-test-mixins:3.3.0"
@@ -210,7 +216,7 @@ if (Boolean.valueOf(inplace)) {
exploded = true
plugins {
implementation(project(':ecodata-client-plugin'))
- implementation(project(':ala-map-plugin'))
+// implementation(project(':ala-map-plugin'))
}
}
diff --git a/gradle.properties b/gradle.properties
index fdcc895be..2e410427e 100644
--- a/gradle.properties
+++ b/gradle.properties
@@ -1,4 +1,4 @@
-biocollectVersion=6.6-SNAPSHOT
+biocollectVersion=6.6-PWA-SNAPSHOT
grailsVersion=5.1.9
grailsGradlePluginVersion=5.1.5
assetPipelineVersion=3.3.4
diff --git a/grails-app/assets/javascripts/biocollect-utils.js b/grails-app/assets/javascripts/biocollect-utils.js
new file mode 100644
index 000000000..5bb1e7329
--- /dev/null
+++ b/grails-app/assets/javascripts/biocollect-utils.js
@@ -0,0 +1,43 @@
+/**
+ * https://stackoverflow.com/a/20584396
+ * @param node
+ * @returns {*}
+ */
+function nodeScriptReplace(node) {
+ if ( nodeScriptIs(node) === true ) {
+ node.parentNode.replaceChild( nodeScriptClone(node) , node );
+ }
+ else {
+ var i = -1, children = node.childNodes;
+ while ( ++i < children.length ) {
+ nodeScriptReplace( children[i] );
+ }
+ }
+
+ return node;
+}
+
+/**
+ * https://stackoverflow.com/a/20584396
+ * @param node
+ * @returns {HTMLScriptElement}
+ */
+function nodeScriptClone(node){
+ var script = document.createElement("script");
+ script.text = node.innerHTML;
+
+ var i = -1, attrs = node.attributes, attr;
+ while ( ++i < attrs.length ) {
+ script.setAttribute( (attr = attrs[i]).name, attr.value );
+ }
+ return script;
+}
+
+/**
+ * https://stackoverflow.com/a/20584396
+ * @param node
+ * @returns {boolean}
+ */
+function nodeScriptIs(node) {
+ return node.tagName === 'SCRIPT';
+}
\ No newline at end of file
diff --git a/grails-app/assets/javascripts/database-schema.js b/grails-app/assets/javascripts/database-schema.js
new file mode 100644
index 000000000..2796461cc
--- /dev/null
+++ b/grails-app/assets/javascripts/database-schema.js
@@ -0,0 +1,51 @@
+function getDB() {
+ var DB_NAME = "biocollect";
+ var db = new Dexie(DB_NAME);
+ db.version(2).stores({
+ taxon: `
+ ++id,
+ projectActivityId,
+ dataFieldName,
+ outputName,
+ name,
+ scientificName,
+ commonName,
+ listId,
+ [projectActivityId+dataFieldName+outputName]`,
+ site: `++siteId,
+ *projects`,
+ projectActivity: `++projectActivityId,*sites`,
+ project: `++projectId`,
+ document: `++documentId`,
+ activity: `++activityId,
+ projectActivityId,
+ projectId`,
+ metaModel: `name`,
+ offlineMap: `++id,name`,
+ credential: `++userId`,
+ });
+
+ return db;
+}
+
+function convertToJqueryPromise(dexiePromise, doNotTransformData) {
+ doNotTransformData = !!doNotTransformData && true;
+ var deferred = $.Deferred();
+ dexiePromise.then(function (result) {
+ if (doNotTransformData) {
+ deferred.resolve.apply(deferred, arguments);
+ }
+ else {
+ deferred.resolve({data: result});
+ }
+ }).catch(function (error) {
+ if(doNotTransformData) {
+ deferred.reject.apply(deferred, arguments);
+ }
+ else {
+ deferred.reject({error: error});
+ }
+ });
+
+ return deferred.promise();
+}
\ No newline at end of file
diff --git a/grails-app/assets/javascripts/enterBioActivityData.js b/grails-app/assets/javascripts/enterBioActivityData.js
index d4737da09..d380a34b9 100644
--- a/grails-app/assets/javascripts/enterBioActivityData.js
+++ b/grails-app/assets/javascripts/enterBioActivityData.js
@@ -87,6 +87,32 @@ function Master(activityId, config) {
return activityData;
};
+ /**
+ * Does not check if model is dirty.
+ * @returns {{}|undefined}
+ */
+ self.getAllModelAsJS = function () {
+ var activityData, outputs = [];
+ $.each(this.subscribers, function(i, obj) {
+ if (obj.model === 'activityModel') {
+ activityData = obj.get();
+ }
+ else {
+ outputs.push(obj.get());
+ }
+ });
+
+ if (activityData === undefined && outputs.length == 0) {
+ return undefined;
+ }
+ if (!activityData) {
+ activityData = {};
+ }
+ activityData.outputs = outputs;
+
+ return activityData;
+ };
+
self.modelAsJSON = function() {
var jsData = self.modelAsJS();
@@ -123,8 +149,13 @@ function Master(activityId, config) {
self.listenForResolution = function () {
$.when.apply($, self.deferredObjects).then(function () {
- if (fcConfig.bulkUpload)
- window.parent.postMessage({eventName: 'viewmodelloadded', data: {}}, fcConfig.originUrl);
+ if (fcConfig.bulkUpload || fcConfig.isCaching) {
+ // event and eventName for backward compatibility
+ window.parent.postMessage({eventName: 'viewmodelloadded', event:'viewmodelloadded', data: {}}, fcConfig.originUrl);
+ }
+ else if (fcConfig.isPWA) {
+ window.parent.postMessage({eventName: 'viewmodelloadded', event:'viewmodelloadded', data: {}}, fcConfig.pwaAppUrl);
+ }
});
}
@@ -141,6 +172,34 @@ function Master(activityId, config) {
* Validates the entire page before saving.
*/
self.save = function () {
+ if (isOffline() && config.isPWA) {
+ self.offlineSave();
+ }
+ else {
+ self.onlineSave();
+ }
+ },
+
+ self.offlineSave = function () {
+ if ($('#validation-container').validationEngine('validate')) {
+ var toSave = this.getAllModelAsJS();
+ toSave.entityUpdated = true;
+ var projectId = toSave.projectId;
+ var projectActivityId = toSave.projectActivityId;
+ toSave = JSON.stringify(toSave);
+ toSave = JSON.parse(toSave);
+
+ entities.saveActivity(toSave).then(function (result) {
+ var activityId = result.data;
+ if (config.isPWA) {
+ document.location.href = config.returnTo;
+ } else
+ document.location.href = fcConfig.activityViewURL + "/" + projectActivityId + "?activityId=" + activityId + "&projectId=" + projectId;
+ });
+ }
+ },
+
+ self.onlineSave = function () {
if ($('#validation-container').validationEngine('validate')) {
var toSave = this.modelAsJS();
toSave = JSON.stringify(toSave);
@@ -174,7 +233,8 @@ function Master(activityId, config) {
} else {
unblock = false; // We will be transitioning off this page.
activityId = config.activityId || data.resp.activityId;
- config.returnTo = config.bioActivityView + activityId;
+ if (!config.isPWA)
+ config.returnTo = config.bioActivityView + activityId;
blockUIWithMessage("Successfully submitted the record.");
self.reset();
self.saved();
@@ -229,7 +289,8 @@ function Master(activityId, config) {
}
else if (config.isMobile) {
location.href = config.returnToMobile;
- } else {
+ }
+ else {
document.location.href = config.returnTo;
}
};
@@ -275,6 +336,7 @@ function ActivityHeaderViewModel (act, site, project, metaModel, pActivity, conf
self.bulkImportId = ko.observable(act.bulkImportId);
self.embargoed = ko.observable(false);
self.projectId = act.projectId;
+ self.projectActivityId = pActivity ? pActivity.projectActivityId : null;
// check if project activity requires manual verification by admin
var verificationStatus = pActivity.adminVerification ? 'not verified' : 'not applicable';
diff --git a/grails-app/assets/javascripts/entities.js b/grails-app/assets/javascripts/entities.js
new file mode 100644
index 000000000..3c5f75fba
--- /dev/null
+++ b/grails-app/assets/javascripts/entities.js
@@ -0,0 +1,838 @@
+var entities = (function () {
+ var GROUP = "GROUP_OF_SPECIES", SINGLE = "SINGLE_SPECIES", ALL = 'ALL_SPECIES', SPECIES_MAX_FETCH = 20;
+
+ var projectPromise, paPromise;
+ var limit = 5, query = "", offset = 0;
+ var db = getDB(), dbOpen = convertToJqueryPromise(db.open(), true), forceOffline = false,
+ downloadingAllSpecies = false;
+
+ function getProject() {
+ if (isOffline()) {
+ return offlineFetchProject();
+ } else {
+ return onlineFetchProject();
+ }
+ }
+
+ function onlineFetchProject(isSave) {
+ isSave = isSave || false;
+ if (!projectPromise) {
+ projectPromise = $.ajax({
+ url: fcConfig.projectURL
+ });
+
+ projectPromise.then(saveProject);
+ }
+
+ return projectPromise.then(function (result) {
+ return {data: result}
+ });
+ }
+
+ function offlineFetchProject(projectId) {
+ projectId = projectId || fcConfig.projectId;
+ return dbOpen.then(function () {
+ return convertToJqueryPromise(db.table('project').where('projectId').equals(projectId).first());
+ });
+ }
+
+ function saveProject(project) {
+ return dbOpen.then(function () {
+ return convertToJqueryPromise(db.table('project').put(project));
+ });
+ }
+
+ function getProjectActivity(pActivityId) {
+ if (isOffline()) {
+ return offlineFetchProjectActivity(pActivityId);
+ } else {
+ return onlineFetchProjectActivity(pActivityId);
+ }
+ }
+
+ function onlineFetchProjectActivity(pActivityId) {
+ if (!paPromise) {
+ paPromise = $.ajax({
+ url: fcConfig.projectActivityURL + "/" + pActivityId
+ });
+
+ paPromise.then(saveProjectActivity);
+ }
+
+ return paPromise.then(function (result) {
+ return {data: result}
+ });
+ }
+
+ function offlineFetchProjectActivity(pActivityId) {
+ pActivityId = pActivityId || fcConfig.projectActivityId;
+ return dbOpen.then(function () {
+ return convertToJqueryPromise(db.table('projectActivity').where('projectActivityId').equals(pActivityId).first());
+ });
+ }
+
+ function saveProjectActivity(pa) {
+ return dbOpen.then(function () {
+ return convertToJqueryPromise(db.table('projectActivity').put(pa));
+ });
+ }
+
+ function getActivitiesForProjectActivity(projectActivityId, max, offset, sort, order) {
+ // if(isOffline()) {
+ return offlineGetActivitiesForProjectActivity(projectActivityId, max, offset, sort, order);
+ // }
+ // else {
+ // return onlineGetActivitiesForProjectActivity(projectActivityId, max, offset, sort, order);
+ // }
+ }
+
+ function onlineGetActivitiesForProjectActivity(max, offset, sort, order) {
+ return dbOpen.then(function () {
+ sort = sort || 'lastUpdated';
+ order = order || 'DESC';
+ max = max || 30;
+ offset = offset || 0;
+
+ return $.ajax({
+ url: fcConfig.activitiesFromProjectActivityURL, data: {
+ sort: sort, order: order, max: max, offset: offset
+ }
+ }).then(function (result) {
+ // save the activities into db so that we can query db to get the unpublished activities.
+ return saveActivitiesForProjectActivity({data: result}).then(function () {
+ return offlineGetActivitiesForProjectActivity(max, offset, sort, order).then(function (offlineResults) {
+ return {data: {activities: offlineResults.data, total: result.total}};
+ });
+ });
+ });
+ });
+ }
+
+ function saveActivitiesForProjectActivity(result) {
+ var activities = result.data.activities;
+ return dbOpen.then(function () {
+ return convertToJqueryPromise(db.table('activity').bulkPut(activities));
+ })
+ }
+
+ function offlineGetActivitiesForProjectActivity(projectActivityId, max, offset, sort, order) {
+ sort = sort || 'lastUpdated';
+ order = order || 'DESC';
+ max = max || 30;
+ offset = offset || 0;
+
+ return dbOpen.then(function () {
+ var promise,
+ countPromise = convertToJqueryPromise(db.table('activity').where('projectActivityId').equals(projectActivityId).count());
+ switch (order) {
+ default:
+ case 'DESC':
+ promise = convertToJqueryPromise(db.table('activity').where('projectActivityId').equals(projectActivityId).reverse().offset(offset).limit(max).sortBy(sort));
+ break;
+ case 'ASC':
+ promise = convertToJqueryPromise(db.table('activity').where('projectActivityId').equals(projectActivityId).offset(offset).limit(max).sortBy(sort));
+ break;
+ }
+
+ return $.when(promise, countPromise).then(function (activitiesResult, totalResult) {
+ return {data: {activities: activitiesResult.data, total: totalResult.data}};
+ });
+ });
+ }
+
+ function getActivity(activityId) {
+ if (isOffline()) {
+ return offlineGetActivity(activityId);
+ } else {
+ return onlineGetActivity(activityId).then(null, function () {
+ // dexie will return not get activity if it is of the wrong type.
+ try {
+ activityId = parseInt(activityId);
+ } catch (e) {
+ console.debug("activityId is not a number - " + activityId);
+ }
+ return offlineGetActivity(activityId);
+ });
+ }
+ }
+
+ function onlineGetActivity(activityId) {
+ var promise = $.ajax({
+ url: fcConfig.activityURL + '/' + activityId
+ });
+
+ promise.then(function (result) {
+ var result = {data: result}
+ saveActivity(result);
+ }, function (error) {
+ console.log("failed to get activity from server");
+ });
+ return promise;
+ }
+
+ // function saveActivity(result) {
+ // var activity = result.data;
+ // return dbOpen.then(function() {
+ // return convertToJqueryPromise(db.table('activity').put(activity));
+ // });
+ // }
+
+ function offlineGetActivity(activityId) {
+ var isDexie = false;
+ if (isUuid(activityId) || (isDexie = isDexieEntityId(activityId))) {
+ if (isDexie) {
+ activityId = convertIdToInteger(activityId);
+ }
+
+ return dbOpen.then(function () {
+ return convertToJqueryPromise(db.table('activity').where('activityId').equals(activityId).first());
+ });
+ } else return $.Deferred().resolve({
+ data: {
+ activityId: '', siteId: '', projectId: fcConfig.projectId, type: fcConfig.type
+ }
+ }).promise();
+ }
+
+ function offlineGetAllActivities(max, offset, sort, order) {
+ sort = sort || 'lastUpdated';
+ order = order || 'DESC';
+ max = max || 30;
+ offset = offset || 0;
+
+ return dbOpen.then(function () {
+ var promise, countPromise = convertToJqueryPromise(db.table('activity').count());
+ switch (order) {
+ default:
+ case 'DESC':
+ promise = convertToJqueryPromise(db.table('activity').reverse().offset(offset).limit(max).sortBy(sort));
+ break;
+ case 'ASC':
+ promise = convertToJqueryPromise(db.table('activity').offset(offset).limit(max).sortBy(sort));
+ break;
+ }
+
+ return $.when(promise, countPromise).then(function (activitiesResult, totalResult) {
+ return {data: {activities: activitiesResult.data, total: totalResult.data}};
+ });
+ });
+ }
+
+ function offlineGetActivitiesForProject(projectId, max, offset, sort, order) {
+ sort = sort || 'lastUpdated';
+ order = order || 'DESC';
+ max = max || 30;
+ offset = offset || 0;
+
+ return dbOpen.then(function () {
+ var promise,
+ countPromise = convertToJqueryPromise(db.table('activity').where('projectId').equals(projectId).count());
+ switch (order) {
+ default:
+ case 'DESC':
+ promise = convertToJqueryPromise(db.table('activity').where('projectId').equals(projectId).reverse().offset(offset).limit(max).sortBy(sort));
+ break;
+ case 'ASC':
+ promise = convertToJqueryPromise(db.table('activity').where('projectId').equals(projectId).offset(offset).limit(max).sortBy(sort));
+ break;
+ }
+
+ return $.when(promise, countPromise).then(function (activitiesResult, totalResult) {
+ return {data: {activities: activitiesResult.data, total: totalResult.data}};
+ });
+ });
+ }
+
+ function getSite(siteId) {
+ if (isOffline()) {
+ return offlineGetSite(siteId);
+ } else {
+ return onlineGetSite(siteId);
+ }
+ }
+
+ function onlineGetSite(siteId) {
+ var deferred = $.Deferred();
+ $.ajax({
+ url: fcConfig.siteUrl + "/" + siteId
+ }).then(function (result) {
+ saveSite(result.site);
+ deferred.resolve(standardiseResult(result.site));
+ }, function (){
+ offlineGetSite(siteId).then(function (result) {
+ deferred.resolve(result);
+ }, function () {
+ deferred.reject();
+ });
+ });
+
+ return deferred;
+ }
+
+ function saveSite(site) {
+ return dbOpen.then(function () {
+ return db.table('site').put(site);
+ });
+ }
+
+ function saveSites(sites) {
+ return dbOpen.then(function () {
+ return convertToJqueryPromise(db.table('site').bulkPut(sites));
+ });
+ }
+
+ function offlineGetSite(siteId) {
+ return dbOpen.then(function () {
+ return convertToJqueryPromise(db.table('site').where('siteId').equals(siteId).first());
+ });
+ }
+
+ function saveSpeciesPaged(species) {
+ return dbOpen.then(function () {
+ return convertToJqueryPromise(db.table('taxon').bulkPut(species));
+ })
+ }
+
+ function deleteAllSpecies() {
+ return dbOpen.then(function () {
+ return db.taxon.where({
+ listId: "all"
+ }).delete();
+ });
+ }
+
+ function countAllSpecies() {
+ return dbOpen.then(function () {
+ return convertToJqueryPromise(db.taxon.where({
+ listId: "all"
+ }).count());
+ });
+ }
+
+ /**
+ * Sequentially download sites. This is done sequentially to avoid overloading the server.
+ * @param sites
+ * @param index
+ * @param deferred
+ * @returns {*}
+ */
+ function getSites(sites, index, deferred) {
+ index = index || 0;
+ deferred = deferred || $.Deferred();
+
+ if (index < sites.length) {
+ onlineGetSite(sites[index]).always(function () {
+ getSites(sites, index + 1, deferred);
+ });
+ } else {
+ deferred.resolve({message: "Finished fetching sites", success: true});
+ }
+
+ return deferred.promise();
+ }
+
+ /**
+ * Save an array of species to the database.
+ * @param data
+ * @returns {*}
+ */
+ function saveSpecies(data, dataFieldName, outputName, projectActivityId) {
+ console.log("in addSpecies");
+ if (data.length === 0) {
+ return;
+ }
+
+ data.forEach(function (item) {
+ delete item.commonNameMatches;
+ delete item.scientificNameMatches;
+ delete item.id;
+ item.projectActivityId = projectActivityId;
+ item.dataFieldName = dataFieldName;
+ item.outputName = outputName;
+ });
+
+ return dbOpen.then(function () {
+ return convertToJqueryPromise(db.taxon.bulkPut(data));
+ });
+ };
+
+ /**
+ *
+ * @param projectActivityId
+ * @param dataFieldName
+ * @param outputName
+ * @returns {*}
+ */
+ function deleteSpeciesEntries(projectActivityId, dataFieldName, outputName) {
+ return dbOpen.then(function () {
+ return convertToJqueryPromise(db.taxon.where({
+ projectActivityId: projectActivityId, dataFieldName: dataFieldName, outputName: outputName
+ }).delete());
+ });
+ }
+
+ function getSpeciesForProjectActivity(pa, callback) {
+ var promises = [];
+ pa.speciesFields && pa.speciesFields.forEach(function (field) {
+ var config = field.config, type = config.type;
+ console.log("fetching species");
+ switch (type) {
+ case GROUP:
+ case SINGLE:
+ promises.push(deleteFetchedSpeciesEntriesAndGetSpeciesForProjectActivityAndFieldInOutput(pa.projectActivityId, field.dataFieldName, field.output, callback));
+ break;
+ case ALL:
+ promises.push(downloadAllSpecies(callback));
+ break;
+ }
+ });
+
+ return $.when.apply($, promises);
+ }
+
+ function onlineGetSpeciesForProjectActivityAndFieldInOutput(offset, projectActivityId, dataFieldName, outputName, limit) {
+ return $.ajax({
+ url: fcConfig.fetchSpeciesUrl, data: {
+ projectActivityId: projectActivityId,
+ dataFieldName: dataFieldName,
+ output: outputName,
+ limit: limit,
+ q: "",
+ offset: offset
+ }
+ }).then(function (result) {
+ return result.autoCompleteList;
+ });
+ };
+
+ function downloadAllSpecies (callback) {
+ var page = 0,
+ total = 1,
+ deferred = $.Deferred();
+ if (downloadingAllSpecies)
+ return
+
+ downloadingAllSpecies = true;
+ function fetchNext () {
+ page ++;
+ if (page <= total) {
+ return $.ajax({
+ url: fcConfig.downloadSpeciesUrl + "?page=" + page
+ }).then(function (species) {
+ updateProgress();
+ saveSpeciesPaged(species).then(fetchNext, deferred.reject);
+ }, function () {
+ updateProgress();
+ deferred.reject();
+ });
+ }
+ else {
+ deferred.resolve();
+ }
+
+ updateProgress();
+ }
+
+ function startFetchingSpecies () {
+ return $.ajax({
+ url: fcConfig.totalUrl,
+ success: function (resp) {
+ total = resp.total;
+ updateProgress();
+ }
+ }).then(fetchNext);
+ }
+
+ function updateProgress () {
+ callback && callback(total, page);
+ }
+
+ countAllSpecies().then(function (result) {
+ if(result.data === 0) {
+ startFetchingSpecies();
+ }
+ else {
+ deferred.resolve();
+ }
+ });
+
+ return deferred.promise();
+ }
+
+
+ function deleteFetchedSpeciesEntriesAndGetSpeciesForProjectActivityAndFieldInOutput(projectActivityId, dataFieldName, outputName) {
+ var offset = 0, deferred = $.Deferred();
+
+ function fetchNext(data) {
+ data = data || [];
+ if (data.length != 0 || offset === 0) {
+ onlineGetSpeciesForProjectActivityAndFieldInOutput(offset, projectActivityId, dataFieldName, outputName, SPECIES_MAX_FETCH).then(function (result) {
+ return saveSpecies(result, dataFieldName, outputName, projectActivityId);
+ }).then(fetchNext).fail(function () {
+ deferred.reject({
+ offset: offset,
+ projectActivityId: projectActivityId,
+ dataFieldName: dataFieldName,
+ outputName: outputName,
+ completed: false,
+ message: "Failed to fetch species for " + dataFieldName + " " + outputName
+ });
+ })
+ offset += SPECIES_MAX_FETCH;
+ } else {
+ deferred.resolve({
+ offset: offset,
+ projectActivityId: projectActivityId,
+ dataFieldName: dataFieldName,
+ outputName: outputName,
+ completed: true,
+ message: "Fetched all spcies for " + dataFieldName + " " + outputName
+ });
+ }
+ }
+
+ function deleteSuccessHandler(count) {
+ console.log("Deleted " + count + " items");
+ return;
+ }
+
+ function deleteFailHandler() {
+ console.log("Deletion failed");
+ console.log(arguments);
+ return;
+ }
+
+ deleteSpeciesEntries(projectActivityId, dataFieldName, outputName).then(deleteSuccessHandler, deleteFailHandler).then(fetchNext);
+ return deferred.promise();
+ }
+
+ // function getActivitiesForProjectActivity(projectActivityId) {
+ // return dbOpen.then(function () {
+ // return convertToJqueryPromise(db.table('activity').where('projectActivityId').equals(projectActivityId).toArray());
+ // });
+ // }
+
+ function saveActivity(activity) {
+ activity.activityId = activity.activityId || undefined;
+ return dbOpen.then(function () {
+ return convertToJqueryPromise(db.table('activity').put(activity));
+ });
+ }
+
+ function getDocument(documentId) {
+ if (isOffline()) {
+ return offlineGetDocument(documentId);
+ } else {
+ return onlineGetDocument(documentId);
+ }
+ }
+
+ function offlineGetDocument(documentId) {
+ return dbOpen.then(function () {
+ return convertToJqueryPromise(db.document.where("documentId").equals(documentId).first());
+ });
+ }
+
+ function onlineGetDocument(documentId) {
+ return $.ajax({
+ url: fcConfig.documentUrl + "/" + documentId
+ });
+ }
+
+ function getProjectActivityMetadata(projectActivityId, activityId) {
+ // if(isOffline()) {
+ // return offlineGetProjectActivityMetadata(projectActivityId);
+ // }
+ // else {
+ return onlineGetProjectActivityMetadata(projectActivityId, activityId);
+ // }
+ }
+
+ function onlineGetProjectActivityMetadata(projectActivityId, activityId) {
+ return $.ajax({
+ url: fcConfig.metadataURL + "?projectActivityId=" + projectActivityId + (isUuid(activityId) ? "&activityId=" + activityId : "")
+ })
+ .done(saveProjectActivityMetadata)
+ .then(function (result) {
+ if (isDexieEntityId(activityId)) {
+ return offlineGetActivity(activityId).then(function (activityResult) {
+ result.activity = activityResult.data;
+ return standardiseResult(result);
+ });
+ }
+
+ return standardiseResult(result);
+ }, function () {
+ return offlineGetProjectActivityMetadata(projectActivityId, activityId)
+ });
+ }
+
+ function saveProjectActivityMetadata(metadata) {
+ if (metadata.projectSite) {
+ saveSite(metadata.projectSite);
+ }
+
+ if (metadata.project) {
+ saveProject(metadata.project);
+ }
+
+ if (metadata.pActivity) {
+ saveProjectActivity(metadata.pActivity);
+ }
+
+ if (metadata.metaModel) {
+ var metaModel = mergeMetaModelAndOutputs(metadata);
+ saveMetaModel(metaModel);
+ }
+ }
+
+ function mergeMetaModelAndOutputs(metadata) {
+ var outputs = metadata.outputModels;
+ metadata.metaModel.outputModels = outputs;
+ return metadata.metaModel;
+ }
+
+ function saveMetaModel(metaModel) {
+ return dbOpen.then(function () {
+ return convertToJqueryPromise(db.table('metaModel').put(metaModel));
+ });
+ }
+
+ function offlineGetMetaModel(modelName) {
+ return dbOpen.then(function () {
+ return convertToJqueryPromise(db.table('metaModel').where('name').equals(modelName).first());
+ });
+ }
+
+ function offlineGetProjectActivityMetadata(projectActivityId, activityId) {
+ var paPromise = offlineFetchProjectActivity(projectActivityId),
+ activityPromise = offlineGetActivity(activityId), result = $.Deferred();
+
+ $.when(paPromise, activityPromise)
+ .then(function (paResult, activityResult) {
+ var pa = paResult.data, activity = activityResult.data, projectId = pa.projectId,
+ projectPromise = offlineFetchProject(projectId),
+ metaModelPromise = offlineGetMetaModel(pa.pActivityFormName),
+ sitePromise = offlineGetSite(activity.siteId)
+
+ $.when(metaModelPromise, projectPromise, sitePromise)
+ .then(function (metaModelResult, projectResult, siteResult) {
+ var metaModel = metaModelResult.data, project = projectResult.data, site = siteResult.data,
+ projectSitePromise = offlineGetSite(project.projectSiteId);
+
+ projectSitePromise.then(function (projectSiteResult) {
+ var projectSite = projectSiteResult.data;
+ result.resolve(standardiseResult({
+ "activity": activity,
+ "mode": "",
+ "site": site,
+ "project": project,
+ "projectSite": projectSite,
+ "speciesLists": [],
+ "metaModel": metaModel,
+ "outputModels": metaModel.outputModels,
+ "themes": [],
+ "user": null,
+ "mapFeatures": [],
+ "pActivity": pa,
+ "speciesConfig": {"surveyConfig": {"speciesFields": pa.speciesFields}},
+ "projectName": project.name,
+ "isUserAdminModeratorOrEditor": false
+ }));
+ });
+ });
+ }).catch(function () {
+ result.reject({message: "Failed to get project activity metadata"});
+ });
+
+ return result.promise();
+ }
+
+ function offlineGetMetaModel(modelName) {
+ return dbOpen.then(function () {
+ return convertToJqueryPromise(db.table('metaModel').where('name').equals(modelName).first());
+ });
+ }
+
+ function bulkDeleteDocuments(documentIds) {
+ return bulkDelete(documentIds, 'document');
+ }
+
+ function deleteSites(siteIds) {
+ return bulkDelete(siteIds, 'site');
+ }
+
+ function deleteActivities(activityIds) {
+ return bulkDelete(activityIds, 'activity');
+ }
+
+ function bulkDelete(ids, tableName) {
+ if (!Array.isArray(ids)) {
+ ids = [ids];
+ }
+
+ return dbOpen.then(function () {
+ return convertToJqueryPromise(db.table(tableName).bulkDelete(ids));
+ });
+ }
+
+ function saveMap(map){
+ return dbOpen.then(function () {
+ return convertToJqueryPromise(db.table('offlineMap').put(map));
+ });
+ }
+
+ function getMaps () {
+ return dbOpen.then(function () {
+ return convertToJqueryPromise(db.table('offlineMap').toArray());
+ })
+ }
+
+ function deleteMap(mapId) {
+ return bulkDelete([mapId], 'offlineMap');
+ }
+
+ function standardiseResult(result) {
+ return {data: result}
+ }
+
+ function convertIdToInteger(id) {
+ if (!isNaN(id)) {
+ id = parseInt(id)
+ }
+
+ return id;
+ }
+
+ function getCredentials() {
+ return dbOpen.then(function () {
+ var promise = db.table('credential').toArray().then(function (credentials) {
+ if (credentials.length > 0) {
+ setupAjax(credentials[0]);
+ }
+
+ return credentials;
+ });
+
+ return convertToJqueryPromise(promise);
+ });
+ }
+
+ function saveCredentials(credentials) {
+ return removeCredentials().then(function () {
+ return db.table('credential').put(credentials);
+ });
+ }
+
+ function setupAjax(credentials) {
+ var authorization = "Bearer " + credentials.token;
+ $.ajaxSetup({
+ cache: false,
+ beforeSend: function (xhr) {
+ xhr.setRequestHeader('Authorization', authorization);
+ }
+ });
+ }
+
+ function removeCredentials() {
+ return dbOpen.then(function () {
+ return convertToJqueryPromise(db.table('credential').clear());
+ });
+ }
+
+ /**
+ * Dexie entity ids are integers.
+ * @param id
+ * @returns {boolean}
+ */
+ function isDexieEntityId(id) {
+ return Number.isInteger(Number.parseInt(id))
+ }
+
+ return {
+ getProject: getProject,
+ getProjectActivity: getProjectActivity,
+ saveProjectActivity: saveProjectActivity,
+ getActivitiesForProjectActivity: getActivitiesForProjectActivity,
+ getActivity: getActivity,
+ getSite: getSite,
+ getSites: getSites,
+ saveSite: saveSite,
+ saveSites: saveSites,
+ deleteMap: deleteMap,
+ saveMap: saveMap,
+ getMaps: getMaps,
+ offlineGetMetaModel: offlineGetMetaModel,
+ offlineGetActivitiesForProject: offlineGetActivitiesForProject,
+ offlineGetAllActivities: offlineGetAllActivities,
+ saveActivity: saveActivity,
+ getDocument: getDocument,
+ saveSpecies: saveSpeciesPaged,
+ deleteAllSpecies: deleteAllSpecies,
+ countAllSpecies: countAllSpecies,
+ offlineGetDocument: offlineGetDocument,
+ getProjectActivityMetadata: getProjectActivityMetadata,
+ getSpeciesForProjectActivity: getSpeciesForProjectActivity,
+ bulkDeleteDocuments: bulkDeleteDocuments,
+ deleteSites: deleteSites,
+ deleteActivities: deleteActivities,
+ getCredentials: getCredentials,
+ removeCredentials: removeCredentials,
+ saveCredentials: saveCredentials,
+ utils: {
+ isDexieEntityId: isDexieEntityId
+ }
+ }
+})();
+
+function getDB() {
+ var DB_NAME = "biocollect";
+ var db = new Dexie(DB_NAME);
+ db.version(2).stores({
+ taxon: `
+ ++id,
+ projectActivityId,
+ dataFieldName,
+ outputName,
+ name,
+ scientificName,
+ commonName,
+ listId,
+ [projectActivityId+dataFieldName+outputName]`,
+ site: `++siteId,
+ *projects`,
+ projectActivity: `++projectActivityId,*sites`,
+ project: `++projectId`,
+ document: `++documentId`,
+ activity: `++activityId,
+ projectActivityId,
+ projectId`,
+ metaModel: `name`,
+ offlineMap: `++id,name`,
+ credential: `++userId`,
+ });
+
+ return db;
+}
+
+function convertToJqueryPromise(dexiePromise, doNotTransformData) {
+ doNotTransformData = !!doNotTransformData && true;
+ var deferred = $.Deferred();
+ dexiePromise.then(function (result) {
+ if (doNotTransformData) {
+ deferred.resolve.apply(deferred, arguments);
+ }
+ else {
+ deferred.resolve({data: result});
+ }
+ }).catch(function (error) {
+ if(doNotTransformData) {
+ deferred.reject.apply(deferred, arguments);
+ }
+ else {
+ deferred.reject({error: error});
+ }
+ });
+
+ return deferred.promise();
+}
\ No newline at end of file
diff --git a/grails-app/assets/javascripts/forms-manifest.js b/grails-app/assets/javascripts/forms-manifest.js
index 4775f880d..84da7a99a 100644
--- a/grails-app/assets/javascripts/forms-manifest.js
+++ b/grails-app/assets/javascripts/forms-manifest.js
@@ -1,3 +1,6 @@
+// from plugin
+//= require utils.js
+
// leaflet
//= require leaflet-manifest.js
@@ -67,4 +70,8 @@
// comments
//= require comment.js
+// indexDB
+//= require dexiejs/dexie.js
+//= require entities.js
+
// audio to be included
\ No newline at end of file
diff --git a/grails-app/assets/javascripts/images.js b/grails-app/assets/javascripts/images.js
index ec20c95b9..503fdd66f 100644
--- a/grails-app/assets/javascripts/images.js
+++ b/grails-app/assets/javascripts/images.js
@@ -23,9 +23,9 @@ function ImageViewModel(prop, skipFindingDocument) {
self.dateTaken = ko.observable(prop.dateTaken || (new Date()).toISOStringNoMillis()).extend({simpleDate: false});
self.contentType = ko.observable(prop.contentType);
- self.url = prop.url;
+ self.url = ko.observable(prop.url);
self.filesize = prop.filesize;
- self.thumbnailUrl = prop.thumbnailUrl || prop.url;
+ self.thumbnailUrl = ko.observable(prop.thumbnailUrl || prop.url);
self.filename = prop.filename;
self.attribution = ko.observable(prop.attribution);
self.licence = ko.observable(prop.licence);
@@ -42,6 +42,7 @@ function ImageViewModel(prop, skipFindingDocument) {
self.activityId = prop.activityId;
self.isEmbargoed = prop.isEmbargoed;
self.identifier = prop.identifier;
+ new Emitter(self);
self.remove = function (images, data, event) {
@@ -63,8 +64,9 @@ function ImageViewModel(prop, skipFindingDocument) {
self.getImageViewerUrl = function () {
// Let the image viewer render high res image.
- self.url = self.url ? self.url.split("/image/proxyImageThumbnailLarge?imageId=").join("/image/proxyImage?imageId=") : self.url;
- return fcConfig.imageLeafletViewer + '?file=' + encodeURIComponent(self.url);
+ var url = self.url() ? self.url().split("/image/proxyImageThumbnailLarge?imageId=").join("/image/proxyImage?imageId=") : self.url()
+ self.url(url);
+ return fcConfig.imageLeafletViewer + '?file=' + encodeURIComponent(self.url());
}
self.summary = function () {
@@ -78,4 +80,93 @@ function ImageViewModel(prop, skipFindingDocument) {
message += takenOn;
return "" + self.notes() + '
' + message + '';
}
+
+ self.load = function(prop){
+ self.dateTaken(prop.dateTaken || (new Date()).toISOStringNoMillis());
+ self.contentType(prop.contentType);
+ self.url(prop.url);
+ self.thumbnailUrl(prop.thumbnailUrl || prop.url);
+ self.filename = prop.filename;
+ prop.attribution && self.attribution(prop.attribution);
+ prop.licence && self.licence(prop.licence);
+ prop.notes && self.notes(prop.notes || '');
+ prop.name && self.name(prop.name);
+ prop.status && self.status(prop.status || 'active');
+ if(prop.filesize)
+ self.filesize = prop.filesize
+ if(prop.licenceDescription)
+ self.licenceDescription = prop.licenceDescription;
+ if(prop.filesize)
+ self.formattedSize = formatBytes(prop.filesize);
+ if(prop.staged !== undefined)
+ self.staged = prop.staged || false;
+ if(prop.documentId)
+ self.documentId = prop.documentId || '';
+ if(prop.projectName)
+ self.projectName = prop.projectName;
+ if(prop.projectId)
+ self.projectId = prop.projectId;
+ if(prop.activityName)
+ self.activityName = prop.activityName;
+ if(prop.activityId)
+ self.activityId = prop.activityId;
+ if(prop.isEmbargoed)
+ self.isEmbargoed = prop.isEmbargoed;
+ if(prop.identifier)
+ self.identifier = prop.identifier;
+ }
+
+ /**
+ * any document that is in index db. Their url will be prefixed with blob:.
+ */
+ self.isBlobDocument = function(){
+ return !!(document && !!document.blob);
+ }
+
+ self.getBlob = function(){
+ return document && document.blobObject;
+ }
+
+ self.isBlobUrl = function(url){
+ return url && url.indexOf('blob:') === 0;
+ }
+
+ self.getDocument = function() {
+ return document
+ }
+
+ /**
+ * Check if the url is a valid object url.
+ */
+ self.fetchImage = function() {
+ if (entities.utils.isDexieEntityId(self.documentId)) {
+ var documentId = parseInt(self.documentId);
+ entities.offlineGetDocument(documentId).then(function(result) {
+ document = result.data;
+ if (self.isBlobDocument()) {
+ var url = self.url();
+ if (self.isBlobUrl(url)) {
+ URL.revokeObjectURL(url);
+ }
+
+ url = ImageViewModel.createObjectURL(document);
+ self.url(url);
+ self.thumbnailUrl(url);
+ }
+
+ document && self.emit('image-fetched', document);
+ });
+ }
+ }
+
+ self.fetchImage();
+}
+
+
+ImageViewModel.createObjectURL = function addObjectURL(document){
+ if (document.blob) {
+ var blob = document.blobObject = new Blob([document.blob], {type: document.contentType});
+ var url = URL.createObjectURL(blob);
+ return url;
+ }
}
\ No newline at end of file
diff --git a/grails-app/assets/javascripts/knockout-custom-bindings.js b/grails-app/assets/javascripts/knockout-custom-bindings.js
index 79cf95b83..b9d9817aa 100644
--- a/grails-app/assets/javascripts/knockout-custom-bindings.js
+++ b/grails-app/assets/javascripts/knockout-custom-bindings.js
@@ -700,10 +700,10 @@ ko.bindingHandlers.ticks = {
ko.bindingHandlers.fileUploadNoImage = {
init: function (element, options) {
-
+ var dropzone = $(element).parent();
var defaults = {autoUpload: true};
var settings = {
- pasteZone: null
+ pasteZone: null, dropZone: dropzone
};
$.extend(settings, defaults, options());
$(element).fileupload(settings
diff --git a/grails-app/assets/javascripts/offline-list.js b/grails-app/assets/javascripts/offline-list.js
new file mode 100644
index 000000000..39513c870
--- /dev/null
+++ b/grails-app/assets/javascripts/offline-list.js
@@ -0,0 +1,365 @@
+function ActivitiesViewModel (config) {
+ var self = this;
+ var projectActivityId = config.projectActivityId;
+ var projectId = config.projectId;
+ self.activities = ko.observableArray();
+ self.pagination = new PaginationViewModel({}, self);
+ self.online = ko.observable(true);
+
+ self.init = function() {
+ window.addEventListener("online", function() {
+ self.online(true);
+ });
+
+ window.addEventListener("offline", function() {
+ self.online(false);
+ });
+ }
+
+ self.load = function(offset) {
+ if (projectActivityId) {
+ self.getActivitiesOfProjectActivity(self.pagination.resultsPerPage() ,offset);
+ }
+ else if (projectId) {
+ self.getActivitiesForProject(self.pagination.resultsPerPage(), offset);
+ }
+ else {
+ self.getAllActivities(self.pagination.resultsPerPage(), offset);
+ }
+ };
+
+ self.refreshPage = function (offset) {
+ self.load(offset);
+ }
+
+ self.getAllActivities = function(max, offset) {
+ entities.offlineGetAllActivities(max, offset).then(function(result) {
+ var activities = result.data.activities,
+ total = result.data.total,
+ container = [];
+
+ activities.forEach(function(activity) {
+ container.push(new ActivityViewModel(activity, self));
+ });
+
+ self.activities(container);
+ self.pagination.loadOffset(offset, total);
+ });
+ }
+
+ self.getActivitiesForProject = function(max, offset) {
+ entities.offlineGetActivitiesForProject(projectId, max, offset).then(function(result) {
+ var activities = result.data.activities,
+ total = result.data.total,
+ container = [];
+
+ activities.forEach(function(activity) {
+ container.push(new ActivityViewModel(activity, self));
+ });
+
+ self.activities(container);
+ self.pagination.loadOffset(offset, total);
+ });
+ }
+
+ self.getActivitiesOfProjectActivity = function(max, offset) {
+ entities.getActivitiesForProjectActivity(projectActivityId, max, offset).then(function(result) {
+ var activities = result.data.activities,
+ total = result.data.total,
+ container = [];
+
+ activities.forEach(function(activity) {
+ container.push(new ActivityViewModel(activity, self));
+ });
+
+ self.activities(container);
+ self.pagination.loadPagination(offset, total);
+ });
+ }
+
+ self.uploadAllHandler = function() {
+ // todo
+ }
+
+ self.remove = function(activity) {
+ self.activities.remove(activity);
+ }
+
+ self.transients = {
+ addActivityUrl: function() {
+ return fcConfig.addActivityUrl + "/" + projectActivityId;
+ },
+ isProjectActivity: !!projectActivityId
+ }
+
+ self.init();
+ self.pagination.first();
+};
+
+function ActivityViewModel (activity, parent) {
+ var self = this, images;
+ self.activityId = activity.activityId;
+ self.projectId = activity.projectId;
+ self.projectActivityId = activity.projectActivityId;
+ self.featureImage = ko.observable();
+ self.species = ko.observableArray();
+ self.metaModel;
+ self.imageViewModels = [];
+ self.transients = {
+ viewActivityUrl: function() {
+ return fcConfig.activityViewUrl + "/" + self.projectActivityId + "?projectId=" + self.projectId + "&activityId=" + self.activityId;
+ },
+ editActivityUrl: function() {
+ return fcConfig.activityEditUrl + "/" + self.projectActivityId + "?projectId=" + self.projectId + "&activityId=" + self.activityId;
+ }
+ }
+
+ self.load = function() {
+ entities.offlineGetMetaModel(activity.type).done(function(result) {
+ var metaModel = result.data,
+ imageViewModel;
+ self.metaModel = new MetaModel(metaModel);
+ self.species(self.metaModel.getDataForType("species", activity));
+ self.imageViewModels = [];
+ images = self.metaModel.getDataForType("image", activity);
+
+ if (images && images.length > 0) {
+ images.forEach(function(image) {
+ imageViewModel = new ImageViewModel(image, true);
+ self.imageViewModels.push(imageViewModel);
+ if (!self.featureImage()) {
+ self.featureImage(imageViewModel);
+ }
+ });
+ }
+ });
+ }
+
+ self.upload = function() {
+ var forceOnline = false;
+ if (!isOffline() || forceOnline) {
+ var promises = [],
+ deferred = $.Deferred();
+ promises.push(self.uploadImages().then(self.deleteImages));
+ promises.push(self.uploadSite().then(self.updateActivityWithSiteId).then(self.saveAsNewSite).then(self.deleteOldSite));
+ $.when.apply($, promises).then(function () {
+ self.saveActivityToDB().then(self.uploadActivity).then(self.deleteActivityFromDB).then(self.removeMeFromList).then(function () {
+ deferred.resolve({data: { activityId: activity.activityId} });
+ });
+ }, function (error) {
+ self.saveActivityToDB().then(function () {
+ deferred.reject({data: { activityId: activity.activityId}, message: "There was an error uploading activity", error: error});
+ });
+ })
+ }
+ else {
+ alert("You are offline. Please connect to the internet and try again.");
+ deferred.reject();
+ }
+
+ return deferred.promise();
+ }
+
+ self.removeMeFromList = function() {
+ parent.remove(self);
+ }
+
+ self.uploadActivity = function() {
+ var oldActivityId = self.activityId;
+ if (entities.utils.isDexieEntityId(activity.activityId)) {
+ activity.activityId = undefined;
+ }
+
+ var toSave = JSON.stringify(activity),
+ deferred = $.Deferred(),
+ url = fcConfig.bioActivityUpdate + "?pActivityId=" + activity.projectActivityId,
+ ajaxRequestParams = {
+ url: url,
+ type: 'POST',
+ data: toSave,
+ contentType: 'application/json',
+ success: function success(data) {
+ if (data.errors || data.error) {
+ deferred.reject({data: {oldActivityId: oldActivityId, error: data.errors || data.error}});
+ }
+ else {
+ deferred.resolve({data: {oldActivityId: oldActivityId, activityId: data.resp.activityId }});
+ }
+ },
+ error: function (jqXHR, status, error) {
+ deferred.reject({data: {activity: activity.activityId, error: error}})
+ }
+ };
+
+ // todo: add user credentials to ajax request
+
+ $.ajax(ajaxRequestParams);
+ return deferred.promise();
+ }
+
+ self.saveActivityToDB = function() {
+ return entities.saveActivity(activity);
+ }
+
+ self.deleteActivityFromDB = function(result) {
+ var activityId = result.data.oldActivityId;
+ return entities.deleteActivities([activityId]);
+ }
+
+ self.updateActivityWithSiteId = function(result) {
+ var siteId = result.data.siteId;
+ activity.siteId = siteId;
+ var sourceNames = self.metaModel.getNamesForDataType("geoMap");
+ self.metaModel.updateDataForSources(sourceNames, activity, siteId);
+ return result;
+ }
+
+ self.saveAsNewSite = function(result) {
+ var site = result.data.site;
+ if (site && isUuid(site.siteId)) {
+ entities.saveSite(site);
+ }
+
+ return result;
+ }
+
+ self.deleteOldSite = function(result) {
+ var siteId = result.data.oldSiteId;
+ if(entities.utils.isDexieEntityId(siteId)) {
+ return entities.deleteSites([siteId]);
+ }
+ else {
+ return $.Deferred().resolve(result);
+ }
+ }
+
+ self.uploadSite = function() {
+ var siteId = self.metaModel.getDataForType("geoMap", activity)[0] || activity.siteId;
+ return entities.getSite(siteId).then(function(result) {
+ var site = result.data,
+ data = {
+ site: site,
+ pActivityId: activity.projectActivityId
+ },
+ id = siteId,
+ deferred = $.Deferred();
+ site['asyncUpdate'] = true; // aysnc update Metadata service for performance improvement
+ if (entities.utils.isDexieEntityId(site.siteId)) {
+ id = site.siteId = undefined;
+ }
+
+ $.ajax({
+ method: 'POST',
+ url: id ? fcConfig.updateSiteUrl + "?id=" + id : fcConfig.updateSiteUrl,
+ data: JSON.stringify(data),
+ contentType: 'application/json',
+ dataType: 'json'
+ }).then(function (result) {
+ if (result.id) {
+ deferred.resolve({data: {siteId: result.id, oldSiteId: siteId, site: site}});
+ }
+ else {
+ deferred.reject({data: result, error : "Site update failed."});
+ }
+ }, function (jqXHR, status, error) {
+ deferred.reject({error : error});
+ });
+
+ return deferred.promise();
+ });
+ }
+
+ self.uploadImages = function() {
+ var uploadedImages = [],
+ promises = [], deferred = $.Deferred();
+
+ self.imageViewModels.forEach(function (imageVM, index) {
+ if (imageVM.isBlobDocument()) {
+ var image = images[index];
+ if (image.documentId && entities.utils.isDexieEntityId(image.documentId)) {
+ uploadedImages.push(image.documentId);
+ }
+
+ promises.push(self.uploadImage(imageVM).then(self.updateImageMetadata.bind(self, imageVM, image)))
+ }
+ });
+
+ $.when.apply($, promises).then(function () {
+ deferred.resolve({data:uploadedImages});
+ }, function (){
+ deferred.reject({error: "Image upload failed."});
+ });
+
+ return deferred.promise();
+ }
+
+ self.updateImageMetadata = function(imageVM, image, stagedMetadata) {
+ $.extend(image, stagedMetadata);
+ imageVM.load(image);
+ if (entities.utils.isDexieEntityId(image.documentId)) {
+ // clear documentId so that BioCollect will create a new document for the image
+ image.documentId = undefined;
+ }
+
+ return image;
+ }
+
+ self.uploadImage = function(image) {
+ var formData = new FormData();
+ formData.append("files", image.getBlob());
+ return $.ajax({
+ url: fcConfig.imageUploadUrl,
+ type: "POST",
+ data: formData,
+ processData: false,
+ contentType: false
+ })
+ .then(function (result) {
+ return (result.files && result.files[0]) || {};
+ });
+ }
+
+ self.deleteImages = function(result) {
+ var imageIds = result.data;
+ return entities.bulkDeleteDocuments(imageIds).then(function() {
+ console.log("Successfully deleted images - " + imageIds.toString());
+ }, function () {
+ console.error("Failed to delete images");
+ });
+ }
+
+ self.load();
+}
+
+function getParameters (activity) {
+ var url = new URL(window.location.href);
+ return {
+ projectId: url.searchParams.get("projectId"),
+ projectActivityId: url.searchParams.get("projectActivityId")
+ }
+}
+
+document.addEventListener("credential-saved", startInitialising);
+document.addEventListener("credential-failed", function () {
+ alert("Error occurred while saving credentials. Please close modal and try again.");
+});
+
+window.addEventListener('load', function (){
+ setTimeout(startInitialising, 2000)
+ // two event attributes for backward compatibility
+ if (fcConfig.isCaching) {
+ window.parent && window.parent.postMessage({eventName: 'viewmodelloadded', event: 'viewmodelloadded', data: {}}, fcConfig.originUrl);
+ }
+ else if (fcConfig.isPWA) {
+ window.parent && window.parent.postMessage({eventName: 'viewmodelloadded', event: 'viewmodelloadded', data: {}}, fcConfig.pwaAppUrl);
+ }
+});
+
+function startInitialising () {
+ entities.getCredentials().then(function (result) {
+ var config = getParameters(),
+ activitiesViewModel = new ActivitiesViewModel(config);
+
+ ko.applyBindings(activitiesViewModel);
+ })
+}
\ No newline at end of file
diff --git a/grails-app/assets/javascripts/outputs.js b/grails-app/assets/javascripts/outputs.js
index 7c091cc87..55673a7a6 100644
--- a/grails-app/assets/javascripts/outputs.js
+++ b/grails-app/assets/javascripts/outputs.js
@@ -234,6 +234,7 @@ ko.bindingHandlers.imageUpload = {
var progress = ko.observable();
var error = ko.observable();
var complete = ko.observable(true);
+ var db;
var config = valueAccessor();
config = $.extend({}, config, defaultConfig);
@@ -250,6 +251,9 @@ ko.bindingHandlers.imageUpload = {
var innerContext = bindingContext.createChildContext(bindingContext);
ko.utils.extend(innerContext, uploadProperties);
var previewElem = $(element).parent().find(config.previewSelector);
+ if (typeof getDB === 'function') {
+ db = getDB();
+ }
// Expected to be a ko.observableArray
$(element).fileupload({
@@ -319,10 +323,90 @@ ko.bindingHandlers.imageUpload = {
}
window.decreaseAsyncCounter && window.decreaseAsyncCounter();
}).on('fileuploadfail', function(e, data) {
- error(data.errorThrown);
+ if (isOffline()) {
+ var file = data.files[0];
+ file && readDocument(file).then(saveDocument).then(fetchDocument).then(addToViewModel);
+ }
+ else {
+ error(data.errorThrown);
+ }
+
window.decreaseAsyncCounter && window.decreaseAsyncCounter();
});
+ function readDocument(file) {
+ var deferred = $.Deferred();
+ if (file) {
+ var reader = new FileReader();
+ reader.onload = function (e) {
+ var contents = e.target.result;
+ deferred.resolve({data:{blob: contents, file: file}});
+ };
+
+ reader.onerror = function (e) {
+ deferred.reject({message: "Failed to read file" + file.name});
+ };
+
+ reader.readAsArrayBuffer(file);
+ } else {
+ deferred.reject();
+ }
+
+ return deferred.promise();
+ }
+
+ function saveDocument(result) {
+ var deferred = $.Deferred(),
+ file = result.data.file,
+ blob = result.data.blob,
+ document = createDocument(file, blob);
+
+ db.document.put(document).then(function (documentId) {
+ deferred.resolve({data:documentId});
+ }).catch(function (error) {
+ deferred.reject({data: document, error: error});
+ });
+
+ return deferred.promise();
+ }
+
+ function fetchDocument (result) {
+ var documentId = result.data;
+ return convertToJqueryPromise(db.document.where("documentId").equals(documentId).first())
+ }
+
+ function addToViewModel(result) {
+ var viewModel;
+ addObjectURL(result.data);
+ viewModel = new ImageViewModel(result.data, true);
+ target.push(viewModel);
+ complete(true);
+ return viewModel;
+ };
+
+ function addObjectURL(document){
+ var url = ImageViewModel.createObjectURL(document);
+ if (url) {
+ document.thumbnailUrl = document.url = url;
+ }
+ }
+
+
+ function createDocument(file, blob) {
+ return {
+ blob: blob,
+ contentType: file.type,
+ filename: file.name,
+ name: file.name,
+ filesize: file.size,
+ dateTaken: file.lastModifiedDate.toISOStringNoMillis(),
+ staged: false,
+ attribution: "",
+ licence: "",
+ entityUpdated: true
+ };
+ }
+
ko.applyBindingsToDescendants(innerContext, element);
return { controlsDescendantBindings: true };
diff --git a/grails-app/assets/javascripts/project-activity-index.js b/grails-app/assets/javascripts/project-activity-index.js
new file mode 100644
index 000000000..b2e8f6827
--- /dev/null
+++ b/grails-app/assets/javascripts/project-activity-index.js
@@ -0,0 +1,99 @@
+// todo: Delete?
+var projectPromise = entities.getProject();
+var paPromise = entities.getProjectActivity();
+$.when(projectPromise, paPromise).done(function (projectResult, paResult) {
+ var project = projectResult.data,
+ pa = paResult.data,
+ paViewModel = new pActivityInfo(pa),
+ actvitiesViewModel = new ActivitiesViewModel(),
+ paID = "pActivity",
+ activitiesID = "activities";
+
+ ko.applyBindings(paViewModel, document.getElementById(paID));
+ ko.applyBindings(actvitiesViewModel, document.getElementById(activitiesID));
+
+ entities.getActivitiesForProjectActivity().then(function (result) {
+ actvitiesViewModel.transients.load(result.data.activities);
+ });
+})
+
+function ActivitiesViewModel() {
+ var self = this;
+
+ self.activities = ko.observableArray();
+
+ self.transients = {
+ load: function (activities) {
+ var models = []
+ activities && activities.forEach(function (activity) {
+ if (activity instanceof ActivityViewModel) {
+ models.push(activity);
+ }
+ else {
+ models.push(new ActivityViewModel(activity));
+ }
+ });
+
+ self.activities(models);
+ }
+ }
+}
+
+function ActivityViewModel(activity) {
+ var self = this;
+ self.rawData = activity;
+ self.activityId = activity.activityId;
+ self.showCrud = ko.observable(activity.showCrud);
+ self.userCanModerate = activity.userCanModerate;
+ self.projectActivityId = activity.projectActivityId;
+ self.name = activity.name;
+ self.type = activity.type;
+ self.lastUpdated = ko.observable(activity.lastUpdated).extend({simpleDate: true});
+ self.ownerName = activity.activityOwnerName;
+ self.userId = activity.userId;
+ self.siteId = ko.observable(activity.siteId);
+ self.embargoed = activity.embargoed;
+ self.embargoUntil = ko.observable(activity.embargoUntil).extend({simpleDate: false});
+ self.projectName = activity.projectName;
+ self.projectId = activity.projectId;
+ self.projectType = activity.projectType;
+ self.records = ko.observableArray();
+ self.isWorksProject = ko.pureComputed(function () {
+ return self.projectType === "works"
+ });
+
+ self.transients = {
+ viewUrl: ko.observable((self.isWorksProject() ? fcConfig.worksActivityViewUrl : fcConfig.activityViewUrl) + "&activityId=" + self.activityId).extend({returnTo: fcConfig.returnTo, dataVersion: fcConfig.version}),
+ editUrl: ko.observable((self.isWorksProject() ? fcConfig.worksActivityEditUrl : fcConfig.activityEditUrl) + "&activityId=" + self.activityId).extend({returnTo: fcConfig.returnTo}),
+ addUrl: ko.observable(fcConfig.activityAddUrl + "?projectActivityId=" + self.projectActivityId).extend({returnTo: fcConfig.returnTo}),
+ thumbnailUrl: ko.observable(activity.thumbnailUrl || fcConfig.imageLocation + "font-awesome/5.15.4/svgs/regular/image.svg"),
+ loadRecords: function (records) {
+ var allRecords = $.map(activity.records ? activity.records : [], function (record, index) {
+ record.parent = self;
+ record.thumbnailUrl = self.transients.thumbnailUrl();
+ return new RecordViewModel(record);
+ });
+
+ self.records(allRecords);
+ }
+ }
+
+ self.transients.loadRecords(activity.records);
+}
+
+function RecordViewModel (record) {
+ var self = this;
+ if (!record) record = {};
+ self.rawData = record;
+ self.parent = record.parent;
+ self.occurrenceID = record.occurrenceID;
+ self.guid = ko.observable(record.guid);
+ self.name = ko.observable(record.name);
+ self.commonName = record.commonName;
+ self.coordinates = record.coordinates;
+ self.multimedia = record.multimedia || [];
+ self.eventTime = record.eventTime;
+ self.individualCount = record.individualCount;
+ self.eventDate = ko.observable(record.eventDate).extend({simpleDate: false});
+ self.thumbnailUrl = record.thumbnailUrl;
+};
\ No newline at end of file
diff --git a/grails-app/assets/javascripts/pwa-cache.js b/grails-app/assets/javascripts/pwa-cache.js
new file mode 100644
index 000000000..4a3e7027a
--- /dev/null
+++ b/grails-app/assets/javascripts/pwa-cache.js
@@ -0,0 +1,65 @@
+var projectPromise, paPromise;
+var surveyName = "Dung Beetle Monitoring", listId = "dr2683", limit=5, query = "", offset = 0;
+var db = getDB();
+
+function fetchProject() {
+ if (!projectPromise) {
+ projectPromise = $.ajax({
+ url: fcConfig.projectURL
+ });
+ }
+
+ return projectPromise;
+}
+
+function saveProject (project) {
+ var deferred = $.Deferred();
+
+ db.project.put(project).then(function (projectId) {
+ deferred.resolve({message: "Saved project to db", success: true, data: project});
+ }).catch(function () {
+ deferred.reject({message: "Failed to save project to db", success: false});
+ });
+
+ return deferred.promise();
+}
+
+function fetchProjectActivity () {
+ if (!paPromise) {
+ paPromise = $.ajax({
+ url: fcConfig.projectActivityURL
+ });
+ }
+
+ return paPromise;
+}
+
+function saveProjectActivity (pa) {
+ var deferred = $.Deferred();
+
+ db.projectActivity.put(pa).then(function () {
+ deferred.resolve({message: "Saved project activity to db", success: true, data: pa});
+ }).catch(function () {
+ deferred.reject({message: "Failed to save project activity to db", success: false});
+ });
+
+ return deferred.promise();
+}
+
+fetchProject().then(saveProject).then(fetchProjectActivity).then(saveProjectActivity).done(function (result) {
+ var pa = result.data;
+ var promises = [];
+ pa.speciesFields && pa.speciesFields.forEach(function (field) {
+ console.log("fetching species");
+ promises.push(updateDBForField(field.dataFieldName, field.output));
+ });
+
+ $.when.apply($, promises).always(function () {
+ console.log("Starting to fetch sites");
+ fetchSites(pa.sites, 0).done(function (result) {
+ console.log(result.message);
+ });
+ });
+}).fail(function () {
+ alert("Failed to fetch species configuration for survey");
+});
\ No newline at end of file
diff --git a/grails-app/assets/javascripts/pwa-form-initialisation-script.js b/grails-app/assets/javascripts/pwa-form-initialisation-script.js
new file mode 100644
index 000000000..ffcc6f086
--- /dev/null
+++ b/grails-app/assets/javascripts/pwa-form-initialisation-script.js
@@ -0,0 +1,43 @@
+var initialisedSuccessfully = false,
+ delay = 2000;
+document.addEventListener("credential-saved", renderPage);
+document.addEventListener("credential-failed", function (e) {
+ alert("Error occurred while saving credentials");
+});
+
+window.addEventListener("load", function (e) {
+ setTimeout(renderPage, delay);
+});
+
+function renderPage() {
+ if (initialisedSuccessfully) {
+ return;
+ }
+
+ entities.getCredentials().then(function (result) {
+ var credentials = result.data;
+ if (credentials && credentials.length > 0) {
+ var credential = credentials[0];
+ var authorization = "Bearer " + credential.token;
+ $.ajax({
+ url: fcConfig.htmlFragmentURL,
+ dataType: 'html',
+ headers: {
+ 'Authorization': authorization
+ },
+ success: function (html) {
+ initialisedSuccessfully = true;
+ var element = document.querySelector("#form-placeholder");
+ element.innerHTML = html;
+ nodeScriptReplace(element);
+ getMetadataAndInitialise();
+ },
+ error: function (){
+ alert("Error occurred while getting content. Close the modal and try again. If the problem persists, contact the administrator.");
+ }
+ });
+ }
+ }, function () {
+ alert("Error occurred while getting credentials");
+ });
+}
\ No newline at end of file
diff --git a/grails-app/assets/javascripts/pwa-index.js b/grails-app/assets/javascripts/pwa-index.js
new file mode 100644
index 000000000..e9317e1b2
--- /dev/null
+++ b/grails-app/assets/javascripts/pwa-index.js
@@ -0,0 +1,511 @@
+async function downloadMapTiles(bounds, tileUrl, minZoom, maxZoom, callback) {
+ minZoom = minZoom || 0; // Minimum zoom level
+ maxZoom = maxZoom || 20; // Maximum zoom level
+
+ var deferred = $.Deferred();
+ // Check if the browser supports the Cache API
+ if ('caches' in window) {
+ // Function to fetch and cache the vector basemap tiles for a bounding box at different zoom levels
+ try {
+ // Loop through each zoom level
+ for (let zoom = minZoom; zoom <= maxZoom; zoom++) {
+ // Loop through the tiles within the bounding box at the current zoom level
+ var coordinates = getTileCoordinatesForBoundsAtZoom(bounds, zoom),
+ xMin = coordinates[0][0],
+ xMax = coordinates[1][0],
+ yMin = coordinates[0][1],
+ yMax = coordinates[1][1];
+
+ for (let x = xMin; x <= xMax; x++) {
+ for (let y = yMin; y <= yMax; y++) {
+ const requestUrl = tileUrl.replace('{z}', zoom).replace('{x}', x).replace('{y}', y);
+
+ // Open the cache
+ const cache = await caches.open(cacheName);
+
+ // Check if the tile is already cached
+ const cachedResponse = await cache.match(requestUrl);
+
+ if (!cachedResponse) {
+ console.log(`Tile at zoom ${zoom}, x ${x}, y ${y} not found in cache. Fetching and caching...`);
+
+ // Fetch the tile from the server
+ const response = await fetch(requestUrl);
+
+ // Clone the response, as it can only be consumed once
+ const responseClone = response.clone();
+
+ // Cache the response
+ await cache.put(requestUrl, responseClone);
+
+ console.log(`Tile at zoom ${zoom}, x ${x}, y ${y} cached.`);
+ } else {
+ console.log(`Tile at zoom ${zoom}, x ${x}, y ${y} found in cache.`);
+ }
+
+ callback && callback();
+ }
+ }
+ }
+
+ console.log('Vector basemap tiles cached for the bounding box.');
+ deferred.resolve();
+ } catch (error) {
+ console.error('Error caching vector basemap:', error);
+ deferred.reject();
+ } // Call the function to cache the vector basemap tiles for the bounding box
+ } else {
+ console.log('Cache API not supported in this browser.');
+ deferred.reject();
+ }
+
+ return deferred.promise();
+}
+
+async function deleteMapTiles(bounds, tileUrl, minZoom, maxZoom, callback) {
+ minZoom = minZoom || 0; // Minimum zoom level
+ maxZoom = maxZoom || 20; // Maximum zoom level
+
+ var deferred = $.Deferred();
+ // Check if the browser supports the Cache API
+ if ('caches' in window) {
+ // Function to fetch and cache the vector basemap tiles for a bounding box at different zoom levels
+ try {
+ // Loop through each zoom level
+ for (let zoom = minZoom; zoom <= maxZoom; zoom++) {
+ // Loop through the tiles within the bounding box at the current zoom level
+ var coordinates = getTileCoordinatesForBoundsAtZoom(bounds, zoom),
+ xMin = coordinates[0][0],
+ xMax = coordinates[1][0],
+ yMin = coordinates[0][1],
+ yMax = coordinates[1][1];
+
+ for (let x = xMin; x <= xMax; x++) {
+ for (let y = yMin; y <= yMax; y++) {
+ const requestUrl = tileUrl.replace('{z}', zoom).replace('{x}', x).replace('{y}', y);
+
+ // Open the cache
+ const cache = await caches.open(cacheName);
+
+ // Check if the tile is already cached
+ await cache.delete(requestUrl);
+
+ callback && callback();
+ }
+ }
+ }
+
+ console.log('Vector basemap tiles cached for the bounding box.');
+ deferred.resolve();
+ } catch (error) {
+ console.error('Error caching vector basemap:', error);
+ deferred.reject();
+ } // Call the function to cache the vector basemap tiles for the bounding box
+ } else {
+ console.log('Cache API not supported in this browser.');
+ deferred.reject();
+ }
+
+ return deferred.promise();
+}
+
+function getTileCoordinatesForBoundsAtZoom (bounds, zoom) {
+ var nLat = bounds.getNorth(),
+ sLat = bounds.getSouth(),
+ wLng = bounds.getWest(),
+ eLng = bounds.getEast(),
+ xWest = tileCoordinateFromLongitude(nLat, wLng, zoom),
+ xEast = tileCoordinateFromLongitude(sLat, eLng, zoom),
+ yNorth = tileCoordinateFromLatitude(nLat, eLng, zoom),
+ ySouth = tileCoordinateFromLatitude(sLat, wLng, zoom),
+ xMin = Math.min(xWest, xEast),
+ xMax = Math.max(xWest, xEast),
+ yMin = Math.min(yNorth, ySouth),
+ yMax = Math.max(yNorth, ySouth);
+
+ // each zoom level should have at least 25 tiles i.e. 5 in each axis
+ if ((yMax - yMin) * (xMax - xMin) < minNumberOfTilesPerZoom) {
+ var xDiff = xMax - xMin,
+ yDiff = yMax - yMin,
+ xAddEachSide = Math.floor((maxTilesPerAxis - xDiff) / 2),
+ yAddEachSide = Math.floor((maxTilesPerAxis - yDiff) / 2),
+ max = Math.pow(2, zoom) - 1;
+
+ xMin -= xAddEachSide;
+ xMax += xAddEachSide;
+ yMin -= yAddEachSide;
+ yMax += yAddEachSide;
+ xMin = xMin < 0 ? 0 : xMin;
+ xMax = xMax > max ? max : xMax;
+ yMin = yMin < 0 ? 0 : yMin;
+ yMax = yMax > max ? max : yMax;
+ }
+
+ return [[xMin, yMin], [xMax, yMax]];
+}
+
+function totalTilesForBoundsAtZoom (bounds, zoom) {
+ var coordinates = getTileCoordinatesForBoundsAtZoom(bounds, zoom),
+ xMin = coordinates[0][0],
+ xMax = coordinates[1][0],
+ yMin = coordinates[0][1],
+ yMax = coordinates[1][1];
+
+ return (xMax - xMin + 1) * (yMax - yMin + 1);
+}
+
+function totalTilesForBounds(bounds, minZoom, maxZoom) {
+ var totalTiles = 0;
+ for (var zoom = minZoom; zoom <= maxZoom; zoom++) {
+ totalTiles += totalTilesForBoundsAtZoom(bounds, zoom);
+ }
+
+ return totalTiles;
+}
+
+// Function to convert longitude to tile coordinate
+function tileCoordinateFromLongitude(lat, lng, zoom) {
+ var latLng = L.latLng(lat, lng);
+ return Math.floor(crs.latLngToPoint(latLng, zoom).x / tileSize);
+}
+
+// Function to convert latitude to tile coordinate
+function tileCoordinateFromLatitude(lat, lng, zoom) {
+ var latLng = L.latLng(lat, lng);
+ return Math.floor(crs.latLngToPoint(latLng, zoom).y / tileSize);
+}
+
+function OfflineViewModel(config) {
+ var self = this,
+ minZoom = config.minZoom || 0,
+ maxZoom = config.maxZoom || 20,
+ mapId = config.mapId,
+ mapOptions = {
+ autoZIndex: false,
+ preserveZIndex: true,
+ addLayersControlHeading: false,
+ drawControl: false,
+ showReset: false,
+ draggableMarkers: false,
+ useMyLocation: true,
+ allowSearchLocationByAddress: true,
+ allowSearchRegionByAddress: true,
+ trackWindowHeight: false,
+ baseLayer: L.tileLayer(config.baseMapUrl, config.baseMapOptions)
+ },
+ alaMap = new ALA.Map(mapId, mapOptions),
+ mapImpl = alaMap.getMapImpl(),
+ totalUrl = config.totalUrl,
+ downloadSpeciesUrl = config.downloadSpeciesUrl,
+ pa = null,
+ project = null,
+ mapSection = config.mapSection || "mapSection";
+
+ self.stages = {metadata: 'metadata', species: 'species', map: 'map', form: 'form'};
+ self.statuses = {done: 'downloaded', doing: 'downloading', error: 'error', wait: 'waiting'};
+ self.currentStage = ko.observable();
+ self.metadataStatus = ko.observable(self.statuses.wait);
+ self.speciesStatus = ko.observable(self.statuses.wait);
+ self.mapStatus = ko.observable(self.statuses.wait);
+ self.formStatus = ko.observable(self.statuses.wait);
+ self.isOnline = ko.observable(true);
+ self.name = ko.observable();
+ self.downloading = ko.observable(false);
+ self.offlineMaps = ko.observableArray([]);
+ self.bounds = ko.observable(mapImpl.getBounds());
+ self.areaInKmOfBounds = ko.pureComputed(function () {
+ var bounds = self.bounds();
+ return bounds && (area( bounds ) / Math.pow(10, 6));
+ })
+ self.numberOfTilesDownloaded = ko.observable(0);
+ self.totalNumberOfTiles = ko.observable(1);
+ self.progress = ko.observable(0);
+ self.totalCount = ko.observable(1);
+ self.numberOfFormsDownloaded = ko.observable(0);
+ self.totalFormDownload = ko.observable(1);
+ self.loadMetadata = ko.observable(false);
+ self.percentageFormDownloaded = ko.pureComputed(function (){
+ return Math.round(self.numberOfFormsDownloaded() / self.totalFormDownload() * 100);
+ });
+ self.isSurveyOfflineCapable = ko.pureComputed(function () {
+ var statuses = [self.metadataStatus(), self.formStatus(), self.speciesStatus(), self.mapStatus()]
+ if (statuses.every(item => item === self.statuses.done)) {
+ window.parent && window.parent.postMessage && window.parent.postMessage({event: "download-complete"}, fcConfig.originUrl);
+ }
+ else {
+ window.parent && window.parent.postMessage && window.parent.postMessage({event: "download-removed"}, fcConfig.originUrl);
+ }
+ });
+
+ self.canMapBeOffline = ko.pureComputed(function () {
+ return self.offlineMaps().length > 0;
+ });
+ self.showSpeciesProgressBar = ko.pureComputed(function () {
+ return self.progress() > 0;
+ });
+ self.downloadPercentageComplete = ko.pureComputed(function () {
+ return Math.round(self.numberOfTilesDownloaded() / self.totalNumberOfTiles() * 100);
+ });
+ self.canDownload = ko.computed(function () {
+ return !!self.name() && self.isBoundsWithinMaxArea();
+ });
+ self.isBoundsWithinMaxArea = ko.pureComputed(function () {
+ var bounds = self.bounds();
+ return area(bounds) <= maxArea;
+ });
+
+ self.speciesDownloadPercentageComplete = ko.pureComputed(function (){
+ return Math.round(self.progress() / self.totalCount() * 100);
+ });
+
+ self.offlineMaps.subscribe(offlineMapCheck);
+ self.currentStage.subscribe(function (stage) {
+ switch (stage) {
+ case self.stages.metadata:
+ getProjectActivityMetadata();
+ break;
+ case self.stages.form:
+ startDownloadingSurveyForms();
+ break;
+ case self.stages.species:
+ startDownloadingSpecies();
+ break;
+ case self.stages.map:
+ offlineMapCheck();
+ break;
+ }
+ });
+
+ function offlineMapCheck() {
+ if (self.canMapBeOffline()) {
+ self.mapStatus(self.statuses.done);
+ }
+ else {
+ self.mapStatus(self.statuses.error);
+ }
+ }
+
+ self.clickSpeciesDownload = function () {
+ self.progress(0);
+ self.totalCount(1);
+ entities.deleteAllSpecies().then(startDownloadingSpecies);
+ }
+
+ self.clickDownload = function () {
+ if (self.canDownload()) {
+ var bounds = self.bounds(),
+ baseMapUrl = config.baseMapUrl,
+ minZoom = config.minZoom || 0;
+
+ self.downloading(true);
+ self.numberOfTilesDownloaded(0);
+ self.totalNumberOfTiles(totalTilesForBounds(bounds, minZoom, maxZoom));
+ downloadMapTiles(bounds, config.baseMapUrl, minZoom, maxZoom, function () {
+ self.numberOfTilesDownloaded(self.numberOfTilesDownloaded() + 1);
+ }).finally(function () {
+ self.numberOfTilesDownloaded(0);
+ self.totalNumberOfTiles(1);
+ self.downloading(false);
+ entities.saveMap({
+ name: self.name(),
+ bounds: self.getBoundsArray(bounds),
+ baseMapUrl: baseMapUrl
+ }).then(function (result) {
+ self.getOfflineMaps();
+ });
+ });
+ }
+ }
+
+ self.getOfflineMaps = function () {
+ entities.getMaps().then(function (result) {
+ var maps = result.data;
+ self.offlineMaps(maps);
+ });
+ }
+
+ self.getBoundsArray = function (bounds) {
+ return [{lat: bounds.getNorth(), lng:bounds.getWest()}, {lat: bounds.getSouth(), lng:bounds.getEast()}];
+ }
+
+ self.getBoundsFromArray = function (boundsArray) {
+ var nw = L.latLng(boundsArray[0]),
+ se = L.latLng(boundsArray[1]);
+
+ return L.latLngBounds(nw, se);
+ }
+
+ self.preview = function (data) {
+ var data = this,
+ boundsArray = data.bounds,
+ bounds = self.getBoundsFromArray(boundsArray);
+
+ bounds && mapImpl.fitBounds(bounds);
+ }
+
+ self.removeMe = function () {
+ var data = this,
+ boundsArray = data.bounds,
+ bounds = self.getBoundsFromArray(boundsArray),
+ minZoom = 14;
+
+ if (data && data.id) {
+ deleteMapTiles(bounds, data.baseMapUrl).finally(function () {
+ entities.deleteMap(data.id).then(function (){
+ self.offlineMaps.remove(data);
+ });
+ });
+ }
+ }
+
+ self.scrollToMapSection = function () {
+ var offset = $("#" + mapSection).offset();
+
+ if (offset) {
+ $("html, body").animate({
+ scrollTop: offset.top + 'px'
+ });
+ }
+ }
+
+ function area(bounds) {
+ var pt1 = new L.LatLng(bounds.getNorth(), bounds.getWest()),
+ pt2 = new L.LatLng(bounds.getNorth(), bounds.getEast()),
+ pt3 = new L.LatLng(bounds.getSouth(), bounds.getEast()),
+ pt4 = new L.LatLng(bounds.getSouth(), bounds.getWest()),
+ area = pt1.distanceTo(pt2) * pt3.distanceTo(pt4);
+
+ console.log(area);
+ return area;
+ }
+
+ function startDownloadingSpecies() {
+ self.currentStage(self.stages.species);
+ self.speciesStatus(self.statuses.doing);
+ entities.getSpeciesForProjectActivity(pa, updateSpeciesProgressBar).then(completedSpeciesDownload, errorSpeciesDownload);
+ }
+
+ function completedSpeciesDownload() {
+ updateSpeciesProgressBar(self.totalCount(), self.totalCount());
+ self.speciesStatus(self.statuses.done);
+ if (self.mapStatus() != self.statuses.done) {
+ self.mapStatus(self.statuses.doing);
+ self.currentStage(self.stages.map);
+ }
+ }
+
+ function errorSpeciesDownload() {
+ self.speciesStatus(self.statuses.error);
+ }
+
+ function updateSpeciesProgressBar (total, count) {
+ self.totalCount(total);
+ self.progress(count);
+ }
+
+ function startDownloadingSurveyForms() {
+ if ('serviceWorker' in navigator) {
+ navigator.serviceWorker.getRegistration().then( function (){
+ self.formStatus(self.statuses.doing);
+ downloadProjectActivityArtefacts(self).then(completedFormDownload, errorFormDownload);
+ }, errorFormDownload);
+ }
+ else {
+ errorFormDownload();
+ }
+ }
+
+ function completedFormDownload() {
+ self.formStatus(self.statuses.done);
+ self.currentStage(self.stages.species);
+ self.speciesStatus(self.statuses.doing);
+ }
+
+ function errorFormDownload() {
+ self.formStatus(self.statuses.error);
+ }
+
+ function getProjectActivityMetadata() {
+ self.metadataStatus(self.statuses.doing);
+ return entities.getProjectActivityMetadata(config.projectActivityId, undefined).then(function (result) {
+ var data = result.data,
+ deferred = $.Deferred();
+ pa = data.pActivity;
+ project = data.project;
+ entities.saveSites(pa.sites).then(completedMetadataDownload, errorMetadataDownload);
+ return deferred.promise();
+ });
+ }
+
+ function completedMetadataDownload() {
+ self.metadataStatus(self.statuses.done);
+ self.currentStage(self.stages.form);
+ self.formStatus(self.statuses.doing);
+ }
+
+ function errorMetadataDownload() {
+ self.metadataStatus(self.statuses.error);
+ }
+
+ (function init() {
+ alaMap.registerListener('zoomend', function () {
+ self.bounds(mapImpl.getBounds());
+ })
+
+ self.getOfflineMaps();
+ self.currentStage(self.stages.metadata);
+ })();
+}
+
+
+function downloadProjectActivityArtefacts(viewModel) {
+ var IFRAME_ID = 'form-content',
+ iframeWindow,
+ delay = 1 * 60 * 1000, // one minute
+ deferred = $.Deferred();
+
+ var urls = [fcConfig.createActivityUrl, fcConfig.indexActivityUrl, fcConfig.offlineListUrl],
+ urlsIndex = 0;
+
+ document.addEventListener('view-model-loaded',function () {
+ increaseFormDownloadedCount();
+ ++urlsIndex;
+ loadIframe();
+ });
+
+ function loadIframe () {
+ if (urlsIndex < urls.length) {
+ var url = urls[urlsIndex],
+ iframe = document.getElementById(IFRAME_ID);
+ iframe.src = url;
+ iframeWindow = iframe.contentWindow;
+ rejectPromiseIfErrorLoadingPage(urlsIndex);
+ increaseFormDownloadedCount();
+ } else {
+ console.info("Finished downloading artefacts!");
+ window.parent && window.parent.postMessage && window.parent.postMessage({event: "download-complete"}, fcConfig.pwaAppUrl);
+ deferred.resolve();
+ }
+ }
+
+ function increaseFormDownloadedCount () {
+ viewModel.numberOfFormsDownloaded(viewModel.numberOfFormsDownloaded() + 1);
+ }
+
+ function rejectPromiseIfErrorLoadingPage (index) {
+ setTimeout(function () {
+ if (index == urlsIndex) {
+ deferred.reject();
+ }
+ }, delay);
+ }
+
+ function init(){
+ viewModel.totalFormDownload(urls.length * 2);
+ viewModel.numberOfFormsDownloaded(0);
+ loadIframe();
+ }
+
+ init();
+ return deferred.promise();
+};
\ No newline at end of file
diff --git a/grails-app/assets/javascripts/pwa-messages.js b/grails-app/assets/javascripts/pwa-messages.js
new file mode 100644
index 000000000..82483779f
--- /dev/null
+++ b/grails-app/assets/javascripts/pwa-messages.js
@@ -0,0 +1,24 @@
+window.addEventListener('message', function(event) {
+ var origins = [fcConfig.originUrl, fcConfig.pwaAppUrl]
+ if (origins.indexOf(event.origin) == -1)
+ return
+
+ var type = event.data.event;
+ switch (type) {
+ case 'viewmodelloadded':
+ // fired by the iframe when the view model is loaded
+ var viewModelLoadedEvent = new Event('view-model-loaded');
+ document.dispatchEvent(viewModelLoadedEvent);
+ break;
+ case 'credentials':
+ entities.saveCredentials(event.data.data).then(function (){
+ var credentialSavedEvent = new Event('credential-saved');
+ document.dispatchEvent(credentialSavedEvent);
+ }, function (){
+ var credentialFailedEvent = new Event('credential-failed');
+ document.dispatchEvent(credentialFailedEvent);
+ });
+ break;
+ }
+
+})
\ No newline at end of file
diff --git a/grails-app/assets/javascripts/sw.js b/grails-app/assets/javascripts/sw.js
new file mode 100644
index 000000000..9d99e54c9
--- /dev/null
+++ b/grails-app/assets/javascripts/sw.js
@@ -0,0 +1,69 @@
+const cacheName = "v3"
+const fcConfig = {
+ pathsToIgnoreCache: ["/image/upload", "/ws/attachment/upload"]
+}
+self.addEventListener('install', e => {
+ console.log("SW: Install");
+});
+
+self.addEventListener('activate', e => {
+ console.log("SW: Activated");
+ // Remove unwanted caches
+ e.waitUntil(
+ caches.keys().then(cacheNames => {
+ return Promise.all(
+ cacheNames.map(cache => {
+ if (cache !== cacheName) {
+ console.log('Service Worker: Clearing Old Cache');
+ return caches.delete(cache);
+ }
+ })
+ );
+ })
+ );
+
+});
+
+self.addEventListener('fetch', e => {
+ console.log('Service Worker: Fetching');
+ e.respondWith(
+ fetch(e.request)
+ .then(res => {
+ // Make copy/clone of response
+ const resClone = res.clone();
+ // Open cache
+ if (res.ok) {
+ caches.open(cacheName).then(cache => {
+ var path = getPath(e.request.url);
+ if (!ignoreCachingForPath(path)) {
+ // Add response to cache
+ cache.put(path, resClone);
+ }
+ });
+ }
+
+ return res;
+ })
+ .catch(err => {
+ var path = getPath(e.request.url);
+ return caches.match(path).then(res => {
+ return res;
+ });
+ })
+ );
+});
+
+function getPath(url) {
+ return new URL(url).pathname;
+}
+
+function ignoreCachingForPath(urlPath) {
+ for (var i in fcConfig.pathsToIgnoreCache) {
+ var path = fcConfig.pathsToIgnoreCache[i];
+ if (urlPath.indexOf(path) == 0) {
+ return true;
+ }
+ }
+
+ return false;
+}
\ No newline at end of file
diff --git a/grails-app/assets/vendor/dexiejs/dexie.js b/grails-app/assets/vendor/dexiejs/dexie.js
new file mode 100644
index 000000000..a531ee22f
--- /dev/null
+++ b/grails-app/assets/vendor/dexiejs/dexie.js
@@ -0,0 +1,5719 @@
+/*
+ * Dexie.js - a minimalistic wrapper for IndexedDB
+ * ===============================================
+ *
+ * By David Fahlander, david.fahlander@gmail.com
+ *
+ * Version 4.0.1-alpha.12, Tue May 30 2023
+ *
+ * https://dexie.org
+ *
+ * Apache License Version 2.0, January 2004, http://www.apache.org/licenses/
+ */
+
+(function (global, factory) {
+ typeof exports === 'object' && typeof module !== 'undefined' ? module.exports = factory() :
+ typeof define === 'function' && define.amd ? define(factory) :
+ (global = typeof globalThis !== 'undefined' ? globalThis : global || self, global.Dexie = factory());
+})(this, (function () { 'use strict';
+
+ /*! *****************************************************************************
+ Copyright (c) Microsoft Corporation.
+ Permission to use, copy, modify, and/or distribute this software for any
+ purpose with or without fee is hereby granted.
+ THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH
+ REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY
+ AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT,
+ INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM
+ LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR
+ OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
+ PERFORMANCE OF THIS SOFTWARE.
+ ***************************************************************************** */
+ var extendStatics = function(d, b) {
+ extendStatics = Object.setPrototypeOf ||
+ ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
+ function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };
+ return extendStatics(d, b);
+ };
+ function __extends(d, b) {
+ if (typeof b !== "function" && b !== null)
+ throw new TypeError("Class extends value " + String(b) + " is not a constructor or null");
+ extendStatics(d, b);
+ function __() { this.constructor = d; }
+ d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
+ }
+ var __assign = function() {
+ __assign = Object.assign || function __assign(t) {
+ for (var s, i = 1, n = arguments.length; i < n; i++) {
+ s = arguments[i];
+ for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p];
+ }
+ return t;
+ };
+ return __assign.apply(this, arguments);
+ };
+ function __spreadArray(to, from, pack) {
+ if (pack || arguments.length === 2) for (var i = 0, l = from.length, ar; i < l; i++) {
+ if (ar || !(i in from)) {
+ if (!ar) ar = Array.prototype.slice.call(from, 0, i);
+ ar[i] = from[i];
+ }
+ }
+ return to.concat(ar || Array.prototype.slice.call(from));
+ }
+
+ var _global = typeof globalThis !== 'undefined' ? globalThis :
+ typeof self !== 'undefined' ? self :
+ typeof window !== 'undefined' ? window :
+ global;
+
+ var keys = Object.keys;
+ var isArray = Array.isArray;
+ if (typeof Promise !== 'undefined' && !_global.Promise) {
+ _global.Promise = Promise;
+ }
+ function extend(obj, extension) {
+ if (typeof extension !== 'object')
+ return obj;
+ keys(extension).forEach(function (key) {
+ obj[key] = extension[key];
+ });
+ return obj;
+ }
+ var getProto = Object.getPrototypeOf;
+ var _hasOwn = {}.hasOwnProperty;
+ function hasOwn(obj, prop) {
+ return _hasOwn.call(obj, prop);
+ }
+ function props(proto, extension) {
+ if (typeof extension === 'function')
+ extension = extension(getProto(proto));
+ (typeof Reflect === "undefined" ? keys : Reflect.ownKeys)(extension).forEach(function (key) {
+ setProp(proto, key, extension[key]);
+ });
+ }
+ var defineProperty = Object.defineProperty;
+ function setProp(obj, prop, functionOrGetSet, options) {
+ defineProperty(obj, prop, extend(functionOrGetSet && hasOwn(functionOrGetSet, "get") && typeof functionOrGetSet.get === 'function' ?
+ { get: functionOrGetSet.get, set: functionOrGetSet.set, configurable: true } :
+ { value: functionOrGetSet, configurable: true, writable: true }, options));
+ }
+ function derive(Child) {
+ return {
+ from: function (Parent) {
+ Child.prototype = Object.create(Parent.prototype);
+ setProp(Child.prototype, "constructor", Child);
+ return {
+ extend: props.bind(null, Child.prototype)
+ };
+ }
+ };
+ }
+ var getOwnPropertyDescriptor = Object.getOwnPropertyDescriptor;
+ function getPropertyDescriptor(obj, prop) {
+ var pd = getOwnPropertyDescriptor(obj, prop);
+ var proto;
+ return pd || (proto = getProto(obj)) && getPropertyDescriptor(proto, prop);
+ }
+ var _slice = [].slice;
+ function slice(args, start, end) {
+ return _slice.call(args, start, end);
+ }
+ function override(origFunc, overridedFactory) {
+ return overridedFactory(origFunc);
+ }
+ function assert(b) {
+ if (!b)
+ throw new Error("Assertion Failed");
+ }
+ function asap$1(fn) {
+ if (_global.setImmediate)
+ setImmediate(fn);
+ else
+ setTimeout(fn, 0);
+ }
+ function arrayToObject(array, extractor) {
+ return array.reduce(function (result, item, i) {
+ var nameAndValue = extractor(item, i);
+ if (nameAndValue)
+ result[nameAndValue[0]] = nameAndValue[1];
+ return result;
+ }, {});
+ }
+ function tryCatch(fn, onerror, args) {
+ try {
+ fn.apply(null, args);
+ }
+ catch (ex) {
+ onerror && onerror(ex);
+ }
+ }
+ function getByKeyPath(obj, keyPath) {
+ if (hasOwn(obj, keyPath))
+ return obj[keyPath];
+ if (!keyPath)
+ return obj;
+ if (typeof keyPath !== 'string') {
+ var rv = [];
+ for (var i = 0, l = keyPath.length; i < l; ++i) {
+ var val = getByKeyPath(obj, keyPath[i]);
+ rv.push(val);
+ }
+ return rv;
+ }
+ var period = keyPath.indexOf('.');
+ if (period !== -1) {
+ var innerObj = obj[keyPath.substr(0, period)];
+ return innerObj === undefined ? undefined : getByKeyPath(innerObj, keyPath.substr(period + 1));
+ }
+ return undefined;
+ }
+ function setByKeyPath(obj, keyPath, value) {
+ if (!obj || keyPath === undefined)
+ return;
+ if ('isFrozen' in Object && Object.isFrozen(obj))
+ return;
+ if (typeof keyPath !== 'string' && 'length' in keyPath) {
+ assert(typeof value !== 'string' && 'length' in value);
+ for (var i = 0, l = keyPath.length; i < l; ++i) {
+ setByKeyPath(obj, keyPath[i], value[i]);
+ }
+ }
+ else {
+ var period = keyPath.indexOf('.');
+ if (period !== -1) {
+ var currentKeyPath = keyPath.substr(0, period);
+ var remainingKeyPath = keyPath.substr(period + 1);
+ if (remainingKeyPath === "")
+ if (value === undefined) {
+ if (isArray(obj) && !isNaN(parseInt(currentKeyPath)))
+ obj.splice(currentKeyPath, 1);
+ else
+ delete obj[currentKeyPath];
+ }
+ else
+ obj[currentKeyPath] = value;
+ else {
+ var innerObj = obj[currentKeyPath];
+ if (!innerObj || !hasOwn(obj, currentKeyPath))
+ innerObj = (obj[currentKeyPath] = {});
+ setByKeyPath(innerObj, remainingKeyPath, value);
+ }
+ }
+ else {
+ if (value === undefined) {
+ if (isArray(obj) && !isNaN(parseInt(keyPath)))
+ obj.splice(keyPath, 1);
+ else
+ delete obj[keyPath];
+ }
+ else
+ obj[keyPath] = value;
+ }
+ }
+ }
+ function delByKeyPath(obj, keyPath) {
+ if (typeof keyPath === 'string')
+ setByKeyPath(obj, keyPath, undefined);
+ else if ('length' in keyPath)
+ [].map.call(keyPath, function (kp) {
+ setByKeyPath(obj, kp, undefined);
+ });
+ }
+ function shallowClone(obj) {
+ var rv = {};
+ for (var m in obj) {
+ if (hasOwn(obj, m))
+ rv[m] = obj[m];
+ }
+ return rv;
+ }
+ var concat = [].concat;
+ function flatten(a) {
+ return concat.apply([], a);
+ }
+ var intrinsicTypeNames = "Boolean,String,Date,RegExp,Blob,File,FileList,FileSystemFileHandle,FileSystemDirectoryHandle,ArrayBuffer,DataView,Uint8ClampedArray,ImageBitmap,ImageData,Map,Set,CryptoKey"
+ .split(',').concat(flatten([8, 16, 32, 64].map(function (num) { return ["Int", "Uint", "Float"].map(function (t) { return t + num + "Array"; }); }))).filter(function (t) { return _global[t]; });
+ var intrinsicTypes = intrinsicTypeNames.map(function (t) { return _global[t]; });
+ arrayToObject(intrinsicTypeNames, function (x) { return [x, true]; });
+ var circularRefs = null;
+ function deepClone(any) {
+ circularRefs = new WeakMap();
+ var rv = innerDeepClone(any);
+ circularRefs = null;
+ return rv;
+ }
+ function innerDeepClone(x) {
+ if (!x || typeof x !== 'object')
+ return x;
+ var rv = circularRefs.get(x);
+ if (rv)
+ return rv;
+ if (isArray(x)) {
+ rv = [];
+ circularRefs.set(x, rv);
+ for (var i = 0, l = x.length; i < l; ++i) {
+ rv.push(innerDeepClone(x[i]));
+ }
+ }
+ else if (intrinsicTypes.indexOf(x.constructor) >= 0) {
+ rv = x;
+ }
+ else {
+ var proto = getProto(x);
+ rv = proto === Object.prototype ? {} : Object.create(proto);
+ circularRefs.set(x, rv);
+ for (var prop in x) {
+ if (hasOwn(x, prop)) {
+ rv[prop] = innerDeepClone(x[prop]);
+ }
+ }
+ }
+ return rv;
+ }
+ var toString = {}.toString;
+ function toStringTag(o) {
+ return toString.call(o).slice(8, -1);
+ }
+ var iteratorSymbol = typeof Symbol !== 'undefined' ?
+ Symbol.iterator :
+ '@@iterator';
+ var getIteratorOf = typeof iteratorSymbol === "symbol" ? function (x) {
+ var i;
+ return x != null && (i = x[iteratorSymbol]) && i.apply(x);
+ } : function () { return null; };
+ function delArrayItem(a, x) {
+ var i = a.indexOf(x);
+ if (i >= 0)
+ a.splice(i, 1);
+ return i >= 0;
+ }
+ var NO_CHAR_ARRAY = {};
+ function getArrayOf(arrayLike) {
+ var i, a, x, it;
+ if (arguments.length === 1) {
+ if (isArray(arrayLike))
+ return arrayLike.slice();
+ if (this === NO_CHAR_ARRAY && typeof arrayLike === 'string')
+ return [arrayLike];
+ if ((it = getIteratorOf(arrayLike))) {
+ a = [];
+ while ((x = it.next()), !x.done)
+ a.push(x.value);
+ return a;
+ }
+ if (arrayLike == null)
+ return [arrayLike];
+ i = arrayLike.length;
+ if (typeof i === 'number') {
+ a = new Array(i);
+ while (i--)
+ a[i] = arrayLike[i];
+ return a;
+ }
+ return [arrayLike];
+ }
+ i = arguments.length;
+ a = new Array(i);
+ while (i--)
+ a[i] = arguments[i];
+ return a;
+ }
+ var isAsyncFunction = typeof Symbol !== 'undefined'
+ ? function (fn) { return fn[Symbol.toStringTag] === 'AsyncFunction'; }
+ : function () { return false; };
+
+ var debug = typeof location !== 'undefined' &&
+ /^(http|https):\/\/(localhost|127\.0\.0\.1)/.test(location.href);
+ function setDebug(value, filter) {
+ debug = value;
+ libraryFilter = filter;
+ }
+ var libraryFilter = function () { return true; };
+ var NEEDS_THROW_FOR_STACK = !new Error("").stack;
+ function getErrorWithStack() {
+ if (NEEDS_THROW_FOR_STACK)
+ try {
+ getErrorWithStack.arguments;
+ throw new Error();
+ }
+ catch (e) {
+ return e;
+ }
+ return new Error();
+ }
+ function prettyStack(exception, numIgnoredFrames) {
+ var stack = exception.stack;
+ if (!stack)
+ return "";
+ numIgnoredFrames = (numIgnoredFrames || 0);
+ if (stack.indexOf(exception.name) === 0)
+ numIgnoredFrames += (exception.name + exception.message).split('\n').length;
+ return stack.split('\n')
+ .slice(numIgnoredFrames)
+ .filter(libraryFilter)
+ .map(function (frame) { return "\n" + frame; })
+ .join('');
+ }
+
+ var dexieErrorNames = [
+ 'Modify',
+ 'Bulk',
+ 'OpenFailed',
+ 'VersionChange',
+ 'Schema',
+ 'Upgrade',
+ 'InvalidTable',
+ 'MissingAPI',
+ 'NoSuchDatabase',
+ 'InvalidArgument',
+ 'SubTransaction',
+ 'Unsupported',
+ 'Internal',
+ 'DatabaseClosed',
+ 'PrematureCommit',
+ 'ForeignAwait'
+ ];
+ var idbDomErrorNames = [
+ 'Unknown',
+ 'Constraint',
+ 'Data',
+ 'TransactionInactive',
+ 'ReadOnly',
+ 'Version',
+ 'NotFound',
+ 'InvalidState',
+ 'InvalidAccess',
+ 'Abort',
+ 'Timeout',
+ 'QuotaExceeded',
+ 'Syntax',
+ 'DataClone'
+ ];
+ var errorList = dexieErrorNames.concat(idbDomErrorNames);
+ var defaultTexts = {
+ VersionChanged: "Database version changed by other database connection",
+ DatabaseClosed: "Database has been closed",
+ Abort: "Transaction aborted",
+ TransactionInactive: "Transaction has already completed or failed",
+ MissingAPI: "IndexedDB API missing. Please visit https://tinyurl.com/y2uuvskb"
+ };
+ function DexieError(name, msg) {
+ this._e = getErrorWithStack();
+ this.name = name;
+ this.message = msg;
+ }
+ derive(DexieError).from(Error).extend({
+ stack: {
+ get: function () {
+ return this._stack ||
+ (this._stack = this.name + ": " + this.message + prettyStack(this._e, 2));
+ }
+ },
+ toString: function () { return this.name + ": " + this.message; }
+ });
+ function getMultiErrorMessage(msg, failures) {
+ return msg + ". Errors: " + Object.keys(failures)
+ .map(function (key) { return failures[key].toString(); })
+ .filter(function (v, i, s) { return s.indexOf(v) === i; })
+ .join('\n');
+ }
+ function ModifyError(msg, failures, successCount, failedKeys) {
+ this._e = getErrorWithStack();
+ this.failures = failures;
+ this.failedKeys = failedKeys;
+ this.successCount = successCount;
+ this.message = getMultiErrorMessage(msg, failures);
+ }
+ derive(ModifyError).from(DexieError);
+ function BulkError(msg, failures) {
+ this._e = getErrorWithStack();
+ this.name = "BulkError";
+ this.failures = Object.keys(failures).map(function (pos) { return failures[pos]; });
+ this.failuresByPos = failures;
+ this.message = getMultiErrorMessage(msg, this.failures);
+ }
+ derive(BulkError).from(DexieError);
+ var errnames = errorList.reduce(function (obj, name) { return (obj[name] = name + "Error", obj); }, {});
+ var BaseException = DexieError;
+ var exceptions = errorList.reduce(function (obj, name) {
+ var fullName = name + "Error";
+ function DexieError(msgOrInner, inner) {
+ this._e = getErrorWithStack();
+ this.name = fullName;
+ if (!msgOrInner) {
+ this.message = defaultTexts[name] || fullName;
+ this.inner = null;
+ }
+ else if (typeof msgOrInner === 'string') {
+ this.message = "".concat(msgOrInner).concat(!inner ? '' : '\n ' + inner);
+ this.inner = inner || null;
+ }
+ else if (typeof msgOrInner === 'object') {
+ this.message = "".concat(msgOrInner.name, " ").concat(msgOrInner.message);
+ this.inner = msgOrInner;
+ }
+ }
+ derive(DexieError).from(BaseException);
+ obj[name] = DexieError;
+ return obj;
+ }, {});
+ exceptions.Syntax = SyntaxError;
+ exceptions.Type = TypeError;
+ exceptions.Range = RangeError;
+ var exceptionMap = idbDomErrorNames.reduce(function (obj, name) {
+ obj[name + "Error"] = exceptions[name];
+ return obj;
+ }, {});
+ function mapError(domError, message) {
+ if (!domError || domError instanceof DexieError || domError instanceof TypeError || domError instanceof SyntaxError || !domError.name || !exceptionMap[domError.name])
+ return domError;
+ var rv = new exceptionMap[domError.name](message || domError.message, domError);
+ if ("stack" in domError) {
+ setProp(rv, "stack", { get: function () {
+ return this.inner.stack;
+ } });
+ }
+ return rv;
+ }
+ var fullNameExceptions = errorList.reduce(function (obj, name) {
+ if (["Syntax", "Type", "Range"].indexOf(name) === -1)
+ obj[name + "Error"] = exceptions[name];
+ return obj;
+ }, {});
+ fullNameExceptions.ModifyError = ModifyError;
+ fullNameExceptions.DexieError = DexieError;
+ fullNameExceptions.BulkError = BulkError;
+
+ function nop() { }
+ function mirror(val) { return val; }
+ function pureFunctionChain(f1, f2) {
+ if (f1 == null || f1 === mirror)
+ return f2;
+ return function (val) {
+ return f2(f1(val));
+ };
+ }
+ function callBoth(on1, on2) {
+ return function () {
+ on1.apply(this, arguments);
+ on2.apply(this, arguments);
+ };
+ }
+ function hookCreatingChain(f1, f2) {
+ if (f1 === nop)
+ return f2;
+ return function () {
+ var res = f1.apply(this, arguments);
+ if (res !== undefined)
+ arguments[0] = res;
+ var onsuccess = this.onsuccess,
+ onerror = this.onerror;
+ this.onsuccess = null;
+ this.onerror = null;
+ var res2 = f2.apply(this, arguments);
+ if (onsuccess)
+ this.onsuccess = this.onsuccess ? callBoth(onsuccess, this.onsuccess) : onsuccess;
+ if (onerror)
+ this.onerror = this.onerror ? callBoth(onerror, this.onerror) : onerror;
+ return res2 !== undefined ? res2 : res;
+ };
+ }
+ function hookDeletingChain(f1, f2) {
+ if (f1 === nop)
+ return f2;
+ return function () {
+ f1.apply(this, arguments);
+ var onsuccess = this.onsuccess,
+ onerror = this.onerror;
+ this.onsuccess = this.onerror = null;
+ f2.apply(this, arguments);
+ if (onsuccess)
+ this.onsuccess = this.onsuccess ? callBoth(onsuccess, this.onsuccess) : onsuccess;
+ if (onerror)
+ this.onerror = this.onerror ? callBoth(onerror, this.onerror) : onerror;
+ };
+ }
+ function hookUpdatingChain(f1, f2) {
+ if (f1 === nop)
+ return f2;
+ return function (modifications) {
+ var res = f1.apply(this, arguments);
+ extend(modifications, res);
+ var onsuccess = this.onsuccess,
+ onerror = this.onerror;
+ this.onsuccess = null;
+ this.onerror = null;
+ var res2 = f2.apply(this, arguments);
+ if (onsuccess)
+ this.onsuccess = this.onsuccess ? callBoth(onsuccess, this.onsuccess) : onsuccess;
+ if (onerror)
+ this.onerror = this.onerror ? callBoth(onerror, this.onerror) : onerror;
+ return res === undefined ?
+ (res2 === undefined ? undefined : res2) :
+ (extend(res, res2));
+ };
+ }
+ function reverseStoppableEventChain(f1, f2) {
+ if (f1 === nop)
+ return f2;
+ return function () {
+ if (f2.apply(this, arguments) === false)
+ return false;
+ return f1.apply(this, arguments);
+ };
+ }
+ function promisableChain(f1, f2) {
+ if (f1 === nop)
+ return f2;
+ return function () {
+ var res = f1.apply(this, arguments);
+ if (res && typeof res.then === 'function') {
+ var thiz = this, i = arguments.length, args = new Array(i);
+ while (i--)
+ args[i] = arguments[i];
+ return res.then(function () {
+ return f2.apply(thiz, args);
+ });
+ }
+ return f2.apply(this, arguments);
+ };
+ }
+
+ var INTERNAL = {};
+ var LONG_STACKS_CLIP_LIMIT = 100,
+ MAX_LONG_STACKS = 20, ZONE_ECHO_LIMIT = 100, _a$1 = typeof Promise === 'undefined' ?
+ [] :
+ (function () {
+ var globalP = Promise.resolve();
+ if (typeof crypto === 'undefined' || !crypto.subtle)
+ return [globalP, getProto(globalP), globalP];
+ var nativeP = crypto.subtle.digest("SHA-512", new Uint8Array([0]));
+ return [
+ nativeP,
+ getProto(nativeP),
+ globalP
+ ];
+ })(), resolvedNativePromise = _a$1[0], nativePromiseProto = _a$1[1], resolvedGlobalPromise = _a$1[2], nativePromiseThen = nativePromiseProto && nativePromiseProto.then;
+ var NativePromise = resolvedNativePromise && resolvedNativePromise.constructor;
+ var patchGlobalPromise = !!resolvedGlobalPromise;
+ var stack_being_generated = false;
+ var schedulePhysicalTick = resolvedGlobalPromise ?
+ function () { resolvedGlobalPromise.then(physicalTick); }
+ :
+ _global.setImmediate ?
+ setImmediate.bind(null, physicalTick) :
+ _global.MutationObserver ?
+ function () {
+ var hiddenDiv = document.createElement("div");
+ (new MutationObserver(function () {
+ physicalTick();
+ hiddenDiv = null;
+ })).observe(hiddenDiv, { attributes: true });
+ hiddenDiv.setAttribute('i', '1');
+ } :
+ function () { setTimeout(physicalTick, 0); };
+ var asap = function (callback, args) {
+ microtickQueue.push([callback, args]);
+ if (needsNewPhysicalTick) {
+ schedulePhysicalTick();
+ needsNewPhysicalTick = false;
+ }
+ };
+ var isOutsideMicroTick = true,
+ needsNewPhysicalTick = true,
+ unhandledErrors = [],
+ rejectingErrors = [],
+ currentFulfiller = null, rejectionMapper = mirror;
+ var globalPSD = {
+ id: 'global',
+ global: true,
+ ref: 0,
+ unhandleds: [],
+ onunhandled: nop,
+ pgp: false,
+ env: {},
+ finalize: nop
+ };
+ var PSD = globalPSD;
+ var microtickQueue = [];
+ var numScheduledCalls = 0;
+ var tickFinalizers = [];
+ function DexiePromise(fn) {
+ if (typeof this !== 'object')
+ throw new TypeError('Promises must be constructed via new');
+ this._listeners = [];
+ this._lib = false;
+ var psd = (this._PSD = PSD);
+ if (debug) {
+ this._stackHolder = getErrorWithStack();
+ this._prev = null;
+ this._numPrev = 0;
+ }
+ if (typeof fn !== 'function') {
+ if (fn !== INTERNAL)
+ throw new TypeError('Not a function');
+ this._state = arguments[1];
+ this._value = arguments[2];
+ if (this._state === false)
+ handleRejection(this, this._value);
+ return;
+ }
+ this._state = null;
+ this._value = null;
+ ++psd.ref;
+ executePromiseTask(this, fn);
+ }
+ var thenProp = {
+ get: function () {
+ var psd = PSD, microTaskId = totalEchoes;
+ function then(onFulfilled, onRejected) {
+ var _this = this;
+ var possibleAwait = !psd.global && (psd !== PSD || microTaskId !== totalEchoes);
+ var cleanup = possibleAwait && !decrementExpectedAwaits();
+ var rv = new DexiePromise(function (resolve, reject) {
+ propagateToListener(_this, new Listener(nativeAwaitCompatibleWrap(onFulfilled, psd, possibleAwait, cleanup), nativeAwaitCompatibleWrap(onRejected, psd, possibleAwait, cleanup), resolve, reject, psd));
+ });
+ debug && linkToPreviousPromise(rv, this);
+ return rv;
+ }
+ then.prototype = INTERNAL;
+ return then;
+ },
+ set: function (value) {
+ setProp(this, 'then', value && value.prototype === INTERNAL ?
+ thenProp :
+ {
+ get: function () {
+ return value;
+ },
+ set: thenProp.set
+ });
+ }
+ };
+ props(DexiePromise.prototype, {
+ then: thenProp,
+ _then: function (onFulfilled, onRejected) {
+ propagateToListener(this, new Listener(null, null, onFulfilled, onRejected, PSD));
+ },
+ catch: function (onRejected) {
+ if (arguments.length === 1)
+ return this.then(null, onRejected);
+ var type = arguments[0], handler = arguments[1];
+ return typeof type === 'function' ? this.then(null, function (err) {
+ return err instanceof type ? handler(err) : PromiseReject(err);
+ })
+ : this.then(null, function (err) {
+ return err && err.name === type ? handler(err) : PromiseReject(err);
+ });
+ },
+ finally: function (onFinally) {
+ return this.then(function (value) {
+ onFinally();
+ return value;
+ }, function (err) {
+ onFinally();
+ return PromiseReject(err);
+ });
+ },
+ stack: {
+ get: function () {
+ if (this._stack)
+ return this._stack;
+ try {
+ stack_being_generated = true;
+ var stacks = getStack(this, [], MAX_LONG_STACKS);
+ var stack = stacks.join("\nFrom previous: ");
+ if (this._state !== null)
+ this._stack = stack;
+ return stack;
+ }
+ finally {
+ stack_being_generated = false;
+ }
+ }
+ },
+ timeout: function (ms, msg) {
+ var _this = this;
+ return ms < Infinity ?
+ new DexiePromise(function (resolve, reject) {
+ var handle = setTimeout(function () { return reject(new exceptions.Timeout(msg)); }, ms);
+ _this.then(resolve, reject).finally(clearTimeout.bind(null, handle));
+ }) : this;
+ }
+ });
+ if (typeof Symbol !== 'undefined' && Symbol.toStringTag)
+ setProp(DexiePromise.prototype, Symbol.toStringTag, 'Dexie.Promise');
+ globalPSD.env = snapShot();
+ function Listener(onFulfilled, onRejected, resolve, reject, zone) {
+ this.onFulfilled = typeof onFulfilled === 'function' ? onFulfilled : null;
+ this.onRejected = typeof onRejected === 'function' ? onRejected : null;
+ this.resolve = resolve;
+ this.reject = reject;
+ this.psd = zone;
+ }
+ props(DexiePromise, {
+ all: function () {
+ var values = getArrayOf.apply(null, arguments)
+ .map(onPossibleParallellAsync);
+ return new DexiePromise(function (resolve, reject) {
+ if (values.length === 0)
+ resolve([]);
+ var remaining = values.length;
+ values.forEach(function (a, i) { return DexiePromise.resolve(a).then(function (x) {
+ values[i] = x;
+ if (!--remaining)
+ resolve(values);
+ }, reject); });
+ });
+ },
+ resolve: function (value) {
+ if (value instanceof DexiePromise)
+ return value;
+ if (value && typeof value.then === 'function')
+ return new DexiePromise(function (resolve, reject) {
+ value.then(resolve, reject);
+ });
+ var rv = new DexiePromise(INTERNAL, true, value);
+ linkToPreviousPromise(rv, currentFulfiller);
+ return rv;
+ },
+ reject: PromiseReject,
+ race: function () {
+ var values = getArrayOf.apply(null, arguments).map(onPossibleParallellAsync);
+ return new DexiePromise(function (resolve, reject) {
+ values.map(function (value) { return DexiePromise.resolve(value).then(resolve, reject); });
+ });
+ },
+ PSD: {
+ get: function () { return PSD; },
+ set: function (value) { return PSD = value; }
+ },
+ totalEchoes: { get: function () { return totalEchoes; } },
+ newPSD: newScope,
+ usePSD: usePSD,
+ scheduler: {
+ get: function () { return asap; },
+ set: function (value) { asap = value; }
+ },
+ rejectionMapper: {
+ get: function () { return rejectionMapper; },
+ set: function (value) { rejectionMapper = value; }
+ },
+ follow: function (fn, zoneProps) {
+ return new DexiePromise(function (resolve, reject) {
+ return newScope(function (resolve, reject) {
+ var psd = PSD;
+ psd.unhandleds = [];
+ psd.onunhandled = reject;
+ psd.finalize = callBoth(function () {
+ var _this = this;
+ run_at_end_of_this_or_next_physical_tick(function () {
+ _this.unhandleds.length === 0 ? resolve() : reject(_this.unhandleds[0]);
+ });
+ }, psd.finalize);
+ fn();
+ }, zoneProps, resolve, reject);
+ });
+ }
+ });
+ if (NativePromise) {
+ if (NativePromise.allSettled)
+ setProp(DexiePromise, "allSettled", function () {
+ var possiblePromises = getArrayOf.apply(null, arguments).map(onPossibleParallellAsync);
+ return new DexiePromise(function (resolve) {
+ if (possiblePromises.length === 0)
+ resolve([]);
+ var remaining = possiblePromises.length;
+ var results = new Array(remaining);
+ possiblePromises.forEach(function (p, i) { return DexiePromise.resolve(p).then(function (value) { return results[i] = { status: "fulfilled", value: value }; }, function (reason) { return results[i] = { status: "rejected", reason: reason }; })
+ .then(function () { return --remaining || resolve(results); }); });
+ });
+ });
+ if (NativePromise.any && typeof AggregateError !== 'undefined')
+ setProp(DexiePromise, "any", function () {
+ var possiblePromises = getArrayOf.apply(null, arguments).map(onPossibleParallellAsync);
+ return new DexiePromise(function (resolve, reject) {
+ if (possiblePromises.length === 0)
+ reject(new AggregateError([]));
+ var remaining = possiblePromises.length;
+ var failures = new Array(remaining);
+ possiblePromises.forEach(function (p, i) { return DexiePromise.resolve(p).then(function (value) { return resolve(value); }, function (failure) {
+ failures[i] = failure;
+ if (!--remaining)
+ reject(new AggregateError(failures));
+ }); });
+ });
+ });
+ }
+ function executePromiseTask(promise, fn) {
+ try {
+ fn(function (value) {
+ if (promise._state !== null)
+ return;
+ if (value === promise)
+ throw new TypeError('A promise cannot be resolved with itself.');
+ var shouldExecuteTick = promise._lib && beginMicroTickScope();
+ if (value && typeof value.then === 'function') {
+ executePromiseTask(promise, function (resolve, reject) {
+ value instanceof DexiePromise ?
+ value._then(resolve, reject) :
+ value.then(resolve, reject);
+ });
+ }
+ else {
+ promise._state = true;
+ promise._value = value;
+ propagateAllListeners(promise);
+ }
+ if (shouldExecuteTick)
+ endMicroTickScope();
+ }, handleRejection.bind(null, promise));
+ }
+ catch (ex) {
+ handleRejection(promise, ex);
+ }
+ }
+ function handleRejection(promise, reason) {
+ rejectingErrors.push(reason);
+ if (promise._state !== null)
+ return;
+ var shouldExecuteTick = promise._lib && beginMicroTickScope();
+ reason = rejectionMapper(reason);
+ promise._state = false;
+ promise._value = reason;
+ debug && reason !== null && typeof reason === 'object' && !reason._promise && tryCatch(function () {
+ var origProp = getPropertyDescriptor(reason, "stack");
+ reason._promise = promise;
+ setProp(reason, "stack", {
+ get: function () {
+ return stack_being_generated ?
+ origProp && (origProp.get ?
+ origProp.get.apply(reason) :
+ origProp.value) :
+ promise.stack;
+ }
+ });
+ });
+ addPossiblyUnhandledError(promise);
+ propagateAllListeners(promise);
+ if (shouldExecuteTick)
+ endMicroTickScope();
+ }
+ function propagateAllListeners(promise) {
+ var listeners = promise._listeners;
+ promise._listeners = [];
+ for (var i = 0, len = listeners.length; i < len; ++i) {
+ propagateToListener(promise, listeners[i]);
+ }
+ var psd = promise._PSD;
+ --psd.ref || psd.finalize();
+ if (numScheduledCalls === 0) {
+ ++numScheduledCalls;
+ asap(function () {
+ if (--numScheduledCalls === 0)
+ finalizePhysicalTick();
+ }, []);
+ }
+ }
+ function propagateToListener(promise, listener) {
+ if (promise._state === null) {
+ promise._listeners.push(listener);
+ return;
+ }
+ var cb = promise._state ? listener.onFulfilled : listener.onRejected;
+ if (cb === null) {
+ return (promise._state ? listener.resolve : listener.reject)(promise._value);
+ }
+ ++listener.psd.ref;
+ ++numScheduledCalls;
+ asap(callListener, [cb, promise, listener]);
+ }
+ function callListener(cb, promise, listener) {
+ try {
+ currentFulfiller = promise;
+ var ret, value = promise._value;
+ if (promise._state) {
+ ret = cb(value);
+ }
+ else {
+ if (rejectingErrors.length)
+ rejectingErrors = [];
+ ret = cb(value);
+ if (rejectingErrors.indexOf(value) === -1)
+ markErrorAsHandled(promise);
+ }
+ listener.resolve(ret);
+ }
+ catch (e) {
+ listener.reject(e);
+ }
+ finally {
+ currentFulfiller = null;
+ if (--numScheduledCalls === 0)
+ finalizePhysicalTick();
+ --listener.psd.ref || listener.psd.finalize();
+ }
+ }
+ function getStack(promise, stacks, limit) {
+ if (stacks.length === limit)
+ return stacks;
+ var stack = "";
+ if (promise._state === false) {
+ var failure = promise._value, errorName, message;
+ if (failure != null) {
+ errorName = failure.name || "Error";
+ message = failure.message || failure;
+ stack = prettyStack(failure, 0);
+ }
+ else {
+ errorName = failure;
+ message = "";
+ }
+ stacks.push(errorName + (message ? ": " + message : "") + stack);
+ }
+ if (debug) {
+ stack = prettyStack(promise._stackHolder, 2);
+ if (stack && stacks.indexOf(stack) === -1)
+ stacks.push(stack);
+ if (promise._prev)
+ getStack(promise._prev, stacks, limit);
+ }
+ return stacks;
+ }
+ function linkToPreviousPromise(promise, prev) {
+ var numPrev = prev ? prev._numPrev + 1 : 0;
+ if (numPrev < LONG_STACKS_CLIP_LIMIT) {
+ promise._prev = prev;
+ promise._numPrev = numPrev;
+ }
+ }
+ function physicalTick() {
+ beginMicroTickScope() && endMicroTickScope();
+ }
+ function beginMicroTickScope() {
+ var wasRootExec = isOutsideMicroTick;
+ isOutsideMicroTick = false;
+ needsNewPhysicalTick = false;
+ return wasRootExec;
+ }
+ function endMicroTickScope() {
+ var callbacks, i, l;
+ do {
+ while (microtickQueue.length > 0) {
+ callbacks = microtickQueue;
+ microtickQueue = [];
+ l = callbacks.length;
+ for (i = 0; i < l; ++i) {
+ var item = callbacks[i];
+ item[0].apply(null, item[1]);
+ }
+ }
+ } while (microtickQueue.length > 0);
+ isOutsideMicroTick = true;
+ needsNewPhysicalTick = true;
+ }
+ function finalizePhysicalTick() {
+ var unhandledErrs = unhandledErrors;
+ unhandledErrors = [];
+ unhandledErrs.forEach(function (p) {
+ p._PSD.onunhandled.call(null, p._value, p);
+ });
+ var finalizers = tickFinalizers.slice(0);
+ var i = finalizers.length;
+ while (i)
+ finalizers[--i]();
+ }
+ function run_at_end_of_this_or_next_physical_tick(fn) {
+ function finalizer() {
+ fn();
+ tickFinalizers.splice(tickFinalizers.indexOf(finalizer), 1);
+ }
+ tickFinalizers.push(finalizer);
+ ++numScheduledCalls;
+ asap(function () {
+ if (--numScheduledCalls === 0)
+ finalizePhysicalTick();
+ }, []);
+ }
+ function addPossiblyUnhandledError(promise) {
+ if (!unhandledErrors.some(function (p) { return p._value === promise._value; }))
+ unhandledErrors.push(promise);
+ }
+ function markErrorAsHandled(promise) {
+ var i = unhandledErrors.length;
+ while (i)
+ if (unhandledErrors[--i]._value === promise._value) {
+ unhandledErrors.splice(i, 1);
+ return;
+ }
+ }
+ function PromiseReject(reason) {
+ return new DexiePromise(INTERNAL, false, reason);
+ }
+ function wrap(fn, errorCatcher) {
+ var psd = PSD;
+ return function () {
+ var wasRootExec = beginMicroTickScope(), outerScope = PSD;
+ try {
+ switchToZone(psd, true);
+ return fn.apply(this, arguments);
+ }
+ catch (e) {
+ errorCatcher && errorCatcher(e);
+ }
+ finally {
+ switchToZone(outerScope, false);
+ if (wasRootExec)
+ endMicroTickScope();
+ }
+ };
+ }
+ var task = { awaits: 0, echoes: 0, id: 0 };
+ var taskCounter = 0;
+ var zoneStack = [];
+ var zoneEchoes = 0;
+ var totalEchoes = 0;
+ var zone_id_counter = 0;
+ function newScope(fn, props, a1, a2) {
+ var parent = PSD, psd = Object.create(parent);
+ psd.parent = parent;
+ psd.ref = 0;
+ psd.global = false;
+ psd.id = ++zone_id_counter;
+ var globalEnv = globalPSD.env;
+ psd.env = patchGlobalPromise ? {
+ Promise: DexiePromise,
+ PromiseProp: { value: DexiePromise, configurable: true, writable: true },
+ all: DexiePromise.all,
+ race: DexiePromise.race,
+ allSettled: DexiePromise.allSettled,
+ any: DexiePromise.any,
+ resolve: DexiePromise.resolve,
+ reject: DexiePromise.reject,
+ nthen: getPatchedPromiseThen(globalEnv.nthen, psd),
+ gthen: getPatchedPromiseThen(globalEnv.gthen, psd)
+ } : {};
+ if (props)
+ extend(psd, props);
+ ++parent.ref;
+ psd.finalize = function () {
+ --this.parent.ref || this.parent.finalize();
+ };
+ var rv = usePSD(psd, fn, a1, a2);
+ if (psd.ref === 0)
+ psd.finalize();
+ return rv;
+ }
+ function incrementExpectedAwaits() {
+ if (!task.id)
+ task.id = ++taskCounter;
+ ++task.awaits;
+ task.echoes += ZONE_ECHO_LIMIT;
+ return task.id;
+ }
+ function decrementExpectedAwaits() {
+ if (!task.awaits)
+ return false;
+ if (--task.awaits === 0)
+ task.id = 0;
+ task.echoes = task.awaits * ZONE_ECHO_LIMIT;
+ return true;
+ }
+ if (('' + nativePromiseThen).indexOf('[native code]') === -1) {
+ incrementExpectedAwaits = decrementExpectedAwaits = nop;
+ }
+ function onPossibleParallellAsync(possiblePromise) {
+ if (task.echoes && possiblePromise && possiblePromise.constructor === NativePromise) {
+ incrementExpectedAwaits();
+ return possiblePromise.then(function (x) {
+ decrementExpectedAwaits();
+ return x;
+ }, function (e) {
+ decrementExpectedAwaits();
+ return rejection(e);
+ });
+ }
+ return possiblePromise;
+ }
+ function zoneEnterEcho(targetZone) {
+ ++totalEchoes;
+ if (!task.echoes || --task.echoes === 0) {
+ task.echoes = task.id = 0;
+ }
+ zoneStack.push(PSD);
+ switchToZone(targetZone, true);
+ }
+ function zoneLeaveEcho() {
+ var zone = zoneStack[zoneStack.length - 1];
+ zoneStack.pop();
+ switchToZone(zone, false);
+ }
+ function switchToZone(targetZone, bEnteringZone) {
+ var currentZone = PSD;
+ if (bEnteringZone ? task.echoes && (!zoneEchoes++ || targetZone !== PSD) : zoneEchoes && (!--zoneEchoes || targetZone !== PSD)) {
+ enqueueNativeMicroTask(bEnteringZone ? zoneEnterEcho.bind(null, targetZone) : zoneLeaveEcho);
+ }
+ if (targetZone === PSD)
+ return;
+ PSD = targetZone;
+ if (currentZone === globalPSD)
+ globalPSD.env = snapShot();
+ if (patchGlobalPromise) {
+ var GlobalPromise_1 = globalPSD.env.Promise;
+ var targetEnv = targetZone.env;
+ nativePromiseProto.then = targetEnv.nthen;
+ GlobalPromise_1.prototype.then = targetEnv.gthen;
+ if (currentZone.global || targetZone.global) {
+ Object.defineProperty(_global, 'Promise', targetEnv.PromiseProp);
+ GlobalPromise_1.all = targetEnv.all;
+ GlobalPromise_1.race = targetEnv.race;
+ GlobalPromise_1.resolve = targetEnv.resolve;
+ GlobalPromise_1.reject = targetEnv.reject;
+ if (targetEnv.allSettled)
+ GlobalPromise_1.allSettled = targetEnv.allSettled;
+ if (targetEnv.any)
+ GlobalPromise_1.any = targetEnv.any;
+ }
+ }
+ }
+ function snapShot() {
+ var GlobalPromise = _global.Promise;
+ return patchGlobalPromise ? {
+ Promise: GlobalPromise,
+ PromiseProp: Object.getOwnPropertyDescriptor(_global, "Promise"),
+ all: GlobalPromise.all,
+ race: GlobalPromise.race,
+ allSettled: GlobalPromise.allSettled,
+ any: GlobalPromise.any,
+ resolve: GlobalPromise.resolve,
+ reject: GlobalPromise.reject,
+ nthen: nativePromiseProto.then,
+ gthen: GlobalPromise.prototype.then
+ } : {};
+ }
+ function usePSD(psd, fn, a1, a2, a3) {
+ var outerScope = PSD;
+ try {
+ switchToZone(psd, true);
+ return fn(a1, a2, a3);
+ }
+ finally {
+ switchToZone(outerScope, false);
+ }
+ }
+ function enqueueNativeMicroTask(job) {
+ nativePromiseThen.call(resolvedNativePromise, job);
+ }
+ function nativeAwaitCompatibleWrap(fn, zone, possibleAwait, cleanup) {
+ return typeof fn !== 'function' ? fn : function () {
+ var outerZone = PSD;
+ if (possibleAwait)
+ incrementExpectedAwaits();
+ switchToZone(zone, true);
+ try {
+ return fn.apply(this, arguments);
+ }
+ finally {
+ switchToZone(outerZone, false);
+ if (cleanup)
+ enqueueNativeMicroTask(decrementExpectedAwaits);
+ }
+ };
+ }
+ function getPatchedPromiseThen(origThen, zone) {
+ return function (onResolved, onRejected) {
+ return origThen.call(this, nativeAwaitCompatibleWrap(onResolved, zone), nativeAwaitCompatibleWrap(onRejected, zone));
+ };
+ }
+ var rejection = DexiePromise.reject;
+
+ function tempTransaction(db, mode, storeNames, fn) {
+ if (!db.idbdb || (!db._state.openComplete && (!PSD.letThrough && !db._vip))) {
+ if (db._state.openComplete) {
+ return rejection(new exceptions.DatabaseClosed(db._state.dbOpenError));
+ }
+ if (!db._state.isBeingOpened) {
+ if (!db._options.autoOpen)
+ return rejection(new exceptions.DatabaseClosed());
+ db.open().catch(nop);
+ }
+ return db._state.dbReadyPromise.then(function () { return tempTransaction(db, mode, storeNames, fn); });
+ }
+ else {
+ var trans = db._createTransaction(mode, storeNames, db._dbSchema);
+ try {
+ trans.create();
+ db._state.PR1398_maxLoop = 3;
+ }
+ catch (ex) {
+ if (ex.name === errnames.InvalidState && db.isOpen() && --db._state.PR1398_maxLoop > 0) {
+ console.warn('Dexie: Need to reopen db');
+ db._close();
+ return db.open().then(function () { return tempTransaction(db, mode, storeNames, fn); });
+ }
+ return rejection(ex);
+ }
+ return trans._promise(mode, function (resolve, reject) {
+ return newScope(function () {
+ PSD.trans = trans;
+ return fn(resolve, reject, trans);
+ });
+ }).then(function (result) {
+ if (mode === 'readwrite')
+ try {
+ trans.idbtrans.commit();
+ }
+ catch (_a) { }
+ return mode === 'readonly' ? result : trans._completion.then(function () { return result; });
+ });
+ }
+ }
+
+ var DEXIE_VERSION = '4.0.1-alpha.12';
+ var maxString = String.fromCharCode(65535);
+ var minKey = -Infinity;
+ var INVALID_KEY_ARGUMENT = "Invalid key provided. Keys must be of type string, number, Date or Array.";
+ var STRING_EXPECTED = "String expected.";
+ var connections = [];
+ var isIEOrEdge = typeof navigator !== 'undefined' && /(MSIE|Trident|Edge)/.test(navigator.userAgent);
+ var hasIEDeleteObjectStoreBug = isIEOrEdge;
+ var hangsOnDeleteLargeKeyRange = isIEOrEdge;
+ var dexieStackFrameFilter = function (frame) { return !/(dexie\.js|dexie\.min\.js)/.test(frame); };
+ var DBNAMES_DB = '__dbnames';
+ var READONLY = 'readonly';
+ var READWRITE = 'readwrite';
+
+ function combine(filter1, filter2) {
+ return filter1 ?
+ filter2 ?
+ function () { return filter1.apply(this, arguments) && filter2.apply(this, arguments); } :
+ filter1 :
+ filter2;
+ }
+
+ var AnyRange = {
+ type: 3 ,
+ lower: -Infinity,
+ lowerOpen: false,
+ upper: [[]],
+ upperOpen: false
+ };
+
+ function workaroundForUndefinedPrimKey(keyPath) {
+ return typeof keyPath === "string" && !/\./.test(keyPath)
+ ? function (obj) {
+ if (obj[keyPath] === undefined && (keyPath in obj)) {
+ obj = deepClone(obj);
+ delete obj[keyPath];
+ }
+ return obj;
+ }
+ : function (obj) { return obj; };
+ }
+
+ function Entity() {
+ throw exceptions.Type();
+ }
+
+ function cmp(a, b) {
+ try {
+ var ta = type(a);
+ var tb = type(b);
+ if (ta !== tb) {
+ if (ta === 'Array')
+ return 1;
+ if (tb === 'Array')
+ return -1;
+ if (ta === 'binary')
+ return 1;
+ if (tb === 'binary')
+ return -1;
+ if (ta === 'string')
+ return 1;
+ if (tb === 'string')
+ return -1;
+ if (ta === 'Date')
+ return 1;
+ if (tb !== 'Date')
+ return NaN;
+ return -1;
+ }
+ switch (ta) {
+ case 'number':
+ case 'Date':
+ case 'string':
+ return a > b ? 1 : a < b ? -1 : 0;
+ case 'binary': {
+ return compareUint8Arrays(getUint8Array(a), getUint8Array(b));
+ }
+ case 'Array':
+ return compareArrays(a, b);
+ }
+ }
+ catch (_a) { }
+ return NaN;
+ }
+ function compareArrays(a, b) {
+ var al = a.length;
+ var bl = b.length;
+ var l = al < bl ? al : bl;
+ for (var i = 0; i < l; ++i) {
+ var res = cmp(a[i], b[i]);
+ if (res !== 0)
+ return res;
+ }
+ return al === bl ? 0 : al < bl ? -1 : 1;
+ }
+ function compareUint8Arrays(a, b) {
+ var al = a.length;
+ var bl = b.length;
+ var l = al < bl ? al : bl;
+ for (var i = 0; i < l; ++i) {
+ if (a[i] !== b[i])
+ return a[i] < b[i] ? -1 : 1;
+ }
+ return al === bl ? 0 : al < bl ? -1 : 1;
+ }
+ function type(x) {
+ var t = typeof x;
+ if (t !== 'object')
+ return t;
+ if (ArrayBuffer.isView(x))
+ return 'binary';
+ var tsTag = toStringTag(x);
+ return tsTag === 'ArrayBuffer' ? 'binary' : tsTag;
+ }
+ function getUint8Array(a) {
+ if (a instanceof Uint8Array)
+ return a;
+ if (ArrayBuffer.isView(a))
+ return new Uint8Array(a.buffer, a.byteOffset, a.byteLength);
+ return new Uint8Array(a);
+ }
+
+ var Table = (function () {
+ function Table() {
+ }
+ Table.prototype._trans = function (mode, fn, writeLocked) {
+ var trans = this._tx || PSD.trans;
+ var tableName = this.name;
+ function checkTableInTransaction(resolve, reject, trans) {
+ if (!trans.schema[tableName])
+ throw new exceptions.NotFound("Table " + tableName + " not part of transaction");
+ return fn(trans.idbtrans, trans);
+ }
+ var wasRootExec = beginMicroTickScope();
+ try {
+ return trans && trans.db === this.db ?
+ trans === PSD.trans ?
+ trans._promise(mode, checkTableInTransaction, writeLocked) :
+ newScope(function () { return trans._promise(mode, checkTableInTransaction, writeLocked); }, { trans: trans, transless: PSD.transless || PSD }) :
+ tempTransaction(this.db, mode, [this.name], checkTableInTransaction);
+ }
+ finally {
+ if (wasRootExec)
+ endMicroTickScope();
+ }
+ };
+ Table.prototype.get = function (keyOrCrit, cb) {
+ var _this = this;
+ if (keyOrCrit && keyOrCrit.constructor === Object)
+ return this.where(keyOrCrit).first(cb);
+ return this._trans('readonly', function (trans) {
+ return _this.core.get({ trans: trans, key: keyOrCrit })
+ .then(function (res) { return _this.hook.reading.fire(res); });
+ }).then(cb);
+ };
+ Table.prototype.where = function (indexOrCrit) {
+ if (typeof indexOrCrit === 'string')
+ return new this.db.WhereClause(this, indexOrCrit);
+ if (isArray(indexOrCrit))
+ return new this.db.WhereClause(this, "[".concat(indexOrCrit.join('+'), "]"));
+ var keyPaths = keys(indexOrCrit);
+ if (keyPaths.length === 1)
+ return this
+ .where(keyPaths[0])
+ .equals(indexOrCrit[keyPaths[0]]);
+ var compoundIndex = this.schema.indexes.concat(this.schema.primKey).filter(function (ix) {
+ return ix.compound &&
+ keyPaths.every(function (keyPath) { return ix.keyPath.indexOf(keyPath) >= 0; }) &&
+ ix.keyPath.every(function (keyPath) { return keyPaths.indexOf(keyPath) >= 0; });
+ })[0];
+ if (compoundIndex && this.db._maxKey !== maxString)
+ return this
+ .where(compoundIndex.name)
+ .equals(compoundIndex.keyPath.map(function (kp) { return indexOrCrit[kp]; }));
+ if (!compoundIndex && debug)
+ console.warn("The query ".concat(JSON.stringify(indexOrCrit), " on ").concat(this.name, " would benefit of a ") +
+ "compound index [".concat(keyPaths.join('+'), "]"));
+ var idxByName = this.schema.idxByName;
+ var idb = this.db._deps.indexedDB;
+ function equals(a, b) {
+ return idb.cmp(a, b) === 0;
+ }
+ var _a = keyPaths.reduce(function (_a, keyPath) {
+ var prevIndex = _a[0], prevFilterFn = _a[1];
+ var index = idxByName[keyPath];
+ var value = indexOrCrit[keyPath];
+ return [
+ prevIndex || index,
+ prevIndex || !index ?
+ combine(prevFilterFn, index && index.multi ?
+ function (x) {
+ var prop = getByKeyPath(x, keyPath);
+ return isArray(prop) && prop.some(function (item) { return equals(value, item); });
+ } : function (x) { return equals(value, getByKeyPath(x, keyPath)); })
+ : prevFilterFn
+ ];
+ }, [null, null]), idx = _a[0], filterFunction = _a[1];
+ return idx ?
+ this.where(idx.name).equals(indexOrCrit[idx.keyPath])
+ .filter(filterFunction) :
+ compoundIndex ?
+ this.filter(filterFunction) :
+ this.where(keyPaths).equals('');
+ };
+ Table.prototype.filter = function (filterFunction) {
+ return this.toCollection().and(filterFunction);
+ };
+ Table.prototype.count = function (thenShortcut) {
+ return this.toCollection().count(thenShortcut);
+ };
+ Table.prototype.offset = function (offset) {
+ return this.toCollection().offset(offset);
+ };
+ Table.prototype.limit = function (numRows) {
+ return this.toCollection().limit(numRows);
+ };
+ Table.prototype.each = function (callback) {
+ return this.toCollection().each(callback);
+ };
+ Table.prototype.toArray = function (thenShortcut) {
+ return this.toCollection().toArray(thenShortcut);
+ };
+ Table.prototype.toCollection = function () {
+ return new this.db.Collection(new this.db.WhereClause(this));
+ };
+ Table.prototype.orderBy = function (index) {
+ return new this.db.Collection(new this.db.WhereClause(this, isArray(index) ?
+ "[".concat(index.join('+'), "]") :
+ index));
+ };
+ Table.prototype.reverse = function () {
+ return this.toCollection().reverse();
+ };
+ Table.prototype.mapToClass = function (constructor) {
+ var _a = this, db = _a.db, tableName = _a.name;
+ this.schema.mappedClass = constructor;
+ if (constructor.prototype instanceof Entity) {
+ constructor = (function (_super) {
+ __extends(class_1, _super);
+ function class_1() {
+ return _super !== null && _super.apply(this, arguments) || this;
+ }
+ Object.defineProperty(class_1.prototype, "db", {
+ get: function () { return db; },
+ enumerable: false,
+ configurable: true
+ });
+ class_1.prototype.table = function () { return tableName; };
+ return class_1;
+ }(constructor));
+ }
+ var inheritedProps = new Set();
+ for (var proto = constructor.prototype; proto; proto = getProto(proto)) {
+ Object.getOwnPropertyNames(proto).forEach(function (propName) { return inheritedProps.add(propName); });
+ }
+ var readHook = function (obj) {
+ if (!obj)
+ return obj;
+ var res = Object.create(constructor.prototype);
+ for (var m in obj)
+ if (!inheritedProps.has(m))
+ try {
+ res[m] = obj[m];
+ }
+ catch (_) { }
+ return res;
+ };
+ if (this.schema.readHook) {
+ this.hook.reading.unsubscribe(this.schema.readHook);
+ }
+ this.schema.readHook = readHook;
+ this.hook("reading", readHook);
+ return constructor;
+ };
+ Table.prototype.defineClass = function () {
+ function Class(content) {
+ extend(this, content);
+ }
+ return this.mapToClass(Class);
+ };
+ Table.prototype.add = function (obj, key) {
+ var _this = this;
+ var _a = this.schema.primKey, auto = _a.auto, keyPath = _a.keyPath;
+ var objToAdd = obj;
+ if (keyPath && auto) {
+ objToAdd = workaroundForUndefinedPrimKey(keyPath)(obj);
+ }
+ return this._trans('readwrite', function (trans) {
+ return _this.core.mutate({ trans: trans, type: 'add', keys: key != null ? [key] : null, values: [objToAdd] });
+ }).then(function (res) { return res.numFailures ? DexiePromise.reject(res.failures[0]) : res.lastResult; })
+ .then(function (lastResult) {
+ if (keyPath) {
+ try {
+ setByKeyPath(obj, keyPath, lastResult);
+ }
+ catch (_) { }
+ }
+ return lastResult;
+ });
+ };
+ Table.prototype.update = function (keyOrObject, modifications) {
+ if (typeof keyOrObject === 'object' && !isArray(keyOrObject)) {
+ var key = getByKeyPath(keyOrObject, this.schema.primKey.keyPath);
+ if (key === undefined)
+ return rejection(new exceptions.InvalidArgument("Given object does not contain its primary key"));
+ return this.where(":id").equals(key).modify(modifications);
+ }
+ else {
+ return this.where(":id").equals(keyOrObject).modify(modifications);
+ }
+ };
+ Table.prototype.put = function (obj, key) {
+ var _this = this;
+ var _a = this.schema.primKey, auto = _a.auto, keyPath = _a.keyPath;
+ var objToAdd = obj;
+ if (keyPath && auto) {
+ objToAdd = workaroundForUndefinedPrimKey(keyPath)(obj);
+ }
+ return this._trans('readwrite', function (trans) { return _this.core.mutate({ trans: trans, type: 'put', values: [objToAdd], keys: key != null ? [key] : null }); })
+ .then(function (res) { return res.numFailures ? DexiePromise.reject(res.failures[0]) : res.lastResult; })
+ .then(function (lastResult) {
+ if (keyPath) {
+ try {
+ setByKeyPath(obj, keyPath, lastResult);
+ }
+ catch (_) { }
+ }
+ return lastResult;
+ });
+ };
+ Table.prototype.delete = function (key) {
+ var _this = this;
+ return this._trans('readwrite', function (trans) { return _this.core.mutate({ trans: trans, type: 'delete', keys: [key] }); })
+ .then(function (res) { return res.numFailures ? DexiePromise.reject(res.failures[0]) : undefined; });
+ };
+ Table.prototype.clear = function () {
+ var _this = this;
+ return this._trans('readwrite', function (trans) { return _this.core.mutate({ trans: trans, type: 'deleteRange', range: AnyRange }); })
+ .then(function (res) { return res.numFailures ? DexiePromise.reject(res.failures[0]) : undefined; });
+ };
+ Table.prototype.bulkGet = function (keys) {
+ var _this = this;
+ return this._trans('readonly', function (trans) {
+ return _this.core.getMany({
+ keys: keys,
+ trans: trans
+ }).then(function (result) { return result.map(function (res) { return _this.hook.reading.fire(res); }); });
+ });
+ };
+ Table.prototype.bulkAdd = function (objects, keysOrOptions, options) {
+ var _this = this;
+ var keys = Array.isArray(keysOrOptions) ? keysOrOptions : undefined;
+ options = options || (keys ? undefined : keysOrOptions);
+ var wantResults = options ? options.allKeys : undefined;
+ return this._trans('readwrite', function (trans) {
+ var _a = _this.schema.primKey, auto = _a.auto, keyPath = _a.keyPath;
+ if (keyPath && keys)
+ throw new exceptions.InvalidArgument("bulkAdd(): keys argument invalid on tables with inbound keys");
+ if (keys && keys.length !== objects.length)
+ throw new exceptions.InvalidArgument("Arguments objects and keys must have the same length");
+ var numObjects = objects.length;
+ var objectsToAdd = keyPath && auto ?
+ objects.map(workaroundForUndefinedPrimKey(keyPath)) :
+ objects;
+ return _this.core.mutate({ trans: trans, type: 'add', keys: keys, values: objectsToAdd, wantResults: wantResults })
+ .then(function (_a) {
+ var numFailures = _a.numFailures, results = _a.results, lastResult = _a.lastResult, failures = _a.failures;
+ var result = wantResults ? results : lastResult;
+ if (numFailures === 0)
+ return result;
+ throw new BulkError("".concat(_this.name, ".bulkAdd(): ").concat(numFailures, " of ").concat(numObjects, " operations failed"), failures);
+ });
+ });
+ };
+ Table.prototype.bulkPut = function (objects, keysOrOptions, options) {
+ var _this = this;
+ var keys = Array.isArray(keysOrOptions) ? keysOrOptions : undefined;
+ options = options || (keys ? undefined : keysOrOptions);
+ var wantResults = options ? options.allKeys : undefined;
+ return this._trans('readwrite', function (trans) {
+ var _a = _this.schema.primKey, auto = _a.auto, keyPath = _a.keyPath;
+ if (keyPath && keys)
+ throw new exceptions.InvalidArgument("bulkPut(): keys argument invalid on tables with inbound keys");
+ if (keys && keys.length !== objects.length)
+ throw new exceptions.InvalidArgument("Arguments objects and keys must have the same length");
+ var numObjects = objects.length;
+ var objectsToPut = keyPath && auto ?
+ objects.map(workaroundForUndefinedPrimKey(keyPath)) :
+ objects;
+ return _this.core.mutate({ trans: trans, type: 'put', keys: keys, values: objectsToPut, wantResults: wantResults })
+ .then(function (_a) {
+ var numFailures = _a.numFailures, results = _a.results, lastResult = _a.lastResult, failures = _a.failures;
+ var result = wantResults ? results : lastResult;
+ if (numFailures === 0)
+ return result;
+ throw new BulkError("".concat(_this.name, ".bulkPut(): ").concat(numFailures, " of ").concat(numObjects, " operations failed"), failures);
+ });
+ });
+ };
+ Table.prototype.bulkUpdate = function (keysAndChanges) {
+ var _this = this;
+ var coreTable = this.core;
+ var keys = keysAndChanges.map(function (entry) { return entry.key; });
+ var changeSpecs = keysAndChanges.map(function (entry) { return entry.changes; });
+ var offsetMap = [];
+ return this._trans('readwrite', function (trans) {
+ return coreTable.getMany({ trans: trans, keys: keys, cache: 'clone' }).then(function (objs) {
+ var resultKeys = [];
+ var resultObjs = [];
+ keysAndChanges.forEach(function (_a, idx) {
+ var key = _a.key, changes = _a.changes;
+ var obj = objs[idx];
+ if (obj) {
+ for (var _i = 0, _b = Object.keys(changes); _i < _b.length; _i++) {
+ var keyPath = _b[_i];
+ var value = changes[keyPath];
+ if (keyPath === _this.schema.primKey.keyPath) {
+ if (cmp(value, key) !== 0) {
+ throw new exceptions.Constraint("Cannot update primary key in bulkUpdate()");
+ }
+ }
+ else {
+ setByKeyPath(obj, keyPath, value);
+ }
+ }
+ offsetMap.push(idx);
+ resultKeys.push(key);
+ resultObjs.push(obj);
+ }
+ });
+ var numEntries = resultKeys.length;
+ return coreTable
+ .mutate({
+ trans: trans,
+ type: 'put',
+ keys: resultKeys,
+ values: resultObjs,
+ updates: {
+ keys: keys,
+ changeSpecs: changeSpecs
+ }
+ })
+ .then(function (_a) {
+ var numFailures = _a.numFailures, failures = _a.failures;
+ if (numFailures === 0)
+ return numEntries;
+ for (var _i = 0, _b = Object.keys(failures); _i < _b.length; _i++) {
+ var offset = _b[_i];
+ var mappedOffset = offsetMap[Number(offset)];
+ if (mappedOffset != null) {
+ var failure = failures[offset];
+ delete failures[offset];
+ failures[mappedOffset] = failure;
+ }
+ }
+ throw new BulkError("".concat(_this.name, ".bulkUpdate(): ").concat(numFailures, " of ").concat(numEntries, " operations failed"), failures);
+ });
+ });
+ });
+ };
+ Table.prototype.bulkDelete = function (keys) {
+ var _this = this;
+ var numKeys = keys.length;
+ return this._trans('readwrite', function (trans) {
+ return _this.core.mutate({ trans: trans, type: 'delete', keys: keys });
+ }).then(function (_a) {
+ var numFailures = _a.numFailures, lastResult = _a.lastResult, failures = _a.failures;
+ if (numFailures === 0)
+ return lastResult;
+ throw new BulkError("".concat(_this.name, ".bulkDelete(): ").concat(numFailures, " of ").concat(numKeys, " operations failed"), failures);
+ });
+ };
+ return Table;
+ }());
+
+ function Events(ctx) {
+ var evs = {};
+ var rv = function (eventName, subscriber) {
+ if (subscriber) {
+ var i = arguments.length, args = new Array(i - 1);
+ while (--i)
+ args[i - 1] = arguments[i];
+ evs[eventName].subscribe.apply(null, args);
+ return ctx;
+ }
+ else if (typeof (eventName) === 'string') {
+ return evs[eventName];
+ }
+ };
+ rv.addEventType = add;
+ for (var i = 1, l = arguments.length; i < l; ++i) {
+ add(arguments[i]);
+ }
+ return rv;
+ function add(eventName, chainFunction, defaultFunction) {
+ if (typeof eventName === 'object')
+ return addConfiguredEvents(eventName);
+ if (!chainFunction)
+ chainFunction = reverseStoppableEventChain;
+ if (!defaultFunction)
+ defaultFunction = nop;
+ var context = {
+ subscribers: [],
+ fire: defaultFunction,
+ subscribe: function (cb) {
+ if (context.subscribers.indexOf(cb) === -1) {
+ context.subscribers.push(cb);
+ context.fire = chainFunction(context.fire, cb);
+ }
+ },
+ unsubscribe: function (cb) {
+ context.subscribers = context.subscribers.filter(function (fn) { return fn !== cb; });
+ context.fire = context.subscribers.reduce(chainFunction, defaultFunction);
+ }
+ };
+ evs[eventName] = rv[eventName] = context;
+ return context;
+ }
+ function addConfiguredEvents(cfg) {
+ keys(cfg).forEach(function (eventName) {
+ var args = cfg[eventName];
+ if (isArray(args)) {
+ add(eventName, cfg[eventName][0], cfg[eventName][1]);
+ }
+ else if (args === 'asap') {
+ var context = add(eventName, mirror, function fire() {
+ var i = arguments.length, args = new Array(i);
+ while (i--)
+ args[i] = arguments[i];
+ context.subscribers.forEach(function (fn) {
+ asap$1(function fireEvent() {
+ fn.apply(null, args);
+ });
+ });
+ });
+ }
+ else
+ throw new exceptions.InvalidArgument("Invalid event config");
+ });
+ }
+ }
+
+ function makeClassConstructor(prototype, constructor) {
+ derive(constructor).from({ prototype: prototype });
+ return constructor;
+ }
+
+ function createTableConstructor(db) {
+ return makeClassConstructor(Table.prototype, function Table(name, tableSchema, trans) {
+ this.db = db;
+ this._tx = trans;
+ this.name = name;
+ this.schema = tableSchema;
+ this.hook = db._allTables[name] ? db._allTables[name].hook : Events(null, {
+ "creating": [hookCreatingChain, nop],
+ "reading": [pureFunctionChain, mirror],
+ "updating": [hookUpdatingChain, nop],
+ "deleting": [hookDeletingChain, nop]
+ });
+ });
+ }
+
+ function isPlainKeyRange(ctx, ignoreLimitFilter) {
+ return !(ctx.filter || ctx.algorithm || ctx.or) &&
+ (ignoreLimitFilter ? ctx.justLimit : !ctx.replayFilter);
+ }
+ function addFilter(ctx, fn) {
+ ctx.filter = combine(ctx.filter, fn);
+ }
+ function addReplayFilter(ctx, factory, isLimitFilter) {
+ var curr = ctx.replayFilter;
+ ctx.replayFilter = curr ? function () { return combine(curr(), factory()); } : factory;
+ ctx.justLimit = isLimitFilter && !curr;
+ }
+ function addMatchFilter(ctx, fn) {
+ ctx.isMatch = combine(ctx.isMatch, fn);
+ }
+ function getIndexOrStore(ctx, coreSchema) {
+ if (ctx.isPrimKey)
+ return coreSchema.primaryKey;
+ var index = coreSchema.getIndexByKeyPath(ctx.index);
+ if (!index)
+ throw new exceptions.Schema("KeyPath " + ctx.index + " on object store " + coreSchema.name + " is not indexed");
+ return index;
+ }
+ function openCursor(ctx, coreTable, trans) {
+ var index = getIndexOrStore(ctx, coreTable.schema);
+ return coreTable.openCursor({
+ trans: trans,
+ values: !ctx.keysOnly,
+ reverse: ctx.dir === 'prev',
+ unique: !!ctx.unique,
+ query: {
+ index: index,
+ range: ctx.range
+ }
+ });
+ }
+ function iter(ctx, fn, coreTrans, coreTable) {
+ var filter = ctx.replayFilter ? combine(ctx.filter, ctx.replayFilter()) : ctx.filter;
+ if (!ctx.or) {
+ return iterate(openCursor(ctx, coreTable, coreTrans), combine(ctx.algorithm, filter), fn, !ctx.keysOnly && ctx.valueMapper);
+ }
+ else {
+ var set_1 = {};
+ var union = function (item, cursor, advance) {
+ if (!filter || filter(cursor, advance, function (result) { return cursor.stop(result); }, function (err) { return cursor.fail(err); })) {
+ var primaryKey = cursor.primaryKey;
+ var key = '' + primaryKey;
+ if (key === '[object ArrayBuffer]')
+ key = '' + new Uint8Array(primaryKey);
+ if (!hasOwn(set_1, key)) {
+ set_1[key] = true;
+ fn(item, cursor, advance);
+ }
+ }
+ };
+ return Promise.all([
+ ctx.or._iterate(union, coreTrans),
+ iterate(openCursor(ctx, coreTable, coreTrans), ctx.algorithm, union, !ctx.keysOnly && ctx.valueMapper)
+ ]);
+ }
+ }
+ function iterate(cursorPromise, filter, fn, valueMapper) {
+ var mappedFn = valueMapper ? function (x, c, a) { return fn(valueMapper(x), c, a); } : fn;
+ var wrappedFn = wrap(mappedFn);
+ return cursorPromise.then(function (cursor) {
+ if (cursor) {
+ return cursor.start(function () {
+ var c = function () { return cursor.continue(); };
+ if (!filter || filter(cursor, function (advancer) { return c = advancer; }, function (val) { cursor.stop(val); c = nop; }, function (e) { cursor.fail(e); c = nop; }))
+ wrappedFn(cursor.value, cursor, function (advancer) { return c = advancer; });
+ c();
+ });
+ }
+ });
+ }
+
+ var Collection = (function () {
+ function Collection() {
+ }
+ Collection.prototype._read = function (fn, cb) {
+ var ctx = this._ctx;
+ return ctx.error ?
+ ctx.table._trans(null, rejection.bind(null, ctx.error)) :
+ ctx.table._trans('readonly', fn).then(cb);
+ };
+ Collection.prototype._write = function (fn) {
+ var ctx = this._ctx;
+ return ctx.error ?
+ ctx.table._trans(null, rejection.bind(null, ctx.error)) :
+ ctx.table._trans('readwrite', fn, "locked");
+ };
+ Collection.prototype._addAlgorithm = function (fn) {
+ var ctx = this._ctx;
+ ctx.algorithm = combine(ctx.algorithm, fn);
+ };
+ Collection.prototype._iterate = function (fn, coreTrans) {
+ return iter(this._ctx, fn, coreTrans, this._ctx.table.core);
+ };
+ Collection.prototype.clone = function (props) {
+ var rv = Object.create(this.constructor.prototype), ctx = Object.create(this._ctx);
+ if (props)
+ extend(ctx, props);
+ rv._ctx = ctx;
+ return rv;
+ };
+ Collection.prototype.raw = function () {
+ this._ctx.valueMapper = null;
+ return this;
+ };
+ Collection.prototype.each = function (fn) {
+ var ctx = this._ctx;
+ return this._read(function (trans) { return iter(ctx, fn, trans, ctx.table.core); });
+ };
+ Collection.prototype.count = function (cb) {
+ var _this = this;
+ return this._read(function (trans) {
+ var ctx = _this._ctx;
+ var coreTable = ctx.table.core;
+ if (isPlainKeyRange(ctx, true)) {
+ return coreTable.count({
+ trans: trans,
+ query: {
+ index: getIndexOrStore(ctx, coreTable.schema),
+ range: ctx.range
+ }
+ }).then(function (count) { return Math.min(count, ctx.limit); });
+ }
+ else {
+ var count = 0;
+ return iter(ctx, function () { ++count; return false; }, trans, coreTable)
+ .then(function () { return count; });
+ }
+ }).then(cb);
+ };
+ Collection.prototype.sortBy = function (keyPath, cb) {
+ var parts = keyPath.split('.').reverse(), lastPart = parts[0], lastIndex = parts.length - 1;
+ function getval(obj, i) {
+ if (i)
+ return getval(obj[parts[i]], i - 1);
+ return obj[lastPart];
+ }
+ var order = this._ctx.dir === "next" ? 1 : -1;
+ function sorter(a, b) {
+ var aVal = getval(a, lastIndex), bVal = getval(b, lastIndex);
+ return aVal < bVal ? -order : aVal > bVal ? order : 0;
+ }
+ return this.toArray(function (a) {
+ return a.sort(sorter);
+ }).then(cb);
+ };
+ Collection.prototype.toArray = function (cb) {
+ var _this = this;
+ return this._read(function (trans) {
+ var ctx = _this._ctx;
+ if (ctx.dir === 'next' && isPlainKeyRange(ctx, true) && ctx.limit > 0) {
+ var valueMapper_1 = ctx.valueMapper;
+ var index = getIndexOrStore(ctx, ctx.table.core.schema);
+ return ctx.table.core.query({
+ trans: trans,
+ limit: ctx.limit,
+ values: true,
+ query: {
+ index: index,
+ range: ctx.range
+ }
+ }).then(function (_a) {
+ var result = _a.result;
+ return valueMapper_1 ? result.map(valueMapper_1) : result;
+ });
+ }
+ else {
+ var a_1 = [];
+ return iter(ctx, function (item) { return a_1.push(item); }, trans, ctx.table.core).then(function () { return a_1; });
+ }
+ }, cb);
+ };
+ Collection.prototype.offset = function (offset) {
+ var ctx = this._ctx;
+ if (offset <= 0)
+ return this;
+ ctx.offset += offset;
+ if (isPlainKeyRange(ctx)) {
+ addReplayFilter(ctx, function () {
+ var offsetLeft = offset;
+ return function (cursor, advance) {
+ if (offsetLeft === 0)
+ return true;
+ if (offsetLeft === 1) {
+ --offsetLeft;
+ return false;
+ }
+ advance(function () {
+ cursor.advance(offsetLeft);
+ offsetLeft = 0;
+ });
+ return false;
+ };
+ });
+ }
+ else {
+ addReplayFilter(ctx, function () {
+ var offsetLeft = offset;
+ return function () { return (--offsetLeft < 0); };
+ });
+ }
+ return this;
+ };
+ Collection.prototype.limit = function (numRows) {
+ this._ctx.limit = Math.min(this._ctx.limit, numRows);
+ addReplayFilter(this._ctx, function () {
+ var rowsLeft = numRows;
+ return function (cursor, advance, resolve) {
+ if (--rowsLeft <= 0)
+ advance(resolve);
+ return rowsLeft >= 0;
+ };
+ }, true);
+ return this;
+ };
+ Collection.prototype.until = function (filterFunction, bIncludeStopEntry) {
+ addFilter(this._ctx, function (cursor, advance, resolve) {
+ if (filterFunction(cursor.value)) {
+ advance(resolve);
+ return bIncludeStopEntry;
+ }
+ else {
+ return true;
+ }
+ });
+ return this;
+ };
+ Collection.prototype.first = function (cb) {
+ return this.limit(1).toArray(function (a) { return a[0]; }).then(cb);
+ };
+ Collection.prototype.last = function (cb) {
+ return this.reverse().first(cb);
+ };
+ Collection.prototype.filter = function (filterFunction) {
+ addFilter(this._ctx, function (cursor) {
+ return filterFunction(cursor.value);
+ });
+ addMatchFilter(this._ctx, filterFunction);
+ return this;
+ };
+ Collection.prototype.and = function (filter) {
+ return this.filter(filter);
+ };
+ Collection.prototype.or = function (indexName) {
+ return new this.db.WhereClause(this._ctx.table, indexName, this);
+ };
+ Collection.prototype.reverse = function () {
+ this._ctx.dir = (this._ctx.dir === "prev" ? "next" : "prev");
+ if (this._ondirectionchange)
+ this._ondirectionchange(this._ctx.dir);
+ return this;
+ };
+ Collection.prototype.desc = function () {
+ return this.reverse();
+ };
+ Collection.prototype.eachKey = function (cb) {
+ var ctx = this._ctx;
+ ctx.keysOnly = !ctx.isMatch;
+ return this.each(function (val, cursor) { cb(cursor.key, cursor); });
+ };
+ Collection.prototype.eachUniqueKey = function (cb) {
+ this._ctx.unique = "unique";
+ return this.eachKey(cb);
+ };
+ Collection.prototype.eachPrimaryKey = function (cb) {
+ var ctx = this._ctx;
+ ctx.keysOnly = !ctx.isMatch;
+ return this.each(function (val, cursor) { cb(cursor.primaryKey, cursor); });
+ };
+ Collection.prototype.keys = function (cb) {
+ var ctx = this._ctx;
+ ctx.keysOnly = !ctx.isMatch;
+ var a = [];
+ return this.each(function (item, cursor) {
+ a.push(cursor.key);
+ }).then(function () {
+ return a;
+ }).then(cb);
+ };
+ Collection.prototype.primaryKeys = function (cb) {
+ var ctx = this._ctx;
+ if (ctx.dir === 'next' && isPlainKeyRange(ctx, true) && ctx.limit > 0) {
+ return this._read(function (trans) {
+ var index = getIndexOrStore(ctx, ctx.table.core.schema);
+ return ctx.table.core.query({
+ trans: trans,
+ values: false,
+ limit: ctx.limit,
+ query: {
+ index: index,
+ range: ctx.range
+ }
+ });
+ }).then(function (_a) {
+ var result = _a.result;
+ return result;
+ }).then(cb);
+ }
+ ctx.keysOnly = !ctx.isMatch;
+ var a = [];
+ return this.each(function (item, cursor) {
+ a.push(cursor.primaryKey);
+ }).then(function () {
+ return a;
+ }).then(cb);
+ };
+ Collection.prototype.uniqueKeys = function (cb) {
+ this._ctx.unique = "unique";
+ return this.keys(cb);
+ };
+ Collection.prototype.firstKey = function (cb) {
+ return this.limit(1).keys(function (a) { return a[0]; }).then(cb);
+ };
+ Collection.prototype.lastKey = function (cb) {
+ return this.reverse().firstKey(cb);
+ };
+ Collection.prototype.distinct = function () {
+ var ctx = this._ctx, idx = ctx.index && ctx.table.schema.idxByName[ctx.index];
+ if (!idx || !idx.multi)
+ return this;
+ var set = {};
+ addFilter(this._ctx, function (cursor) {
+ var strKey = cursor.primaryKey.toString();
+ var found = hasOwn(set, strKey);
+ set[strKey] = true;
+ return !found;
+ });
+ return this;
+ };
+ Collection.prototype.modify = function (changes) {
+ var _this = this;
+ var ctx = this._ctx;
+ return this._write(function (trans) {
+ var modifyer;
+ if (typeof changes === 'function') {
+ modifyer = changes;
+ }
+ else {
+ var keyPaths = keys(changes);
+ var numKeys = keyPaths.length;
+ modifyer = function (item) {
+ var anythingModified = false;
+ for (var i = 0; i < numKeys; ++i) {
+ var keyPath = keyPaths[i], val = changes[keyPath];
+ if (getByKeyPath(item, keyPath) !== val) {
+ setByKeyPath(item, keyPath, val);
+ anythingModified = true;
+ }
+ }
+ return anythingModified;
+ };
+ }
+ var coreTable = ctx.table.core;
+ var _a = coreTable.schema.primaryKey, outbound = _a.outbound, extractKey = _a.extractKey;
+ var limit = _this.db._options.modifyChunkSize || 200;
+ var totalFailures = [];
+ var successCount = 0;
+ var failedKeys = [];
+ var applyMutateResult = function (expectedCount, res) {
+ var failures = res.failures, numFailures = res.numFailures;
+ successCount += expectedCount - numFailures;
+ for (var _i = 0, _a = keys(failures); _i < _a.length; _i++) {
+ var pos = _a[_i];
+ totalFailures.push(failures[pos]);
+ }
+ };
+ return _this.clone().primaryKeys().then(function (keys) {
+ var nextChunk = function (offset) {
+ var count = Math.min(limit, keys.length - offset);
+ return coreTable.getMany({
+ trans: trans,
+ keys: keys.slice(offset, offset + count),
+ cache: "immutable"
+ }).then(function (values) {
+ var addValues = [];
+ var putValues = [];
+ var putKeys = outbound ? [] : null;
+ var deleteKeys = [];
+ for (var i = 0; i < count; ++i) {
+ var origValue = values[i];
+ var ctx_1 = {
+ value: deepClone(origValue),
+ primKey: keys[offset + i]
+ };
+ if (modifyer.call(ctx_1, ctx_1.value, ctx_1) !== false) {
+ if (ctx_1.value == null) {
+ deleteKeys.push(keys[offset + i]);
+ }
+ else if (!outbound && cmp(extractKey(origValue), extractKey(ctx_1.value)) !== 0) {
+ deleteKeys.push(keys[offset + i]);
+ addValues.push(ctx_1.value);
+ }
+ else {
+ putValues.push(ctx_1.value);
+ if (outbound)
+ putKeys.push(keys[offset + i]);
+ }
+ }
+ }
+ var criteria = isPlainKeyRange(ctx) &&
+ ctx.limit === Infinity &&
+ (typeof changes !== 'function' || changes === deleteCallback) && {
+ index: ctx.index,
+ range: ctx.range
+ };
+ return Promise.resolve(addValues.length > 0 &&
+ coreTable.mutate({ trans: trans, type: 'add', values: addValues })
+ .then(function (res) {
+ for (var pos in res.failures) {
+ deleteKeys.splice(parseInt(pos), 1);
+ }
+ applyMutateResult(addValues.length, res);
+ })).then(function () { return (putValues.length > 0 || (criteria && typeof changes === 'object')) &&
+ coreTable.mutate({
+ trans: trans,
+ type: 'put',
+ keys: putKeys,
+ values: putValues,
+ criteria: criteria,
+ changeSpec: typeof changes !== 'function'
+ && changes
+ }).then(function (res) { return applyMutateResult(putValues.length, res); }); }).then(function () { return (deleteKeys.length > 0 || (criteria && changes === deleteCallback)) &&
+ coreTable.mutate({
+ trans: trans,
+ type: 'delete',
+ keys: deleteKeys,
+ criteria: criteria
+ }).then(function (res) { return applyMutateResult(deleteKeys.length, res); }); }).then(function () {
+ return keys.length > offset + count && nextChunk(offset + limit);
+ });
+ });
+ };
+ return nextChunk(0).then(function () {
+ if (totalFailures.length > 0)
+ throw new ModifyError("Error modifying one or more objects", totalFailures, successCount, failedKeys);
+ return keys.length;
+ });
+ });
+ });
+ };
+ Collection.prototype.delete = function () {
+ var ctx = this._ctx, range = ctx.range;
+ if (isPlainKeyRange(ctx) &&
+ ((ctx.isPrimKey && !hangsOnDeleteLargeKeyRange) || range.type === 3 ))
+ {
+ return this._write(function (trans) {
+ var primaryKey = ctx.table.core.schema.primaryKey;
+ var coreRange = range;
+ return ctx.table.core.count({ trans: trans, query: { index: primaryKey, range: coreRange } }).then(function (count) {
+ return ctx.table.core.mutate({ trans: trans, type: 'deleteRange', range: coreRange })
+ .then(function (_a) {
+ var failures = _a.failures; _a.lastResult; _a.results; var numFailures = _a.numFailures;
+ if (numFailures)
+ throw new ModifyError("Could not delete some values", Object.keys(failures).map(function (pos) { return failures[pos]; }), count - numFailures);
+ return count - numFailures;
+ });
+ });
+ });
+ }
+ return this.modify(deleteCallback);
+ };
+ return Collection;
+ }());
+ var deleteCallback = function (value, ctx) { return ctx.value = null; };
+
+ function createCollectionConstructor(db) {
+ return makeClassConstructor(Collection.prototype, function Collection(whereClause, keyRangeGenerator) {
+ this.db = db;
+ var keyRange = AnyRange, error = null;
+ if (keyRangeGenerator)
+ try {
+ keyRange = keyRangeGenerator();
+ }
+ catch (ex) {
+ error = ex;
+ }
+ var whereCtx = whereClause._ctx;
+ var table = whereCtx.table;
+ var readingHook = table.hook.reading.fire;
+ this._ctx = {
+ table: table,
+ index: whereCtx.index,
+ isPrimKey: (!whereCtx.index || (table.schema.primKey.keyPath && whereCtx.index === table.schema.primKey.name)),
+ range: keyRange,
+ keysOnly: false,
+ dir: "next",
+ unique: "",
+ algorithm: null,
+ filter: null,
+ replayFilter: null,
+ justLimit: true,
+ isMatch: null,
+ offset: 0,
+ limit: Infinity,
+ error: error,
+ or: whereCtx.or,
+ valueMapper: readingHook !== mirror ? readingHook : null
+ };
+ });
+ }
+
+ function simpleCompare(a, b) {
+ return a < b ? -1 : a === b ? 0 : 1;
+ }
+ function simpleCompareReverse(a, b) {
+ return a > b ? -1 : a === b ? 0 : 1;
+ }
+
+ function fail(collectionOrWhereClause, err, T) {
+ var collection = collectionOrWhereClause instanceof WhereClause ?
+ new collectionOrWhereClause.Collection(collectionOrWhereClause) :
+ collectionOrWhereClause;
+ collection._ctx.error = T ? new T(err) : new TypeError(err);
+ return collection;
+ }
+ function emptyCollection(whereClause) {
+ return new whereClause.Collection(whereClause, function () { return rangeEqual(""); }).limit(0);
+ }
+ function upperFactory(dir) {
+ return dir === "next" ?
+ function (s) { return s.toUpperCase(); } :
+ function (s) { return s.toLowerCase(); };
+ }
+ function lowerFactory(dir) {
+ return dir === "next" ?
+ function (s) { return s.toLowerCase(); } :
+ function (s) { return s.toUpperCase(); };
+ }
+ function nextCasing(key, lowerKey, upperNeedle, lowerNeedle, cmp, dir) {
+ var length = Math.min(key.length, lowerNeedle.length);
+ var llp = -1;
+ for (var i = 0; i < length; ++i) {
+ var lwrKeyChar = lowerKey[i];
+ if (lwrKeyChar !== lowerNeedle[i]) {
+ if (cmp(key[i], upperNeedle[i]) < 0)
+ return key.substr(0, i) + upperNeedle[i] + upperNeedle.substr(i + 1);
+ if (cmp(key[i], lowerNeedle[i]) < 0)
+ return key.substr(0, i) + lowerNeedle[i] + upperNeedle.substr(i + 1);
+ if (llp >= 0)
+ return key.substr(0, llp) + lowerKey[llp] + upperNeedle.substr(llp + 1);
+ return null;
+ }
+ if (cmp(key[i], lwrKeyChar) < 0)
+ llp = i;
+ }
+ if (length < lowerNeedle.length && dir === "next")
+ return key + upperNeedle.substr(key.length);
+ if (length < key.length && dir === "prev")
+ return key.substr(0, upperNeedle.length);
+ return (llp < 0 ? null : key.substr(0, llp) + lowerNeedle[llp] + upperNeedle.substr(llp + 1));
+ }
+ function addIgnoreCaseAlgorithm(whereClause, match, needles, suffix) {
+ var upper, lower, compare, upperNeedles, lowerNeedles, direction, nextKeySuffix, needlesLen = needles.length;
+ if (!needles.every(function (s) { return typeof s === 'string'; })) {
+ return fail(whereClause, STRING_EXPECTED);
+ }
+ function initDirection(dir) {
+ upper = upperFactory(dir);
+ lower = lowerFactory(dir);
+ compare = (dir === "next" ? simpleCompare : simpleCompareReverse);
+ var needleBounds = needles.map(function (needle) {
+ return { lower: lower(needle), upper: upper(needle) };
+ }).sort(function (a, b) {
+ return compare(a.lower, b.lower);
+ });
+ upperNeedles = needleBounds.map(function (nb) { return nb.upper; });
+ lowerNeedles = needleBounds.map(function (nb) { return nb.lower; });
+ direction = dir;
+ nextKeySuffix = (dir === "next" ? "" : suffix);
+ }
+ initDirection("next");
+ var c = new whereClause.Collection(whereClause, function () { return createRange(upperNeedles[0], lowerNeedles[needlesLen - 1] + suffix); });
+ c._ondirectionchange = function (direction) {
+ initDirection(direction);
+ };
+ var firstPossibleNeedle = 0;
+ c._addAlgorithm(function (cursor, advance, resolve) {
+ var key = cursor.key;
+ if (typeof key !== 'string')
+ return false;
+ var lowerKey = lower(key);
+ if (match(lowerKey, lowerNeedles, firstPossibleNeedle)) {
+ return true;
+ }
+ else {
+ var lowestPossibleCasing = null;
+ for (var i = firstPossibleNeedle; i < needlesLen; ++i) {
+ var casing = nextCasing(key, lowerKey, upperNeedles[i], lowerNeedles[i], compare, direction);
+ if (casing === null && lowestPossibleCasing === null)
+ firstPossibleNeedle = i + 1;
+ else if (lowestPossibleCasing === null || compare(lowestPossibleCasing, casing) > 0) {
+ lowestPossibleCasing = casing;
+ }
+ }
+ if (lowestPossibleCasing !== null) {
+ advance(function () { cursor.continue(lowestPossibleCasing + nextKeySuffix); });
+ }
+ else {
+ advance(resolve);
+ }
+ return false;
+ }
+ });
+ return c;
+ }
+ function createRange(lower, upper, lowerOpen, upperOpen) {
+ return {
+ type: 2 ,
+ lower: lower,
+ upper: upper,
+ lowerOpen: lowerOpen,
+ upperOpen: upperOpen
+ };
+ }
+ function rangeEqual(value) {
+ return {
+ type: 1 ,
+ lower: value,
+ upper: value
+ };
+ }
+
+ var WhereClause = (function () {
+ function WhereClause() {
+ }
+ Object.defineProperty(WhereClause.prototype, "Collection", {
+ get: function () {
+ return this._ctx.table.db.Collection;
+ },
+ enumerable: false,
+ configurable: true
+ });
+ WhereClause.prototype.between = function (lower, upper, includeLower, includeUpper) {
+ includeLower = includeLower !== false;
+ includeUpper = includeUpper === true;
+ try {
+ if ((this._cmp(lower, upper) > 0) ||
+ (this._cmp(lower, upper) === 0 && (includeLower || includeUpper) && !(includeLower && includeUpper)))
+ return emptyCollection(this);
+ return new this.Collection(this, function () { return createRange(lower, upper, !includeLower, !includeUpper); });
+ }
+ catch (e) {
+ return fail(this, INVALID_KEY_ARGUMENT);
+ }
+ };
+ WhereClause.prototype.equals = function (value) {
+ if (value == null)
+ return fail(this, INVALID_KEY_ARGUMENT);
+ return new this.Collection(this, function () { return rangeEqual(value); });
+ };
+ WhereClause.prototype.above = function (value) {
+ if (value == null)
+ return fail(this, INVALID_KEY_ARGUMENT);
+ return new this.Collection(this, function () { return createRange(value, undefined, true); });
+ };
+ WhereClause.prototype.aboveOrEqual = function (value) {
+ if (value == null)
+ return fail(this, INVALID_KEY_ARGUMENT);
+ return new this.Collection(this, function () { return createRange(value, undefined, false); });
+ };
+ WhereClause.prototype.below = function (value) {
+ if (value == null)
+ return fail(this, INVALID_KEY_ARGUMENT);
+ return new this.Collection(this, function () { return createRange(undefined, value, false, true); });
+ };
+ WhereClause.prototype.belowOrEqual = function (value) {
+ if (value == null)
+ return fail(this, INVALID_KEY_ARGUMENT);
+ return new this.Collection(this, function () { return createRange(undefined, value); });
+ };
+ WhereClause.prototype.startsWith = function (str) {
+ if (typeof str !== 'string')
+ return fail(this, STRING_EXPECTED);
+ return this.between(str, str + maxString, true, true);
+ };
+ WhereClause.prototype.startsWithIgnoreCase = function (str) {
+ if (str === "")
+ return this.startsWith(str);
+ return addIgnoreCaseAlgorithm(this, function (x, a) { return x.indexOf(a[0]) === 0; }, [str], maxString);
+ };
+ WhereClause.prototype.equalsIgnoreCase = function (str) {
+ return addIgnoreCaseAlgorithm(this, function (x, a) { return x === a[0]; }, [str], "");
+ };
+ WhereClause.prototype.anyOfIgnoreCase = function () {
+ var set = getArrayOf.apply(NO_CHAR_ARRAY, arguments);
+ if (set.length === 0)
+ return emptyCollection(this);
+ return addIgnoreCaseAlgorithm(this, function (x, a) { return a.indexOf(x) !== -1; }, set, "");
+ };
+ WhereClause.prototype.startsWithAnyOfIgnoreCase = function () {
+ var set = getArrayOf.apply(NO_CHAR_ARRAY, arguments);
+ if (set.length === 0)
+ return emptyCollection(this);
+ return addIgnoreCaseAlgorithm(this, function (x, a) { return a.some(function (n) { return x.indexOf(n) === 0; }); }, set, maxString);
+ };
+ WhereClause.prototype.anyOf = function () {
+ var _this = this;
+ var set = getArrayOf.apply(NO_CHAR_ARRAY, arguments);
+ var compare = this._cmp;
+ try {
+ set.sort(compare);
+ }
+ catch (e) {
+ return fail(this, INVALID_KEY_ARGUMENT);
+ }
+ if (set.length === 0)
+ return emptyCollection(this);
+ var c = new this.Collection(this, function () { return createRange(set[0], set[set.length - 1]); });
+ c._ondirectionchange = function (direction) {
+ compare = (direction === "next" ?
+ _this._ascending :
+ _this._descending);
+ set.sort(compare);
+ };
+ var i = 0;
+ c._addAlgorithm(function (cursor, advance, resolve) {
+ var key = cursor.key;
+ while (compare(key, set[i]) > 0) {
+ ++i;
+ if (i === set.length) {
+ advance(resolve);
+ return false;
+ }
+ }
+ if (compare(key, set[i]) === 0) {
+ return true;
+ }
+ else {
+ advance(function () { cursor.continue(set[i]); });
+ return false;
+ }
+ });
+ return c;
+ };
+ WhereClause.prototype.notEqual = function (value) {
+ return this.inAnyRange([[minKey, value], [value, this.db._maxKey]], { includeLowers: false, includeUppers: false });
+ };
+ WhereClause.prototype.noneOf = function () {
+ var set = getArrayOf.apply(NO_CHAR_ARRAY, arguments);
+ if (set.length === 0)
+ return new this.Collection(this);
+ try {
+ set.sort(this._ascending);
+ }
+ catch (e) {
+ return fail(this, INVALID_KEY_ARGUMENT);
+ }
+ var ranges = set.reduce(function (res, val) { return res ?
+ res.concat([[res[res.length - 1][1], val]]) :
+ [[minKey, val]]; }, null);
+ ranges.push([set[set.length - 1], this.db._maxKey]);
+ return this.inAnyRange(ranges, { includeLowers: false, includeUppers: false });
+ };
+ WhereClause.prototype.inAnyRange = function (ranges, options) {
+ var _this = this;
+ var cmp = this._cmp, ascending = this._ascending, descending = this._descending, min = this._min, max = this._max;
+ if (ranges.length === 0)
+ return emptyCollection(this);
+ if (!ranges.every(function (range) {
+ return range[0] !== undefined &&
+ range[1] !== undefined &&
+ ascending(range[0], range[1]) <= 0;
+ })) {
+ return fail(this, "First argument to inAnyRange() must be an Array of two-value Arrays [lower,upper] where upper must not be lower than lower", exceptions.InvalidArgument);
+ }
+ var includeLowers = !options || options.includeLowers !== false;
+ var includeUppers = options && options.includeUppers === true;
+ function addRange(ranges, newRange) {
+ var i = 0, l = ranges.length;
+ for (; i < l; ++i) {
+ var range = ranges[i];
+ if (cmp(newRange[0], range[1]) < 0 && cmp(newRange[1], range[0]) > 0) {
+ range[0] = min(range[0], newRange[0]);
+ range[1] = max(range[1], newRange[1]);
+ break;
+ }
+ }
+ if (i === l)
+ ranges.push(newRange);
+ return ranges;
+ }
+ var sortDirection = ascending;
+ function rangeSorter(a, b) { return sortDirection(a[0], b[0]); }
+ var set;
+ try {
+ set = ranges.reduce(addRange, []);
+ set.sort(rangeSorter);
+ }
+ catch (ex) {
+ return fail(this, INVALID_KEY_ARGUMENT);
+ }
+ var rangePos = 0;
+ var keyIsBeyondCurrentEntry = includeUppers ?
+ function (key) { return ascending(key, set[rangePos][1]) > 0; } :
+ function (key) { return ascending(key, set[rangePos][1]) >= 0; };
+ var keyIsBeforeCurrentEntry = includeLowers ?
+ function (key) { return descending(key, set[rangePos][0]) > 0; } :
+ function (key) { return descending(key, set[rangePos][0]) >= 0; };
+ function keyWithinCurrentRange(key) {
+ return !keyIsBeyondCurrentEntry(key) && !keyIsBeforeCurrentEntry(key);
+ }
+ var checkKey = keyIsBeyondCurrentEntry;
+ var c = new this.Collection(this, function () { return createRange(set[0][0], set[set.length - 1][1], !includeLowers, !includeUppers); });
+ c._ondirectionchange = function (direction) {
+ if (direction === "next") {
+ checkKey = keyIsBeyondCurrentEntry;
+ sortDirection = ascending;
+ }
+ else {
+ checkKey = keyIsBeforeCurrentEntry;
+ sortDirection = descending;
+ }
+ set.sort(rangeSorter);
+ };
+ c._addAlgorithm(function (cursor, advance, resolve) {
+ var key = cursor.key;
+ while (checkKey(key)) {
+ ++rangePos;
+ if (rangePos === set.length) {
+ advance(resolve);
+ return false;
+ }
+ }
+ if (keyWithinCurrentRange(key)) {
+ return true;
+ }
+ else if (_this._cmp(key, set[rangePos][1]) === 0 || _this._cmp(key, set[rangePos][0]) === 0) {
+ return false;
+ }
+ else {
+ advance(function () {
+ if (sortDirection === ascending)
+ cursor.continue(set[rangePos][0]);
+ else
+ cursor.continue(set[rangePos][1]);
+ });
+ return false;
+ }
+ });
+ return c;
+ };
+ WhereClause.prototype.startsWithAnyOf = function () {
+ var set = getArrayOf.apply(NO_CHAR_ARRAY, arguments);
+ if (!set.every(function (s) { return typeof s === 'string'; })) {
+ return fail(this, "startsWithAnyOf() only works with strings");
+ }
+ if (set.length === 0)
+ return emptyCollection(this);
+ return this.inAnyRange(set.map(function (str) { return [str, str + maxString]; }));
+ };
+ return WhereClause;
+ }());
+
+ function createWhereClauseConstructor(db) {
+ return makeClassConstructor(WhereClause.prototype, function WhereClause(table, index, orCollection) {
+ this.db = db;
+ this._ctx = {
+ table: table,
+ index: index === ":id" ? null : index,
+ or: orCollection
+ };
+ this._cmp = this._ascending = cmp;
+ this._descending = function (a, b) { return cmp(b, a); };
+ this._max = function (a, b) { return cmp(a, b) > 0 ? a : b; };
+ this._min = function (a, b) { return cmp(a, b) < 0 ? a : b; };
+ this._IDBKeyRange = db._deps.IDBKeyRange;
+ if (!this._IDBKeyRange)
+ throw new exceptions.MissingAPI();
+ });
+ }
+
+ function eventRejectHandler(reject) {
+ return wrap(function (event) {
+ preventDefault(event);
+ reject(event.target.error);
+ return false;
+ });
+ }
+ function preventDefault(event) {
+ if (event.stopPropagation)
+ event.stopPropagation();
+ if (event.preventDefault)
+ event.preventDefault();
+ }
+
+ var DEXIE_STORAGE_MUTATED_EVENT_NAME = 'storagemutated';
+ var STORAGE_MUTATED_DOM_EVENT_NAME = 'x-storagemutated-1';
+ var globalEvents = Events(null, DEXIE_STORAGE_MUTATED_EVENT_NAME);
+
+ var Transaction = (function () {
+ function Transaction() {
+ }
+ Transaction.prototype._lock = function () {
+ assert(!PSD.global);
+ ++this._reculock;
+ if (this._reculock === 1 && !PSD.global)
+ PSD.lockOwnerFor = this;
+ return this;
+ };
+ Transaction.prototype._unlock = function () {
+ assert(!PSD.global);
+ if (--this._reculock === 0) {
+ if (!PSD.global)
+ PSD.lockOwnerFor = null;
+ while (this._blockedFuncs.length > 0 && !this._locked()) {
+ var fnAndPSD = this._blockedFuncs.shift();
+ try {
+ usePSD(fnAndPSD[1], fnAndPSD[0]);
+ }
+ catch (e) { }
+ }
+ }
+ return this;
+ };
+ Transaction.prototype._locked = function () {
+ return this._reculock && PSD.lockOwnerFor !== this;
+ };
+ Transaction.prototype.create = function (idbtrans) {
+ var _this = this;
+ if (!this.mode)
+ return this;
+ var idbdb = this.db.idbdb;
+ var dbOpenError = this.db._state.dbOpenError;
+ assert(!this.idbtrans);
+ if (!idbtrans && !idbdb) {
+ switch (dbOpenError && dbOpenError.name) {
+ case "DatabaseClosedError":
+ throw new exceptions.DatabaseClosed(dbOpenError);
+ case "MissingAPIError":
+ throw new exceptions.MissingAPI(dbOpenError.message, dbOpenError);
+ default:
+ throw new exceptions.OpenFailed(dbOpenError);
+ }
+ }
+ if (!this.active)
+ throw new exceptions.TransactionInactive();
+ assert(this._completion._state === null);
+ idbtrans = this.idbtrans = idbtrans ||
+ (this.db.core
+ ? this.db.core.transaction(this.storeNames, this.mode, { durability: this.chromeTransactionDurability })
+ : idbdb.transaction(this.storeNames, this.mode, { durability: this.chromeTransactionDurability }));
+ idbtrans.onerror = wrap(function (ev) {
+ preventDefault(ev);
+ _this._reject(idbtrans.error);
+ });
+ idbtrans.onabort = wrap(function (ev) {
+ preventDefault(ev);
+ _this.active && _this._reject(new exceptions.Abort(idbtrans.error));
+ _this.active = false;
+ _this.on("abort").fire(ev);
+ });
+ idbtrans.oncomplete = wrap(function () {
+ _this.active = false;
+ _this._resolve();
+ if ('mutatedParts' in idbtrans) {
+ globalEvents.storagemutated.fire(idbtrans["mutatedParts"]);
+ }
+ });
+ return this;
+ };
+ Transaction.prototype._promise = function (mode, fn, bWriteLock) {
+ var _this = this;
+ if (mode === 'readwrite' && this.mode !== 'readwrite')
+ return rejection(new exceptions.ReadOnly("Transaction is readonly"));
+ if (!this.active)
+ return rejection(new exceptions.TransactionInactive());
+ if (this._locked()) {
+ return new DexiePromise(function (resolve, reject) {
+ _this._blockedFuncs.push([function () {
+ _this._promise(mode, fn, bWriteLock).then(resolve, reject);
+ }, PSD]);
+ });
+ }
+ else if (bWriteLock) {
+ return newScope(function () {
+ var p = new DexiePromise(function (resolve, reject) {
+ _this._lock();
+ var rv = fn(resolve, reject, _this);
+ if (rv && rv.then)
+ rv.then(resolve, reject);
+ });
+ p.finally(function () { return _this._unlock(); });
+ p._lib = true;
+ return p;
+ });
+ }
+ else {
+ var p = new DexiePromise(function (resolve, reject) {
+ var rv = fn(resolve, reject, _this);
+ if (rv && rv.then)
+ rv.then(resolve, reject);
+ });
+ p._lib = true;
+ return p;
+ }
+ };
+ Transaction.prototype._root = function () {
+ return this.parent ? this.parent._root() : this;
+ };
+ Transaction.prototype.waitFor = function (promiseLike) {
+ var root = this._root();
+ var promise = DexiePromise.resolve(promiseLike);
+ if (root._waitingFor) {
+ root._waitingFor = root._waitingFor.then(function () { return promise; });
+ }
+ else {
+ root._waitingFor = promise;
+ root._waitingQueue = [];
+ var store = root.idbtrans.objectStore(root.storeNames[0]);
+ (function spin() {
+ ++root._spinCount;
+ while (root._waitingQueue.length)
+ (root._waitingQueue.shift())();
+ if (root._waitingFor)
+ store.get(-Infinity).onsuccess = spin;
+ }());
+ }
+ var currentWaitPromise = root._waitingFor;
+ return new DexiePromise(function (resolve, reject) {
+ promise.then(function (res) { return root._waitingQueue.push(wrap(resolve.bind(null, res))); }, function (err) { return root._waitingQueue.push(wrap(reject.bind(null, err))); }).finally(function () {
+ if (root._waitingFor === currentWaitPromise) {
+ root._waitingFor = null;
+ }
+ });
+ });
+ };
+ Transaction.prototype.abort = function () {
+ if (this.active) {
+ this.active = false;
+ if (this.idbtrans)
+ this.idbtrans.abort();
+ this._reject(new exceptions.Abort());
+ }
+ };
+ Transaction.prototype.table = function (tableName) {
+ var memoizedTables = (this._memoizedTables || (this._memoizedTables = {}));
+ if (hasOwn(memoizedTables, tableName))
+ return memoizedTables[tableName];
+ var tableSchema = this.schema[tableName];
+ if (!tableSchema) {
+ throw new exceptions.NotFound("Table " + tableName + " not part of transaction");
+ }
+ var transactionBoundTable = new this.db.Table(tableName, tableSchema, this);
+ transactionBoundTable.core = this.db.core.table(tableName);
+ memoizedTables[tableName] = transactionBoundTable;
+ return transactionBoundTable;
+ };
+ return Transaction;
+ }());
+
+ function createTransactionConstructor(db) {
+ return makeClassConstructor(Transaction.prototype, function Transaction(mode, storeNames, dbschema, chromeTransactionDurability, parent) {
+ var _this = this;
+ this.db = db;
+ this.mode = mode;
+ this.storeNames = storeNames;
+ this.schema = dbschema;
+ this.chromeTransactionDurability = chromeTransactionDurability;
+ this.idbtrans = null;
+ this.on = Events(this, "complete", "error", "abort");
+ this.parent = parent || null;
+ this.active = true;
+ this._reculock = 0;
+ this._blockedFuncs = [];
+ this._resolve = null;
+ this._reject = null;
+ this._waitingFor = null;
+ this._waitingQueue = null;
+ this._spinCount = 0;
+ this._completion = new DexiePromise(function (resolve, reject) {
+ _this._resolve = resolve;
+ _this._reject = reject;
+ });
+ this._completion.then(function () {
+ _this.active = false;
+ _this.on.complete.fire();
+ }, function (e) {
+ var wasActive = _this.active;
+ _this.active = false;
+ _this.on.error.fire(e);
+ _this.parent ?
+ _this.parent._reject(e) :
+ wasActive && _this.idbtrans && _this.idbtrans.abort();
+ return rejection(e);
+ });
+ });
+ }
+
+ function createIndexSpec(name, keyPath, unique, multi, auto, compound, isPrimKey) {
+ return {
+ name: name,
+ keyPath: keyPath,
+ unique: unique,
+ multi: multi,
+ auto: auto,
+ compound: compound,
+ src: (unique && !isPrimKey ? '&' : '') + (multi ? '*' : '') + (auto ? "++" : "") + nameFromKeyPath(keyPath)
+ };
+ }
+ function nameFromKeyPath(keyPath) {
+ return typeof keyPath === 'string' ?
+ keyPath :
+ keyPath ? ('[' + [].join.call(keyPath, '+') + ']') : "";
+ }
+
+ function createTableSchema(name, primKey, indexes) {
+ return {
+ name: name,
+ primKey: primKey,
+ indexes: indexes,
+ mappedClass: null,
+ idxByName: arrayToObject(indexes, function (index) { return [index.name, index]; })
+ };
+ }
+
+ function safariMultiStoreFix(storeNames) {
+ return storeNames.length === 1 ? storeNames[0] : storeNames;
+ }
+ var getMaxKey = function (IdbKeyRange) {
+ try {
+ IdbKeyRange.only([[]]);
+ getMaxKey = function () { return [[]]; };
+ return [[]];
+ }
+ catch (e) {
+ getMaxKey = function () { return maxString; };
+ return maxString;
+ }
+ };
+
+ function getKeyExtractor(keyPath) {
+ if (keyPath == null) {
+ return function () { return undefined; };
+ }
+ else if (typeof keyPath === 'string') {
+ return getSinglePathKeyExtractor(keyPath);
+ }
+ else {
+ return function (obj) { return getByKeyPath(obj, keyPath); };
+ }
+ }
+ function getSinglePathKeyExtractor(keyPath) {
+ var split = keyPath.split('.');
+ if (split.length === 1) {
+ return function (obj) { return obj[keyPath]; };
+ }
+ else {
+ return function (obj) { return getByKeyPath(obj, keyPath); };
+ }
+ }
+
+ function arrayify(arrayLike) {
+ return [].slice.call(arrayLike);
+ }
+ var _id_counter = 0;
+ function getKeyPathAlias(keyPath) {
+ return keyPath == null ?
+ ":id" :
+ typeof keyPath === 'string' ?
+ keyPath :
+ "[".concat(keyPath.join('+'), "]");
+ }
+ function createDBCore(db, IdbKeyRange, tmpTrans) {
+ function extractSchema(db, trans) {
+ var tables = arrayify(db.objectStoreNames);
+ return {
+ schema: {
+ name: db.name,
+ tables: tables.map(function (table) { return trans.objectStore(table); }).map(function (store) {
+ var keyPath = store.keyPath, autoIncrement = store.autoIncrement;
+ var compound = isArray(keyPath);
+ var outbound = keyPath == null;
+ var indexByKeyPath = {};
+ var result = {
+ name: store.name,
+ primaryKey: {
+ name: null,
+ isPrimaryKey: true,
+ outbound: outbound,
+ compound: compound,
+ keyPath: keyPath,
+ autoIncrement: autoIncrement,
+ unique: true,
+ extractKey: getKeyExtractor(keyPath)
+ },
+ indexes: arrayify(store.indexNames).map(function (indexName) { return store.index(indexName); })
+ .map(function (index) {
+ var name = index.name, unique = index.unique, multiEntry = index.multiEntry, keyPath = index.keyPath;
+ var compound = isArray(keyPath);
+ var result = {
+ name: name,
+ compound: compound,
+ keyPath: keyPath,
+ unique: unique,
+ multiEntry: multiEntry,
+ extractKey: getKeyExtractor(keyPath)
+ };
+ indexByKeyPath[getKeyPathAlias(keyPath)] = result;
+ return result;
+ }),
+ getIndexByKeyPath: function (keyPath) { return indexByKeyPath[getKeyPathAlias(keyPath)]; }
+ };
+ indexByKeyPath[":id"] = result.primaryKey;
+ if (keyPath != null) {
+ indexByKeyPath[getKeyPathAlias(keyPath)] = result.primaryKey;
+ }
+ return result;
+ })
+ },
+ hasGetAll: tables.length > 0 && ('getAll' in trans.objectStore(tables[0])) &&
+ !(typeof navigator !== 'undefined' && /Safari/.test(navigator.userAgent) &&
+ !/(Chrome\/|Edge\/)/.test(navigator.userAgent) &&
+ [].concat(navigator.userAgent.match(/Safari\/(\d*)/))[1] < 604)
+ };
+ }
+ function makeIDBKeyRange(range) {
+ if (range.type === 3 )
+ return null;
+ if (range.type === 4 )
+ throw new Error("Cannot convert never type to IDBKeyRange");
+ var lower = range.lower, upper = range.upper, lowerOpen = range.lowerOpen, upperOpen = range.upperOpen;
+ var idbRange = lower === undefined ?
+ upper === undefined ?
+ null :
+ IdbKeyRange.upperBound(upper, !!upperOpen) :
+ upper === undefined ?
+ IdbKeyRange.lowerBound(lower, !!lowerOpen) :
+ IdbKeyRange.bound(lower, upper, !!lowerOpen, !!upperOpen);
+ return idbRange;
+ }
+ function createDbCoreTable(tableSchema) {
+ var tableName = tableSchema.name;
+ function mutate(_a) {
+ var trans = _a.trans, type = _a.type, keys = _a.keys, values = _a.values, range = _a.range;
+ return new Promise(function (resolve, reject) {
+ resolve = wrap(resolve);
+ var store = trans.objectStore(tableName);
+ var outbound = store.keyPath == null;
+ var isAddOrPut = type === "put" || type === "add";
+ if (!isAddOrPut && type !== 'delete' && type !== 'deleteRange')
+ throw new Error("Invalid operation type: " + type);
+ var length = (keys || values || { length: 1 }).length;
+ if (keys && values && keys.length !== values.length) {
+ throw new Error("Given keys array must have same length as given values array.");
+ }
+ if (length === 0)
+ return resolve({ numFailures: 0, failures: {}, results: [], lastResult: undefined });
+ var req;
+ var reqs = [];
+ var failures = [];
+ var numFailures = 0;
+ var errorHandler = function (event) {
+ ++numFailures;
+ preventDefault(event);
+ };
+ if (type === 'deleteRange') {
+ if (range.type === 4 )
+ return resolve({ numFailures: numFailures, failures: failures, results: [], lastResult: undefined });
+ if (range.type === 3 )
+ reqs.push(req = store.clear());
+ else
+ reqs.push(req = store.delete(makeIDBKeyRange(range)));
+ }
+ else {
+ var _a = isAddOrPut ?
+ outbound ?
+ [values, keys] :
+ [values, null] :
+ [keys, null], args1 = _a[0], args2 = _a[1];
+ if (isAddOrPut) {
+ for (var i = 0; i < length; ++i) {
+ reqs.push(req = (args2 && args2[i] !== undefined ?
+ store[type](args1[i], args2[i]) :
+ store[type](args1[i])));
+ req.onerror = errorHandler;
+ }
+ }
+ else {
+ for (var i = 0; i < length; ++i) {
+ reqs.push(req = store[type](args1[i]));
+ req.onerror = errorHandler;
+ }
+ }
+ }
+ var done = function (event) {
+ var lastResult = event.target.result;
+ reqs.forEach(function (req, i) { return req.error != null && (failures[i] = req.error); });
+ resolve({
+ numFailures: numFailures,
+ failures: failures,
+ results: type === "delete" ? keys : reqs.map(function (req) { return req.result; }),
+ lastResult: lastResult
+ });
+ };
+ req.onerror = function (event) {
+ errorHandler(event);
+ done(event);
+ };
+ req.onsuccess = done;
+ });
+ }
+ function openCursor(_a) {
+ var trans = _a.trans, values = _a.values, query = _a.query, reverse = _a.reverse, unique = _a.unique;
+ return new Promise(function (resolve, reject) {
+ resolve = wrap(resolve);
+ var index = query.index, range = query.range;
+ var store = trans.objectStore(tableName);
+ var source = index.isPrimaryKey ?
+ store :
+ store.index(index.name);
+ var direction = reverse ?
+ unique ?
+ "prevunique" :
+ "prev" :
+ unique ?
+ "nextunique" :
+ "next";
+ var req = values || !('openKeyCursor' in source) ?
+ source.openCursor(makeIDBKeyRange(range), direction) :
+ source.openKeyCursor(makeIDBKeyRange(range), direction);
+ req.onerror = eventRejectHandler(reject);
+ req.onsuccess = wrap(function (ev) {
+ var cursor = req.result;
+ if (!cursor) {
+ resolve(null);
+ return;
+ }
+ cursor.___id = ++_id_counter;
+ cursor.done = false;
+ var _cursorContinue = cursor.continue.bind(cursor);
+ var _cursorContinuePrimaryKey = cursor.continuePrimaryKey;
+ if (_cursorContinuePrimaryKey)
+ _cursorContinuePrimaryKey = _cursorContinuePrimaryKey.bind(cursor);
+ var _cursorAdvance = cursor.advance.bind(cursor);
+ var doThrowCursorIsNotStarted = function () { throw new Error("Cursor not started"); };
+ var doThrowCursorIsStopped = function () { throw new Error("Cursor not stopped"); };
+ cursor.trans = trans;
+ cursor.stop = cursor.continue = cursor.continuePrimaryKey = cursor.advance = doThrowCursorIsNotStarted;
+ cursor.fail = wrap(reject);
+ cursor.next = function () {
+ var _this = this;
+ var gotOne = 1;
+ return this.start(function () { return gotOne-- ? _this.continue() : _this.stop(); }).then(function () { return _this; });
+ };
+ cursor.start = function (callback) {
+ var iterationPromise = new Promise(function (resolveIteration, rejectIteration) {
+ resolveIteration = wrap(resolveIteration);
+ req.onerror = eventRejectHandler(rejectIteration);
+ cursor.fail = rejectIteration;
+ cursor.stop = function (value) {
+ cursor.stop = cursor.continue = cursor.continuePrimaryKey = cursor.advance = doThrowCursorIsStopped;
+ resolveIteration(value);
+ };
+ });
+ var guardedCallback = function () {
+ if (req.result) {
+ try {
+ callback();
+ }
+ catch (err) {
+ cursor.fail(err);
+ }
+ }
+ else {
+ cursor.done = true;
+ cursor.start = function () { throw new Error("Cursor behind last entry"); };
+ cursor.stop();
+ }
+ };
+ req.onsuccess = wrap(function (ev) {
+ req.onsuccess = guardedCallback;
+ guardedCallback();
+ });
+ cursor.continue = _cursorContinue;
+ cursor.continuePrimaryKey = _cursorContinuePrimaryKey;
+ cursor.advance = _cursorAdvance;
+ guardedCallback();
+ return iterationPromise;
+ };
+ resolve(cursor);
+ }, reject);
+ });
+ }
+ function query(hasGetAll) {
+ return function (request) {
+ return new Promise(function (resolve, reject) {
+ resolve = wrap(resolve);
+ var trans = request.trans, values = request.values, limit = request.limit, query = request.query;
+ var nonInfinitLimit = limit === Infinity ? undefined : limit;
+ var index = query.index, range = query.range;
+ var store = trans.objectStore(tableName);
+ var source = index.isPrimaryKey ? store : store.index(index.name);
+ var idbKeyRange = makeIDBKeyRange(range);
+ if (limit === 0)
+ return resolve({ result: [] });
+ if (hasGetAll) {
+ var req = values ?
+ source.getAll(idbKeyRange, nonInfinitLimit) :
+ source.getAllKeys(idbKeyRange, nonInfinitLimit);
+ req.onsuccess = function (event) { return resolve({ result: event.target.result }); };
+ req.onerror = eventRejectHandler(reject);
+ }
+ else {
+ var count_1 = 0;
+ var req_1 = values || !('openKeyCursor' in source) ?
+ source.openCursor(idbKeyRange) :
+ source.openKeyCursor(idbKeyRange);
+ var result_1 = [];
+ req_1.onsuccess = function (event) {
+ var cursor = req_1.result;
+ if (!cursor)
+ return resolve({ result: result_1 });
+ result_1.push(values ? cursor.value : cursor.primaryKey);
+ if (++count_1 === limit)
+ return resolve({ result: result_1 });
+ cursor.continue();
+ };
+ req_1.onerror = eventRejectHandler(reject);
+ }
+ });
+ };
+ }
+ return {
+ name: tableName,
+ schema: tableSchema,
+ mutate: mutate,
+ getMany: function (_a) {
+ var trans = _a.trans, keys = _a.keys;
+ return new Promise(function (resolve, reject) {
+ resolve = wrap(resolve);
+ var store = trans.objectStore(tableName);
+ var length = keys.length;
+ var result = new Array(length);
+ var keyCount = 0;
+ var callbackCount = 0;
+ var req;
+ var successHandler = function (event) {
+ var req = event.target;
+ if ((result[req._pos] = req.result) != null)
+ ;
+ if (++callbackCount === keyCount)
+ resolve(result);
+ };
+ var errorHandler = eventRejectHandler(reject);
+ for (var i = 0; i < length; ++i) {
+ var key = keys[i];
+ if (key != null) {
+ req = store.get(keys[i]);
+ req._pos = i;
+ req.onsuccess = successHandler;
+ req.onerror = errorHandler;
+ ++keyCount;
+ }
+ }
+ if (keyCount === 0)
+ resolve(result);
+ });
+ },
+ get: function (_a) {
+ var trans = _a.trans, key = _a.key;
+ return new Promise(function (resolve, reject) {
+ resolve = wrap(resolve);
+ var store = trans.objectStore(tableName);
+ var req = store.get(key);
+ req.onsuccess = function (event) { return resolve(event.target.result); };
+ req.onerror = eventRejectHandler(reject);
+ });
+ },
+ query: query(hasGetAll),
+ openCursor: openCursor,
+ count: function (_a) {
+ var query = _a.query, trans = _a.trans;
+ var index = query.index, range = query.range;
+ return new Promise(function (resolve, reject) {
+ var store = trans.objectStore(tableName);
+ var source = index.isPrimaryKey ? store : store.index(index.name);
+ var idbKeyRange = makeIDBKeyRange(range);
+ var req = idbKeyRange ? source.count(idbKeyRange) : source.count();
+ req.onsuccess = wrap(function (ev) { return resolve(ev.target.result); });
+ req.onerror = eventRejectHandler(reject);
+ });
+ }
+ };
+ }
+ var _a = extractSchema(db, tmpTrans), schema = _a.schema, hasGetAll = _a.hasGetAll;
+ var tables = schema.tables.map(function (tableSchema) { return createDbCoreTable(tableSchema); });
+ var tableMap = {};
+ tables.forEach(function (table) { return tableMap[table.name] = table; });
+ return {
+ stack: "dbcore",
+ transaction: db.transaction.bind(db),
+ table: function (name) {
+ var result = tableMap[name];
+ if (!result)
+ throw new Error("Table '".concat(name, "' not found"));
+ return tableMap[name];
+ },
+ MIN_KEY: -Infinity,
+ MAX_KEY: getMaxKey(IdbKeyRange),
+ schema: schema
+ };
+ }
+
+ function createMiddlewareStack(stackImpl, middlewares) {
+ return middlewares.reduce(function (down, _a) {
+ var create = _a.create;
+ return (__assign(__assign({}, down), create(down)));
+ }, stackImpl);
+ }
+ function createMiddlewareStacks(middlewares, idbdb, _a, tmpTrans) {
+ var IDBKeyRange = _a.IDBKeyRange; _a.indexedDB;
+ var dbcore = createMiddlewareStack(createDBCore(idbdb, IDBKeyRange, tmpTrans), middlewares.dbcore);
+ return {
+ dbcore: dbcore
+ };
+ }
+ function generateMiddlewareStacks(_a, tmpTrans) {
+ var db = _a._novip;
+ var idbdb = tmpTrans.db;
+ var stacks = createMiddlewareStacks(db._middlewares, idbdb, db._deps, tmpTrans);
+ db.core = stacks.dbcore;
+ db.tables.forEach(function (table) {
+ var tableName = table.name;
+ if (db.core.schema.tables.some(function (tbl) { return tbl.name === tableName; })) {
+ table.core = db.core.table(tableName);
+ if (db[tableName] instanceof db.Table) {
+ db[tableName].core = table.core;
+ }
+ }
+ });
+ }
+
+ function setApiOnPlace(_a, objs, tableNames, dbschema) {
+ var db = _a._novip;
+ tableNames.forEach(function (tableName) {
+ var schema = dbschema[tableName];
+ objs.forEach(function (obj) {
+ var propDesc = getPropertyDescriptor(obj, tableName);
+ if (!propDesc || ("value" in propDesc && propDesc.value === undefined)) {
+ if (obj === db.Transaction.prototype || obj instanceof db.Transaction) {
+ setProp(obj, tableName, {
+ get: function () { return this.table(tableName); },
+ set: function (value) {
+ defineProperty(this, tableName, { value: value, writable: true, configurable: true, enumerable: true });
+ }
+ });
+ }
+ else {
+ obj[tableName] = new db.Table(tableName, schema);
+ }
+ }
+ });
+ });
+ }
+ function removeTablesApi(_a, objs) {
+ var db = _a._novip;
+ objs.forEach(function (obj) {
+ for (var key in obj) {
+ if (obj[key] instanceof db.Table)
+ delete obj[key];
+ }
+ });
+ }
+ function lowerVersionFirst(a, b) {
+ return a._cfg.version - b._cfg.version;
+ }
+ function runUpgraders(db, oldVersion, idbUpgradeTrans, reject) {
+ var globalSchema = db._dbSchema;
+ var trans = db._createTransaction('readwrite', db._storeNames, globalSchema);
+ trans.create(idbUpgradeTrans);
+ trans._completion.catch(reject);
+ var rejectTransaction = trans._reject.bind(trans);
+ var transless = PSD.transless || PSD;
+ newScope(function () {
+ PSD.trans = trans;
+ PSD.transless = transless;
+ if (oldVersion === 0) {
+ keys(globalSchema).forEach(function (tableName) {
+ createTable(idbUpgradeTrans, tableName, globalSchema[tableName].primKey, globalSchema[tableName].indexes);
+ });
+ generateMiddlewareStacks(db, idbUpgradeTrans);
+ DexiePromise.follow(function () { return db.on.populate.fire(trans); }).catch(rejectTransaction);
+ }
+ else
+ updateTablesAndIndexes(db, oldVersion, trans, idbUpgradeTrans).catch(rejectTransaction);
+ });
+ }
+ function updateTablesAndIndexes(_a, oldVersion, trans, idbUpgradeTrans) {
+ var db = _a._novip;
+ var queue = [];
+ var versions = db._versions;
+ var globalSchema = db._dbSchema = buildGlobalSchema(db, db.idbdb, idbUpgradeTrans);
+ var anyContentUpgraderHasRun = false;
+ var versToRun = versions.filter(function (v) { return v._cfg.version >= oldVersion; });
+ versToRun.forEach(function (version) {
+ queue.push(function () {
+ var oldSchema = globalSchema;
+ var newSchema = version._cfg.dbschema;
+ adjustToExistingIndexNames(db, oldSchema, idbUpgradeTrans);
+ adjustToExistingIndexNames(db, newSchema, idbUpgradeTrans);
+ globalSchema = db._dbSchema = newSchema;
+ var diff = getSchemaDiff(oldSchema, newSchema);
+ diff.add.forEach(function (tuple) {
+ createTable(idbUpgradeTrans, tuple[0], tuple[1].primKey, tuple[1].indexes);
+ });
+ diff.change.forEach(function (change) {
+ if (change.recreate) {
+ throw new exceptions.Upgrade("Not yet support for changing primary key");
+ }
+ else {
+ var store_1 = idbUpgradeTrans.objectStore(change.name);
+ change.add.forEach(function (idx) { return addIndex(store_1, idx); });
+ change.change.forEach(function (idx) {
+ store_1.deleteIndex(idx.name);
+ addIndex(store_1, idx);
+ });
+ change.del.forEach(function (idxName) { return store_1.deleteIndex(idxName); });
+ }
+ });
+ var contentUpgrade = version._cfg.contentUpgrade;
+ if (contentUpgrade && version._cfg.version > oldVersion) {
+ generateMiddlewareStacks(db, idbUpgradeTrans);
+ trans._memoizedTables = {};
+ anyContentUpgraderHasRun = true;
+ var upgradeSchema_1 = shallowClone(newSchema);
+ diff.del.forEach(function (table) {
+ upgradeSchema_1[table] = oldSchema[table];
+ });
+ removeTablesApi(db, [db.Transaction.prototype]);
+ setApiOnPlace(db, [db.Transaction.prototype], keys(upgradeSchema_1), upgradeSchema_1);
+ trans.schema = upgradeSchema_1;
+ var contentUpgradeIsAsync_1 = isAsyncFunction(contentUpgrade);
+ if (contentUpgradeIsAsync_1) {
+ incrementExpectedAwaits();
+ }
+ var returnValue_1;
+ var promiseFollowed = DexiePromise.follow(function () {
+ returnValue_1 = contentUpgrade(trans);
+ if (returnValue_1) {
+ if (contentUpgradeIsAsync_1) {
+ var decrementor = decrementExpectedAwaits.bind(null, null);
+ returnValue_1.then(decrementor, decrementor);
+ }
+ }
+ });
+ return (returnValue_1 && typeof returnValue_1.then === 'function' ?
+ DexiePromise.resolve(returnValue_1) : promiseFollowed.then(function () { return returnValue_1; }));
+ }
+ });
+ queue.push(function (idbtrans) {
+ if (!anyContentUpgraderHasRun || !hasIEDeleteObjectStoreBug) {
+ var newSchema = version._cfg.dbschema;
+ deleteRemovedTables(newSchema, idbtrans);
+ }
+ removeTablesApi(db, [db.Transaction.prototype]);
+ setApiOnPlace(db, [db.Transaction.prototype], db._storeNames, db._dbSchema);
+ trans.schema = db._dbSchema;
+ });
+ });
+ function runQueue() {
+ return queue.length ? DexiePromise.resolve(queue.shift()(trans.idbtrans)).then(runQueue) :
+ DexiePromise.resolve();
+ }
+ return runQueue().then(function () {
+ createMissingTables(globalSchema, idbUpgradeTrans);
+ });
+ }
+ function getSchemaDiff(oldSchema, newSchema) {
+ var diff = {
+ del: [],
+ add: [],
+ change: []
+ };
+ var table;
+ for (table in oldSchema) {
+ if (!newSchema[table])
+ diff.del.push(table);
+ }
+ for (table in newSchema) {
+ var oldDef = oldSchema[table], newDef = newSchema[table];
+ if (!oldDef) {
+ diff.add.push([table, newDef]);
+ }
+ else {
+ var change = {
+ name: table,
+ def: newDef,
+ recreate: false,
+ del: [],
+ add: [],
+ change: []
+ };
+ if ((
+ '' + (oldDef.primKey.keyPath || '')) !== ('' + (newDef.primKey.keyPath || '')) ||
+ (oldDef.primKey.auto !== newDef.primKey.auto && !isIEOrEdge))
+ {
+ change.recreate = true;
+ diff.change.push(change);
+ }
+ else {
+ var oldIndexes = oldDef.idxByName;
+ var newIndexes = newDef.idxByName;
+ var idxName = void 0;
+ for (idxName in oldIndexes) {
+ if (!newIndexes[idxName])
+ change.del.push(idxName);
+ }
+ for (idxName in newIndexes) {
+ var oldIdx = oldIndexes[idxName], newIdx = newIndexes[idxName];
+ if (!oldIdx)
+ change.add.push(newIdx);
+ else if (oldIdx.src !== newIdx.src)
+ change.change.push(newIdx);
+ }
+ if (change.del.length > 0 || change.add.length > 0 || change.change.length > 0) {
+ diff.change.push(change);
+ }
+ }
+ }
+ }
+ return diff;
+ }
+ function createTable(idbtrans, tableName, primKey, indexes) {
+ var store = idbtrans.db.createObjectStore(tableName, primKey.keyPath ?
+ { keyPath: primKey.keyPath, autoIncrement: primKey.auto } :
+ { autoIncrement: primKey.auto });
+ indexes.forEach(function (idx) { return addIndex(store, idx); });
+ return store;
+ }
+ function createMissingTables(newSchema, idbtrans) {
+ keys(newSchema).forEach(function (tableName) {
+ if (!idbtrans.db.objectStoreNames.contains(tableName)) {
+ createTable(idbtrans, tableName, newSchema[tableName].primKey, newSchema[tableName].indexes);
+ }
+ });
+ }
+ function deleteRemovedTables(newSchema, idbtrans) {
+ [].slice.call(idbtrans.db.objectStoreNames).forEach(function (storeName) {
+ return newSchema[storeName] == null && idbtrans.db.deleteObjectStore(storeName);
+ });
+ }
+ function addIndex(store, idx) {
+ store.createIndex(idx.name, idx.keyPath, { unique: idx.unique, multiEntry: idx.multi });
+ }
+ function buildGlobalSchema(db, idbdb, tmpTrans) {
+ var globalSchema = {};
+ var dbStoreNames = slice(idbdb.objectStoreNames, 0);
+ dbStoreNames.forEach(function (storeName) {
+ var store = tmpTrans.objectStore(storeName);
+ var keyPath = store.keyPath;
+ var primKey = createIndexSpec(nameFromKeyPath(keyPath), keyPath || "", false, false, !!store.autoIncrement, keyPath && typeof keyPath !== "string", true);
+ var indexes = [];
+ for (var j = 0; j < store.indexNames.length; ++j) {
+ var idbindex = store.index(store.indexNames[j]);
+ keyPath = idbindex.keyPath;
+ var index = createIndexSpec(idbindex.name, keyPath, !!idbindex.unique, !!idbindex.multiEntry, false, keyPath && typeof keyPath !== "string", false);
+ indexes.push(index);
+ }
+ globalSchema[storeName] = createTableSchema(storeName, primKey, indexes);
+ });
+ return globalSchema;
+ }
+ function readGlobalSchema(_a, idbdb, tmpTrans) {
+ var db = _a._novip;
+ db.verno = idbdb.version / 10;
+ var globalSchema = db._dbSchema = buildGlobalSchema(db, idbdb, tmpTrans);
+ db._storeNames = slice(idbdb.objectStoreNames, 0);
+ setApiOnPlace(db, [db._allTables], keys(globalSchema), globalSchema);
+ }
+ function verifyInstalledSchema(db, tmpTrans) {
+ var installedSchema = buildGlobalSchema(db, db.idbdb, tmpTrans);
+ var diff = getSchemaDiff(installedSchema, db._dbSchema);
+ return !(diff.add.length || diff.change.some(function (ch) { return ch.add.length || ch.change.length; }));
+ }
+ function adjustToExistingIndexNames(_a, schema, idbtrans) {
+ var db = _a._novip;
+ var storeNames = idbtrans.db.objectStoreNames;
+ for (var i = 0; i < storeNames.length; ++i) {
+ var storeName = storeNames[i];
+ var store = idbtrans.objectStore(storeName);
+ db._hasGetAll = 'getAll' in store;
+ for (var j = 0; j < store.indexNames.length; ++j) {
+ var indexName = store.indexNames[j];
+ var keyPath = store.index(indexName).keyPath;
+ var dexieName = typeof keyPath === 'string' ? keyPath : "[" + slice(keyPath).join('+') + "]";
+ if (schema[storeName]) {
+ var indexSpec = schema[storeName].idxByName[dexieName];
+ if (indexSpec) {
+ indexSpec.name = indexName;
+ delete schema[storeName].idxByName[dexieName];
+ schema[storeName].idxByName[indexName] = indexSpec;
+ }
+ }
+ }
+ }
+ if (typeof navigator !== 'undefined' && /Safari/.test(navigator.userAgent) &&
+ !/(Chrome\/|Edge\/)/.test(navigator.userAgent) &&
+ _global.WorkerGlobalScope && _global instanceof _global.WorkerGlobalScope &&
+ [].concat(navigator.userAgent.match(/Safari\/(\d*)/))[1] < 604) {
+ db._hasGetAll = false;
+ }
+ }
+ function parseIndexSyntax(primKeyAndIndexes) {
+ return primKeyAndIndexes.split(',').map(function (index, indexNum) {
+ index = index.trim();
+ var name = index.replace(/([&*]|\+\+)/g, "");
+ var keyPath = /^\[/.test(name) ? name.match(/^\[(.*)\]$/)[1].split('+') : name;
+ return createIndexSpec(name, keyPath || null, /\&/.test(index), /\*/.test(index), /\+\+/.test(index), isArray(keyPath), indexNum === 0);
+ });
+ }
+
+ var Version = (function () {
+ function Version() {
+ }
+ Version.prototype._parseStoresSpec = function (stores, outSchema) {
+ keys(stores).forEach(function (tableName) {
+ if (stores[tableName] !== null) {
+ var indexes = parseIndexSyntax(stores[tableName]);
+ var primKey = indexes.shift();
+ if (primKey.multi)
+ throw new exceptions.Schema("Primary key cannot be multi-valued");
+ indexes.forEach(function (idx) {
+ if (idx.auto)
+ throw new exceptions.Schema("Only primary key can be marked as autoIncrement (++)");
+ if (!idx.keyPath)
+ throw new exceptions.Schema("Index must have a name and cannot be an empty string");
+ });
+ outSchema[tableName] = createTableSchema(tableName, primKey, indexes);
+ }
+ });
+ };
+ Version.prototype.stores = function (stores) {
+ var db = this.db;
+ this._cfg.storesSource = this._cfg.storesSource ?
+ extend(this._cfg.storesSource, stores) :
+ stores;
+ var versions = db._versions;
+ var storesSpec = {};
+ var dbschema = {};
+ versions.forEach(function (version) {
+ extend(storesSpec, version._cfg.storesSource);
+ dbschema = (version._cfg.dbschema = {});
+ version._parseStoresSpec(storesSpec, dbschema);
+ });
+ db._dbSchema = dbschema;
+ removeTablesApi(db, [db._allTables, db, db.Transaction.prototype]);
+ setApiOnPlace(db, [db._allTables, db, db.Transaction.prototype, this._cfg.tables], keys(dbschema), dbschema);
+ db._storeNames = keys(dbschema);
+ return this;
+ };
+ Version.prototype.upgrade = function (upgradeFunction) {
+ this._cfg.contentUpgrade = promisableChain(this._cfg.contentUpgrade || nop, upgradeFunction);
+ return this;
+ };
+ return Version;
+ }());
+
+ function createVersionConstructor(db) {
+ return makeClassConstructor(Version.prototype, function Version(versionNumber) {
+ this.db = db;
+ this._cfg = {
+ version: versionNumber,
+ storesSource: null,
+ dbschema: {},
+ tables: {},
+ contentUpgrade: null
+ };
+ });
+ }
+
+ function getDbNamesTable(indexedDB, IDBKeyRange) {
+ var dbNamesDB = indexedDB["_dbNamesDB"];
+ if (!dbNamesDB) {
+ dbNamesDB = indexedDB["_dbNamesDB"] = new Dexie$1(DBNAMES_DB, {
+ addons: [],
+ indexedDB: indexedDB,
+ IDBKeyRange: IDBKeyRange,
+ });
+ dbNamesDB.version(1).stores({ dbnames: "name" });
+ }
+ return dbNamesDB.table("dbnames");
+ }
+ function hasDatabasesNative(indexedDB) {
+ return indexedDB && typeof indexedDB.databases === "function";
+ }
+ function getDatabaseNames(_a) {
+ var indexedDB = _a.indexedDB, IDBKeyRange = _a.IDBKeyRange;
+ return hasDatabasesNative(indexedDB)
+ ? Promise.resolve(indexedDB.databases()).then(function (infos) {
+ return infos
+ .map(function (info) { return info.name; })
+ .filter(function (name) { return name !== DBNAMES_DB; });
+ })
+ : getDbNamesTable(indexedDB, IDBKeyRange).toCollection().primaryKeys();
+ }
+ function _onDatabaseCreated(_a, name) {
+ var indexedDB = _a.indexedDB, IDBKeyRange = _a.IDBKeyRange;
+ !hasDatabasesNative(indexedDB) &&
+ name !== DBNAMES_DB &&
+ getDbNamesTable(indexedDB, IDBKeyRange).put({ name: name }).catch(nop);
+ }
+ function _onDatabaseDeleted(_a, name) {
+ var indexedDB = _a.indexedDB, IDBKeyRange = _a.IDBKeyRange;
+ !hasDatabasesNative(indexedDB) &&
+ name !== DBNAMES_DB &&
+ getDbNamesTable(indexedDB, IDBKeyRange).delete(name).catch(nop);
+ }
+
+ function vip(fn) {
+ return newScope(function () {
+ PSD.letThrough = true;
+ return fn();
+ });
+ }
+
+ function idbReady() {
+ var isSafari = !navigator.userAgentData &&
+ /Safari\//.test(navigator.userAgent) &&
+ !/Chrom(e|ium)\//.test(navigator.userAgent);
+ if (!isSafari || !indexedDB.databases)
+ return Promise.resolve();
+ var intervalId;
+ return new Promise(function (resolve) {
+ var tryIdb = function () { return indexedDB.databases().finally(resolve); };
+ intervalId = setInterval(tryIdb, 100);
+ tryIdb();
+ }).finally(function () { return clearInterval(intervalId); });
+ }
+
+ function dexieOpen(db) {
+ var state = db._state;
+ var indexedDB = db._deps.indexedDB;
+ if (state.isBeingOpened || db.idbdb)
+ return state.dbReadyPromise.then(function () { return state.dbOpenError ?
+ rejection(state.dbOpenError) :
+ db; });
+ debug && (state.openCanceller._stackHolder = getErrorWithStack());
+ state.isBeingOpened = true;
+ state.dbOpenError = null;
+ state.openComplete = false;
+ var openCanceller = state.openCanceller;
+ function throwIfCancelled() {
+ if (state.openCanceller !== openCanceller)
+ throw new exceptions.DatabaseClosed('db.open() was cancelled');
+ }
+ var resolveDbReady = state.dbReadyResolve,
+ upgradeTransaction = null, wasCreated = false;
+ return DexiePromise.race([openCanceller, (typeof navigator === 'undefined' ? DexiePromise.resolve() : idbReady()).then(function () { return new DexiePromise(function (resolve, reject) {
+ throwIfCancelled();
+ if (!indexedDB)
+ throw new exceptions.MissingAPI();
+ var dbName = db.name;
+ var req = state.autoSchema ?
+ indexedDB.open(dbName) :
+ indexedDB.open(dbName, Math.round(db.verno * 10));
+ if (!req)
+ throw new exceptions.MissingAPI();
+ req.onerror = eventRejectHandler(reject);
+ req.onblocked = wrap(db._fireOnBlocked);
+ req.onupgradeneeded = wrap(function (e) {
+ upgradeTransaction = req.transaction;
+ if (state.autoSchema && !db._options.allowEmptyDB) {
+ req.onerror = preventDefault;
+ upgradeTransaction.abort();
+ req.result.close();
+ var delreq = indexedDB.deleteDatabase(dbName);
+ delreq.onsuccess = delreq.onerror = wrap(function () {
+ reject(new exceptions.NoSuchDatabase("Database ".concat(dbName, " doesnt exist")));
+ });
+ }
+ else {
+ upgradeTransaction.onerror = eventRejectHandler(reject);
+ var oldVer = e.oldVersion > Math.pow(2, 62) ? 0 : e.oldVersion;
+ wasCreated = oldVer < 1;
+ db._novip.idbdb = req.result;
+ runUpgraders(db, oldVer / 10, upgradeTransaction, reject);
+ }
+ }, reject);
+ req.onsuccess = wrap(function () {
+ upgradeTransaction = null;
+ var idbdb = db._novip.idbdb = req.result;
+ var objectStoreNames = slice(idbdb.objectStoreNames);
+ if (objectStoreNames.length > 0)
+ try {
+ var tmpTrans = idbdb.transaction(safariMultiStoreFix(objectStoreNames), 'readonly');
+ if (state.autoSchema)
+ readGlobalSchema(db, idbdb, tmpTrans);
+ else {
+ adjustToExistingIndexNames(db, db._dbSchema, tmpTrans);
+ if (!verifyInstalledSchema(db, tmpTrans)) {
+ console.warn("Dexie SchemaDiff: Schema was extended without increasing the number passed to db.version(). Some queries may fail.");
+ }
+ }
+ generateMiddlewareStacks(db, tmpTrans);
+ }
+ catch (e) {
+ }
+ connections.push(db);
+ idbdb.onversionchange = wrap(function (ev) {
+ state.vcFired = true;
+ db.on("versionchange").fire(ev);
+ });
+ idbdb.onclose = wrap(function (ev) {
+ db.on("close").fire(ev);
+ });
+ if (wasCreated)
+ _onDatabaseCreated(db._deps, dbName);
+ resolve();
+ }, reject);
+ }); })]).then(function () {
+ throwIfCancelled();
+ state.onReadyBeingFired = [];
+ return DexiePromise.resolve(vip(function () { return db.on.ready.fire(db.vip); })).then(function fireRemainders() {
+ if (state.onReadyBeingFired.length > 0) {
+ var remainders_1 = state.onReadyBeingFired.reduce(promisableChain, nop);
+ state.onReadyBeingFired = [];
+ return DexiePromise.resolve(vip(function () { return remainders_1(db.vip); })).then(fireRemainders);
+ }
+ });
+ }).finally(function () {
+ state.onReadyBeingFired = null;
+ state.isBeingOpened = false;
+ }).then(function () {
+ return db;
+ }).catch(function (err) {
+ state.dbOpenError = err;
+ try {
+ upgradeTransaction && upgradeTransaction.abort();
+ }
+ catch (_a) { }
+ if (openCanceller === state.openCanceller) {
+ db._close();
+ }
+ return rejection(err);
+ }).finally(function () {
+ state.openComplete = true;
+ resolveDbReady();
+ });
+ }
+
+ function awaitIterator(iterator) {
+ var callNext = function (result) { return iterator.next(result); }, doThrow = function (error) { return iterator.throw(error); }, onSuccess = step(callNext), onError = step(doThrow);
+ function step(getNext) {
+ return function (val) {
+ var next = getNext(val), value = next.value;
+ return next.done ? value :
+ (!value || typeof value.then !== 'function' ?
+ isArray(value) ? Promise.all(value).then(onSuccess, onError) : onSuccess(value) :
+ value.then(onSuccess, onError));
+ };
+ }
+ return step(callNext)();
+ }
+
+ function extractTransactionArgs(mode, _tableArgs_, scopeFunc) {
+ var i = arguments.length;
+ if (i < 2)
+ throw new exceptions.InvalidArgument("Too few arguments");
+ var args = new Array(i - 1);
+ while (--i)
+ args[i - 1] = arguments[i];
+ scopeFunc = args.pop();
+ var tables = flatten(args);
+ return [mode, tables, scopeFunc];
+ }
+ function enterTransactionScope(db, mode, storeNames, parentTransaction, scopeFunc) {
+ return DexiePromise.resolve().then(function () {
+ var transless = PSD.transless || PSD;
+ var trans = db._createTransaction(mode, storeNames, db._dbSchema, parentTransaction);
+ trans.explicit = true;
+ var zoneProps = {
+ trans: trans,
+ transless: transless
+ };
+ if (parentTransaction) {
+ trans.idbtrans = parentTransaction.idbtrans;
+ }
+ else {
+ try {
+ trans.create();
+ db._state.PR1398_maxLoop = 3;
+ }
+ catch (ex) {
+ if (ex.name === errnames.InvalidState && db.isOpen() && --db._state.PR1398_maxLoop > 0) {
+ console.warn('Dexie: Need to reopen db');
+ db._close();
+ return db.open().then(function () { return enterTransactionScope(db, mode, storeNames, null, scopeFunc); });
+ }
+ return rejection(ex);
+ }
+ }
+ var scopeFuncIsAsync = isAsyncFunction(scopeFunc);
+ if (scopeFuncIsAsync) {
+ incrementExpectedAwaits();
+ }
+ var returnValue;
+ var promiseFollowed = DexiePromise.follow(function () {
+ returnValue = scopeFunc.call(trans, trans);
+ if (returnValue) {
+ if (scopeFuncIsAsync) {
+ var decrementor = decrementExpectedAwaits.bind(null, null);
+ returnValue.then(decrementor, decrementor);
+ }
+ else if (typeof returnValue.next === 'function' && typeof returnValue.throw === 'function') {
+ returnValue = awaitIterator(returnValue);
+ }
+ }
+ }, zoneProps);
+ return (returnValue && typeof returnValue.then === 'function' ?
+ DexiePromise.resolve(returnValue).then(function (x) { return trans.active ?
+ x
+ : rejection(new exceptions.PrematureCommit("Transaction committed too early. See http://bit.ly/2kdckMn")); })
+ : promiseFollowed.then(function () { return returnValue; })).then(function (x) {
+ if (parentTransaction)
+ trans._resolve();
+ return trans._completion.then(function () { return x; });
+ }).catch(function (e) {
+ trans._reject(e);
+ return rejection(e);
+ });
+ });
+ }
+
+ function pad(a, value, count) {
+ var result = isArray(a) ? a.slice() : [a];
+ for (var i = 0; i < count; ++i)
+ result.push(value);
+ return result;
+ }
+ function createVirtualIndexMiddleware(down) {
+ return __assign(__assign({}, down), { table: function (tableName) {
+ var table = down.table(tableName);
+ var schema = table.schema;
+ var indexLookup = {};
+ var allVirtualIndexes = [];
+ function addVirtualIndexes(keyPath, keyTail, lowLevelIndex) {
+ var keyPathAlias = getKeyPathAlias(keyPath);
+ var indexList = (indexLookup[keyPathAlias] = indexLookup[keyPathAlias] || []);
+ var keyLength = keyPath == null ? 0 : typeof keyPath === 'string' ? 1 : keyPath.length;
+ var isVirtual = keyTail > 0;
+ var virtualIndex = __assign(__assign({}, lowLevelIndex), { isVirtual: isVirtual, keyTail: keyTail, keyLength: keyLength, extractKey: getKeyExtractor(keyPath), unique: !isVirtual && lowLevelIndex.unique });
+ indexList.push(virtualIndex);
+ if (!virtualIndex.isPrimaryKey) {
+ allVirtualIndexes.push(virtualIndex);
+ }
+ if (keyLength > 1) {
+ var virtualKeyPath = keyLength === 2 ?
+ keyPath[0] :
+ keyPath.slice(0, keyLength - 1);
+ addVirtualIndexes(virtualKeyPath, keyTail + 1, lowLevelIndex);
+ }
+ indexList.sort(function (a, b) { return a.keyTail - b.keyTail; });
+ return virtualIndex;
+ }
+ var primaryKey = addVirtualIndexes(schema.primaryKey.keyPath, 0, schema.primaryKey);
+ indexLookup[":id"] = [primaryKey];
+ for (var _i = 0, _a = schema.indexes; _i < _a.length; _i++) {
+ var index = _a[_i];
+ addVirtualIndexes(index.keyPath, 0, index);
+ }
+ function findBestIndex(keyPath) {
+ var result = indexLookup[getKeyPathAlias(keyPath)];
+ return result && result[0];
+ }
+ function translateRange(range, keyTail) {
+ return {
+ type: range.type === 1 ?
+ 2 :
+ range.type,
+ lower: pad(range.lower, range.lowerOpen ? down.MAX_KEY : down.MIN_KEY, keyTail),
+ lowerOpen: true,
+ upper: pad(range.upper, range.upperOpen ? down.MIN_KEY : down.MAX_KEY, keyTail),
+ upperOpen: true
+ };
+ }
+ function translateRequest(req) {
+ var index = req.query.index;
+ return index.isVirtual ? __assign(__assign({}, req), { query: {
+ index: index,
+ range: translateRange(req.query.range, index.keyTail)
+ } }) : req;
+ }
+ var result = __assign(__assign({}, table), { schema: __assign(__assign({}, schema), { primaryKey: primaryKey, indexes: allVirtualIndexes, getIndexByKeyPath: findBestIndex }), count: function (req) {
+ return table.count(translateRequest(req));
+ }, query: function (req) {
+ return table.query(translateRequest(req));
+ }, openCursor: function (req) {
+ var _a = req.query.index, keyTail = _a.keyTail, isVirtual = _a.isVirtual, keyLength = _a.keyLength;
+ if (!isVirtual)
+ return table.openCursor(req);
+ function createVirtualCursor(cursor) {
+ function _continue(key) {
+ key != null ?
+ cursor.continue(pad(key, req.reverse ? down.MAX_KEY : down.MIN_KEY, keyTail)) :
+ req.unique ?
+ cursor.continue(cursor.key.slice(0, keyLength)
+ .concat(req.reverse
+ ? down.MIN_KEY
+ : down.MAX_KEY, keyTail)) :
+ cursor.continue();
+ }
+ var virtualCursor = Object.create(cursor, {
+ continue: { value: _continue },
+ continuePrimaryKey: {
+ value: function (key, primaryKey) {
+ cursor.continuePrimaryKey(pad(key, down.MAX_KEY, keyTail), primaryKey);
+ }
+ },
+ primaryKey: {
+ get: function () {
+ return cursor.primaryKey;
+ }
+ },
+ key: {
+ get: function () {
+ var key = cursor.key;
+ return keyLength === 1 ?
+ key[0] :
+ key.slice(0, keyLength);
+ }
+ },
+ value: {
+ get: function () {
+ return cursor.value;
+ }
+ }
+ });
+ return virtualCursor;
+ }
+ return table.openCursor(translateRequest(req))
+ .then(function (cursor) { return cursor && createVirtualCursor(cursor); });
+ } });
+ return result;
+ } });
+ }
+ var virtualIndexMiddleware = {
+ stack: "dbcore",
+ name: "VirtualIndexMiddleware",
+ level: 1,
+ create: createVirtualIndexMiddleware
+ };
+
+ function getObjectDiff(a, b, rv, prfx) {
+ rv = rv || {};
+ prfx = prfx || '';
+ keys(a).forEach(function (prop) {
+ if (!hasOwn(b, prop)) {
+ rv[prfx + prop] = undefined;
+ }
+ else {
+ var ap = a[prop], bp = b[prop];
+ if (typeof ap === 'object' && typeof bp === 'object' && ap && bp) {
+ var apTypeName = toStringTag(ap);
+ var bpTypeName = toStringTag(bp);
+ if (apTypeName !== bpTypeName) {
+ rv[prfx + prop] = b[prop];
+ }
+ else if (apTypeName === 'Object') {
+ getObjectDiff(ap, bp, rv, prfx + prop + '.');
+ }
+ else if (ap !== bp) {
+ rv[prfx + prop] = b[prop];
+ }
+ }
+ else if (ap !== bp)
+ rv[prfx + prop] = b[prop];
+ }
+ });
+ keys(b).forEach(function (prop) {
+ if (!hasOwn(a, prop)) {
+ rv[prfx + prop] = b[prop];
+ }
+ });
+ return rv;
+ }
+
+ function getEffectiveKeys(primaryKey, req) {
+ if (req.type === 'delete')
+ return req.keys;
+ return req.keys || req.values.map(primaryKey.extractKey);
+ }
+
+ var hooksMiddleware = {
+ stack: "dbcore",
+ name: "HooksMiddleware",
+ level: 2,
+ create: function (downCore) { return (__assign(__assign({}, downCore), { table: function (tableName) {
+ var downTable = downCore.table(tableName);
+ var primaryKey = downTable.schema.primaryKey;
+ var tableMiddleware = __assign(__assign({}, downTable), { mutate: function (req) {
+ var dxTrans = PSD.trans;
+ var _a = dxTrans.table(tableName).hook, deleting = _a.deleting, creating = _a.creating, updating = _a.updating;
+ switch (req.type) {
+ case 'add':
+ if (creating.fire === nop)
+ break;
+ return dxTrans._promise('readwrite', function () { return addPutOrDelete(req); }, true);
+ case 'put':
+ if (creating.fire === nop && updating.fire === nop)
+ break;
+ return dxTrans._promise('readwrite', function () { return addPutOrDelete(req); }, true);
+ case 'delete':
+ if (deleting.fire === nop)
+ break;
+ return dxTrans._promise('readwrite', function () { return addPutOrDelete(req); }, true);
+ case 'deleteRange':
+ if (deleting.fire === nop)
+ break;
+ return dxTrans._promise('readwrite', function () { return deleteRange(req); }, true);
+ }
+ return downTable.mutate(req);
+ function addPutOrDelete(req) {
+ var dxTrans = PSD.trans;
+ var keys = req.keys || getEffectiveKeys(primaryKey, req);
+ if (!keys)
+ throw new Error("Keys missing");
+ req = req.type === 'add' || req.type === 'put' ? __assign(__assign({}, req), { keys: keys }) : __assign({}, req);
+ if (req.type !== 'delete')
+ req.values = __spreadArray([], req.values, true);
+ if (req.keys)
+ req.keys = __spreadArray([], req.keys, true);
+ return getExistingValues(downTable, req, keys).then(function (existingValues) {
+ var contexts = keys.map(function (key, i) {
+ var existingValue = existingValues[i];
+ var ctx = { onerror: null, onsuccess: null };
+ if (req.type === 'delete') {
+ deleting.fire.call(ctx, key, existingValue, dxTrans);
+ }
+ else if (req.type === 'add' || existingValue === undefined) {
+ var generatedPrimaryKey = creating.fire.call(ctx, key, req.values[i], dxTrans);
+ if (key == null && generatedPrimaryKey != null) {
+ key = generatedPrimaryKey;
+ req.keys[i] = key;
+ if (!primaryKey.outbound) {
+ setByKeyPath(req.values[i], primaryKey.keyPath, key);
+ }
+ }
+ }
+ else {
+ var objectDiff = getObjectDiff(existingValue, req.values[i]);
+ var additionalChanges_1 = updating.fire.call(ctx, objectDiff, key, existingValue, dxTrans);
+ if (additionalChanges_1) {
+ var requestedValue_1 = req.values[i];
+ Object.keys(additionalChanges_1).forEach(function (keyPath) {
+ if (hasOwn(requestedValue_1, keyPath)) {
+ requestedValue_1[keyPath] = additionalChanges_1[keyPath];
+ }
+ else {
+ setByKeyPath(requestedValue_1, keyPath, additionalChanges_1[keyPath]);
+ }
+ });
+ }
+ }
+ return ctx;
+ });
+ return downTable.mutate(req).then(function (_a) {
+ var failures = _a.failures, results = _a.results, numFailures = _a.numFailures, lastResult = _a.lastResult;
+ for (var i = 0; i < keys.length; ++i) {
+ var primKey = results ? results[i] : keys[i];
+ var ctx = contexts[i];
+ if (primKey == null) {
+ ctx.onerror && ctx.onerror(failures[i]);
+ }
+ else {
+ ctx.onsuccess && ctx.onsuccess(req.type === 'put' && existingValues[i] ?
+ req.values[i] :
+ primKey
+ );
+ }
+ }
+ return { failures: failures, results: results, numFailures: numFailures, lastResult: lastResult };
+ }).catch(function (error) {
+ contexts.forEach(function (ctx) { return ctx.onerror && ctx.onerror(error); });
+ return Promise.reject(error);
+ });
+ });
+ }
+ function deleteRange(req) {
+ return deleteNextChunk(req.trans, req.range, 10000);
+ }
+ function deleteNextChunk(trans, range, limit) {
+ return downTable.query({ trans: trans, values: false, query: { index: primaryKey, range: range }, limit: limit })
+ .then(function (_a) {
+ var result = _a.result;
+ return addPutOrDelete({ type: 'delete', keys: result, trans: trans }).then(function (res) {
+ if (res.numFailures > 0)
+ return Promise.reject(res.failures[0]);
+ if (result.length < limit) {
+ return { failures: [], numFailures: 0, lastResult: undefined };
+ }
+ else {
+ return deleteNextChunk(trans, __assign(__assign({}, range), { lower: result[result.length - 1], lowerOpen: true }), limit);
+ }
+ });
+ });
+ }
+ } });
+ return tableMiddleware;
+ } })); }
+ };
+ function getExistingValues(table, req, effectiveKeys) {
+ return req.type === "add"
+ ? Promise.resolve([])
+ : table.getMany({ trans: req.trans, keys: effectiveKeys, cache: "immutable" });
+ }
+
+ function getFromTransactionCache(keys, cache, clone) {
+ try {
+ if (!cache)
+ return null;
+ if (cache.keys.length < keys.length)
+ return null;
+ var result = [];
+ for (var i = 0, j = 0; i < cache.keys.length && j < keys.length; ++i) {
+ if (cmp(cache.keys[i], keys[j]) !== 0)
+ continue;
+ result.push(clone ? deepClone(cache.values[i]) : cache.values[i]);
+ ++j;
+ }
+ return result.length === keys.length ? result : null;
+ }
+ catch (_a) {
+ return null;
+ }
+ }
+ var cacheExistingValuesMiddleware = {
+ stack: "dbcore",
+ level: -1,
+ create: function (core) {
+ return {
+ table: function (tableName) {
+ var table = core.table(tableName);
+ return __assign(__assign({}, table), { getMany: function (req) {
+ if (!req.cache) {
+ return table.getMany(req);
+ }
+ var cachedResult = getFromTransactionCache(req.keys, req.trans["_cache"], req.cache === "clone");
+ if (cachedResult) {
+ return DexiePromise.resolve(cachedResult);
+ }
+ return table.getMany(req).then(function (res) {
+ req.trans["_cache"] = {
+ keys: req.keys,
+ values: req.cache === "clone" ? deepClone(res) : res,
+ };
+ return res;
+ });
+ }, mutate: function (req) {
+ if (req.type !== "add")
+ req.trans["_cache"] = null;
+ return table.mutate(req);
+ } });
+ },
+ };
+ },
+ };
+
+ var _a;
+ function isEmptyRange(node) {
+ return !("from" in node);
+ }
+ var RangeSet = function (fromOrTree, to) {
+ if (this) {
+ extend(this, arguments.length ? { d: 1, from: fromOrTree, to: arguments.length > 1 ? to : fromOrTree } : { d: 0 });
+ }
+ else {
+ var rv = new RangeSet();
+ if (fromOrTree && ("d" in fromOrTree)) {
+ extend(rv, fromOrTree);
+ }
+ return rv;
+ }
+ };
+ props(RangeSet.prototype, (_a = {
+ add: function (rangeSet) {
+ mergeRanges(this, rangeSet);
+ return this;
+ },
+ addKey: function (key) {
+ addRange(this, key, key);
+ return this;
+ },
+ addKeys: function (keys) {
+ var _this = this;
+ keys.forEach(function (key) { return addRange(_this, key, key); });
+ return this;
+ }
+ },
+ _a[iteratorSymbol] = function () {
+ return getRangeSetIterator(this);
+ },
+ _a));
+ function addRange(target, from, to) {
+ var diff = cmp(from, to);
+ if (isNaN(diff))
+ return;
+ if (diff > 0)
+ throw RangeError();
+ if (isEmptyRange(target))
+ return extend(target, { from: from, to: to, d: 1 });
+ var left = target.l;
+ var right = target.r;
+ if (cmp(to, target.from) < 0) {
+ left
+ ? addRange(left, from, to)
+ : (target.l = { from: from, to: to, d: 1, l: null, r: null });
+ return rebalance(target);
+ }
+ if (cmp(from, target.to) > 0) {
+ right
+ ? addRange(right, from, to)
+ : (target.r = { from: from, to: to, d: 1, l: null, r: null });
+ return rebalance(target);
+ }
+ if (cmp(from, target.from) < 0) {
+ target.from = from;
+ target.l = null;
+ target.d = right ? right.d + 1 : 1;
+ }
+ if (cmp(to, target.to) > 0) {
+ target.to = to;
+ target.r = null;
+ target.d = target.l ? target.l.d + 1 : 1;
+ }
+ var rightWasCutOff = !target.r;
+ if (left && !target.l) {
+ mergeRanges(target, left);
+ }
+ if (right && rightWasCutOff) {
+ mergeRanges(target, right);
+ }
+ }
+ function mergeRanges(target, newSet) {
+ function _addRangeSet(target, _a) {
+ var from = _a.from, to = _a.to, l = _a.l, r = _a.r;
+ addRange(target, from, to);
+ if (l)
+ _addRangeSet(target, l);
+ if (r)
+ _addRangeSet(target, r);
+ }
+ if (!isEmptyRange(newSet))
+ _addRangeSet(target, newSet);
+ }
+ function rangesOverlap(rangeSet1, rangeSet2) {
+ var i1 = getRangeSetIterator(rangeSet2);
+ var nextResult1 = i1.next();
+ if (nextResult1.done)
+ return false;
+ var a = nextResult1.value;
+ var i2 = getRangeSetIterator(rangeSet1);
+ var nextResult2 = i2.next(a.from);
+ var b = nextResult2.value;
+ while (!nextResult1.done && !nextResult2.done) {
+ if (cmp(b.from, a.to) <= 0 && cmp(b.to, a.from) >= 0)
+ return true;
+ cmp(a.from, b.from) < 0
+ ? (a = (nextResult1 = i1.next(b.from)).value)
+ : (b = (nextResult2 = i2.next(a.from)).value);
+ }
+ return false;
+ }
+ function getRangeSetIterator(node) {
+ var state = isEmptyRange(node) ? null : { s: 0, n: node };
+ return {
+ next: function (key) {
+ var keyProvided = arguments.length > 0;
+ while (state) {
+ switch (state.s) {
+ case 0:
+ state.s = 1;
+ if (keyProvided) {
+ while (state.n.l && cmp(key, state.n.from) < 0)
+ state = { up: state, n: state.n.l, s: 1 };
+ }
+ else {
+ while (state.n.l)
+ state = { up: state, n: state.n.l, s: 1 };
+ }
+ case 1:
+ state.s = 2;
+ if (!keyProvided || cmp(key, state.n.to) <= 0)
+ return { value: state.n, done: false };
+ case 2:
+ if (state.n.r) {
+ state.s = 3;
+ state = { up: state, n: state.n.r, s: 0 };
+ continue;
+ }
+ case 3:
+ state = state.up;
+ }
+ }
+ return { done: true };
+ },
+ };
+ }
+ function rebalance(target) {
+ var _a, _b;
+ var diff = (((_a = target.r) === null || _a === void 0 ? void 0 : _a.d) || 0) - (((_b = target.l) === null || _b === void 0 ? void 0 : _b.d) || 0);
+ var r = diff > 1 ? "r" : diff < -1 ? "l" : "";
+ if (r) {
+ var l = r === "r" ? "l" : "r";
+ var rootClone = __assign({}, target);
+ var oldRootRight = target[r];
+ target.from = oldRootRight.from;
+ target.to = oldRootRight.to;
+ target[r] = oldRootRight[r];
+ rootClone[r] = oldRootRight[l];
+ target[l] = rootClone;
+ rootClone.d = computeDepth(rootClone);
+ }
+ target.d = computeDepth(target);
+ }
+ function computeDepth(_a) {
+ var r = _a.r, l = _a.l;
+ return (r ? (l ? Math.max(r.d, l.d) : r.d) : l ? l.d : 0) + 1;
+ }
+
+ function isCachableContext(ctx, table) {
+ return (ctx.trans.mode === 'readonly' &&
+ !!ctx.subscr &&
+ !ctx.trans.explicit &&
+ ctx.trans.db._options.cache !== 'disabled' &&
+ !table.schema.primaryKey.outbound);
+ }
+
+ function isCachableRequest(type, req) {
+ switch (type) {
+ case 'query':
+ return req.values && !req.unique;
+ case 'get':
+ return false;
+ case 'getMany':
+ return false;
+ case 'count':
+ return false;
+ case 'openCursor':
+ return false;
+ }
+ }
+
+ function extendObservabilitySet(target, newSet) {
+ keys(newSet).forEach(function (part) {
+ var rangeSet = target[part] || (target[part] = new RangeSet());
+ mergeRanges(rangeSet, newSet[part]);
+ });
+ return target;
+ }
+
+ var observabilityMiddleware = {
+ stack: "dbcore",
+ level: 0,
+ name: "Observability",
+ create: function (core) {
+ var dbName = core.schema.name;
+ var FULL_RANGE = new RangeSet(core.MIN_KEY, core.MAX_KEY);
+ return __assign(__assign({}, core), { transaction: function (stores, mode, options) {
+ if (!PSD.subscr)
+ return core.transaction(stores, mode, options);
+ if (mode !== 'readonly')
+ throw new exceptions.ReadOnly('write transaction not allowed within liveQueries');
+ return core.transaction(stores, mode, options);
+ }, table: function (tableName) {
+ var table = core.table(tableName);
+ var schema = table.schema;
+ var primaryKey = schema.primaryKey;
+ var extractKey = primaryKey.extractKey, outbound = primaryKey.outbound;
+ var tableClone = __assign(__assign({}, table), { mutate: function (req) {
+ var trans = req.trans;
+ var mutatedParts = req.mutatedParts || (req.mutatedParts = {});
+ var getRangeSet = function (indexName) {
+ var part = "idb://".concat(dbName, "/").concat(tableName, "/").concat(indexName);
+ return (mutatedParts[part] ||
+ (mutatedParts[part] = new RangeSet()));
+ };
+ var pkRangeSet = getRangeSet("");
+ var delsRangeSet = getRangeSet(":dels");
+ var type = req.type;
+ var _a = req.type === "deleteRange"
+ ? [req.range]
+ : req.type === "delete"
+ ? [req.keys]
+ : req.values.length < 50
+ ? [getEffectiveKeys(primaryKey, req).filter(function (id) { return id; }), req.values]
+ : [], keys = _a[0], newObjs = _a[1];
+ var oldCache = req.trans["_cache"];
+ if (isArray(keys)) {
+ pkRangeSet.addKeys(keys);
+ var oldObjs = type === 'delete' || keys.length === newObjs.length ? getFromTransactionCache(keys, oldCache) : null;
+ if (!oldObjs && type !== "add") {
+ delsRangeSet.addKeys(keys);
+ }
+ if (oldObjs || newObjs) {
+ trackAffectedIndexes(getRangeSet, schema, oldObjs, newObjs);
+ }
+ }
+ else if (keys) {
+ var range = { from: keys.lower, to: keys.upper };
+ delsRangeSet.add(range);
+ pkRangeSet.add(range);
+ }
+ else {
+ pkRangeSet.add(FULL_RANGE);
+ delsRangeSet.add(FULL_RANGE);
+ schema.indexes.forEach(function (idx) { return getRangeSet(idx.name).add(FULL_RANGE); });
+ }
+ return table.mutate(req).then(function (res) {
+ if (keys && primaryKey.autoIncrement && (req.type === 'add' || req.type === 'put')) {
+ pkRangeSet.addKeys(res.results);
+ }
+ trans.mutatedParts = extendObservabilitySet(trans.mutatedParts || {}, mutatedParts);
+ return res;
+ });
+ } });
+ var getRange = function (_a) {
+ var _b, _c;
+ var _d = _a.query, index = _d.index, range = _d.range;
+ return [
+ index,
+ new RangeSet((_b = range.lower) !== null && _b !== void 0 ? _b : core.MIN_KEY, (_c = range.upper) !== null && _c !== void 0 ? _c : core.MAX_KEY),
+ ];
+ };
+ var readSubscribers = {
+ get: function (req) { return [primaryKey, new RangeSet(req.key)]; },
+ getMany: function (req) { return [primaryKey, new RangeSet().addKeys(req.keys)]; },
+ count: getRange,
+ query: getRange,
+ openCursor: getRange,
+ };
+ keys(readSubscribers).forEach(function (method) {
+ tableClone[method] = function (req) {
+ var subscr = PSD.subscr;
+ var isLiveQuery = !!subscr;
+ var cachable = isCachableContext(PSD, table) && isCachableRequest(method, req);
+ var obsSet = cachable
+ ? req.obsSet = {}
+ : subscr;
+ if (isLiveQuery) {
+ var signal = PSD.signal;
+ if (signal && signal.aborted)
+ throw new exceptions.Abort();
+ var getRangeSet = function (indexName) {
+ var part = "idb://".concat(dbName, "/").concat(tableName, "/").concat(indexName);
+ return (obsSet[part] ||
+ (obsSet[part] = new RangeSet()));
+ };
+ var pkRangeSet_1 = getRangeSet("");
+ var delsRangeSet_1 = getRangeSet(":dels");
+ var _a = readSubscribers[method](req), queriedIndex = _a[0], queriedRanges = _a[1];
+ getRangeSet(queriedIndex.name || "").add(queriedRanges);
+ if (!queriedIndex.isPrimaryKey) {
+ if (method === "count") {
+ delsRangeSet_1.add(FULL_RANGE);
+ }
+ else {
+ var keysPromise_1 = method === "query" &&
+ outbound &&
+ req.values &&
+ table.query(__assign(__assign({}, req), { values: false }));
+ return table[method].apply(this, arguments).then(function (res) {
+ if (method === "query") {
+ if (outbound && req.values) {
+ return keysPromise_1.then(function (_a) {
+ var resultingKeys = _a.result;
+ pkRangeSet_1.addKeys(resultingKeys);
+ return res;
+ });
+ }
+ var pKeys = req.values
+ ? res.result.map(extractKey)
+ : res.result;
+ if (req.values) {
+ pkRangeSet_1.addKeys(pKeys);
+ }
+ else {
+ delsRangeSet_1.addKeys(pKeys);
+ }
+ }
+ else if (method === "openCursor") {
+ var cursor_1 = res;
+ var wantValues_1 = req.values;
+ return (cursor_1 &&
+ Object.create(cursor_1, {
+ key: {
+ get: function () {
+ delsRangeSet_1.addKey(cursor_1.primaryKey);
+ return cursor_1.key;
+ },
+ },
+ primaryKey: {
+ get: function () {
+ var pkey = cursor_1.primaryKey;
+ delsRangeSet_1.addKey(pkey);
+ return pkey;
+ },
+ },
+ value: {
+ get: function () {
+ wantValues_1 && pkRangeSet_1.addKey(cursor_1.primaryKey);
+ return cursor_1.value;
+ },
+ },
+ }));
+ }
+ return res;
+ });
+ }
+ }
+ }
+ return table[method].apply(this, arguments);
+ };
+ });
+ return tableClone;
+ } });
+ },
+ };
+ function trackAffectedIndexes(getRangeSet, schema, oldObjs, newObjs) {
+ function addAffectedIndex(ix) {
+ var rangeSet = getRangeSet(ix.name || "");
+ function extractKey(obj) {
+ return obj != null ? ix.extractKey(obj) : null;
+ }
+ var addKeyOrKeys = function (key) { return ix.multiEntry && isArray(key)
+ ? key.forEach(function (key) { return rangeSet.addKey(key); })
+ : rangeSet.addKey(key); };
+ (oldObjs || newObjs).forEach(function (_, i) {
+ var oldKey = oldObjs && extractKey(oldObjs[i]);
+ var newKey = newObjs && extractKey(newObjs[i]);
+ if (cmp(oldKey, newKey) !== 0) {
+ if (oldKey != null)
+ addKeyOrKeys(oldKey);
+ if (newKey != null)
+ addKeyOrKeys(newKey);
+ }
+ });
+ }
+ schema.indexes.forEach(addAffectedIndex);
+ }
+
+ function isAboveLower(key, range) {
+ return range.lower === undefined
+ ? true
+ : range.lowerOpen
+ ? cmp(key, range.lower) > 0
+ : cmp(key, range.lower) >= 0;
+ }
+ function isBelowUpper(key, range) {
+ return range.upper === undefined
+ ? true
+ : range.upperOpen
+ ? cmp(key, range.upper) < 0
+ : cmp(key, range.upper) <= 0;
+ }
+ function isWithinRange(key, range) {
+ return isAboveLower(key, range) && isBelowUpper(key, range);
+ }
+
+ function applyOptimisticOps(result, req, ops, table, cacheEntry, immutable) {
+ if (!ops || ops.length === 0)
+ return result;
+ var sortIndex = req.query.index;
+ var primaryKey = table.schema.primaryKey;
+ var extractPrimKey = primaryKey.extractKey;
+ var extractIndex = sortIndex.extractKey;
+ var finalResult = ops.reduce(function (result, op) {
+ var modifedResult = result;
+ var includedValues = op.type === 'add' || op.type === 'put'
+ ? op.values.filter(function (v) {
+ return isWithinRange(extractIndex(v), req.query.range);
+ }).map(function (v) {
+ v = deepClone(v);
+ if (immutable)
+ Object.freeze(v);
+ return v;
+ })
+ : [];
+ switch (op.type) {
+ case 'add':
+ modifedResult = result.concat(req.values
+ ? includedValues
+ : includedValues.map(function (v) { return extractPrimKey(v); }));
+ break;
+ case 'put':
+ var keySet_1 = new RangeSet().addKeys(op.values.map(function (v) { return extractPrimKey(v); }));
+ modifedResult = result
+ .filter(function (item) {
+ var key = req.values ? extractPrimKey(item) : item;
+ return !rangesOverlap(new RangeSet(key), keySet_1);
+ })
+ .concat(req.values
+ ? includedValues
+ : includedValues.map(function (v) { return extractPrimKey(v); }));
+ break;
+ case 'delete':
+ var keysToDelete_1 = new RangeSet().addKeys(op.keys);
+ modifedResult = result.filter(function (item) {
+ var key = req.values ? extractPrimKey(item) : item;
+ return !rangesOverlap(new RangeSet(key), keysToDelete_1);
+ });
+ break;
+ case 'deleteRange':
+ var range_1 = op.range;
+ var rangeSet_1 = new RangeSet(range_1.lower, range_1.upper);
+ modifedResult = result.filter(function (item) {
+ var key = primaryKey.extractKey(item);
+ return !((rangesOverlap(new RangeSet(key), rangeSet_1) &&
+ isWithinRange(key, range_1))
+ );
+ });
+ break;
+ }
+ return modifedResult;
+ }, result);
+ if (finalResult === result)
+ return result;
+ finalResult.sort(function (a, b) {
+ return cmp(sortIndex.extractKey(a), sortIndex.extractKey(b));
+ });
+ if (req.limit) {
+ if (finalResult.length > req.limit) {
+ finalResult.length = req.limit;
+ }
+ else if (result.length === req.limit && finalResult.length < req.limit) {
+ cacheEntry.dirty = true;
+ }
+ }
+ return immutable ? Object.freeze(finalResult) : finalResult;
+ }
+
+ var cache = {};
+
+ function areRangesEqual(r1, r2) {
+ return (cmp(r1.lower, r2.lower) === 0 &&
+ cmp(r1.upper, r2.upper) === 0 &&
+ !!r1.lowerOpen === !!r2.lowerOpen &&
+ !!r1.upperOpen === !!r2.upperOpen);
+ }
+
+ function compareLowers(lower1, lower2, lowerOpen1, lowerOpen2) {
+ if (lower1 === undefined)
+ return lower2 !== undefined ? -1 : 0;
+ if (lower2 === undefined)
+ return 1;
+ var c = cmp(lower1, lower2);
+ if (c === 0) {
+ if (lowerOpen1 && lowerOpen2)
+ return 0;
+ if (lowerOpen1)
+ return 1;
+ if (lowerOpen2)
+ return -1;
+ }
+ return c;
+ }
+ function compareUppers(upper1, upper2, upperOpen1, upperOpen2) {
+ if (upper1 === undefined)
+ return upper2 !== undefined ? 1 : 0;
+ if (upper2 === undefined)
+ return -1;
+ var c = cmp(upper1, upper2);
+ if (c === 0) {
+ if (upperOpen1 && upperOpen2)
+ return 0;
+ if (upperOpen1)
+ return -1;
+ if (upperOpen2)
+ return 1;
+ }
+ return c;
+ }
+ function isSuperRange(r1, r2) {
+ return (compareLowers(r1.lower, r2.lower, r1.lowerOpen, r2.lowerOpen) <= 0 &&
+ compareUppers(r1.upper, r2.upper, r1.upperOpen, r2.upperOpen) >= 0);
+ }
+
+ function findCompatibleQuery(dbName, tableName, type, req) {
+ var tblCache = cache["idb://".concat(dbName, "/").concat(tableName)];
+ if (!tblCache)
+ return [];
+ var queries = tblCache.queries[type];
+ if (!queries)
+ return [null, false, tblCache, null];
+ var indexName = req.query ? req.query.index.name : null;
+ var entries = queries[indexName || ''];
+ if (!entries)
+ return [null, false, tblCache, null];
+ switch (type) {
+ case 'query':
+ var equalEntry = entries.find(function (entry) {
+ return entry.req.limit === req.limit &&
+ entry.req.values === req.values &&
+ areRangesEqual(entry.req.query.range, req.query.range);
+ });
+ if (equalEntry)
+ return [
+ equalEntry,
+ true,
+ tblCache,
+ entries,
+ ];
+ var superEntry = entries.find(function (entry) {
+ var limit = 'limit' in entry.req ? entry.req.limit : Infinity;
+ return (limit >= req.limit &&
+ (req.values ? entry.req.values : true) &&
+ isSuperRange(entry.req.query.range, req.query.range));
+ });
+ return [superEntry, false, tblCache, entries];
+ case 'count':
+ var countQuery = entries.find(function (entry) {
+ return areRangesEqual(entry.req.query.range, req.query.range);
+ });
+ return [countQuery, !!countQuery, tblCache, entries];
+ }
+ }
+
+ function obsSetsOverlap(os1, os2) {
+ return Object.keys(os1).some(function (key) { return os2[key] && rangesOverlap(os2[key], os1[key]); });
+ }
+
+ function signalSubscribers(tblCache, mutatedParts) {
+ extendObservabilitySet(tblCache.unsignaledParts, mutatedParts);
+ if (!tblCache.signalTimer) {
+ tblCache.signalTimer = setTimeout(function () {
+ tblCache.signalTimer = null;
+ signalSubscribersNow(tblCache);
+ }, 0);
+ }
+ }
+ function signalSubscribersNow(tblCache) {
+ var collectedSubscribers = new Set();
+ for (var _i = 0, _a = Object.values(tblCache.queries.query); _i < _a.length; _i++) {
+ var entries = _a[_i];
+ for (var _b = 0, entries_1 = entries; _b < entries_1.length; _b++) {
+ var entry = entries_1[_b];
+ if (entry.obsSet && obsSetsOverlap(entry.obsSet, tblCache.unsignaledParts)) {
+ entry.subscribers.forEach(function (requery) { return collectedSubscribers.add(requery); });
+ }
+ }
+ }
+ tblCache.unsignaledParts = {};
+ collectedSubscribers.forEach(function (requery) { return requery(); });
+ }
+
+ function subscribeToCacheEntry(cacheEntry, container, requery, signal) {
+ cacheEntry.subscribers.add(requery);
+ signal.addEventListener("abort", function () {
+ cacheEntry.subscribers.delete(requery);
+ if (cacheEntry.subscribers.size === 0) {
+ enqueForDeletion(cacheEntry, container);
+ }
+ });
+ }
+ function enqueForDeletion(cacheEntry, container) {
+ setTimeout(function () {
+ if (cacheEntry.subscribers.size === 0) {
+ delArrayItem(container, cacheEntry);
+ }
+ }, 3000);
+ }
+
+ var cacheMiddleware = {
+ stack: 'dbcore',
+ level: 0,
+ name: 'Cache',
+ create: function (core) {
+ var dbName = core.schema.name;
+ var coreMW = __assign(__assign({}, core), { transaction: function (stores, mode, options) {
+ var idbtrans = core.transaction(stores, mode, options);
+ var txs = PSD.txs;
+ if (txs || mode === 'readwrite') {
+ if (txs)
+ txs.push(idbtrans);
+ var ac_1 = new AbortController();
+ var signal = ac_1.signal;
+ var endTransaction = function (wasCommitted) { return function () {
+ if (txs)
+ delArrayItem(txs, idbtrans);
+ ac_1.abort();
+ if (mode === 'readwrite') {
+ for (var _i = 0, stores_1 = stores; _i < stores_1.length; _i++) {
+ var storeName = stores_1[_i];
+ var tblCache = cache["idb://".concat(dbName, "/").concat(storeName)];
+ var table = core.table(storeName);
+ if (tblCache) {
+ var ops = tblCache.optimisticOps.filter(function (op) { return op.trans === idbtrans; });
+ if (ops.length > 0) {
+ tblCache.optimisticOps = tblCache.optimisticOps.filter(function (op) { return op.trans !== idbtrans; });
+ for (var _a = 0, _b = Object.values(tblCache.queries.query); _a < _b.length; _a++) {
+ var entries = _b[_a];
+ for (var _c = 0, _d = entries.slice(); _c < _d.length; _c++) {
+ var entry = _d[_c];
+ if (entry.res != null &&
+ idbtrans.mutatedParts
+ ) {
+ if (wasCommitted && !entry.dirty) {
+ var freezeResults = Object.isFrozen(entry.res);
+ var modRes = applyOptimisticOps(entry.res, entry.req, ops, table, entry, freezeResults);
+ if (entry.dirty) {
+ delArrayItem(entries, entry);
+ entry.subscribers.forEach(function (requery) { return requery(); });
+ }
+ else if (modRes !== entry.res) {
+ entry.res = modRes;
+ entry.promise = DexiePromise.resolve({ result: modRes });
+ }
+ }
+ else {
+ if (entry.dirty) {
+ delArrayItem(entries, entry);
+ }
+ entry.subscribers.forEach(function (requery) { return requery(); });
+ }
+ }
+ }
+ }
+ }
+ }
+ }
+ }
+ }; };
+ idbtrans.addEventListener('abort', endTransaction(false), {
+ signal: signal,
+ });
+ idbtrans.addEventListener('error', endTransaction(false), {
+ signal: signal,
+ });
+ idbtrans.addEventListener('complete', endTransaction(true), {
+ signal: signal,
+ });
+ }
+ return idbtrans;
+ }, table: function (tableName) {
+ var downTable = core.table(tableName);
+ var primKey = downTable.schema.primaryKey;
+ var tableMW = __assign(__assign({}, downTable), { mutate: function (req) {
+ if (primKey.outbound ||
+ PSD.trans.db._options.cache === 'disabled'
+ ) {
+ return downTable.mutate(req);
+ }
+ var tblCache = cache["idb://".concat(dbName, "/").concat(tableName)];
+ if (!tblCache)
+ return downTable.mutate(req);
+ var promise = downTable.mutate(req);
+ if (primKey.autoIncrement && (req.type === 'add' || req.type === 'put') && (req.values.length < 50 || getEffectiveKeys(primKey, req).some(function (key) { return key == null; }))) {
+ promise.then(function (res) {
+ var reqWithResolvedKeys = __assign(__assign({}, req), { values: req.values.map(function (value, i) {
+ var valueWithKey = primKey.keyPath.includes('.')
+ ? deepClone(value)
+ : __assign({}, value);
+ setByKeyPath(valueWithKey, primKey.keyPath, res.results[i]);
+ return valueWithKey;
+ }) });
+ tblCache.optimisticOps.push(reqWithResolvedKeys);
+ queueMicrotask(function () { return signalSubscribers(tblCache, req.mutatedParts); });
+ });
+ }
+ else {
+ tblCache.optimisticOps.push(req);
+ signalSubscribers(tblCache, req.mutatedParts);
+ promise.catch(function () {
+ delArrayItem(tblCache.optimisticOps, req);
+ signalSubscribers(tblCache, req.mutatedParts);
+ });
+ }
+ return promise;
+ }, query: function (req) {
+ if (!isCachableContext(PSD, downTable) || !isCachableRequest("query", req))
+ return downTable.query(req);
+ var freezeResults = PSD.trans.db._options.cache === 'immutable';
+ var _a = PSD, requery = _a.requery, signal = _a.signal;
+ var _b = findCompatibleQuery(dbName, tableName, 'query', req), cacheEntry = _b[0], exactMatch = _b[1], tblCache = _b[2], container = _b[3];
+ if (cacheEntry && exactMatch) {
+ cacheEntry.obsSet = req.obsSet;
+ }
+ else {
+ var promise = downTable.query(req).then(function (res) {
+ var result = res.result;
+ cacheEntry.res = result;
+ if (freezeResults) {
+ for (var i = 0, l = result.length; i < l; ++i) {
+ Object.freeze(result[i]);
+ }
+ Object.freeze(result);
+ }
+ else {
+ res.result = deepClone(result);
+ }
+ return res;
+ }).catch(function (error) {
+ if (container && cacheEntry)
+ delArrayItem(container, cacheEntry);
+ return Promise.reject(error);
+ });
+ cacheEntry = {
+ obsSet: req.obsSet,
+ promise: promise.catch(function (error) {
+ if (req.trans.aborted) {
+ var trans = coreMW.transaction([tableName], 'readonly');
+ return tableMW.query(__assign(__assign({}, req), { trans: trans }));
+ }
+ return Promise.reject(error);
+ }),
+ subscribers: new Set(),
+ type: 'query',
+ req: req,
+ dirty: false,
+ };
+ if (container) {
+ container.push(cacheEntry);
+ }
+ else {
+ container = [cacheEntry];
+ if (!tblCache) {
+ tblCache = cache["idb://".concat(dbName, "/").concat(tableName)] = {
+ queries: {
+ query: {},
+ count: {},
+ },
+ objs: new Map(),
+ optimisticOps: [],
+ unsignaledParts: {}
+ };
+ }
+ tblCache.queries.query[req.query.index.name || ''] = container;
+ }
+ }
+ subscribeToCacheEntry(cacheEntry, container, requery, signal);
+ return cacheEntry.promise.then(function (res) {
+ return {
+ result: applyOptimisticOps(res.result, req, tblCache === null || tblCache === void 0 ? void 0 : tblCache.optimisticOps, downTable, cacheEntry, freezeResults),
+ };
+ });
+ } });
+ return tableMW;
+ } });
+ return coreMW;
+ },
+ };
+
+ var Dexie$1 = (function () {
+ function Dexie(name, options) {
+ var _this = this;
+ this._middlewares = {};
+ this.verno = 0;
+ var deps = Dexie.dependencies;
+ this._options = options = __assign({
+ addons: Dexie.addons, autoOpen: true,
+ indexedDB: deps.indexedDB, IDBKeyRange: deps.IDBKeyRange, cache: 'cloned' }, options);
+ this._deps = {
+ indexedDB: options.indexedDB,
+ IDBKeyRange: options.IDBKeyRange
+ };
+ var addons = options.addons;
+ this._dbSchema = {};
+ this._versions = [];
+ this._storeNames = [];
+ this._allTables = {};
+ this.idbdb = null;
+ this._novip = this;
+ var state = {
+ dbOpenError: null,
+ isBeingOpened: false,
+ onReadyBeingFired: null,
+ openComplete: false,
+ dbReadyResolve: nop,
+ dbReadyPromise: null,
+ cancelOpen: nop,
+ openCanceller: null,
+ autoSchema: true,
+ PR1398_maxLoop: 3
+ };
+ state.dbReadyPromise = new DexiePromise(function (resolve) {
+ state.dbReadyResolve = resolve;
+ });
+ state.openCanceller = new DexiePromise(function (_, reject) {
+ state.cancelOpen = reject;
+ });
+ this._state = state;
+ this.name = name;
+ this.on = Events(this, "populate", "blocked", "versionchange", "close", { ready: [promisableChain, nop] });
+ this.on.ready.subscribe = override(this.on.ready.subscribe, function (subscribe) {
+ return function (subscriber, bSticky) {
+ Dexie.vip(function () {
+ var state = _this._state;
+ if (state.openComplete) {
+ if (!state.dbOpenError)
+ DexiePromise.resolve().then(subscriber);
+ if (bSticky)
+ subscribe(subscriber);
+ }
+ else if (state.onReadyBeingFired) {
+ state.onReadyBeingFired.push(subscriber);
+ if (bSticky)
+ subscribe(subscriber);
+ }
+ else {
+ subscribe(subscriber);
+ var db_1 = _this;
+ if (!bSticky)
+ subscribe(function unsubscribe() {
+ db_1.on.ready.unsubscribe(subscriber);
+ db_1.on.ready.unsubscribe(unsubscribe);
+ });
+ }
+ });
+ };
+ });
+ this.Collection = createCollectionConstructor(this);
+ this.Table = createTableConstructor(this);
+ this.Transaction = createTransactionConstructor(this);
+ this.Version = createVersionConstructor(this);
+ this.WhereClause = createWhereClauseConstructor(this);
+ this.on("versionchange", function (ev) {
+ if (ev.newVersion > 0)
+ console.warn("Another connection wants to upgrade database '".concat(_this.name, "'. Closing db now to resume the upgrade."));
+ else
+ console.warn("Another connection wants to delete database '".concat(_this.name, "'. Closing db now to resume the delete request."));
+ _this.close();
+ });
+ this.on("blocked", function (ev) {
+ if (!ev.newVersion || ev.newVersion < ev.oldVersion)
+ console.warn("Dexie.delete('".concat(_this.name, "') was blocked"));
+ else
+ console.warn("Upgrade '".concat(_this.name, "' blocked by other connection holding version ").concat(ev.oldVersion / 10));
+ });
+ this._maxKey = getMaxKey(options.IDBKeyRange);
+ this._createTransaction = function (mode, storeNames, dbschema, parentTransaction) { return new _this.Transaction(mode, storeNames, dbschema, _this._options.chromeTransactionDurability, parentTransaction); };
+ this._fireOnBlocked = function (ev) {
+ _this.on("blocked").fire(ev);
+ connections
+ .filter(function (c) { return c.name === _this.name && c !== _this && !c._state.vcFired; })
+ .map(function (c) { return c.on("versionchange").fire(ev); });
+ };
+ this.use(virtualIndexMiddleware);
+ this.use(hooksMiddleware);
+ this.use(cacheMiddleware);
+ this.use(observabilityMiddleware);
+ this.use(cacheExistingValuesMiddleware);
+ this.vip = Object.create(this, { _vip: { value: true } });
+ addons.forEach(function (addon) { return addon(_this); });
+ }
+ Dexie.prototype.version = function (versionNumber) {
+ if (isNaN(versionNumber) || versionNumber < 0.1)
+ throw new exceptions.Type("Given version is not a positive number");
+ versionNumber = Math.round(versionNumber * 10) / 10;
+ if (this.idbdb || this._state.isBeingOpened)
+ throw new exceptions.Schema("Cannot add version when database is open");
+ this.verno = Math.max(this.verno, versionNumber);
+ var versions = this._versions;
+ var versionInstance = versions.filter(function (v) { return v._cfg.version === versionNumber; })[0];
+ if (versionInstance)
+ return versionInstance;
+ versionInstance = new this.Version(versionNumber);
+ versions.push(versionInstance);
+ versions.sort(lowerVersionFirst);
+ versionInstance.stores({});
+ this._state.autoSchema = false;
+ return versionInstance;
+ };
+ Dexie.prototype._whenReady = function (fn) {
+ var _this = this;
+ return (this.idbdb && (this._state.openComplete || PSD.letThrough || this._vip)) ? fn() : new DexiePromise(function (resolve, reject) {
+ if (_this._state.openComplete) {
+ return reject(new exceptions.DatabaseClosed(_this._state.dbOpenError));
+ }
+ if (!_this._state.isBeingOpened) {
+ if (!_this._options.autoOpen) {
+ reject(new exceptions.DatabaseClosed());
+ return;
+ }
+ _this.open().catch(nop);
+ }
+ _this._state.dbReadyPromise.then(resolve, reject);
+ }).then(fn);
+ };
+ Dexie.prototype.use = function (_a) {
+ var stack = _a.stack, create = _a.create, level = _a.level, name = _a.name;
+ if (name)
+ this.unuse({ stack: stack, name: name });
+ var middlewares = this._middlewares[stack] || (this._middlewares[stack] = []);
+ middlewares.push({ stack: stack, create: create, level: level == null ? 10 : level, name: name });
+ middlewares.sort(function (a, b) { return a.level - b.level; });
+ return this;
+ };
+ Dexie.prototype.unuse = function (_a) {
+ var stack = _a.stack, name = _a.name, create = _a.create;
+ if (stack && this._middlewares[stack]) {
+ this._middlewares[stack] = this._middlewares[stack].filter(function (mw) {
+ return create ? mw.create !== create :
+ name ? mw.name !== name :
+ false;
+ });
+ }
+ return this;
+ };
+ Dexie.prototype.open = function () {
+ return dexieOpen(this);
+ };
+ Dexie.prototype._close = function () {
+ var state = this._state;
+ var idx = connections.indexOf(this);
+ if (idx >= 0)
+ connections.splice(idx, 1);
+ if (this.idbdb) {
+ try {
+ this.idbdb.close();
+ }
+ catch (e) { }
+ this._novip.idbdb = null;
+ }
+ state.dbReadyPromise = new DexiePromise(function (resolve) {
+ state.dbReadyResolve = resolve;
+ });
+ state.openCanceller = new DexiePromise(function (_, reject) {
+ state.cancelOpen = reject;
+ });
+ };
+ Dexie.prototype.close = function () {
+ this._close();
+ var state = this._state;
+ this._options.autoOpen = false;
+ state.dbOpenError = new exceptions.DatabaseClosed();
+ if (state.isBeingOpened)
+ state.cancelOpen(state.dbOpenError);
+ };
+ Dexie.prototype.delete = function () {
+ var _this = this;
+ var hasArguments = arguments.length > 0;
+ var state = this._state;
+ return new DexiePromise(function (resolve, reject) {
+ var doDelete = function () {
+ _this.close();
+ var req = _this._deps.indexedDB.deleteDatabase(_this.name);
+ req.onsuccess = wrap(function () {
+ _onDatabaseDeleted(_this._deps, _this.name);
+ resolve();
+ });
+ req.onerror = eventRejectHandler(reject);
+ req.onblocked = _this._fireOnBlocked;
+ };
+ if (hasArguments)
+ throw new exceptions.InvalidArgument("Arguments not allowed in db.delete()");
+ if (state.isBeingOpened) {
+ state.dbReadyPromise.then(doDelete);
+ }
+ else {
+ doDelete();
+ }
+ });
+ };
+ Dexie.prototype.backendDB = function () {
+ return this.idbdb;
+ };
+ Dexie.prototype.isOpen = function () {
+ return this.idbdb !== null;
+ };
+ Dexie.prototype.hasBeenClosed = function () {
+ var dbOpenError = this._state.dbOpenError;
+ return dbOpenError && (dbOpenError.name === 'DatabaseClosed');
+ };
+ Dexie.prototype.hasFailed = function () {
+ return this._state.dbOpenError !== null;
+ };
+ Dexie.prototype.dynamicallyOpened = function () {
+ return this._state.autoSchema;
+ };
+ Object.defineProperty(Dexie.prototype, "tables", {
+ get: function () {
+ var _this = this;
+ return keys(this._allTables).map(function (name) { return _this._allTables[name]; });
+ },
+ enumerable: false,
+ configurable: true
+ });
+ Dexie.prototype.transaction = function () {
+ var args = extractTransactionArgs.apply(this, arguments);
+ return this._transaction.apply(this, args);
+ };
+ Dexie.prototype._transaction = function (mode, tables, scopeFunc) {
+ var _this = this;
+ var parentTransaction = PSD.trans;
+ if (!parentTransaction || parentTransaction.db !== this || mode.indexOf('!') !== -1)
+ parentTransaction = null;
+ var onlyIfCompatible = mode.indexOf('?') !== -1;
+ mode = mode.replace('!', '').replace('?', '');
+ var idbMode, storeNames;
+ try {
+ storeNames = tables.map(function (table) {
+ var storeName = table instanceof _this.Table ? table.name : table;
+ if (typeof storeName !== 'string')
+ throw new TypeError("Invalid table argument to Dexie.transaction(). Only Table or String are allowed");
+ return storeName;
+ });
+ if (mode == "r" || mode === READONLY)
+ idbMode = READONLY;
+ else if (mode == "rw" || mode == READWRITE)
+ idbMode = READWRITE;
+ else
+ throw new exceptions.InvalidArgument("Invalid transaction mode: " + mode);
+ if (parentTransaction) {
+ if (parentTransaction.mode === READONLY && idbMode === READWRITE) {
+ if (onlyIfCompatible) {
+ parentTransaction = null;
+ }
+ else
+ throw new exceptions.SubTransaction("Cannot enter a sub-transaction with READWRITE mode when parent transaction is READONLY");
+ }
+ if (parentTransaction) {
+ storeNames.forEach(function (storeName) {
+ if (parentTransaction && parentTransaction.storeNames.indexOf(storeName) === -1) {
+ if (onlyIfCompatible) {
+ parentTransaction = null;
+ }
+ else
+ throw new exceptions.SubTransaction("Table " + storeName +
+ " not included in parent transaction.");
+ }
+ });
+ }
+ if (onlyIfCompatible && parentTransaction && !parentTransaction.active) {
+ parentTransaction = null;
+ }
+ }
+ }
+ catch (e) {
+ return parentTransaction ?
+ parentTransaction._promise(null, function (_, reject) { reject(e); }) :
+ rejection(e);
+ }
+ var enterTransaction = enterTransactionScope.bind(null, this, idbMode, storeNames, parentTransaction, scopeFunc);
+ return (parentTransaction ?
+ parentTransaction._promise(idbMode, enterTransaction, "lock") :
+ PSD.trans ?
+ usePSD(PSD.transless, function () { return _this._whenReady(enterTransaction); }) :
+ this._whenReady(enterTransaction));
+ };
+ Dexie.prototype.table = function (tableName) {
+ if (!hasOwn(this._allTables, tableName)) {
+ throw new exceptions.InvalidTable("Table ".concat(tableName, " does not exist"));
+ }
+ return this._allTables[tableName];
+ };
+ return Dexie;
+ }());
+
+ var symbolObservable = typeof Symbol !== "undefined" && "observable" in Symbol
+ ? Symbol.observable
+ : "@@observable";
+ var Observable = (function () {
+ function Observable(subscribe) {
+ this._subscribe = subscribe;
+ }
+ Observable.prototype.subscribe = function (x, error, complete) {
+ return this._subscribe(!x || typeof x === "function" ? { next: x, error: error, complete: complete } : x);
+ };
+ Observable.prototype[symbolObservable] = function () {
+ return this;
+ };
+ return Observable;
+ }());
+
+ var domDeps;
+ try {
+ domDeps = {
+ indexedDB: _global.indexedDB || _global.mozIndexedDB || _global.webkitIndexedDB || _global.msIndexedDB,
+ IDBKeyRange: _global.IDBKeyRange || _global.webkitIDBKeyRange
+ };
+ }
+ catch (e) {
+ domDeps = { indexedDB: null, IDBKeyRange: null };
+ }
+
+ function liveQuery(querier) {
+ var hasValue = false;
+ var currentValue = undefined;
+ var observable = new Observable(function (observer) {
+ var scopeFuncIsAsync = isAsyncFunction(querier);
+ function execute(ctx) {
+ if (scopeFuncIsAsync) {
+ incrementExpectedAwaits();
+ }
+ var rv = newScope(querier, ctx);
+ if (scopeFuncIsAsync) {
+ rv.then(decrementExpectedAwaits, decrementExpectedAwaits);
+ }
+ return rv;
+ }
+ var closed = false;
+ var abortController;
+ var txs = [];
+ var accumMuts = {};
+ var currentObs = {};
+ var subscription = {
+ get closed() {
+ return closed;
+ },
+ unsubscribe: function () {
+ closed = true;
+ if (abortController)
+ abortController.abort();
+ globalEvents.storagemutated.unsubscribe(mutationListener);
+ txs.forEach(function (idbtrans) {
+ idbtrans.aborted = true;
+ try {
+ idbtrans.abort();
+ }
+ catch (_a) { }
+ });
+ },
+ };
+ observer.start && observer.start(subscription);
+ var startedListening = false;
+ function shouldNotify() {
+ return obsSetsOverlap(currentObs, accumMuts);
+ }
+ var mutationListener = function (parts) {
+ extendObservabilitySet(accumMuts, parts);
+ if (shouldNotify()) {
+ doQuery();
+ }
+ };
+ var doQuery = function () {
+ if (closed ||
+ !domDeps.indexedDB)
+ {
+ return;
+ }
+ accumMuts = {};
+ var subscr = {};
+ if (abortController)
+ abortController.abort();
+ abortController = new AbortController();
+ if (txs.length) {
+ txs.forEach(function (idbtrans) {
+ idbtrans.aborted = true;
+ try {
+ idbtrans.abort();
+ }
+ catch (_a) { }
+ });
+ txs.length = 0;
+ }
+ var ctx = {
+ subscr: subscr,
+ txs: txs,
+ signal: abortController.signal,
+ requery: doQuery,
+ trans: null
+ };
+ var ret = execute(ctx);
+ if (!startedListening) {
+ globalEvents(DEXIE_STORAGE_MUTATED_EVENT_NAME, mutationListener);
+ startedListening = true;
+ }
+ Promise.resolve(ret).then(function (result) {
+ hasValue = true;
+ currentValue = result;
+ if (closed || ctx.signal.aborted) {
+ return;
+ }
+ accumMuts = {};
+ currentObs = subscr;
+ observer.next && observer.next(result);
+ }, function (err) {
+ hasValue = false;
+ if (!['DatabaseClosedError', 'AbortError'].includes(err === null || err === void 0 ? void 0 : err.name)) {
+ if (closed)
+ return;
+ observer.error && observer.error(err);
+ }
+ });
+ };
+ doQuery();
+ return subscription;
+ });
+ observable.hasValue = function () { return hasValue; };
+ observable.getValue = function () { return currentValue; };
+ return observable;
+ }
+
+ var Dexie = Dexie$1;
+ props(Dexie, __assign(__assign({}, fullNameExceptions), {
+ delete: function (databaseName) {
+ var db = new Dexie(databaseName, { addons: [] });
+ return db.delete();
+ },
+ exists: function (name) {
+ return new Dexie(name, { addons: [] }).open().then(function (db) {
+ db.close();
+ return true;
+ }).catch('NoSuchDatabaseError', function () { return false; });
+ },
+ getDatabaseNames: function (cb) {
+ try {
+ return getDatabaseNames(Dexie.dependencies).then(cb);
+ }
+ catch (_a) {
+ return rejection(new exceptions.MissingAPI());
+ }
+ },
+ defineClass: function () {
+ function Class(content) {
+ extend(this, content);
+ }
+ return Class;
+ }, ignoreTransaction: function (scopeFunc) {
+ return PSD.trans ?
+ usePSD(PSD.transless, scopeFunc) :
+ scopeFunc();
+ }, vip: vip, async: function (generatorFn) {
+ return function () {
+ try {
+ var rv = awaitIterator(generatorFn.apply(this, arguments));
+ if (!rv || typeof rv.then !== 'function')
+ return DexiePromise.resolve(rv);
+ return rv;
+ }
+ catch (e) {
+ return rejection(e);
+ }
+ };
+ }, spawn: function (generatorFn, args, thiz) {
+ try {
+ var rv = awaitIterator(generatorFn.apply(thiz, args || []));
+ if (!rv || typeof rv.then !== 'function')
+ return DexiePromise.resolve(rv);
+ return rv;
+ }
+ catch (e) {
+ return rejection(e);
+ }
+ },
+ currentTransaction: {
+ get: function () { return PSD.trans || null; }
+ }, waitFor: function (promiseOrFunction, optionalTimeout) {
+ var promise = DexiePromise.resolve(typeof promiseOrFunction === 'function' ?
+ Dexie.ignoreTransaction(promiseOrFunction) :
+ promiseOrFunction)
+ .timeout(optionalTimeout || 60000);
+ return PSD.trans ?
+ PSD.trans.waitFor(promise) :
+ promise;
+ },
+ Promise: DexiePromise,
+ debug: {
+ get: function () { return debug; },
+ set: function (value) {
+ setDebug(value, value === 'dexie' ? function () { return true; } : dexieStackFrameFilter);
+ }
+ },
+ derive: derive, extend: extend, props: props, override: override,
+ Events: Events, on: globalEvents, liveQuery: liveQuery, extendObservabilitySet: extendObservabilitySet,
+ getByKeyPath: getByKeyPath, setByKeyPath: setByKeyPath, delByKeyPath: delByKeyPath, shallowClone: shallowClone, deepClone: deepClone, getObjectDiff: getObjectDiff, cmp: cmp, asap: asap$1,
+ minKey: minKey,
+ addons: [],
+ connections: connections,
+ errnames: errnames,
+ dependencies: domDeps, cache: cache,
+ semVer: DEXIE_VERSION, version: DEXIE_VERSION.split('.')
+ .map(function (n) { return parseInt(n); })
+ .reduce(function (p, c, i) { return p + (c / Math.pow(10, i * 2)); }) }));
+ Dexie.maxKey = getMaxKey(Dexie.dependencies.IDBKeyRange);
+
+ if (typeof dispatchEvent !== 'undefined' && typeof addEventListener !== 'undefined') {
+ globalEvents(DEXIE_STORAGE_MUTATED_EVENT_NAME, function (updatedParts) {
+ if (!propagatingLocally) {
+ var event_1;
+ if (isIEOrEdge) {
+ event_1 = document.createEvent('CustomEvent');
+ event_1.initCustomEvent(STORAGE_MUTATED_DOM_EVENT_NAME, true, true, updatedParts);
+ }
+ else {
+ event_1 = new CustomEvent(STORAGE_MUTATED_DOM_EVENT_NAME, {
+ detail: updatedParts
+ });
+ }
+ propagatingLocally = true;
+ dispatchEvent(event_1);
+ propagatingLocally = false;
+ }
+ });
+ addEventListener(STORAGE_MUTATED_DOM_EVENT_NAME, function (_a) {
+ var detail = _a.detail;
+ if (!propagatingLocally) {
+ propagateLocally(detail);
+ }
+ });
+ }
+ function propagateLocally(updateParts) {
+ var wasMe = propagatingLocally;
+ try {
+ propagatingLocally = true;
+ globalEvents.storagemutated.fire(updateParts);
+ }
+ finally {
+ propagatingLocally = wasMe;
+ }
+ }
+ var propagatingLocally = false;
+
+ if (typeof BroadcastChannel !== 'undefined') {
+ var bc_1 = new BroadcastChannel(STORAGE_MUTATED_DOM_EVENT_NAME);
+ if (typeof bc_1.unref === 'function') {
+ bc_1.unref();
+ }
+ globalEvents(DEXIE_STORAGE_MUTATED_EVENT_NAME, function (changedParts) {
+ if (!propagatingLocally) {
+ bc_1.postMessage(changedParts);
+ }
+ });
+ bc_1.onmessage = function (ev) {
+ if (ev.data)
+ propagateLocally(ev.data);
+ };
+ }
+ else if (typeof self !== 'undefined' && typeof navigator !== 'undefined') {
+ globalEvents(DEXIE_STORAGE_MUTATED_EVENT_NAME, function (changedParts) {
+ try {
+ if (!propagatingLocally) {
+ if (typeof localStorage !== 'undefined') {
+ localStorage.setItem(STORAGE_MUTATED_DOM_EVENT_NAME, JSON.stringify({
+ trig: Math.random(),
+ changedParts: changedParts,
+ }));
+ }
+ if (typeof self['clients'] === 'object') {
+ __spreadArray([], self['clients'].matchAll({ includeUncontrolled: true }), true).forEach(function (client) {
+ return client.postMessage({
+ type: STORAGE_MUTATED_DOM_EVENT_NAME,
+ changedParts: changedParts,
+ });
+ });
+ }
+ }
+ }
+ catch (_a) { }
+ });
+ if (typeof addEventListener !== 'undefined') {
+ addEventListener('storage', function (ev) {
+ if (ev.key === STORAGE_MUTATED_DOM_EVENT_NAME) {
+ var data = JSON.parse(ev.newValue);
+ if (data)
+ propagateLocally(data.changedParts);
+ }
+ });
+ }
+ var swContainer = self.document && navigator.serviceWorker;
+ if (swContainer) {
+ swContainer.addEventListener('message', propagateMessageLocally);
+ }
+ }
+ function propagateMessageLocally(_a) {
+ var data = _a.data;
+ if (data && data.type === STORAGE_MUTATED_DOM_EVENT_NAME) {
+ propagateLocally(data.changedParts);
+ }
+ }
+
+ DexiePromise.rejectionMapper = mapError;
+ setDebug(debug, dexieStackFrameFilter);
+
+ var namedExports = /*#__PURE__*/Object.freeze({
+ __proto__: null,
+ Dexie: Dexie$1,
+ liveQuery: liveQuery,
+ Entity: Entity,
+ cmp: cmp,
+ 'default': Dexie$1,
+ RangeSet: RangeSet,
+ mergeRanges: mergeRanges,
+ rangesOverlap: rangesOverlap
+ });
+
+ __assign(Dexie$1, namedExports, { default: Dexie$1 });
+
+ return Dexie$1;
+
+}));
+//# sourceMappingURL=dexie.js.map
diff --git a/grails-app/assets/vendor/dexiejs/dexie.js.map b/grails-app/assets/vendor/dexiejs/dexie.js.map
new file mode 100644
index 000000000..5ebeb62fb
--- /dev/null
+++ b/grails-app/assets/vendor/dexiejs/dexie.js.map
@@ -0,0 +1 @@
+{"version":3,"file":"dexie.js","sources":["../node_modules/.pnpm/tslib@2.3.1/node_modules/tslib/tslib.es6.js","../src/globals/global.ts","../src/functions/utils.ts","../src/helpers/debug.ts","../src/errors/errors.js","../src/functions/chaining-functions.js","../src/helpers/promise.js","../src/functions/temp-transaction.ts","../src/globals/constants.ts","../src/functions/combine.ts","../src/dbcore/keyrange.ts","../src/functions/workaround-undefined-primkey.ts","../src/classes/entity/Entity.ts","../src/functions/cmp.ts","../src/classes/table/table.ts","../src/helpers/Events.js","../src/functions/make-class-constructor.ts","../src/classes/table/table-constructor.ts","../src/classes/collection/collection-helpers.ts","../src/classes/collection/collection.ts","../src/classes/collection/collection-constructor.ts","../src/functions/compare-functions.ts","../src/classes/where-clause/where-clause-helpers.ts","../src/classes/where-clause/where-clause.ts","../src/classes/where-clause/where-clause-constructor.ts","../src/functions/event-wrappers.ts","../src/globals/global-events.ts","../src/classes/transaction/transaction.ts","../src/classes/transaction/transaction-constructor.ts","../src/helpers/index-spec.ts","../src/helpers/table-schema.ts","../src/functions/quirks.ts","../src/dbcore/get-key-extractor.ts","../src/dbcore/dbcore-indexeddb.ts","../src/classes/dexie/generate-middleware-stacks.ts","../src/classes/version/schema-helpers.ts","../src/classes/version/version.ts","../src/classes/version/version-constructor.ts","../src/helpers/database-enumerator.ts","../src/classes/dexie/vip.ts","../node_modules/.pnpm/safari-14-idb-fix@3.0.0/node_modules/safari-14-idb-fix/dist/index.js","../src/classes/dexie/dexie-open.ts","../src/helpers/yield-support.ts","../src/classes/dexie/transaction-helpers.ts","../src/dbcore/virtual-index-middleware.ts","../src/functions/get-object-diff.ts","../src/dbcore/get-effective-keys.ts","../src/hooks/hooks-middleware.ts","../src/dbcore/cache-existing-values-middleware.ts","../src/helpers/rangeset.ts","../src/live-query/cache/is-cachable-context.ts","../src/live-query/cache/is-cachable-request.ts","../src/live-query/extend-observability-set.ts","../src/live-query/observability-middleware.ts","../src/live-query/cache/is-within-range.ts","../src/live-query/cache/apply-optimistic-ops.ts","../src/live-query/cache/cache.ts","../src/live-query/cache/are-ranges-equal.ts","../src/live-query/cache/is-super-range.ts","../src/live-query/cache/find-compatible-query.ts","../src/live-query/obs-sets-overlap.ts","../src/live-query/cache/signalSubscribers.ts","../src/live-query/cache/subscribe-cachentry.ts","../src/live-query/cache/cache-middleware.ts","../src/classes/dexie/dexie.ts","../src/classes/observable/observable.ts","../src/classes/dexie/dexie-dom-dependencies.ts","../src/live-query/live-query.ts","../src/classes/dexie/dexie-static-props.ts","../src/live-query/propagate-locally.ts","../src/live-query/enable-broadcast.ts","../src/index.ts","../src/index-umd.ts"],"sourcesContent":["/*! *****************************************************************************\r\nCopyright (c) Microsoft Corporation.\r\n\r\nPermission to use, copy, modify, and/or distribute this software for any\r\npurpose with or without fee is hereby granted.\r\n\r\nTHE SOFTWARE IS PROVIDED \"AS IS\" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH\r\nREGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY\r\nAND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT,\r\nINDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM\r\nLOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR\r\nOTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR\r\nPERFORMANCE OF THIS SOFTWARE.\r\n***************************************************************************** */\r\n/* global Reflect, Promise */\r\n\r\nvar extendStatics = function(d, b) {\r\n extendStatics = Object.setPrototypeOf ||\r\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\r\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\r\n return extendStatics(d, b);\r\n};\r\n\r\nexport function __extends(d, b) {\r\n if (typeof b !== \"function\" && b !== null)\r\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\r\n extendStatics(d, b);\r\n function __() { this.constructor = d; }\r\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\r\n}\r\n\r\nexport var __assign = function() {\r\n __assign = Object.assign || function __assign(t) {\r\n for (var s, i = 1, n = arguments.length; i < n; i++) {\r\n s = arguments[i];\r\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p];\r\n }\r\n return t;\r\n }\r\n return __assign.apply(this, arguments);\r\n}\r\n\r\nexport function __rest(s, e) {\r\n var t = {};\r\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)\r\n t[p] = s[p];\r\n if (s != null && typeof Object.getOwnPropertySymbols === \"function\")\r\n for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {\r\n if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))\r\n t[p[i]] = s[p[i]];\r\n }\r\n return t;\r\n}\r\n\r\nexport function __decorate(decorators, target, key, desc) {\r\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\r\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\r\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\r\n return c > 3 && r && Object.defineProperty(target, key, r), r;\r\n}\r\n\r\nexport function __param(paramIndex, decorator) {\r\n return function (target, key) { decorator(target, key, paramIndex); }\r\n}\r\n\r\nexport function __metadata(metadataKey, metadataValue) {\r\n if (typeof Reflect === \"object\" && typeof Reflect.metadata === \"function\") return Reflect.metadata(metadataKey, metadataValue);\r\n}\r\n\r\nexport function __awaiter(thisArg, _arguments, P, generator) {\r\n function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }\r\n return new (P || (P = Promise))(function (resolve, reject) {\r\n function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\r\n function rejected(value) { try { step(generator[\"throw\"](value)); } catch (e) { reject(e); } }\r\n function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }\r\n step((generator = generator.apply(thisArg, _arguments || [])).next());\r\n });\r\n}\r\n\r\nexport function __generator(thisArg, body) {\r\n var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;\r\n return g = { next: verb(0), \"throw\": verb(1), \"return\": verb(2) }, typeof Symbol === \"function\" && (g[Symbol.iterator] = function() { return this; }), g;\r\n function verb(n) { return function (v) { return step([n, v]); }; }\r\n function step(op) {\r\n if (f) throw new TypeError(\"Generator is already executing.\");\r\n while (_) try {\r\n if (f = 1, y && (t = op[0] & 2 ? y[\"return\"] : op[0] ? y[\"throw\"] || ((t = y[\"return\"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;\r\n if (y = 0, t) op = [op[0] & 2, t.value];\r\n switch (op[0]) {\r\n case 0: case 1: t = op; break;\r\n case 4: _.label++; return { value: op[1], done: false };\r\n case 5: _.label++; y = op[1]; op = [0]; continue;\r\n case 7: op = _.ops.pop(); _.trys.pop(); continue;\r\n default:\r\n if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }\r\n if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }\r\n if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }\r\n if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }\r\n if (t[2]) _.ops.pop();\r\n _.trys.pop(); continue;\r\n }\r\n op = body.call(thisArg, _);\r\n } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }\r\n if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };\r\n }\r\n}\r\n\r\nexport var __createBinding = Object.create ? (function(o, m, k, k2) {\r\n if (k2 === undefined) k2 = k;\r\n Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });\r\n}) : (function(o, m, k, k2) {\r\n if (k2 === undefined) k2 = k;\r\n o[k2] = m[k];\r\n});\r\n\r\nexport function __exportStar(m, o) {\r\n for (var p in m) if (p !== \"default\" && !Object.prototype.hasOwnProperty.call(o, p)) __createBinding(o, m, p);\r\n}\r\n\r\nexport function __values(o) {\r\n var s = typeof Symbol === \"function\" && Symbol.iterator, m = s && o[s], i = 0;\r\n if (m) return m.call(o);\r\n if (o && typeof o.length === \"number\") return {\r\n next: function () {\r\n if (o && i >= o.length) o = void 0;\r\n return { value: o && o[i++], done: !o };\r\n }\r\n };\r\n throw new TypeError(s ? \"Object is not iterable.\" : \"Symbol.iterator is not defined.\");\r\n}\r\n\r\nexport function __read(o, n) {\r\n var m = typeof Symbol === \"function\" && o[Symbol.iterator];\r\n if (!m) return o;\r\n var i = m.call(o), r, ar = [], e;\r\n try {\r\n while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);\r\n }\r\n catch (error) { e = { error: error }; }\r\n finally {\r\n try {\r\n if (r && !r.done && (m = i[\"return\"])) m.call(i);\r\n }\r\n finally { if (e) throw e.error; }\r\n }\r\n return ar;\r\n}\r\n\r\n/** @deprecated */\r\nexport function __spread() {\r\n for (var ar = [], i = 0; i < arguments.length; i++)\r\n ar = ar.concat(__read(arguments[i]));\r\n return ar;\r\n}\r\n\r\n/** @deprecated */\r\nexport function __spreadArrays() {\r\n for (var s = 0, i = 0, il = arguments.length; i < il; i++) s += arguments[i].length;\r\n for (var r = Array(s), k = 0, i = 0; i < il; i++)\r\n for (var a = arguments[i], j = 0, jl = a.length; j < jl; j++, k++)\r\n r[k] = a[j];\r\n return r;\r\n}\r\n\r\nexport function __spreadArray(to, from, pack) {\r\n if (pack || arguments.length === 2) for (var i = 0, l = from.length, ar; i < l; i++) {\r\n if (ar || !(i in from)) {\r\n if (!ar) ar = Array.prototype.slice.call(from, 0, i);\r\n ar[i] = from[i];\r\n }\r\n }\r\n return to.concat(ar || Array.prototype.slice.call(from));\r\n}\r\n\r\nexport function __await(v) {\r\n return this instanceof __await ? (this.v = v, this) : new __await(v);\r\n}\r\n\r\nexport function __asyncGenerator(thisArg, _arguments, generator) {\r\n if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\r\n var g = generator.apply(thisArg, _arguments || []), i, q = [];\r\n return i = {}, verb(\"next\"), verb(\"throw\"), verb(\"return\"), i[Symbol.asyncIterator] = function () { return this; }, i;\r\n function verb(n) { if (g[n]) i[n] = function (v) { return new Promise(function (a, b) { q.push([n, v, a, b]) > 1 || resume(n, v); }); }; }\r\n function resume(n, v) { try { step(g[n](v)); } catch (e) { settle(q[0][3], e); } }\r\n function step(r) { r.value instanceof __await ? Promise.resolve(r.value.v).then(fulfill, reject) : settle(q[0][2], r); }\r\n function fulfill(value) { resume(\"next\", value); }\r\n function reject(value) { resume(\"throw\", value); }\r\n function settle(f, v) { if (f(v), q.shift(), q.length) resume(q[0][0], q[0][1]); }\r\n}\r\n\r\nexport function __asyncDelegator(o) {\r\n var i, p;\r\n return i = {}, verb(\"next\"), verb(\"throw\", function (e) { throw e; }), verb(\"return\"), i[Symbol.iterator] = function () { return this; }, i;\r\n function verb(n, f) { i[n] = o[n] ? function (v) { return (p = !p) ? { value: __await(o[n](v)), done: n === \"return\" } : f ? f(v) : v; } : f; }\r\n}\r\n\r\nexport function __asyncValues(o) {\r\n if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\r\n var m = o[Symbol.asyncIterator], i;\r\n return m ? m.call(o) : (o = typeof __values === \"function\" ? __values(o) : o[Symbol.iterator](), i = {}, verb(\"next\"), verb(\"throw\"), verb(\"return\"), i[Symbol.asyncIterator] = function () { return this; }, i);\r\n function verb(n) { i[n] = o[n] && function (v) { return new Promise(function (resolve, reject) { v = o[n](v), settle(resolve, reject, v.done, v.value); }); }; }\r\n function settle(resolve, reject, d, v) { Promise.resolve(v).then(function(v) { resolve({ value: v, done: d }); }, reject); }\r\n}\r\n\r\nexport function __makeTemplateObject(cooked, raw) {\r\n if (Object.defineProperty) { Object.defineProperty(cooked, \"raw\", { value: raw }); } else { cooked.raw = raw; }\r\n return cooked;\r\n};\r\n\r\nvar __setModuleDefault = Object.create ? (function(o, v) {\r\n Object.defineProperty(o, \"default\", { enumerable: true, value: v });\r\n}) : function(o, v) {\r\n o[\"default\"] = v;\r\n};\r\n\r\nexport function __importStar(mod) {\r\n if (mod && mod.__esModule) return mod;\r\n var result = {};\r\n if (mod != null) for (var k in mod) if (k !== \"default\" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);\r\n __setModuleDefault(result, mod);\r\n return result;\r\n}\r\n\r\nexport function __importDefault(mod) {\r\n return (mod && mod.__esModule) ? mod : { default: mod };\r\n}\r\n\r\nexport function __classPrivateFieldGet(receiver, state, kind, f) {\r\n if (kind === \"a\" && !f) throw new TypeError(\"Private accessor was defined without a getter\");\r\n if (typeof state === \"function\" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError(\"Cannot read private member from an object whose class did not declare it\");\r\n return kind === \"m\" ? f : kind === \"a\" ? f.call(receiver) : f ? f.value : state.get(receiver);\r\n}\r\n\r\nexport function __classPrivateFieldSet(receiver, state, value, kind, f) {\r\n if (kind === \"m\") throw new TypeError(\"Private method is not writable\");\r\n if (kind === \"a\" && !f) throw new TypeError(\"Private accessor was defined without a setter\");\r\n if (typeof state === \"function\" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError(\"Cannot write private member to an object whose class did not declare it\");\r\n return (kind === \"a\" ? f.call(receiver, value) : f ? f.value = value : state.set(receiver, value)), value;\r\n}\r\n","declare var global;\nexport const _global: any =\n typeof globalThis !== 'undefined' ? globalThis :\n typeof self !== 'undefined' ? self :\n typeof window !== 'undefined' ? window :\n global;\n","import { _global } from \"../globals/global\";\nexport const keys = Object.keys;\nexport const isArray = Array.isArray;\nif (typeof Promise !== 'undefined' && !_global.Promise){\n // In jsdom, this it can be the case that Promise is not put on the global object.\n // If so, we need to patch the global object for the rest of the code to work as expected.\n // Other dexie code expects Promise to be on the global object (like normal browser environments)\n _global.Promise = Promise;\n}\nexport { _global }\n\nexport function extend(obj: T, extension: X): T & X {\n if (typeof extension !== 'object') return obj as T & X;\n keys(extension).forEach(function (key) {\n obj[key] = extension[key];\n });\n return obj as T & X;\n}\n\nexport const getProto = Object.getPrototypeOf;\nexport const _hasOwn = {}.hasOwnProperty;\nexport function hasOwn(obj, prop) {\n return _hasOwn.call(obj, prop);\n}\n\nexport function props (proto, extension) {\n if (typeof extension === 'function') extension = extension(getProto(proto));\n (typeof Reflect === \"undefined\" ? keys : Reflect.ownKeys)(extension).forEach(key => {\n setProp(proto, key, extension[key]);\n });\n}\n\nexport const defineProperty = Object.defineProperty;\n\nexport function setProp(obj, prop, functionOrGetSet, options?) {\n defineProperty(obj, prop, extend(functionOrGetSet && hasOwn(functionOrGetSet, \"get\") && typeof functionOrGetSet.get === 'function' ?\n {get: functionOrGetSet.get, set: functionOrGetSet.set, configurable: true} :\n {value: functionOrGetSet, configurable: true, writable: true}, options));\n}\n\nexport function derive(Child) {\n return {\n from: function (Parent) {\n Child.prototype = Object.create(Parent.prototype);\n setProp(Child.prototype, \"constructor\", Child);\n return {\n extend: props.bind(null, Child.prototype)\n };\n }\n };\n}\n\nexport const getOwnPropertyDescriptor = Object.getOwnPropertyDescriptor;\n\nexport function getPropertyDescriptor(obj, prop) {\n const pd = getOwnPropertyDescriptor(obj, prop);\n let proto;\n return pd || (proto = getProto(obj)) && getPropertyDescriptor (proto, prop);\n}\n\nconst _slice = [].slice;\nexport function slice(args, start?, end?) {\n return _slice.call(args, start, end);\n}\n\nexport function override(origFunc, overridedFactory) {\n return overridedFactory(origFunc);\n}\n\nexport function assert (b) {\n if (!b) throw new Error(\"Assertion Failed\");\n}\n\nexport function asap(fn) {\n // @ts-ignore\n if (_global.setImmediate) setImmediate(fn); else setTimeout(fn, 0);\n}\n\nexport function getUniqueArray(a) {\n return a.filter((value, index, self) => self.indexOf(value) === index);\n}\n\n/** Generate an object (hash map) based on given array.\n * @param extractor Function taking an array item and its index and returning an array of 2 items ([key, value]) to\n * instert on the resulting object for each item in the array. If this function returns a falsy value, the\n * current item wont affect the resulting object.\n */\nexport function arrayToObject (array: T[], extractor: (x:T, idx: number)=>[string, R]): {[name: string]: R} {\n return array.reduce((result, item, i) => {\n var nameAndValue = extractor(item, i);\n if (nameAndValue) result[nameAndValue[0]] = nameAndValue[1];\n return result;\n }, {});\n}\n\nexport function trycatcher(fn, reject) {\n return function () {\n try {\n fn.apply(this, arguments);\n } catch (e) {\n reject(e);\n }\n };\n}\n\nexport function tryCatch(fn: (...args: any[])=>void, onerror, args?) : void {\n try {\n fn.apply(null, args);\n } catch (ex) {\n onerror && onerror(ex);\n }\n}\n\nexport function getByKeyPath(obj, keyPath) {\n // http://www.w3.org/TR/IndexedDB/#steps-for-extracting-a-key-from-a-value-using-a-key-path\n if (hasOwn(obj, keyPath)) return obj[keyPath]; // This line is moved from last to first for optimization purpose.\n if (!keyPath) return obj;\n if (typeof keyPath !== 'string') {\n var rv = [];\n for (var i = 0, l = keyPath.length; i < l; ++i) {\n var val = getByKeyPath(obj, keyPath[i]);\n rv.push(val);\n }\n return rv;\n }\n var period = keyPath.indexOf('.');\n if (period !== -1) {\n var innerObj = obj[keyPath.substr(0, period)];\n return innerObj === undefined ? undefined : getByKeyPath(innerObj, keyPath.substr(period + 1));\n }\n return undefined;\n}\n\nexport function setByKeyPath(obj, keyPath, value) {\n if (!obj || keyPath === undefined) return;\n if ('isFrozen' in Object && Object.isFrozen(obj)) return;\n if (typeof keyPath !== 'string' && 'length' in keyPath) {\n assert(typeof value !== 'string' && 'length' in value);\n for (var i = 0, l = keyPath.length; i < l; ++i) {\n setByKeyPath(obj, keyPath[i], value[i]);\n }\n } else {\n var period = keyPath.indexOf('.');\n if (period !== -1) {\n var currentKeyPath = keyPath.substr(0, period);\n var remainingKeyPath = keyPath.substr(period + 1);\n if (remainingKeyPath === \"\")\n if (value === undefined) {\n if (isArray(obj) && !isNaN(parseInt(currentKeyPath))) obj.splice(currentKeyPath, 1);\n else delete obj[currentKeyPath];\n } else obj[currentKeyPath] = value;\n else {\n var innerObj = obj[currentKeyPath];\n if (!innerObj || !hasOwn(obj, currentKeyPath)) innerObj = (obj[currentKeyPath] = {});\n setByKeyPath(innerObj, remainingKeyPath, value);\n }\n } else {\n if (value === undefined) {\n if (isArray(obj) && !isNaN(parseInt(keyPath))) obj.splice(keyPath, 1);\n else delete obj[keyPath];\n } else obj[keyPath] = value;\n }\n }\n}\n\nexport function delByKeyPath(obj, keyPath) {\n if (typeof keyPath === 'string')\n setByKeyPath(obj, keyPath, undefined);\n else if ('length' in keyPath)\n [].map.call(keyPath, function(kp) {\n setByKeyPath(obj, kp, undefined);\n });\n}\n\nexport function shallowClone(obj) {\n var rv = {};\n for (var m in obj) {\n if (hasOwn(obj, m)) rv[m] = obj[m];\n }\n return rv;\n}\n\nconst concat = [].concat;\nexport function flatten (a: (T | T[])[]) : T[] {\n return concat.apply([], a);\n}\n\n//https://developer.mozilla.org/en-US/docs/Web/API/Web_Workers_API/Structured_clone_algorithm\nconst intrinsicTypeNames =\n \"Boolean,String,Date,RegExp,Blob,File,FileList,FileSystemFileHandle,FileSystemDirectoryHandle,ArrayBuffer,DataView,Uint8ClampedArray,ImageBitmap,ImageData,Map,Set,CryptoKey\"\n .split(',').concat(\n flatten([8,16,32,64].map(num=>[\"Int\",\"Uint\",\"Float\"].map(t=>t+num+\"Array\")))\n ).filter(t=>_global[t]);\nconst intrinsicTypes = intrinsicTypeNames.map(t=>_global[t]);\nexport const intrinsicTypeNameSet = arrayToObject(intrinsicTypeNames, x=>[x,true]);\n\nlet circularRefs: null | WeakMap = null;\nexport function deepClone(any: T): T {\n circularRefs = new WeakMap();\n const rv = innerDeepClone(any);\n circularRefs = null;\n return rv;\n}\n\nfunction innerDeepClone(x: T): T {\n if (!x || typeof x !== 'object') return x;\n let rv = circularRefs.get(x); // Resolve circular references\n if (rv) return rv;\n if (isArray(x)) {\n rv = [];\n circularRefs.set(x, rv);\n for (var i = 0, l = x.length; i < l; ++i) {\n rv.push(innerDeepClone(x[i]));\n }\n } else if (intrinsicTypes.indexOf(x.constructor) >= 0) {\n // For performance, we're less strict than structuredClone - we're only\n // cloning arrays and custom objects.\n // Typed arrays, Dates etc are not cloned.\n rv = x;\n } else {\n // We're nicer to custom classes than what structuredClone() is -\n // we preserve the proto of each object.\n const proto = getProto(x);\n rv = proto === Object.prototype ? {} : Object.create(proto);\n circularRefs.set(x, rv);\n for (var prop in x) {\n if (hasOwn(x, prop)) {\n rv[prop] = innerDeepClone(x[prop]);\n }\n }\n }\n return rv;\n}\n\nconst {toString} = {};\nexport function toStringTag(o: Object) {\n return toString.call(o).slice(8, -1);\n}\n\n// If first argument is iterable or array-like, return it as an array\nexport const iteratorSymbol = typeof Symbol !== 'undefined' ?\n Symbol.iterator :\n '@@iterator';\nexport const getIteratorOf = typeof iteratorSymbol === \"symbol\" ? function(x) {\n var i;\n return x != null && (i = x[iteratorSymbol]) && i.apply(x);\n} : function () { return null; };\nexport const asyncIteratorSymbol = typeof Symbol !== 'undefined'\n ? Symbol.asyncIterator || Symbol.for(\"Symbol.asyncIterator\")\n : '@asyncIterator';\n\nexport function delArrayItem(a: any[], x: any) {\n const i = a.indexOf(x);\n if (i >= 0) a.splice(i, 1);\n return i >= 0;\n}\n\nexport const NO_CHAR_ARRAY = {};\n// Takes one or several arguments and returns an array based on the following criteras:\n// * If several arguments provided, return arguments converted to an array in a way that\n// still allows javascript engine to optimize the code.\n// * If single argument is an array, return a clone of it.\n// * If this-pointer equals NO_CHAR_ARRAY, don't accept strings as valid iterables as a special\n// case to the two bullets below.\n// * If single argument is an iterable, convert it to an array and return the resulting array.\n// * If single argument is array-like (has length of type number), convert it to an array.\nexport function getArrayOf (arrayLike) {\n var i, a, x, it;\n if (arguments.length === 1) {\n if (isArray(arrayLike)) return arrayLike.slice();\n if (this === NO_CHAR_ARRAY && typeof arrayLike === 'string') return [arrayLike];\n if ((it = getIteratorOf(arrayLike))) {\n a = [];\n while ((x = it.next()), !x.done) a.push(x.value);\n return a;\n }\n if (arrayLike == null) return [arrayLike];\n i = arrayLike.length;\n if (typeof i === 'number') {\n a = new Array(i);\n while (i--) a[i] = arrayLike[i];\n return a;\n }\n return [arrayLike];\n }\n i = arguments.length;\n a = new Array(i);\n while (i--) a[i] = arguments[i];\n return a;\n}\nexport const isAsyncFunction = typeof Symbol !== 'undefined'\n ? (fn: Function) => fn[Symbol.toStringTag] === 'AsyncFunction'\n : ()=>false;\n","// By default, debug will be true only if platform is a web platform and its page is served from localhost.\n// When debug = true, error's stacks will contain asyncronic long stacks.\nexport var debug = typeof location !== 'undefined' &&\n // By default, use debug mode if served from localhost.\n /^(http|https):\\/\\/(localhost|127\\.0\\.0\\.1)/.test(location.href);\n\nexport function setDebug(value, filter) {\n debug = value;\n libraryFilter = filter;\n}\n\nexport var libraryFilter = () => true;\n\nexport const NEEDS_THROW_FOR_STACK = !new Error(\"\").stack;\n\nexport function getErrorWithStack() {\n \"use strict\";\n if (NEEDS_THROW_FOR_STACK) try {\n // Doing something naughty in strict mode here to trigger a specific error\n // that can be explicitely ignored in debugger's exception settings.\n // If we'd just throw new Error() here, IE's debugger's exception settings\n // will just consider it as \"exception thrown by javascript code\" which is\n // something you wouldn't want it to ignore.\n getErrorWithStack.arguments;\n throw new Error(); // Fallback if above line don't throw.\n } catch(e) {\n return e;\n }\n return new Error();\n}\n\nexport function prettyStack(exception, numIgnoredFrames) {\n var stack = exception.stack;\n if (!stack) return \"\";\n numIgnoredFrames = (numIgnoredFrames || 0);\n if (stack.indexOf(exception.name) === 0)\n numIgnoredFrames += (exception.name + exception.message).split('\\n').length;\n return stack.split('\\n')\n .slice(numIgnoredFrames)\n .filter(libraryFilter)\n .map(frame => \"\\n\" + frame)\n .join('');\n}\n\n// TODO: Replace this in favor of a decorator instead.\nexport function deprecated (what: string, fn: (...args)=>T) {\n return function () {\n console.warn(`${what} is deprecated. See https://dexie.org/docs/Deprecations. ${prettyStack(getErrorWithStack(), 1)}`);\n return fn.apply(this, arguments);\n } as (...args)=>T\n}\n","import { derive, setProp } from '../functions/utils';\nimport { getErrorWithStack, prettyStack } from '../helpers/debug';\n\nvar dexieErrorNames = [\n 'Modify',\n 'Bulk',\n 'OpenFailed',\n 'VersionChange',\n 'Schema',\n 'Upgrade',\n 'InvalidTable',\n 'MissingAPI',\n 'NoSuchDatabase',\n 'InvalidArgument',\n 'SubTransaction',\n 'Unsupported',\n 'Internal',\n 'DatabaseClosed',\n 'PrematureCommit',\n 'ForeignAwait'\n];\n\nvar idbDomErrorNames = [\n 'Unknown',\n 'Constraint',\n 'Data',\n 'TransactionInactive',\n 'ReadOnly',\n 'Version',\n 'NotFound',\n 'InvalidState',\n 'InvalidAccess',\n 'Abort',\n 'Timeout',\n 'QuotaExceeded',\n 'Syntax',\n 'DataClone'\n];\n\nvar errorList = dexieErrorNames.concat(idbDomErrorNames);\n\nvar defaultTexts = {\n VersionChanged: \"Database version changed by other database connection\",\n DatabaseClosed: \"Database has been closed\",\n Abort: \"Transaction aborted\",\n TransactionInactive: \"Transaction has already completed or failed\",\n MissingAPI: \"IndexedDB API missing. Please visit https://tinyurl.com/y2uuvskb\"\n};\n\n//\n// DexieError - base class of all out exceptions.\n//\nexport function DexieError (name, msg) {\n // Reason we don't use ES6 classes is because:\n // 1. It bloats transpiled code and increases size of minified code.\n // 2. It doesn't give us much in this case.\n // 3. It would require sub classes to call super(), which\n // is not needed when deriving from Error.\n this._e = getErrorWithStack();\n this.name = name;\n this.message = msg;\n}\n\nderive(DexieError).from(Error).extend({\n stack: {\n get: function() {\n return this._stack ||\n (this._stack = this.name + \": \" + this.message + prettyStack(this._e, 2));\n }\n },\n toString: function(){ return this.name + \": \" + this.message; }\n});\n\nfunction getMultiErrorMessage (msg, failures) {\n return msg + \". Errors: \" + Object.keys(failures)\n .map(key=>failures[key].toString())\n .filter((v,i,s)=>s.indexOf(v) === i) // Only unique error strings\n .join('\\n');\n}\n\n//\n// ModifyError - thrown in Collection.modify()\n// Specific constructor because it contains members failures and failedKeys.\n//\nexport function ModifyError (msg, failures, successCount, failedKeys) {\n this._e = getErrorWithStack();\n this.failures = failures;\n this.failedKeys = failedKeys;\n this.successCount = successCount;\n this.message = getMultiErrorMessage(msg, failures);\n}\nderive(ModifyError).from(DexieError);\n\nexport function BulkError (msg, failures) {\n this._e = getErrorWithStack();\n this.name = \"BulkError\";\n this.failures = Object.keys(failures).map(pos => failures[pos]);\n this.failuresByPos = failures;\n this.message = getMultiErrorMessage(msg, this.failures);\n}\nderive(BulkError).from(DexieError);\n\n//\n//\n// Dynamically generate error names and exception classes based\n// on the names in errorList.\n//\n//\n\n// Map of {ErrorName -> ErrorName + \"Error\"}\nexport var errnames = errorList.reduce((obj,name)=>(obj[name]=name+\"Error\",obj),{});\n\n// Need an alias for DexieError because we're gonna create subclasses with the same name.\nconst BaseException = DexieError;\n// Map of {ErrorName -> exception constructor}\nexport var exceptions = errorList.reduce((obj,name)=>{\n // Let the name be \"DexieError\" because this name may\n // be shown in call stack and when debugging. DexieError is\n // the most true name because it derives from DexieError,\n // and we cannot change Function.name programatically without\n // dynamically create a Function object, which would be considered\n // 'eval-evil'.\n var fullName = name + \"Error\";\n function DexieError (msgOrInner, inner){\n this._e = getErrorWithStack();\n this.name = fullName;\n if (!msgOrInner) {\n this.message = defaultTexts[name] || fullName;\n this.inner = null;\n } else if (typeof msgOrInner === 'string') {\n this.message = `${msgOrInner}${!inner ? '' : '\\n ' + inner}`;\n this.inner = inner || null;\n } else if (typeof msgOrInner === 'object') {\n this.message = `${msgOrInner.name} ${msgOrInner.message}`;\n this.inner = msgOrInner;\n }\n }\n derive(DexieError).from(BaseException);\n obj[name]=DexieError;\n return obj;\n},{});\n\n// Use ECMASCRIPT standard exceptions where applicable:\nexceptions.Syntax = SyntaxError;\nexceptions.Type = TypeError;\nexceptions.Range = RangeError;\n\nexport var exceptionMap = idbDomErrorNames.reduce((obj, name)=>{\n obj[name + \"Error\"] = exceptions[name];\n return obj;\n}, {});\n\nexport function mapError (domError, message) {\n if (!domError || domError instanceof DexieError || domError instanceof TypeError || domError instanceof SyntaxError || !domError.name || !exceptionMap[domError.name])\n return domError;\n var rv = new exceptionMap[domError.name](message || domError.message, domError);\n if (\"stack\" in domError) {\n // Derive stack from inner exception if it has a stack\n setProp(rv, \"stack\", {get: function(){\n return this.inner.stack;\n }});\n }\n return rv;\n}\n\nexport var fullNameExceptions = errorList.reduce((obj, name)=>{\n if ([\"Syntax\",\"Type\",\"Range\"].indexOf(name) === -1)\n obj[name + \"Error\"] = exceptions[name];\n return obj;\n}, {});\n\nfullNameExceptions.ModifyError = ModifyError;\nfullNameExceptions.DexieError = DexieError;\nfullNameExceptions.BulkError = BulkError;\n","import {extend} from './utils';\n\nexport function nop() { }\nexport function mirror(val) { return val; }\nexport function pureFunctionChain(f1, f2) {\n // Enables chained events that takes ONE argument and returns it to the next function in chain.\n // This pattern is used in the hook(\"reading\") event.\n if (f1 == null || f1 === mirror) return f2;\n return function (val) {\n return f2(f1(val));\n };\n}\n\nexport function callBoth(on1, on2) {\n return function () {\n on1.apply(this, arguments);\n on2.apply(this, arguments);\n };\n}\n\nexport function hookCreatingChain(f1, f2) {\n // Enables chained events that takes several arguments and may modify first argument by making a modification and then returning the same instance.\n // This pattern is used in the hook(\"creating\") event.\n if (f1 === nop) return f2;\n return function () {\n var res = f1.apply(this, arguments);\n if (res !== undefined) arguments[0] = res;\n var onsuccess = this.onsuccess, // In case event listener has set this.onsuccess\n onerror = this.onerror; // In case event listener has set this.onerror\n this.onsuccess = null;\n this.onerror = null;\n var res2 = f2.apply(this, arguments);\n if (onsuccess) this.onsuccess = this.onsuccess ? callBoth(onsuccess, this.onsuccess) : onsuccess;\n if (onerror) this.onerror = this.onerror ? callBoth(onerror, this.onerror) : onerror;\n return res2 !== undefined ? res2 : res;\n };\n}\n\nexport function hookDeletingChain(f1, f2) {\n if (f1 === nop) return f2;\n return function () {\n f1.apply(this, arguments);\n var onsuccess = this.onsuccess, // In case event listener has set this.onsuccess\n onerror = this.onerror; // In case event listener has set this.onerror\n this.onsuccess = this.onerror = null;\n f2.apply(this, arguments);\n if (onsuccess) this.onsuccess = this.onsuccess ? callBoth(onsuccess, this.onsuccess) : onsuccess;\n if (onerror) this.onerror = this.onerror ? callBoth(onerror, this.onerror) : onerror;\n };\n}\n\nexport function hookUpdatingChain(f1, f2) {\n if (f1 === nop) return f2;\n return function (modifications) {\n var res = f1.apply(this, arguments);\n extend(modifications, res); // If f1 returns new modifications, extend caller's modifications with the result before calling next in chain.\n var onsuccess = this.onsuccess, // In case event listener has set this.onsuccess\n onerror = this.onerror; // In case event listener has set this.onerror\n this.onsuccess = null;\n this.onerror = null;\n var res2 = f2.apply(this, arguments);\n if (onsuccess) this.onsuccess = this.onsuccess ? callBoth(onsuccess, this.onsuccess) : onsuccess;\n if (onerror) this.onerror = this.onerror ? callBoth(onerror, this.onerror) : onerror;\n return res === undefined ?\n (res2 === undefined ? undefined : res2) :\n (extend(res, res2));\n };\n}\n\nexport function reverseStoppableEventChain(f1, f2) {\n if (f1 === nop) return f2;\n return function () {\n if (f2.apply(this, arguments) === false) return false;\n return f1.apply(this, arguments);\n };\n}\n\nexport function nonStoppableEventChain(f1, f2) {\n if (f1 === nop) return f2;\n return function () {\n f1.apply(this, arguments);\n f2.apply(this, arguments);\n };\n}\n\nexport function promisableChain(f1, f2) {\n if (f1 === nop) return f2;\n return function () {\n var res = f1.apply(this, arguments);\n if (res && typeof res.then === 'function') {\n var thiz = this,\n i = arguments.length,\n args = new Array(i);\n while (i--) args[i] = arguments[i];\n return res.then(function () {\n return f2.apply(thiz, args);\n });\n }\n return f2.apply(this, arguments);\n };\n}\n","/*\n * Copyright (c) 2014-2017 David Fahlander\n * Apache License Version 2.0, January 2004, http://www.apache.org/licenses/LICENSE-2.0\n */\nimport { _global } from '../globals/global';\nimport {tryCatch, props, setProp,\n getPropertyDescriptor, getArrayOf, extend, getProto} from '../functions/utils';\nimport {nop, callBoth, mirror} from '../functions/chaining-functions';\nimport {debug, prettyStack, getErrorWithStack} from './debug';\nimport {exceptions} from '../errors';\n\n//\n// Promise and Zone (PSD) for Dexie library\n//\n// I started out writing this Promise class by copying promise-light (https://github.com/taylorhakes/promise-light) by\n// https://github.com/taylorhakes - an A+ and ECMASCRIPT 6 compliant Promise implementation.\n//\n// In previous versions this was fixed by not calling setTimeout when knowing that the resolve() or reject() came from another\n// tick. In Dexie v1.4.0, I've rewritten the Promise class entirely. Just some fragments of promise-light is left. I use\n// another strategy now that simplifies everything a lot: to always execute callbacks in a new micro-task, but have an own micro-task\n// engine that is indexedDB compliant across all browsers.\n// Promise class has also been optimized a lot with inspiration from bluebird - to avoid closures as much as possible.\n// Also with inspiration from bluebird, asyncronic stacks in debug mode.\n//\n// Specific non-standard features of this Promise class:\n// * Custom zone support (a.k.a. PSD) with ability to keep zones also when using native promises as well as\n// native async / await.\n// * Promise.follow() method built upon the custom zone engine, that allows user to track all promises created from current stack frame\n// and below + all promises that those promises creates or awaits.\n// * Detect any unhandled promise in a PSD-scope (PSD.onunhandled). \n//\n// David Fahlander, https://github.com/dfahlander\n//\n\n// Just a pointer that only this module knows about.\n// Used in Promise constructor to emulate a private constructor.\nvar INTERNAL = {};\n\n// Async stacks (long stacks) must not grow infinitely.\nconst\n LONG_STACKS_CLIP_LIMIT = 100,\n // When calling error.stack or promise.stack, limit the number of asyncronic stacks to print out. \n MAX_LONG_STACKS = 20,\n ZONE_ECHO_LIMIT = 100,\n [resolvedNativePromise, nativePromiseProto, resolvedGlobalPromise] = typeof Promise === 'undefined' ?\n [] :\n (()=>{\n let globalP = Promise.resolve();\n if (typeof crypto === 'undefined' || !crypto.subtle)\n return [globalP, getProto(globalP), globalP];\n // Generate a native promise (as window.Promise may have been patched)\n const nativeP = crypto.subtle.digest(\"SHA-512\", new Uint8Array([0]));\n return [\n nativeP,\n getProto(nativeP),\n globalP\n ];\n })(),\n nativePromiseThen = nativePromiseProto && nativePromiseProto.then;\n\nexport const NativePromise = resolvedNativePromise && resolvedNativePromise.constructor;\nconst patchGlobalPromise = !!resolvedGlobalPromise;\n\nvar stack_being_generated = false;\n\n/* The default function used only for the very first promise in a promise chain.\n As soon as then promise is resolved or rejected, all next tasks will be executed in micro ticks\n emulated in this module. For indexedDB compatibility, this means that every method needs to \n execute at least one promise before doing an indexedDB operation. Dexie will always call \n db.ready().then() for every operation to make sure the indexedDB event is started in an\n indexedDB-compatible emulated micro task loop.\n*/\nvar schedulePhysicalTick = resolvedGlobalPromise ?\n () => {resolvedGlobalPromise.then(physicalTick);}\n :\n _global.setImmediate ? \n // setImmediate supported. Those modern platforms also supports Function.bind().\n setImmediate.bind(null, physicalTick) :\n _global.MutationObserver ?\n // MutationObserver supported\n () => {\n var hiddenDiv = document.createElement(\"div\");\n (new MutationObserver(() => {\n physicalTick();\n hiddenDiv = null;\n })).observe(hiddenDiv, { attributes: true });\n hiddenDiv.setAttribute('i', '1');\n } :\n // No support for setImmediate or MutationObserver. No worry, setTimeout is only called\n // once time. Every tick that follows will be our emulated micro tick.\n // Could have uses setTimeout.bind(null, 0, physicalTick) if it wasnt for that FF13 and below has a bug \n ()=>{setTimeout(physicalTick,0);};\n\n// Configurable through Promise.scheduler.\n// Don't export because it would be unsafe to let unknown\n// code call it unless they do try..catch within their callback.\n// This function can be retrieved through getter of Promise.scheduler though,\n// but users must not do Promise.scheduler = myFuncThatThrowsException\nvar asap = function (callback, args) {\n microtickQueue.push([callback, args]);\n if (needsNewPhysicalTick) {\n schedulePhysicalTick();\n needsNewPhysicalTick = false;\n }\n};\n\nvar isOutsideMicroTick = true, // True when NOT in a virtual microTick.\n needsNewPhysicalTick = true, // True when a push to microtickQueue must also schedulePhysicalTick()\n unhandledErrors = [], // Rejected promises that has occured. Used for triggering 'unhandledrejection'.\n rejectingErrors = [], // Tracks if errors are being re-rejected during onRejected callback.\n currentFulfiller = null,\n rejectionMapper = mirror; // Remove in next major when removing error mapping of DOMErrors and DOMExceptions\n \nexport var globalPSD = {\n id: 'global',\n global: true,\n ref: 0,\n unhandleds: [],\n onunhandled: nop,\n pgp: false,\n env: {},\n finalize: nop\n};\n\nexport var PSD = globalPSD;\n\nexport var microtickQueue = []; // Callbacks to call in this or next physical tick.\nexport var numScheduledCalls = 0; // Number of listener-calls left to do in this physical tick.\nexport var tickFinalizers = []; // Finalizers to call when there are no more async calls scheduled within current physical tick.\n\nexport default function DexiePromise(fn) {\n if (typeof this !== 'object') throw new TypeError('Promises must be constructed via new'); \n this._listeners = [];\n \n // A library may set `promise._lib = true;` after promise is created to make resolve() or reject()\n // execute the microtask engine implicitely within the call to resolve() or reject().\n // To remain A+ compliant, a library must only set `_lib=true` if it can guarantee that the stack\n // only contains library code when calling resolve() or reject().\n // RULE OF THUMB: ONLY set _lib = true for promises explicitely resolving/rejecting directly from\n // global scope (event handler, timer etc)!\n this._lib = false;\n // Current async scope\n var psd = (this._PSD = PSD);\n\n if (debug) {\n this._stackHolder = getErrorWithStack();\n this._prev = null;\n this._numPrev = 0; // Number of previous promises (for long stacks)\n }\n \n if (typeof fn !== 'function') {\n if (fn !== INTERNAL) throw new TypeError('Not a function');\n // Private constructor (INTERNAL, state, value).\n // Used internally by Promise.resolve() and Promise.reject().\n this._state = arguments[1];\n this._value = arguments[2];\n if (this._state === false)\n handleRejection(this, this._value); // Map error, set stack and addPossiblyUnhandledError().\n return;\n }\n \n this._state = null; // null (=pending), false (=rejected) or true (=resolved)\n this._value = null; // error or result\n ++psd.ref; // Refcounting current scope\n executePromiseTask(this, fn);\n}\n\n// Prepare a property descriptor to put onto Promise.prototype.then\nconst thenProp = {\n get: function() {\n var psd = PSD, microTaskId = totalEchoes;\n\n function then (onFulfilled, onRejected) {\n var possibleAwait = !psd.global && (psd !== PSD || microTaskId !== totalEchoes);\n const cleanup = possibleAwait && !decrementExpectedAwaits();\n var rv = new DexiePromise((resolve, reject) => {\n propagateToListener(this, new Listener(\n nativeAwaitCompatibleWrap(onFulfilled, psd, possibleAwait, cleanup),\n nativeAwaitCompatibleWrap(onRejected, psd, possibleAwait, cleanup),\n resolve,\n reject,\n psd));\n });\n debug && linkToPreviousPromise(rv, this);\n return rv;\n }\n\n then.prototype = INTERNAL; // For idempotense, see setter below.\n\n return then;\n },\n // Be idempotent and allow another framework (such as zone.js or another instance of a Dexie.Promise module) to replace Promise.prototype.then\n // and when that framework wants to restore the original property, we must identify that and restore the original property descriptor.\n set: function (value) {\n setProp (this, 'then', value && value.prototype === INTERNAL ?\n thenProp : // Restore to original property descriptor.\n {\n get: function(){\n return value; // Getter returning provided value (behaves like value is just changed)\n },\n set: thenProp.set // Keep a setter that is prepared to restore original.\n }\n );\n }\n};\n\nprops(DexiePromise.prototype, {\n then: thenProp, // Defined above.\n _then: function (onFulfilled, onRejected) {\n // A little tinier version of then() that don't have to create a resulting promise.\n propagateToListener(this, new Listener(null, null, onFulfilled, onRejected, PSD)); \n },\n\n catch: function (onRejected) {\n if (arguments.length === 1) return this.then(null, onRejected);\n // First argument is the Error type to catch\n var type = arguments[0],\n handler = arguments[1];\n return typeof type === 'function' ? this.then(null, err =>\n // Catching errors by its constructor type (similar to java / c++ / c#)\n // Sample: promise.catch(TypeError, function (e) { ... });\n err instanceof type ? handler(err) : PromiseReject(err))\n : this.then(null, err =>\n // Catching errors by the error.name property. Makes sense for indexedDB where error type\n // is always DOMError but where e.name tells the actual error type.\n // Sample: promise.catch('ConstraintError', function (e) { ... });\n err && err.name === type ? handler(err) : PromiseReject(err));\n },\n\n finally: function (onFinally) {\n return this.then(value => {\n onFinally();\n return value;\n }, err => {\n onFinally();\n return PromiseReject(err);\n });\n },\n \n stack: {\n get: function() {\n if (this._stack) return this._stack;\n try {\n stack_being_generated = true;\n var stacks = getStack (this, [], MAX_LONG_STACKS);\n var stack = stacks.join(\"\\nFrom previous: \");\n if (this._state !== null) this._stack = stack; // Stack may be updated on reject.\n return stack;\n } finally {\n stack_being_generated = false;\n }\n }\n },\n\n timeout: function (ms, msg) {\n return ms < Infinity ?\n new DexiePromise((resolve, reject) => {\n var handle = setTimeout(() => reject(new exceptions.Timeout(msg)), ms);\n this.then(resolve, reject).finally(clearTimeout.bind(null, handle));\n }) : this;\n }\n});\n\nif (typeof Symbol !== 'undefined' && Symbol.toStringTag)\n setProp(DexiePromise.prototype, Symbol.toStringTag, 'Dexie.Promise');\n\n// Now that Promise.prototype is defined, we have all it takes to set globalPSD.env.\n// Environment globals snapshotted on leaving global zone\nglobalPSD.env = snapShot();\n\nfunction Listener(onFulfilled, onRejected, resolve, reject, zone) {\n this.onFulfilled = typeof onFulfilled === 'function' ? onFulfilled : null;\n this.onRejected = typeof onRejected === 'function' ? onRejected : null;\n this.resolve = resolve;\n this.reject = reject;\n this.psd = zone;\n}\n\n// Promise Static Properties\nprops (DexiePromise, {\n all: function () {\n var values = getArrayOf.apply(null, arguments) // Supports iterables, implicit arguments and array-like.\n .map(onPossibleParallellAsync); // Handle parallell async/awaits \n return new DexiePromise(function (resolve, reject) {\n if (values.length === 0) resolve([]);\n var remaining = values.length;\n values.forEach((a,i) => DexiePromise.resolve(a).then(x => {\n values[i] = x;\n if (!--remaining) resolve(values);\n }, reject));\n });\n },\n \n resolve: value => {\n if (value instanceof DexiePromise) return value;\n if (value && typeof value.then === 'function') return new DexiePromise((resolve, reject)=>{\n value.then(resolve, reject);\n });\n var rv = new DexiePromise(INTERNAL, true, value);\n linkToPreviousPromise(rv, currentFulfiller);\n return rv;\n },\n \n reject: PromiseReject,\n \n race: function () {\n var values = getArrayOf.apply(null, arguments).map(onPossibleParallellAsync);\n return new DexiePromise((resolve, reject) => {\n values.map(value => DexiePromise.resolve(value).then(resolve, reject));\n });\n },\n\n PSD: {\n get: ()=>PSD,\n set: value => PSD = value\n },\n\n totalEchoes: {get: ()=>totalEchoes},\n\n //task: {get: ()=>task},\n \n newPSD: newScope,\n \n usePSD: usePSD,\n \n scheduler: {\n get: () => asap,\n set: value => {asap = value}\n },\n \n rejectionMapper: {\n get: () => rejectionMapper,\n set: value => {rejectionMapper = value;} // Map reject failures\n },\n \n follow: (fn, zoneProps) => {\n return new DexiePromise((resolve, reject) => {\n return newScope((resolve, reject) => {\n var psd = PSD;\n psd.unhandleds = []; // For unhandled standard- or 3rd party Promises. Checked at psd.finalize()\n psd.onunhandled = reject; // Triggered directly on unhandled promises of this library.\n psd.finalize = callBoth(function () {\n // Unhandled standard or 3rd part promises are put in PSD.unhandleds and\n // examined upon scope completion while unhandled rejections in this Promise\n // will trigger directly through psd.onunhandled\n run_at_end_of_this_or_next_physical_tick(()=>{\n this.unhandleds.length === 0 ? resolve() : reject(this.unhandleds[0]);\n });\n }, psd.finalize);\n fn();\n }, zoneProps, resolve, reject);\n });\n }\n});\n\nif (NativePromise) {\n if (NativePromise.allSettled) setProp (DexiePromise, \"allSettled\", function() {\n const possiblePromises = getArrayOf.apply(null, arguments).map(onPossibleParallellAsync);\n return new DexiePromise(resolve => {\n if (possiblePromises.length === 0) resolve([]);\n let remaining = possiblePromises.length;\n const results = new Array(remaining);\n possiblePromises.forEach((p, i) => DexiePromise.resolve(p).then(\n value => results[i] = {status: \"fulfilled\", value},\n reason => results[i] = {status: \"rejected\", reason})\n .then(()=>--remaining || resolve(results)));\n });\n });\n if (NativePromise.any && typeof AggregateError !== 'undefined') setProp(DexiePromise, \"any\", function() {\n const possiblePromises = getArrayOf.apply(null, arguments).map(onPossibleParallellAsync);\n return new DexiePromise((resolve, reject) => {\n if (possiblePromises.length === 0) reject(new AggregateError([]));\n let remaining = possiblePromises.length;\n const failures = new Array(remaining);\n possiblePromises.forEach((p, i) => DexiePromise.resolve(p).then(\n value => resolve(value),\n failure => {\n failures[i] = failure;\n if (!--remaining) reject(new AggregateError(failures));\n }));\n });\n });\n}\n\n/**\n* Take a potentially misbehaving resolver function and make sure\n* onFulfilled and onRejected are only called once.\n*\n* Makes no guarantees about asynchrony.\n*/\nfunction executePromiseTask (promise, fn) {\n // Promise Resolution Procedure:\n // https://github.com/promises-aplus/promises-spec#the-promise-resolution-procedure\n try {\n fn(value => {\n if (promise._state !== null) return; // Already settled\n if (value === promise) throw new TypeError('A promise cannot be resolved with itself.');\n var shouldExecuteTick = promise._lib && beginMicroTickScope();\n if (value && typeof value.then === 'function') {\n executePromiseTask(promise, (resolve, reject) => {\n value instanceof DexiePromise ?\n value._then(resolve, reject) :\n value.then(resolve, reject);\n });\n } else {\n promise._state = true;\n promise._value = value;\n propagateAllListeners(promise);\n }\n if (shouldExecuteTick) endMicroTickScope();\n }, handleRejection.bind(null, promise)); // If Function.bind is not supported. Exception is handled in catch below\n } catch (ex) {\n handleRejection(promise, ex);\n }\n}\n\nfunction handleRejection (promise, reason) {\n rejectingErrors.push(reason);\n if (promise._state !== null) return;\n var shouldExecuteTick = promise._lib && beginMicroTickScope();\n reason = rejectionMapper(reason);\n promise._state = false;\n promise._value = reason;\n debug && reason !== null && typeof reason === 'object' && !reason._promise && tryCatch(()=>{\n var origProp = getPropertyDescriptor(reason, \"stack\"); \n reason._promise = promise; \n setProp(reason, \"stack\", {\n get: () =>\n stack_being_generated ?\n origProp && (origProp.get ?\n origProp.get.apply(reason) :\n origProp.value) :\n promise.stack\n });\n });\n // Add the failure to a list of possibly uncaught errors\n addPossiblyUnhandledError(promise);\n propagateAllListeners(promise);\n if (shouldExecuteTick) endMicroTickScope();\n}\n\nfunction propagateAllListeners (promise) {\n //debug && linkToPreviousPromise(promise);\n var listeners = promise._listeners;\n promise._listeners = [];\n for (var i = 0, len = listeners.length; i < len; ++i) {\n propagateToListener(promise, listeners[i]);\n }\n var psd = promise._PSD;\n --psd.ref || psd.finalize(); // if psd.ref reaches zero, call psd.finalize();\n if (numScheduledCalls === 0) {\n // If numScheduledCalls is 0, it means that our stack is not in a callback of a scheduled call,\n // and that no deferreds where listening to this rejection or success.\n // Since there is a risk that our stack can contain application code that may\n // do stuff after this code is finished that may generate new calls, we cannot\n // call finalizers here.\n ++numScheduledCalls;\n asap(()=>{\n if (--numScheduledCalls === 0) finalizePhysicalTick(); // Will detect unhandled errors\n }, []);\n }\n}\n\nfunction propagateToListener(promise, listener) {\n if (promise._state === null) {\n promise._listeners.push(listener);\n return;\n }\n\n var cb = promise._state ? listener.onFulfilled : listener.onRejected;\n if (cb === null) {\n // This Listener doesnt have a listener for the event being triggered (onFulfilled or onReject) so lets forward the event to any eventual listeners on the Promise instance returned by then() or catch()\n return (promise._state ? listener.resolve : listener.reject) (promise._value);\n }\n ++listener.psd.ref;\n ++numScheduledCalls;\n asap (callListener, [cb, promise, listener]);\n}\n\nfunction callListener (cb, promise, listener) {\n try {\n // Set static variable currentFulfiller to the promise that is being fullfilled,\n // so that we connect the chain of promises (for long stacks support)\n currentFulfiller = promise;\n \n // Call callback and resolve our listener with it's return value.\n var ret, value = promise._value;\n \n if (promise._state) {\n // cb is onResolved\n ret = cb (value);\n } else {\n // cb is onRejected\n if (rejectingErrors.length) rejectingErrors = [];\n ret = cb(value);\n if (rejectingErrors.indexOf(value) === -1)\n markErrorAsHandled(promise); // Callback didnt do Promise.reject(err) nor reject(err) onto another promise.\n }\n listener.resolve(ret);\n } catch (e) {\n // Exception thrown in callback. Reject our listener.\n listener.reject(e);\n } finally {\n // Restore env and currentFulfiller.\n currentFulfiller = null;\n if (--numScheduledCalls === 0) finalizePhysicalTick();\n --listener.psd.ref || listener.psd.finalize();\n }\n}\n\nfunction getStack (promise, stacks, limit) {\n if (stacks.length === limit) return stacks;\n var stack = \"\";\n if (promise._state === false) {\n var failure = promise._value,\n errorName,\n message;\n \n if (failure != null) {\n errorName = failure.name || \"Error\";\n message = failure.message || failure;\n stack = prettyStack(failure, 0);\n } else {\n errorName = failure; // If error is undefined or null, show that.\n message = \"\";\n }\n stacks.push(errorName + (message ? \": \" + message : \"\") + stack);\n }\n if (debug) {\n stack = prettyStack(promise._stackHolder, 2);\n if (stack && stacks.indexOf(stack) === -1) stacks.push(stack);\n if (promise._prev) getStack(promise._prev, stacks, limit);\n }\n return stacks;\n}\n\nfunction linkToPreviousPromise(promise, prev) {\n // Support long stacks by linking to previous completed promise.\n var numPrev = prev ? prev._numPrev + 1 : 0;\n if (numPrev < LONG_STACKS_CLIP_LIMIT) { // Prohibit infinite Promise loops to get an infinite long memory consuming \"tail\".\n promise._prev = prev;\n promise._numPrev = numPrev;\n }\n}\n\n/* The callback to schedule with setImmediate() or setTimeout().\n It runs a virtual microtick and executes any callback registered in microtickQueue.\n */\nfunction physicalTick() {\n beginMicroTickScope() && endMicroTickScope();\n}\n\nexport function beginMicroTickScope() {\n var wasRootExec = isOutsideMicroTick;\n isOutsideMicroTick = false;\n needsNewPhysicalTick = false;\n return wasRootExec;\n}\n\n/* Executes micro-ticks without doing try..catch.\n This can be possible because we only use this internally and\n the registered functions are exception-safe (they do try..catch\n internally before calling any external method). If registering\n functions in the microtickQueue that are not exception-safe, this\n would destroy the framework and make it instable. So we don't export\n our asap method.\n*/\nexport function endMicroTickScope() {\n var callbacks, i, l;\n do {\n while (microtickQueue.length > 0) {\n callbacks = microtickQueue;\n microtickQueue = [];\n l = callbacks.length;\n for (i = 0; i < l; ++i) {\n var item = callbacks[i];\n item[0].apply(null, item[1]);\n }\n }\n } while (microtickQueue.length > 0);\n isOutsideMicroTick = true;\n needsNewPhysicalTick = true;\n}\n\nfunction finalizePhysicalTick() {\n var unhandledErrs = unhandledErrors;\n unhandledErrors = [];\n unhandledErrs.forEach(p => {\n p._PSD.onunhandled.call(null, p._value, p);\n });\n var finalizers = tickFinalizers.slice(0); // Clone first because finalizer may remove itself from list.\n var i = finalizers.length;\n while (i) finalizers[--i](); \n}\n\nfunction run_at_end_of_this_or_next_physical_tick (fn) {\n function finalizer() {\n fn();\n tickFinalizers.splice(tickFinalizers.indexOf(finalizer), 1);\n }\n tickFinalizers.push(finalizer);\n ++numScheduledCalls;\n asap(()=>{\n if (--numScheduledCalls === 0) finalizePhysicalTick();\n }, []);\n}\n\nfunction addPossiblyUnhandledError(promise) {\n // Only add to unhandledErrors if not already there. The first one to add to this list\n // will be upon the first rejection so that the root cause (first promise in the\n // rejection chain) is the one listed.\n if (!unhandledErrors.some(p => p._value === promise._value))\n unhandledErrors.push(promise);\n}\n\nfunction markErrorAsHandled(promise) {\n // Called when a reject handled is actually being called.\n // Search in unhandledErrors for any promise whos _value is this promise_value (list\n // contains only rejected promises, and only one item per error)\n var i = unhandledErrors.length;\n while (i) if (unhandledErrors[--i]._value === promise._value) {\n // Found a promise that failed with this same error object pointer,\n // Remove that since there is a listener that actually takes care of it.\n unhandledErrors.splice(i, 1);\n return;\n }\n}\n\nfunction PromiseReject (reason) {\n return new DexiePromise(INTERNAL, false, reason);\n}\n\nexport function wrap (fn, errorCatcher) {\n var psd = PSD;\n return function() {\n var wasRootExec = beginMicroTickScope(),\n outerScope = PSD;\n\n try {\n switchToZone(psd, true);\n return fn.apply(this, arguments);\n } catch (e) {\n errorCatcher && errorCatcher(e);\n } finally {\n switchToZone(outerScope, false);\n if (wasRootExec) endMicroTickScope();\n }\n };\n}\n\n\n//\n// variables used for native await support\n//\nconst task = { awaits: 0, echoes: 0, id: 0}; // The ongoing macro-task when using zone-echoing.\nvar taskCounter = 0; // ID counter for macro tasks.\nvar zoneStack = []; // Stack of left zones to restore asynchronically.\nvar zoneEchoes = 0; // zoneEchoes is a must in order to persist zones between native await expressions.\nvar totalEchoes = 0; // ID counter for micro-tasks. Used to detect possible native await in our Promise.prototype.then.\n\n\nvar zone_id_counter = 0;\nexport function newScope (fn, props, a1, a2) {\n var parent = PSD,\n psd = Object.create(parent);\n psd.parent = parent;\n psd.ref = 0;\n psd.global = false;\n psd.id = ++zone_id_counter;\n // Prepare for promise patching (done in usePSD):\n var globalEnv = globalPSD.env;\n psd.env = patchGlobalPromise ? {\n Promise: DexiePromise, // Changing window.Promise could be omitted for Chrome and Edge, where IDB+Promise plays well!\n PromiseProp: {value: DexiePromise, configurable: true, writable: true},\n all: DexiePromise.all,\n race: DexiePromise.race,\n allSettled: DexiePromise.allSettled,\n any: DexiePromise.any,\n resolve: DexiePromise.resolve,\n reject: DexiePromise.reject,\n nthen: getPatchedPromiseThen (globalEnv.nthen, psd), // native then\n gthen: getPatchedPromiseThen (globalEnv.gthen, psd) // global then\n } : {};\n if (props) extend(psd, props);\n \n // unhandleds and onunhandled should not be specifically set here.\n // Leave them on parent prototype.\n // unhandleds.push(err) will push to parent's prototype\n // onunhandled() will call parents onunhandled (with this scope's this-pointer though!)\n ++parent.ref;\n psd.finalize = function () {\n --this.parent.ref || this.parent.finalize();\n }\n var rv = usePSD (psd, fn, a1, a2);\n if (psd.ref === 0) psd.finalize();\n return rv;\n}\n\n// Function to call if scopeFunc returns NativePromise\n// Also for each NativePromise in the arguments to Promise.all()\nexport function incrementExpectedAwaits() {\n if (!task.id) task.id = ++taskCounter;\n ++task.awaits;\n task.echoes += ZONE_ECHO_LIMIT;\n return task.id;\n}\n\n// Function to call when 'then' calls back on a native promise where onAwaitExpected() had been called.\n// Also call this when a native await calls then method on a promise. In that case, don't supply\n// sourceTaskId because we already know it refers to current task.\nexport function decrementExpectedAwaits() {\n if (!task.awaits) return false;\n if (--task.awaits === 0) task.id = 0;\n task.echoes = task.awaits * ZONE_ECHO_LIMIT; // Will reset echoes to 0 if awaits is 0.\n return true;\n}\n\nif ((''+nativePromiseThen).indexOf('[native code]') === -1) {\n // If the native promise' prototype is patched, we cannot rely on zone echoing.\n // Disable that here:\n incrementExpectedAwaits = decrementExpectedAwaits = nop;\n}\n\n// Call from Promise.all() and Promise.race()\nexport function onPossibleParallellAsync (possiblePromise) {\n if (task.echoes && possiblePromise && possiblePromise.constructor === NativePromise) {\n incrementExpectedAwaits(); \n return possiblePromise.then(x => {\n decrementExpectedAwaits();\n return x;\n }, e => {\n decrementExpectedAwaits();\n return rejection(e);\n });\n }\n return possiblePromise;\n}\n\nfunction zoneEnterEcho(targetZone) {\n ++totalEchoes;\n //console.log(\"Total echoes \", totalEchoes);\n if (!task.echoes || --task.echoes === 0) {\n task.echoes = task.id = 0; // Cancel zone echoing.\n }\n\n zoneStack.push(PSD);\n switchToZone(targetZone, true);\n}\n\nfunction zoneLeaveEcho() {\n var zone = zoneStack[zoneStack.length-1];\n zoneStack.pop();\n switchToZone(zone, false);\n}\n\nfunction switchToZone (targetZone, bEnteringZone) {\n var currentZone = PSD;\n if (bEnteringZone ? task.echoes && (!zoneEchoes++ || targetZone !== PSD) : zoneEchoes && (!--zoneEchoes || targetZone !== PSD)) {\n // Enter or leave zone asynchronically as well, so that tasks initiated during current tick\n // will be surrounded by the zone when they are invoked.\n enqueueNativeMicroTask(bEnteringZone ? zoneEnterEcho.bind(null, targetZone) : zoneLeaveEcho);\n }\n if (targetZone === PSD) return;\n\n PSD = targetZone; // The actual zone switch occurs at this line.\n\n // Snapshot on every leave from global zone.\n if (currentZone === globalPSD) globalPSD.env = snapShot();\n\n if (patchGlobalPromise) {\n // Let's patch the global and native Promises (may be same or may be different)\n var GlobalPromise = globalPSD.env.Promise;\n // Swich environments (may be PSD-zone or the global zone. Both apply.)\n var targetEnv = targetZone.env;\n\n // Change Promise.prototype.then for native and global Promise (they MAY differ on polyfilled environments, but both can be accessed)\n // Must be done on each zone change because the patched method contains targetZone in its closure.\n nativePromiseProto.then = targetEnv.nthen;\n GlobalPromise.prototype.then = targetEnv.gthen;\n\n if (currentZone.global || targetZone.global) {\n // Leaving or entering global zone. It's time to patch / restore global Promise.\n\n // Set this Promise to window.Promise so that transiled async functions will work on Firefox, Safari and IE, as well as with Zonejs and angular.\n Object.defineProperty(_global, 'Promise', targetEnv.PromiseProp);\n\n // Support Promise.all() etc to work indexedDB-safe also when people are including es6-promise as a module (they might\n // not be accessing global.Promise but a local reference to it)\n GlobalPromise.all = targetEnv.all;\n GlobalPromise.race = targetEnv.race;\n GlobalPromise.resolve = targetEnv.resolve;\n GlobalPromise.reject = targetEnv.reject;\n if (targetEnv.allSettled) GlobalPromise.allSettled = targetEnv.allSettled;\n if (targetEnv.any) GlobalPromise.any = targetEnv.any;\n }\n }\n}\n\nfunction snapShot () {\n var GlobalPromise = _global.Promise;\n return patchGlobalPromise ? {\n Promise: GlobalPromise,\n PromiseProp: Object.getOwnPropertyDescriptor(_global, \"Promise\"),\n all: GlobalPromise.all,\n race: GlobalPromise.race,\n allSettled: GlobalPromise.allSettled,\n any: GlobalPromise.any,\n resolve: GlobalPromise.resolve,\n reject: GlobalPromise.reject,\n nthen: nativePromiseProto.then,\n gthen: GlobalPromise.prototype.then\n } : {};\n}\n\nexport function usePSD (psd, fn, a1, a2, a3) {\n var outerScope = PSD;\n try {\n switchToZone(psd, true);\n return fn(a1, a2, a3);\n } finally {\n switchToZone(outerScope, false);\n }\n}\n\nfunction enqueueNativeMicroTask (job) {\n //\n // Precondition: nativePromiseThen !== undefined\n //\n nativePromiseThen.call(resolvedNativePromise, job);\n}\n\nfunction nativeAwaitCompatibleWrap(fn, zone, possibleAwait, cleanup) {\n return typeof fn !== 'function' ? fn : function () {\n var outerZone = PSD;\n if (possibleAwait) incrementExpectedAwaits();\n switchToZone(zone, true);\n try {\n return fn.apply(this, arguments);\n } finally {\n switchToZone(outerZone, false);\n if (cleanup) enqueueNativeMicroTask(decrementExpectedAwaits);\n }\n };\n}\n\nfunction getPatchedPromiseThen (origThen, zone) {\n return function (onResolved, onRejected) {\n return origThen.call(this,\n nativeAwaitCompatibleWrap(onResolved, zone),\n nativeAwaitCompatibleWrap(onRejected, zone));\n };\n}\n\nexport var rejection = DexiePromise.reject;\n\nexport {DexiePromise};\n","import { PSD, rejection, newScope } from \"../helpers/promise\";\nimport { DexieOptions } from \"../public/types/dexie-constructor\";\nimport { errnames, exceptions } from \"../errors\";\nimport { nop } from \"./chaining-functions\";\nimport { Transaction } from \"../classes/transaction\";\nimport { Dexie } from '../classes/dexie';\n\n/* Generate a temporary transaction when db operations are done outside a transaction scope.\n*/\nexport function tempTransaction (\n db: Dexie,\n mode: IDBTransactionMode,\n storeNames: string[],\n fn: (resolve, reject, trans: Transaction) => any)\n // Last argument is \"writeLocked\". But this doesnt apply to oneshot direct db operations, so we ignore it.\n{\n if (!db.idbdb || (!db._state.openComplete && (!PSD.letThrough && !db._vip))) {\n if (db._state.openComplete) {\n // db.idbdb is falsy but openComplete is true. Must have been an exception durin open.\n // Don't wait for openComplete as it would lead to infinite loop.\n return rejection(new exceptions.DatabaseClosed(db._state.dbOpenError));\n }\n if (!db._state.isBeingOpened) {\n if (!db._options.autoOpen)\n return rejection(new exceptions.DatabaseClosed());\n db.open().catch(nop); // Open in background. If if fails, it will be catched by the final promise anyway.\n }\n return db._state.dbReadyPromise.then(() => tempTransaction(db, mode, storeNames, fn));\n } else {\n var trans = db._createTransaction(mode, storeNames, db._dbSchema);\n try {\n trans.create();\n db._state.PR1398_maxLoop = 3;\n } catch (ex) {\n if (ex.name === errnames.InvalidState && db.isOpen() && --db._state.PR1398_maxLoop > 0) {\n console.warn('Dexie: Need to reopen db');\n db._close();\n return db.open().then(()=>tempTransaction(db, mode, storeNames, fn));\n }\n return rejection(ex);\n }\n return trans._promise(mode, (resolve, reject) => {\n return newScope(() => { // OPTIMIZATION POSSIBLE? newScope() not needed because it's already done in _promise.\n PSD.trans = trans;\n return fn(resolve, reject, trans);\n });\n }).then(result => {\n // Instead of resolving value directly, wait with resolving it until transaction has completed.\n // Otherwise the data would not be in the DB if requesting it in the then() operation.\n // Specifically, to ensure that the following expression will work:\n //\n // db.friends.put({name: \"Arne\"}).then(function () {\n // db.friends.where(\"name\").equals(\"Arne\").count(function(count) {\n // assert (count === 1);\n // });\n // });\n //\n if (mode === 'readwrite') try {trans.idbtrans.commit();} catch {}\n return mode === 'readonly' ? result : trans._completion.then(() => result);\n });/*.catch(err => { // Don't do this as of now. If would affect bulk- and modify methods in a way that could be more intuitive. But wait! Maybe change in next major.\n trans._reject(err);\n return rejection(err);\n });*/\n }\n}\n","import { Dexie } from \"../classes/dexie\";\n\nexport const DEXIE_VERSION = '{version}'; // Replaced by build-script.\nexport const maxString = String.fromCharCode(65535);\nexport const minKey = -Infinity; // minKey can be constant. maxKey must be a prop of Dexie (_maxKey)\nexport const INVALID_KEY_ARGUMENT =\n \"Invalid key provided. Keys must be of type string, number, Date or Array.\";\nexport const STRING_EXPECTED = \"String expected.\";\nexport const connections: Dexie[] = [];\nexport const isIEOrEdge =\n typeof navigator !== 'undefined' && /(MSIE|Trident|Edge)/.test(navigator.userAgent);\nexport const hasIEDeleteObjectStoreBug = isIEOrEdge;\nexport const hangsOnDeleteLargeKeyRange = isIEOrEdge;\nexport const dexieStackFrameFilter = frame => !/(dexie\\.js|dexie\\.min\\.js)/.test(frame);\nexport const DBNAMES_DB = '__dbnames';\nexport const READONLY = 'readonly';\nexport const READWRITE = 'readwrite';\n","export function combine(filter1, filter2) {\n return filter1 ?\n filter2 ?\n function () { return filter1.apply(this, arguments) && filter2.apply(this, arguments); } :\n filter1 :\n filter2;\n}\n","import { DBCoreKeyRange, DBCoreRangeType } from '../public/types/dbcore';\n\nexport const AnyRange: DBCoreKeyRange = {\n type: DBCoreRangeType.Any,\n lower: -Infinity,\n lowerOpen: false,\n upper: [[]],\n upperOpen: false\n}\n\nexport const NeverRange: DBCoreKeyRange = {\n type: DBCoreRangeType.Never,\n lower: -Infinity,\n lowerOpen: true,\n upper: -Infinity,\n upperOpen: true\n}\n","import { deepClone, delByKeyPath, getByKeyPath } from './utils';\n\n// This workaround is needed since obj could be a custom-class instance with an\n// uninitialized keyPath. See the following comment for more context:\n// https://github.com/dfahlander/Dexie.js/issues/1280#issuecomment-823557881\nexport function workaroundForUndefinedPrimKey(keyPath: string | ArrayLike) {\n // Workaround only needed for plain non-dotted keyPaths\n return typeof keyPath === \"string\" && !/\\./.test(keyPath) \n ? (obj: object) => {\n if (obj[keyPath] === undefined && (keyPath in obj)) {\n // property exists but is undefined. This will not be liked by Indexeddb.\n // Need to remove the property before adding it but we need to clone it before\n // doing that to not be intrusive.\n obj = deepClone(obj);\n delete obj[keyPath];\n }\n return obj;\n }\n : (obj: object) => obj;\n}","import { exceptions } from \"../../errors\";\n\nexport function Entity(){\n throw exceptions.Type();\n}\n","// Implementation of https://www.w3.org/TR/IndexedDB-3/#compare-two-keys\n\nimport { toStringTag } from './utils';\n\n// ... with the adjustment to return NaN instead of throwing.\nexport function cmp(a: any, b: any): number {\n try {\n const ta = type(a);\n const tb = type(b);\n if (ta !== tb) {\n if (ta === 'Array') return 1;\n if (tb === 'Array') return -1;\n if (ta === 'binary') return 1;\n if (tb === 'binary') return -1;\n if (ta === 'string') return 1;\n if (tb === 'string') return -1;\n if (ta === 'Date') return 1;\n if (tb !== 'Date') return NaN;\n return -1;\n }\n switch (ta) {\n case 'number':\n case 'Date':\n case 'string':\n return a > b ? 1 : a < b ? -1 : 0;\n case 'binary': {\n return compareUint8Arrays(getUint8Array(a), getUint8Array(b));\n }\n case 'Array':\n return compareArrays(a, b);\n }\n } catch {}\n return NaN; // Return value if any given args are valid keys.\n}\n\nexport function compareArrays(a: any[], b: any[]): number {\n const al = a.length;\n const bl = b.length;\n const l = al < bl ? al : bl;\n for (let i = 0; i < l; ++i) {\n const res = cmp(a[i], b[i]);\n if (res !== 0) return res;\n }\n return al === bl ? 0 : al < bl ? -1 : 1;\n}\n\nexport function compareUint8Arrays(\n a: Uint8Array,\n b: Uint8Array\n) {\n const al = a.length;\n const bl = b.length;\n const l = al < bl ? al : bl;\n for (let i = 0; i < l; ++i) {\n if (a[i] !== b[i]) return a[i] < b[i] ? -1 : 1;\n }\n return al === bl ? 0 : al < bl ? -1 : 1;\n}\n\n// Implementation of https://www.w3.org/TR/IndexedDB-3/#key-type\nfunction type(x: any) {\n const t = typeof x;\n if (t !== 'object') return t;\n if (ArrayBuffer.isView(x)) return 'binary';\n const tsTag = toStringTag(x); // Cannot use instanceof in Safari\n return tsTag === 'ArrayBuffer' ? 'binary' : (tsTag as 'Array' | 'Date');\n}\n\ntype BinaryType =\n | ArrayBuffer\n | DataView\n | Uint8ClampedArray\n | ArrayBufferView\n | Uint8Array\n | Int8Array\n | Uint16Array\n | Int16Array\n | Uint32Array\n | Int32Array\n | Float32Array\n | Float64Array;\n\nfunction getUint8Array(a: BinaryType): Uint8Array {\n if (a instanceof Uint8Array) return a;\n if (ArrayBuffer.isView(a))\n // TypedArray or DataView\n return new Uint8Array(a.buffer, a.byteOffset, a.byteLength);\n return new Uint8Array(a); // ArrayBuffer\n}\n","import { BulkError, exceptions } from '../../errors';\nimport { Table as ITable } from '../../public/types/table';\nimport { TableSchema } from '../../public/types/table-schema';\nimport { TableHooks } from '../../public/types/table-hooks';\nimport { DexiePromise as Promise, PSD, newScope, rejection, beginMicroTickScope, endMicroTickScope } from '../../helpers/promise';\nimport { Transaction } from '../transaction';\nimport { Dexie } from '../dexie';\nimport { tempTransaction } from '../../functions/temp-transaction';\nimport { Collection } from '../collection';\nimport { isArray, keys, getByKeyPath, setByKeyPath, extend, getProto } from '../../functions/utils';\nimport { maxString } from '../../globals/constants';\nimport { combine } from '../../functions/combine';\nimport { PromiseExtended } from \"../../public/types/promise-extended\";\nimport { IndexableType } from '../../public/types/indexable-type';\nimport { debug } from '../../helpers/debug';\nimport { DBCoreTable } from '../../public/types/dbcore';\nimport { AnyRange } from '../../dbcore/keyrange';\nimport { workaroundForUndefinedPrimKey } from '../../functions/workaround-undefined-primkey';\nimport { Entity } from '../entity/Entity';\nimport { UpdateSpec } from '../../public';\nimport { cmp } from '../../functions/cmp';\n\n/** class Table\n * \n * https://dexie.org/docs/Table/Table\n */\nexport class Table implements ITable {\n db: Dexie;\n _tx?: Transaction;\n name: string;\n schema: TableSchema;\n hook: TableHooks;\n core: DBCoreTable;\n\n _trans(\n mode: IDBTransactionMode,\n fn: (idbtrans: IDBTransaction, dxTrans: Transaction) => PromiseLike | void,\n writeLocked?: boolean | string) : PromiseExtended\n {\n const trans: Transaction = this._tx || PSD.trans;\n const tableName = this.name;\n \n function checkTableInTransaction(resolve, reject, trans: Transaction) {\n if (!trans.schema[tableName])\n throw new exceptions.NotFound(\"Table \" + tableName + \" not part of transaction\");\n return fn(trans.idbtrans, trans);\n }\n // Surround all in a microtick scope.\n // Reason: Browsers (modern Safari + older others)\n // still as of 2018-10-10 has problems keeping a transaction\n // alive between micro ticks. Safari because if transaction\n // is created but not used in same microtick, it will go\n // away. That specific issue could be solved in DBCore\n // by opening the transaction just before using it instead.\n // But older Firefoxes and IE11 (with Promise polyfills)\n // will still have probs.\n // The beginMicrotickScope()/endMicrotickScope() works\n // in cooperation with Dexie.Promise to orchestrate\n // the micro-ticks in endMicrotickScope() rather than\n // in native engine.\n const wasRootExec = beginMicroTickScope();\n try {\n return trans && trans.db === this.db ?\n trans === PSD.trans ?\n trans._promise(mode, checkTableInTransaction, writeLocked) :\n newScope(() => trans._promise(mode, checkTableInTransaction, writeLocked), { trans: trans, transless: PSD.transless || PSD }) :\n tempTransaction(this.db, mode, [this.name], checkTableInTransaction);\n } finally {\n if (wasRootExec) endMicroTickScope();\n }\n }\n\n /** Table.get()\n * \n * https://dexie.org/docs/Table/Table.get()\n * \n **/\n get(keyOrCrit, cb?) {\n if (keyOrCrit && keyOrCrit.constructor === Object)\n return this.where(keyOrCrit as { [key: string]: IndexableType }).first(cb);\n\n return this._trans('readonly', (trans) => {\n return this.core.get({trans, key: keyOrCrit})\n .then(res => this.hook.reading.fire(res));\n }).then(cb);\n }\n\n /** Table.where()\n * \n * https://dexie.org/docs/Table/Table.where()\n * \n **/\n where(indexOrCrit: string | string[] | { [key: string]: IndexableType }) {\n if (typeof indexOrCrit === 'string')\n return new this.db.WhereClause(this, indexOrCrit);\n if (isArray(indexOrCrit))\n return new this.db.WhereClause(this, `[${indexOrCrit.join('+')}]`);\n // indexOrCrit is an object map of {[keyPath]:value} \n const keyPaths = keys(indexOrCrit);\n if (keyPaths.length === 1)\n // Only one critera. This was the easy case:\n return this\n .where(keyPaths[0])\n .equals(indexOrCrit[keyPaths[0]]);\n\n // Multiple criterias.\n // Let's try finding a compound index that matches all keyPaths in\n // arbritary order:\n const compoundIndex = this.schema.indexes.concat(this.schema.primKey).filter(ix =>\n ix.compound &&\n keyPaths.every(keyPath => ix.keyPath.indexOf(keyPath) >= 0) &&\n (ix.keyPath as string[]).every(keyPath => keyPaths.indexOf(keyPath) >= 0))[0];\n\n if (compoundIndex && this.db._maxKey !== maxString)\n // Cool! We found such compound index\n // and this browser supports compound indexes (maxKey !== maxString)!\n return this\n .where(compoundIndex.name)\n .equals((compoundIndex.keyPath as string[]).map(kp => indexOrCrit[kp]));\n\n if (!compoundIndex && debug) console.warn(\n `The query ${JSON.stringify(indexOrCrit)} on ${this.name} would benefit of a ` +\n `compound index [${keyPaths.join('+')}]`);\n\n // Ok, now let's fallback to finding at least one matching index\n // and filter the rest.\n const { idxByName } = this.schema;\n const idb = this.db._deps.indexedDB;\n\n function equals (a, b) {\n return idb.cmp(a,b) === 0; // Works with all indexable types including binary keys.\n }\n\n const [idx, filterFunction] = keyPaths.reduce(([prevIndex, prevFilterFn], keyPath) => {\n const index = idxByName[keyPath];\n const value = indexOrCrit[keyPath];\n return [\n prevIndex || index, // idx::=Pick index of first matching keypath\n prevIndex || !index ? // filter::=null if not needed, otherwise combine function filter\n combine(\n prevFilterFn,\n index && index.multi ?\n x => {\n const prop = getByKeyPath(x, keyPath);\n return isArray(prop) && prop.some(item => equals(value, item));\n } : x => equals(value, getByKeyPath(x, keyPath)))\n : prevFilterFn\n ];\n }, [null, null]);\n\n return idx ?\n this.where(idx.name).equals(indexOrCrit[idx.keyPath])\n .filter(filterFunction) :\n compoundIndex ?\n this.filter(filterFunction) : // Has compound but browser bad. Allow filter.\n this.where(keyPaths).equals(''); // No index at all. Fail lazily with \"[a+b+c] is not indexed\"\n }\n\n /** Table.filter()\n * \n * https://dexie.org/docs/Table/Table.filter()\n * \n **/\n filter(filterFunction: (obj: any) => boolean) {\n return this.toCollection().and(filterFunction);\n }\n\n /** Table.count()\n * \n * https://dexie.org/docs/Table/Table.count()\n * \n **/\n count(thenShortcut?: any) {\n return this.toCollection().count(thenShortcut);\n }\n\n /** Table.offset()\n * \n * https://dexie.org/docs/Table/Table.offset()\n * \n **/\n offset(offset: number) {\n return this.toCollection().offset(offset);\n }\n\n /** Table.limit()\n * \n * https://dexie.org/docs/Table/Table.limit()\n * \n **/\n limit(numRows: number) {\n return this.toCollection().limit(numRows);\n }\n\n /** Table.each()\n * \n * https://dexie.org/docs/Table/Table.each()\n * \n **/\n each(callback: (obj: any, cursor: { key: IndexableType, primaryKey: IndexableType }) => any) {\n return this.toCollection().each(callback);\n }\n\n /** Table.toArray()\n * \n * https://dexie.org/docs/Table/Table.toArray()\n * \n **/\n toArray(thenShortcut?: any) {\n return this.toCollection().toArray(thenShortcut);\n }\n\n /** Table.toCollection()\n * \n * https://dexie.org/docs/Table/Table.toCollection()\n * \n **/\n toCollection() {\n return new this.db.Collection(new this.db.WhereClause(this));\n }\n\n /** Table.orderBy()\n * \n * https://dexie.org/docs/Table/Table.orderBy()\n * \n **/\n orderBy(index: string | string[]) {\n return new this.db.Collection(\n new this.db.WhereClause(this, isArray(index) ?\n `[${index.join('+')}]` :\n index));\n }\n\n /** Table.reverse()\n * \n * https://dexie.org/docs/Table/Table.reverse()\n * \n **/\n reverse(): Collection {\n return this.toCollection().reverse();\n }\n\n /** Table.mapToClass()\n * \n * https://dexie.org/docs/Table/Table.mapToClass()\n * \n **/\n mapToClass(constructor: Function) {\n const {db, name: tableName} = this;\n this.schema.mappedClass = constructor;\n if (constructor.prototype instanceof Entity) {\n constructor = class extends (constructor as any) {\n get db () { return db; }\n table() { return tableName; }\n }\n }\n // Collect all inherited property names (including method names) by\n // walking the prototype chain. This is to avoid overwriting them from\n // database data - so application code can rely on inherited props never\n // becoming shadowed by database object props.\n const inheritedProps = new Set();\n for (let proto = constructor.prototype; proto; proto = getProto(proto)) {\n Object.getOwnPropertyNames(proto).forEach(propName => inheritedProps.add(propName));\n }\n \n // Now, subscribe to the when(\"reading\") event to make all objects that come out from this table inherit from given class\n // no matter which method to use for reading (Table.get() or Table.where(...)... )\n const readHook = (obj: Object) => {\n if (!obj) return obj; // No valid object. (Value is null or undefined). Return as is.\n // Create a new object that derives from constructor:\n const res = Object.create(constructor.prototype);\n // Clone members (but never those that collide with a property in the prototype\n // hierchary (MUST BE ABLE TO RELY ON Entity methods and props!)):\n for (let m in obj) if (!inheritedProps.has(m)) try { res[m] = obj[m]; } catch (_) { }\n return res;\n };\n\n if (this.schema.readHook) {\n this.hook.reading.unsubscribe(this.schema.readHook);\n }\n this.schema.readHook = readHook;\n this.hook(\"reading\", readHook);\n return constructor;\n }\n\n /** @deprecated */\n defineClass() {\n function Class (content){\n extend(this, content);\n };\n return this.mapToClass(Class);\n }\n\n /** Table.add()\n * \n * https://dexie.org/docs/Table/Table.add()\n * \n **/\n add(obj, key?: IndexableType): PromiseExtended {\n const {auto, keyPath} = this.schema.primKey;\n let objToAdd = obj;\n if (keyPath && auto) {\n objToAdd = workaroundForUndefinedPrimKey(keyPath)(obj);\n }\n return this._trans('readwrite', trans => {\n return this.core.mutate({trans, type: 'add', keys: key != null ? [key] : null, values: [objToAdd]});\n }).then(res => res.numFailures ? Promise.reject(res.failures[0]) : res.lastResult)\n .then(lastResult => {\n if (keyPath) {\n // This part should be here for backward compatibility.\n // If ever feeling too bad about this, please wait to a new major before removing it,\n // and document the change thoroughly.\n try{setByKeyPath(obj, keyPath, lastResult);}catch(_){};\n }\n return lastResult;\n });\n }\n\n /** Table.update()\n * \n * https://dexie.org/docs/Table/Table.update()\n * \n **/\n update(keyOrObject, modifications: { [keyPath: string]: any; } | ((obj: any, ctx:{value: any, primKey: IndexableType}) => void | boolean)): PromiseExtended {\n if (typeof keyOrObject === 'object' && !isArray(keyOrObject)) {\n const key = getByKeyPath(keyOrObject, this.schema.primKey.keyPath);\n if (key === undefined) return rejection(new exceptions.InvalidArgument(\n \"Given object does not contain its primary key\"));\n /*// object to modify. Also modify given object with the modifications:\n // This part should be here for backward compatibility.\n // If ever feeling too bad about mutating given object, please wait to a new major before removing it,\n // and document the change thoroughly. TODO: Document this change!\n if (!Object.isFrozen(keyOrObject)) try {\n if (typeof modifications !== \"function\") {\n keys(modifications).forEach(keyPath => {\n setByKeyPath(keyOrObject, keyPath, modifications[keyPath]);\n });\n } else {\n // Now since we support function argument, we should have a similar behavior here as well\n // (as long as we do this mutability stuff on the given object)\n modifications(keyOrObject, {value: keyOrObject, primKey: key});\n }\n } catch {\n // Maybe given object was frozen.\n // This part is not essential. Just move on as nothing happened...\n }*/\n return this.where(\":id\").equals(key).modify(modifications);\n } else {\n // key to modify\n return this.where(\":id\").equals(keyOrObject).modify(modifications);\n }\n }\n\n /** Table.put()\n * \n * https://dexie.org/docs/Table/Table.put()\n * \n **/\n put(obj, key?: IndexableType): PromiseExtended {\n const {auto, keyPath} = this.schema.primKey;\n let objToAdd = obj;\n if (keyPath && auto) {\n objToAdd = workaroundForUndefinedPrimKey(keyPath)(obj);\n }\n return this._trans(\n 'readwrite',\n trans => this.core.mutate({trans, type: 'put', values: [objToAdd], keys: key != null ? [key] : null}))\n .then(res => res.numFailures ? Promise.reject(res.failures[0]) : res.lastResult)\n .then(lastResult => {\n if (keyPath) {\n // This part should be here for backward compatibility.\n // If ever feeling too bad about this, please wait to a new major before removing it,\n // and document the change thoroughly.\n try{setByKeyPath(obj, keyPath, lastResult);}catch(_){};\n }\n return lastResult;\n });\n }\n\n /** Table.delete()\n * \n * https://dexie.org/docs/Table/Table.delete()\n * \n **/\n delete(key: IndexableType): PromiseExtended {\n return this._trans('readwrite',\n trans => this.core.mutate({trans, type: 'delete', keys: [key]}))\n .then(res => res.numFailures ? Promise.reject(res.failures[0]) : undefined);\n }\n\n /** Table.clear()\n * \n * https://dexie.org/docs/Table/Table.clear()\n * \n **/\n clear() {\n return this._trans('readwrite',\n trans => this.core.mutate({trans, type: 'deleteRange', range: AnyRange}))\n .then(res => res.numFailures ? Promise.reject(res.failures[0]) : undefined);\n }\n\n /** Table.bulkGet()\n * \n * https://dexie.org/docs/Table/Table.bulkGet()\n * \n * @param keys \n */\n bulkGet(keys: IndexableType[]) {\n return this._trans('readonly', trans => {\n return this.core.getMany({\n keys,\n trans\n }).then(result => result.map(res => this.hook.reading.fire(res)));\n });\n }\n\n /** Table.bulkAdd()\n * \n * https://dexie.org/docs/Table/Table.bulkAdd()\n * \n **/\n bulkAdd(\n objects: readonly any[],\n keysOrOptions?: ReadonlyArray | { allKeys?: boolean },\n options?: { allKeys?: boolean }\n ) { \n const keys = Array.isArray(keysOrOptions) ? keysOrOptions : undefined;\n options = options || (keys ? undefined : keysOrOptions as { allKeys?: boolean });\n const wantResults = options ? options.allKeys : undefined;\n\n return this._trans('readwrite', trans => {\n const {auto, keyPath} = this.schema.primKey;\n if (keyPath && keys)\n throw new exceptions.InvalidArgument(\"bulkAdd(): keys argument invalid on tables with inbound keys\");\n if (keys && keys.length !== objects.length)\n throw new exceptions.InvalidArgument(\"Arguments objects and keys must have the same length\");\n\n const numObjects = objects.length; // Pick length here to allow garbage collection of objects later\n let objectsToAdd = keyPath && auto ?\n objects.map(workaroundForUndefinedPrimKey(keyPath)) :\n objects;\n return this.core.mutate(\n {trans, type: 'add', keys: keys as IndexableType[], values: objectsToAdd, wantResults}\n )\n .then(({numFailures, results,lastResult, failures}) => {\n const result = wantResults ? results : lastResult;\n if (numFailures === 0) return result;\n throw new BulkError(\n `${this.name}.bulkAdd(): ${numFailures} of ${numObjects} operations failed`, failures);\n });\n });\n }\n\n /** Table.bulkPut()\n * \n * https://dexie.org/docs/Table/Table.bulkPut()\n * \n **/\n bulkPut(\n objects: readonly any[],\n keysOrOptions?: ReadonlyArray | { allKeys?: boolean },\n options?: { allKeys?: boolean }\n ) { \n const keys = Array.isArray(keysOrOptions) ? keysOrOptions : undefined;\n options = options || (keys ? undefined : keysOrOptions as { allKeys?: boolean });\n const wantResults = options ? options.allKeys : undefined;\n\n return this._trans('readwrite', trans => {\n const {auto, keyPath} = this.schema.primKey;\n if (keyPath && keys)\n throw new exceptions.InvalidArgument(\"bulkPut(): keys argument invalid on tables with inbound keys\");\n if (keys && keys.length !== objects.length)\n throw new exceptions.InvalidArgument(\"Arguments objects and keys must have the same length\");\n\n const numObjects = objects.length; // Pick length here to allow garbage collection of objects later\n let objectsToPut = keyPath && auto ?\n objects.map(workaroundForUndefinedPrimKey(keyPath)) :\n objects;\n\n return this.core.mutate(\n {trans, type: 'put', keys: keys as IndexableType[], values: objectsToPut, wantResults}\n )\n .then(({numFailures, results, lastResult, failures}) => {\n const result = wantResults ? results : lastResult;\n if (numFailures === 0) return result;\n throw new BulkError(\n `${this.name}.bulkPut(): ${numFailures} of ${numObjects} operations failed`, failures);\n });\n });\n }\n\n /** Table.bulkUpdate()\n *\n * https://dexie.org/docs/Table.Table.bulkUpdate()\n */\n bulkUpdate(\n keysAndChanges: readonly { key: any; changes: UpdateSpec }[]\n ): PromiseExtended {\n const coreTable = this.core;\n const keys = keysAndChanges.map((entry) => entry.key);\n const changeSpecs = keysAndChanges.map((entry) => entry.changes);\n const offsetMap: number[] = [];\n return this._trans('readwrite', (trans) => {\n return coreTable.getMany({ trans, keys, cache: 'clone' }).then((objs) => {\n const resultKeys: any[] = [];\n const resultObjs: any[] = [];\n keysAndChanges.forEach(({ key, changes }, idx) => {\n const obj = objs[idx];\n if (obj) {\n for (const keyPath of Object.keys(changes)) {\n const value = changes[keyPath];\n if (keyPath === this.schema.primKey.keyPath) {\n if (cmp(value, key) !== 0) {\n throw new exceptions.Constraint(\n `Cannot update primary key in bulkUpdate()`\n );\n }\n } else {\n setByKeyPath(obj, keyPath, value);\n }\n }\n offsetMap.push(idx);\n resultKeys.push(key);\n resultObjs.push(obj);\n }\n });\n const numEntries = resultKeys.length;\n return coreTable\n .mutate({\n trans,\n type: 'put',\n keys: resultKeys,\n values: resultObjs,\n updates: {\n keys,\n changeSpecs\n }\n })\n .then(({ numFailures, failures }) => {\n if (numFailures === 0) return numEntries;\n // Failure. bulkPut() may have a subset of keys\n // so we must translate returned 'failutes' into the offsets of given argument:\n for (const offset of Object.keys(failures)) {\n const mappedOffset = offsetMap[Number(offset)];\n if (mappedOffset != null) {\n const failure = failures[offset];\n delete failures[offset];\n failures[mappedOffset] = failure;\n }\n }\n throw new BulkError(\n `${this.name}.bulkUpdate(): ${numFailures} of ${numEntries} operations failed`,\n failures\n );\n });\n });\n });\n }\n\n /** Table.bulkDelete()\n * \n * https://dexie.org/docs/Table/Table.bulkDelete()\n * \n **/\n bulkDelete(keys: ReadonlyArray): PromiseExtended {\n const numKeys = keys.length;\n return this._trans('readwrite', trans => {\n return this.core.mutate({trans, type: 'delete', keys: keys as IndexableType[]});\n }).then(({numFailures, lastResult, failures}) => {\n if (numFailures === 0) return lastResult;\n throw new BulkError(\n `${this.name}.bulkDelete(): ${numFailures} of ${numKeys} operations failed`, failures);\n });\n }\n}\n","import {keys, isArray, asap} from '../functions/utils';\nimport {nop, mirror, reverseStoppableEventChain} from '../functions/chaining-functions';\nimport {exceptions} from '../errors';\n\nexport default function Events(ctx) {\n var evs = {};\n var rv = function (eventName, subscriber) {\n if (subscriber) {\n // Subscribe. If additional arguments than just the subscriber was provided, forward them as well.\n var i = arguments.length, args = new Array(i - 1);\n while (--i) args[i - 1] = arguments[i];\n evs[eventName].subscribe.apply(null, args);\n return ctx;\n } else if (typeof (eventName) === 'string') {\n // Return interface allowing to fire or unsubscribe from event\n return evs[eventName];\n }\n };\n rv.addEventType = add;\n \n for (var i = 1, l = arguments.length; i < l; ++i) {\n add(arguments[i]);\n }\n \n return rv;\n\n function add(eventName, chainFunction, defaultFunction) {\n if (typeof eventName === 'object') return addConfiguredEvents(eventName);\n if (!chainFunction) chainFunction = reverseStoppableEventChain;\n if (!defaultFunction) defaultFunction = nop;\n\n var context = {\n subscribers: [],\n fire: defaultFunction,\n subscribe: function (cb) {\n if (context.subscribers.indexOf(cb) === -1) {\n context.subscribers.push(cb);\n context.fire = chainFunction(context.fire, cb);\n }\n },\n unsubscribe: function (cb) {\n context.subscribers = context.subscribers.filter(function (fn) { return fn !== cb; });\n context.fire = context.subscribers.reduce(chainFunction, defaultFunction);\n }\n };\n evs[eventName] = rv[eventName] = context;\n return context;\n }\n\n function addConfiguredEvents(cfg) {\n // events(this, {reading: [functionChain, nop]});\n keys(cfg).forEach(function (eventName) {\n var args = cfg[eventName];\n if (isArray(args)) {\n add(eventName, cfg[eventName][0], cfg[eventName][1]);\n } else if (args === 'asap') {\n // Rather than approaching event subscription using a functional approach, we here do it in a for-loop where subscriber is executed in its own stack\n // enabling that any exception that occur wont disturb the initiator and also not nescessary be catched and forgotten.\n var context = add(eventName, mirror, function fire() {\n // Optimazation-safe cloning of arguments into args.\n var i = arguments.length, args = new Array(i);\n while (i--) args[i] = arguments[i];\n // All each subscriber:\n context.subscribers.forEach(function (fn) {\n asap(function fireEvent() {\n fn.apply(null, args);\n });\n });\n });\n } else throw new exceptions.InvalidArgument(\"Invalid event config\");\n });\n }\n}\n","import { arrayToObject, derive } from './utils';\n\n\nexport function makeClassConstructor (prototype: Object, constructor: Function) {\n /*const propertyDescriptorMap = arrayToObject(\n Object.getOwnPropertyNames(prototype),\n propKey => [propKey, Object.getOwnPropertyDescriptor(prototype, propKey)]);\n\n // Both derive and clone the prototype.\n // derive: So that x instanceof T returns true when T is the class template.\n // clone: Optimizes method access a bit (but actually not nescessary)\n const derivedPrototypeClone = Object.create(prototype, propertyDescriptorMap);\n derivedPrototypeClone.constructor = constructor;\n constructor.prototype = derivedPrototypeClone;\n return constructor as any as TConstructor;*/\n\n // Keep the above code in case we want to clone AND derive the parent prototype.\n // Reason would be optimization of property access.\n // The code below will only create a prototypal inheritance from given constructor function\n // to given prototype.\n derive(constructor).from({prototype});\n return constructor as any as TConstructor; \n}\n","import { Dexie } from '../dexie';\nimport { TableSchema } from '../../public/types/table-schema';\nimport { Transaction } from '../transaction/transaction';\nimport { hookCreatingChain, pureFunctionChain, nop, mirror, hookUpdatingChain, hookDeletingChain } from '../../functions/chaining-functions';\nimport { TableHooks } from '../../public/types/table-hooks';\nimport { Table } from './table';\nimport Events from '../../helpers/Events';\nimport { makeClassConstructor } from '../../functions/make-class-constructor';\n\nexport interface TableConstructor {\n new (name: string, tableSchema: TableSchema, optionalTrans?: Transaction) : Table;\n prototype: Table;\n}\n\n/** Generates a Table constructor bound to given Dexie instance.\n * \n * The purpose of having dynamically created constructors, is to allow\n * addons to extend classes for a certain Dexie instance without affecting\n * other db instances.\n */\nexport function createTableConstructor (db: Dexie) {\n return makeClassConstructor(\n Table.prototype,\n\n function Table (this: Table, name: string, tableSchema: TableSchema, trans?: Transaction) {\n this.db = db;\n this._tx = trans;\n this.name = name;\n this.schema = tableSchema;\n this.hook = db._allTables[name] ? db._allTables[name].hook : Events(null, {\n \"creating\": [hookCreatingChain, nop],\n \"reading\": [pureFunctionChain, mirror],\n \"updating\": [hookUpdatingChain, nop],\n \"deleting\": [hookDeletingChain, nop]\n }) as TableHooks;\n }\n\n );\n}\n","import { combine } from \"../../functions/combine\";\nimport { exceptions } from \"../../errors\";\nimport { hasOwn } from \"../../functions/utils\";\nimport { wrap } from \"../../helpers/promise\";\nimport { Collection } from './';\nimport { DBCoreCursor, DBCoreTable, DBCoreTransaction, DBCoreTableSchema, DBCoreRangeType } from '../../public/types/dbcore';\nimport { nop } from '../../functions/chaining-functions';\n\ntype CollectionContext = Collection[\"_ctx\"];\n\nexport function isPlainKeyRange (ctx: CollectionContext, ignoreLimitFilter?: boolean) {\n return !(ctx.filter || ctx.algorithm || ctx.or) &&\n (ignoreLimitFilter ? ctx.justLimit : !ctx.replayFilter);\n} \n\nexport function addFilter(ctx: CollectionContext, fn: Function) {\n ctx.filter = combine(ctx.filter, fn);\n}\n\nexport function addReplayFilter (ctx: CollectionContext, factory, isLimitFilter?) {\n var curr = ctx.replayFilter;\n ctx.replayFilter = curr ? ()=>combine(curr(), factory()) : factory;\n ctx.justLimit = isLimitFilter && !curr;\n}\n\nexport function addMatchFilter(ctx: CollectionContext, fn) {\n ctx.isMatch = combine(ctx.isMatch, fn);\n}\n\nexport function getIndexOrStore(ctx: CollectionContext, coreSchema: DBCoreTableSchema) {\n // TODO: Rewrite this. No need to know ctx.isPrimKey. ctx.index should hold the keypath.\n // Still, throw if not found!\n if (ctx.isPrimKey) return coreSchema.primaryKey;\n const index = coreSchema.getIndexByKeyPath(ctx.index);\n if (!index) throw new exceptions.Schema(\"KeyPath \" + ctx.index + \" on object store \" + coreSchema.name + \" is not indexed\");\n return index;\n}\n\nexport function openCursor(ctx: CollectionContext, coreTable: DBCoreTable, trans: DBCoreTransaction) {\n const index = getIndexOrStore(ctx, coreTable.schema);\n return coreTable.openCursor({\n trans,\n values: !ctx.keysOnly,\n reverse: ctx.dir === 'prev',\n unique: !!ctx.unique,\n query: {\n index, \n range: ctx.range\n }\n });\n}\n\nexport function iter (\n ctx: CollectionContext, \n fn: (item, cursor: DBCoreCursor, advance: Function)=>void,\n coreTrans: DBCoreTransaction,\n coreTable: DBCoreTable): Promise\n{\n const filter = ctx.replayFilter ? combine(ctx.filter, ctx.replayFilter()) : ctx.filter;\n if (!ctx.or) {\n return iterate(\n openCursor(ctx, coreTable, coreTrans),\n combine(ctx.algorithm, filter), fn, !ctx.keysOnly && ctx.valueMapper);\n } else {\n const set = {};\n\n const union = (item: any, cursor: DBCoreCursor, advance) => {\n if (!filter || filter(cursor, advance, result=>cursor.stop(result), err => cursor.fail(err))) {\n var primaryKey = cursor.primaryKey;\n var key = '' + primaryKey;\n if (key === '[object ArrayBuffer]') key = '' + new Uint8Array(primaryKey);\n if (!hasOwn(set, key)) {\n set[key] = true;\n fn(item, cursor, advance);\n }\n }\n }\n\n return Promise.all([\n ctx.or._iterate(union, coreTrans),\n iterate(openCursor(ctx, coreTable, coreTrans), ctx.algorithm, union, !ctx.keysOnly && ctx.valueMapper)\n ]);\n }\n}\n\nfunction iterate(cursorPromise: Promise, filter, fn, valueMapper): Promise {\n \n // Apply valueMapper (hook('reading') or mappped class)\n var mappedFn = valueMapper ? (x,c,a) => fn(valueMapper(x),c,a) : fn;\n // Wrap fn with PSD and microtick stuff from Promise.\n var wrappedFn = wrap(mappedFn);\n \n return cursorPromise.then(cursor => {\n if (cursor) {\n return cursor.start(()=>{\n var c = ()=>cursor.continue();\n if (!filter || filter(cursor, advancer => c = advancer, val=>{cursor.stop(val);c=nop}, e => {cursor.fail(e);c = nop;}))\n wrappedFn(cursor.value, cursor, advancer => c = advancer);\n c();\n });\n }\n });\n}\n","import { Collection as ICollection } from \"../../public/types/collection\";\nimport { Dexie } from \"../dexie\";\nimport { Table } from \"../table\";\nimport { IndexableType, IndexableTypeArrayReadonly } from \"../../public/types/indexable-type\";\nimport { PromiseExtended } from \"../../public/types/promise-extended\";\nimport { iter, isPlainKeyRange, getIndexOrStore, addReplayFilter, addFilter, addMatchFilter } from \"./collection-helpers\";\nimport { rejection } from \"../../helpers/promise\";\nimport { combine } from \"../../functions/combine\";\nimport { extend, hasOwn, deepClone, keys, setByKeyPath, getByKeyPath } from \"../../functions/utils\";\nimport { ModifyError } from \"../../errors\";\nimport { hangsOnDeleteLargeKeyRange } from \"../../globals/constants\";\nimport { ThenShortcut } from \"../../public/types/then-shortcut\";\nimport { Transaction } from '../transaction';\nimport { DBCoreCursor, DBCoreTransaction, DBCoreRangeType, DBCoreMutateResponse, DBCoreKeyRange } from '../../public/types/dbcore';\nimport { cmp } from \"../../functions/cmp\";\n\n/** class Collection\n * \n * https://dexie.org/docs/Collection/Collection\n */\nexport class Collection implements ICollection {\n db: Dexie;\n _ctx: {\n table: Table;\n index?: string | null;\n isPrimKey?: boolean;\n range: DBCoreKeyRange;\n keysOnly: boolean;\n dir: \"next\" | \"prev\";\n unique: \"\" | \"unique\";\n algorithm?: Function | null;\n filter?: Function | null;\n replayFilter: Function | null;\n justLimit: boolean; // True if a replayFilter is just a filter that performs a \"limit\" operation (or none at all)\n isMatch: Function | null;\n offset: number,\n limit: number,\n error: any, // If set, any promise must be rejected with this error\n or: Collection,\n valueMapper: (any) => any\n }\n \n _ondirectionchange?: Function;\n\n _read(fn: (idbtrans: IDBTransaction, dxTrans: Transaction) => PromiseLike, cb?): PromiseExtended {\n var ctx = this._ctx;\n return ctx.error ?\n ctx.table._trans(null, rejection.bind(null, ctx.error)) :\n ctx.table._trans('readonly', fn).then(cb);\n }\n\n _write(fn: (idbtrans: IDBTransaction, dxTrans: Transaction) => PromiseLike): PromiseExtended {\n var ctx = this._ctx;\n return ctx.error ?\n ctx.table._trans(null, rejection.bind(null, ctx.error)) :\n ctx.table._trans('readwrite', fn, \"locked\"); // When doing write operations on collections, always lock the operation so that upcoming operations gets queued.\n }\n\n _addAlgorithm(fn) {\n var ctx = this._ctx;\n ctx.algorithm = combine(ctx.algorithm, fn);\n }\n\n _iterate(\n fn: (item, cursor: DBCoreCursor, advance: Function) => void,\n coreTrans: DBCoreTransaction) : Promise\n {\n return iter(this._ctx, fn, coreTrans, this._ctx.table.core);\n }\n\n /** Collection.clone()\n * \n * https://dexie.org/docs/Collection/Collection.clone()\n * \n **/\n clone(props?) {\n var rv = Object.create(this.constructor.prototype),\n ctx = Object.create(this._ctx);\n if (props) extend(ctx, props);\n rv._ctx = ctx;\n return rv;\n }\n\n /** Collection.raw()\n * \n * https://dexie.org/docs/Collection/Collection.raw()\n * \n **/\n raw() {\n this._ctx.valueMapper = null;\n return this;\n }\n\n /** Collection.each()\n * \n * https://dexie.org/docs/Collection/Collection.each()\n * \n **/\n each(fn: (obj, cursor: DBCoreCursor) => any): PromiseExtended {\n var ctx = this._ctx;\n\n return this._read(trans => iter(ctx, fn, trans, ctx.table.core));\n }\n\n /** Collection.count()\n * \n * https://dexie.org/docs/Collection/Collection.count()\n * \n **/\n count(cb?) {\n return this._read(trans => {\n const ctx = this._ctx;\n const coreTable = ctx.table.core;\n if (isPlainKeyRange(ctx, true)) {\n // This is a plain key range. We can use the count() method if the index.\n return coreTable.count({\n trans,\n query: {\n index: getIndexOrStore(ctx, coreTable.schema),\n range: ctx.range\n }\n }).then(count => Math.min(count, ctx.limit));\n } else {\n // Algorithms, filters or expressions are applied. Need to count manually.\n var count = 0;\n return iter(ctx, () => { ++count; return false; }, trans, coreTable)\n .then(()=>count);\n }\n }).then(cb);\n }\n\n /** Collection.sortBy()\n * \n * https://dexie.org/docs/Collection/Collection.sortBy()\n * \n **/\n sortBy(keyPath: string): PromiseExtended;\n sortBy(keyPath: string, thenShortcut: ThenShortcut) : PromiseExtended;\n sortBy(keyPath: string, cb?: ThenShortcut) {\n const parts = keyPath.split('.').reverse(),\n lastPart = parts[0],\n lastIndex = parts.length - 1;\n function getval(obj, i) {\n if (i) return getval(obj[parts[i]], i - 1);\n return obj[lastPart];\n }\n var order = this._ctx.dir === \"next\" ? 1 : -1;\n\n function sorter(a, b) {\n var aVal = getval(a, lastIndex),\n bVal = getval(b, lastIndex);\n return aVal < bVal ? -order : aVal > bVal ? order : 0;\n }\n return this.toArray(function (a) {\n return a.sort(sorter);\n }).then(cb);\n }\n\n /** Collection.toArray()\n * \n * https://dexie.org/docs/Collection/Collection.toArray()\n * \n **/\n toArray(cb?): PromiseExtended {\n return this._read(trans => {\n var ctx = this._ctx;\n if (ctx.dir === 'next' && isPlainKeyRange(ctx, true) && ctx.limit > 0) {\n // Special optimation if we could use IDBObjectStore.getAll() or\n // IDBKeyRange.getAll():\n const {valueMapper} = ctx;\n const index = getIndexOrStore(ctx, ctx.table.core.schema);\n return ctx.table.core.query({\n trans,\n limit: ctx.limit,\n values: true,\n query: {\n index,\n range: ctx.range\n }\n }).then(({result}) => valueMapper ? result.map(valueMapper) : result);\n } else {\n // Getting array through a cursor.\n const a = [];\n return iter(ctx, item => a.push(item), trans, ctx.table.core).then(()=>a);\n }\n }, cb);\n }\n\n /** Collection.offset()\n * \n * https://dexie.org/docs/Collection/Collection.offset()\n * \n **/\n offset(offset: number) : Collection{\n var ctx = this._ctx;\n if (offset <= 0) return this;\n ctx.offset += offset; // For count()\n if (isPlainKeyRange(ctx)) {\n addReplayFilter(ctx, () => {\n var offsetLeft = offset;\n return (cursor, advance) => {\n if (offsetLeft === 0) return true;\n if (offsetLeft === 1) { --offsetLeft; return false; }\n advance(() => {\n cursor.advance(offsetLeft);\n offsetLeft = 0;\n });\n return false;\n };\n });\n } else {\n addReplayFilter(ctx, () => {\n var offsetLeft = offset;\n return () => (--offsetLeft < 0);\n });\n }\n return this;\n }\n\n /** Collection.limit()\n * \n * https://dexie.org/docs/Collection/Collection.limit()\n * \n **/\n limit(numRows: number) : Collection {\n this._ctx.limit = Math.min(this._ctx.limit, numRows); // For count()\n addReplayFilter(this._ctx, () => {\n var rowsLeft = numRows;\n return function (cursor, advance, resolve) {\n if (--rowsLeft <= 0) advance(resolve); // Stop after this item has been included\n return rowsLeft >= 0; // If numRows is already below 0, return false because then 0 was passed to numRows initially. Otherwise we wouldnt come here.\n };\n }, true);\n return this;\n }\n\n /** Collection.until()\n * \n * https://dexie.org/docs/Collection/Collection.until()\n * \n **/\n until(filterFunction: (x) => boolean, bIncludeStopEntry?) {\n addFilter(this._ctx, function (cursor, advance, resolve) {\n if (filterFunction(cursor.value)) {\n advance(resolve);\n return bIncludeStopEntry;\n } else {\n return true;\n }\n });\n return this;\n }\n\n /** Collection.first()\n * \n * https://dexie.org/docs/Collection/Collection.first()\n * \n **/\n first(cb?) {\n return this.limit(1).toArray(function (a) { return a[0]; }).then(cb);\n }\n\n /** Collection.last()\n * \n * https://dexie.org/docs/Collection/Collection.last()\n * \n **/\n last(cb?) {\n return this.reverse().first(cb);\n }\n\n /** Collection.filter()\n * \n * https://dexie.org/docs/Collection/Collection.filter()\n * \n **/\n filter(filterFunction: (x) => boolean): Collection {\n /// function(val){return true/false}\n addFilter(this._ctx, function (cursor) {\n return filterFunction(cursor.value);\n });\n // match filters not used in Dexie.js but can be used by 3rd part libraries to test a\n // collection for a match without querying DB. Used by Dexie.Observable.\n addMatchFilter(this._ctx, filterFunction);\n return this;\n }\n\n /** Collection.and()\n * \n * https://dexie.org/docs/Collection/Collection.and()\n * \n **/\n and(filter: (x) => boolean) {\n return this.filter(filter);\n }\n\n /** Collection.or()\n * \n * https://dexie.org/docs/Collection/Collection.or()\n * \n **/\n or(indexName: string) {\n return new this.db.WhereClause(this._ctx.table, indexName, this);\n }\n\n /** Collection.reverse()\n * \n * https://dexie.org/docs/Collection/Collection.reverse()\n * \n **/\n reverse() {\n this._ctx.dir = (this._ctx.dir === \"prev\" ? \"next\" : \"prev\");\n if (this._ondirectionchange) this._ondirectionchange(this._ctx.dir);\n return this;\n }\n\n /** Collection.desc()\n * \n * https://dexie.org/docs/Collection/Collection.desc()\n * \n **/\n desc() {\n return this.reverse();\n }\n\n /** Collection.eachKey()\n * \n * https://dexie.org/docs/Collection/Collection.eachKey()\n * \n **/\n eachKey(cb?) {\n var ctx = this._ctx;\n ctx.keysOnly = !ctx.isMatch;\n return this.each(function (val, cursor) { cb(cursor.key, cursor); });\n }\n\n /** Collection.eachUniqueKey()\n * \n * https://dexie.org/docs/Collection/Collection.eachUniqueKey()\n * \n **/\n eachUniqueKey(cb?) {\n this._ctx.unique = \"unique\";\n return this.eachKey(cb);\n }\n\n /** Collection.eachPrimaryKey()\n * \n * https://dexie.org/docs/Collection/Collection.eachPrimaryKey()\n * \n **/\n eachPrimaryKey(cb?) {\n var ctx = this._ctx;\n ctx.keysOnly = !ctx.isMatch;\n return this.each(function (val, cursor) { cb(cursor.primaryKey, cursor); });\n }\n\n /** Collection.keys()\n * \n * https://dexie.org/docs/Collection/Collection.keys()\n * \n **/\n keys(cb?) {\n var ctx = this._ctx;\n ctx.keysOnly = !ctx.isMatch;\n var a = [];\n return this.each(function (item, cursor) {\n a.push(cursor.key);\n }).then(function () {\n return a;\n }).then(cb);\n }\n\n /** Collection.primaryKeys()\n * \n * https://dexie.org/docs/Collection/Collection.primaryKeys()\n * \n **/\n primaryKeys(cb?) : PromiseExtended {\n var ctx = this._ctx;\n if (ctx.dir === 'next' && isPlainKeyRange(ctx, true) && ctx.limit > 0) {\n // Special optimation if we could use IDBObjectStore.getAllKeys() or\n // IDBKeyRange.getAllKeys():\n return this._read(trans => {\n var index = getIndexOrStore(ctx, ctx.table.core.schema);\n return ctx.table.core.query({\n trans,\n values: false,\n limit: ctx.limit,\n query: {\n index,\n range: ctx.range\n }});\n }).then(({result})=>result).then(cb);\n }\n ctx.keysOnly = !ctx.isMatch;\n var a = [];\n return this.each(function (item, cursor) {\n a.push(cursor.primaryKey);\n }).then(function () {\n return a;\n }).then(cb);\n }\n\n /** Collection.uniqueKeys()\n * \n * https://dexie.org/docs/Collection/Collection.uniqueKeys()\n * \n **/\n uniqueKeys(cb?) {\n this._ctx.unique = \"unique\";\n return this.keys(cb);\n }\n\n /** Collection.firstKey()\n * \n * https://dexie.org/docs/Collection/Collection.firstKey()\n * \n **/\n firstKey(cb?) {\n return this.limit(1).keys(function (a) { return a[0]; }).then(cb);\n }\n\n /** Collection.lastKey()\n * \n * https://dexie.org/docs/Collection/Collection.lastKey()\n * \n **/\n lastKey(cb?) {\n return this.reverse().firstKey(cb);\n }\n\n /** Collection.distinct()\n * \n * https://dexie.org/docs/Collection/Collection.distinct()\n * \n **/\n distinct() {\n var ctx = this._ctx,\n idx = ctx.index && ctx.table.schema.idxByName[ctx.index];\n if (!idx || !idx.multi) return this; // distinct() only makes differencies on multiEntry indexes.\n var set = {};\n addFilter(this._ctx, function (cursor: DBCoreCursor) {\n var strKey = cursor.primaryKey.toString(); // Converts any Date to String, String to String, Number to String and Array to comma-separated string\n var found = hasOwn(set, strKey);\n set[strKey] = true;\n return !found;\n });\n return this;\n }\n\n //\n // Methods that mutate storage\n //\n\n /** Collection.modify()\n * \n * https://dexie.org/docs/Collection/Collection.modify()\n * \n **/\n modify(changes: { [keyPath: string]: any }) : PromiseExtended\n modify(changes: (obj: any, ctx:{value: any, primKey: IndexableType}) => void | boolean): PromiseExtended {\n var ctx = this._ctx;\n return this._write(trans => {\n var modifyer: (obj: any, ctx:{value: any, primKey: IndexableType}) => void | boolean\n if (typeof changes === 'function') {\n // Changes is a function that may update, add or delete propterties or even require a deletion the object itself (delete this.item)\n modifyer = changes;\n } else {\n // changes is a set of {keyPath: value} and no one is listening to the updating hook.\n var keyPaths = keys(changes);\n var numKeys = keyPaths.length;\n modifyer = function (item) {\n var anythingModified = false;\n for (var i = 0; i < numKeys; ++i) {\n var keyPath = keyPaths[i], val = changes[keyPath];\n if (getByKeyPath(item, keyPath) !== val) {\n setByKeyPath(item, keyPath, val); // Adding {keyPath: undefined} means that the keyPath should be deleted. Handled by setByKeyPath\n anythingModified = true;\n }\n }\n return anythingModified;\n };\n }\n\n const coreTable = ctx.table.core;\n const {outbound, extractKey} = coreTable.schema.primaryKey;\n const limit = this.db._options.modifyChunkSize || 200;\n const totalFailures = [];\n let successCount = 0;\n const failedKeys: IndexableType[] = [];\n const applyMutateResult = (expectedCount: number, res: DBCoreMutateResponse) => {\n const {failures, numFailures} = res;\n successCount += expectedCount - numFailures;\n for (let pos of keys(failures)) {\n totalFailures.push(failures[pos]);\n }\n }\n return this.clone().primaryKeys().then(keys => {\n\n const nextChunk = (offset: number) => {\n const count = Math.min(limit, keys.length - offset);\n return coreTable.getMany({\n trans,\n keys: keys.slice(offset, offset + count),\n cache: \"immutable\" // Optimize for 2 things:\n // 1) observability-middleware can track changes better.\n // 2) hooks middleware don't have to query the existing values again when tracking changes.\n // We can use \"immutable\" because we promise to not touch the values we retrieve here!\n }).then(values => {\n const addValues = [];\n const putValues = [];\n const putKeys = outbound ? [] : null;\n const deleteKeys = [];\n for (let i=0; i 0 &&\n coreTable.mutate({trans, type: 'add', values: addValues})\n .then(res => {\n for (let pos in res.failures) {\n // Remove from deleteKeys the key of the object that failed to change its primary key\n deleteKeys.splice(parseInt(pos), 1);\n }\n applyMutateResult(addValues.length, res);\n })\n ).then(()=>(putValues.length > 0 || (criteria && typeof changes === 'object')) &&\n coreTable.mutate({\n trans,\n type: 'put',\n keys: putKeys,\n values: putValues,\n criteria,\n changeSpec: typeof changes !== 'function'\n && changes\n }).then(res=>applyMutateResult(putValues.length, res))\n ).then(()=>(deleteKeys.length > 0 || (criteria && changes === deleteCallback)) &&\n coreTable.mutate({\n trans,\n type: 'delete',\n keys: deleteKeys,\n criteria\n }).then(res=>applyMutateResult(deleteKeys.length, res))\n ).then(()=>{\n return keys.length > offset + count && nextChunk(offset + limit);\n });\n });\n }\n\n return nextChunk(0).then(()=>{\n if (totalFailures.length > 0)\n throw new ModifyError(\"Error modifying one or more objects\", totalFailures, successCount, failedKeys as IndexableTypeArrayReadonly);\n\n return keys.length;\n });\n });\n\n });\n }\n\n /** Collection.delete()\n * \n * https://dexie.org/docs/Collection/Collection.delete()\n * \n **/\n delete() : PromiseExtended {\n var ctx = this._ctx,\n range = ctx.range;\n //deletingHook = ctx.table.hook.deleting.fire,\n //hasDeleteHook = deletingHook !== nop;\n if (isPlainKeyRange(ctx) &&\n ((ctx.isPrimKey && !hangsOnDeleteLargeKeyRange) || range.type === DBCoreRangeType.Any)) // if no range, we'll use clear().\n {\n // May use IDBObjectStore.delete(IDBKeyRange) in this case (Issue #208)\n // For chromium, this is the way most optimized version.\n // For IE/Edge, this could hang the indexedDB engine and make operating system instable\n // (https://gist.github.com/dfahlander/5a39328f029de18222cf2125d56c38f7)\n return this._write(trans => {\n // Our API contract is to return a count of deleted items, so we have to count() before delete().\n const {primaryKey} = ctx.table.core.schema;\n const coreRange = range;\n return ctx.table.core.count({trans, query: {index: primaryKey, range: coreRange}}).then(count => {\n return ctx.table.core.mutate({trans, type: 'deleteRange', range: coreRange})\n .then(({failures, lastResult, results, numFailures}) => {\n if (numFailures) throw new ModifyError(\"Could not delete some values\",\n Object.keys(failures).map(pos => failures[pos]),\n count - numFailures);\n return count - numFailures;\n });\n });\n });\n }\n\n return this.modify(deleteCallback);\n }\n}\n\nconst deleteCallback = (value, ctx) => ctx.value = null;\n","import { Dexie } from '../../classes/dexie';\nimport { makeClassConstructor } from '../../functions/make-class-constructor';\nimport { Collection } from './collection';\nimport { WhereClause } from '../where-clause/where-clause';\nimport { AnyRange } from '../../dbcore/keyrange';\nimport { DBCoreKeyRange } from '../../public/types/dbcore';\nimport { mirror } from '../../functions/chaining-functions';\n\n/** Constructs a Collection instance. */\nexport interface CollectionConstructor {\n new(whereClause?: WhereClause | null, keyRangeGenerator?: () => DBCoreKeyRange): Collection;\n prototype: Collection;\n}\n\n/** Generates a Collection constructor bound to given Dexie instance.\n * \n * The purpose of having dynamically created constructors, is to allow\n * addons to extend classes for a certain Dexie instance without affecting\n * other db instances.\n */\nexport function createCollectionConstructor(db: Dexie) {\n return makeClassConstructor(\n Collection.prototype,\n\n function Collection(\n this: Collection,\n whereClause?: WhereClause | null,\n keyRangeGenerator?: () => DBCoreKeyRange)\n {\n this.db = db;\n let keyRange = AnyRange, error = null;\n if (keyRangeGenerator) try {\n keyRange = keyRangeGenerator();\n } catch (ex) {\n error = ex;\n }\n\n const whereCtx = whereClause._ctx;\n const table = whereCtx.table;\n const readingHook = table.hook.reading.fire;\n this._ctx = {\n table: table,\n index: whereCtx.index,\n isPrimKey: (!whereCtx.index || (table.schema.primKey.keyPath && whereCtx.index === table.schema.primKey.name)),\n range: keyRange,\n keysOnly: false,\n dir: \"next\",\n unique: \"\",\n algorithm: null,\n filter: null,\n replayFilter: null,\n justLimit: true, // True if a replayFilter is just a filter that performs a \"limit\" operation (or none at all)\n isMatch: null,\n offset: 0,\n limit: Infinity,\n error: error, // If set, any promise must be rejected with this error\n or: whereCtx.or,\n valueMapper: readingHook !== mirror ? readingHook : null\n };\n }\n );\n}\n","import { IndexableType } from '../public/types/indexable-type';\n\nexport function simpleCompare(a, b) {\n return a < b ? -1 : a === b ? 0 : 1;\n}\n\nexport function simpleCompareReverse(a, b) {\n return a > b ? -1 : a === b ? 0 : 1;\n}\n","import { WhereClause } from './where-clause';\nimport { Collection } from '../collection';\nimport { STRING_EXPECTED } from '../../globals/constants';\nimport { simpleCompare, simpleCompareReverse } from '../../functions/compare-functions';\nimport { IndexableType } from '../../public';\nimport { DBCoreKeyRange, DBCoreRangeType } from '../../public/types/dbcore';\n\nexport function fail(collectionOrWhereClause: Collection | WhereClause, err, T?) {\n var collection = collectionOrWhereClause instanceof WhereClause ?\n new collectionOrWhereClause.Collection (collectionOrWhereClause) :\n collectionOrWhereClause;\n \n collection._ctx.error = T ? new T(err) : new TypeError(err);\n return collection;\n}\n\nexport function emptyCollection(whereClause: WhereClause) {\n return new whereClause.Collection (whereClause, () => rangeEqual(\"\")).limit(0);\n}\n\nexport function upperFactory(dir: 'next' | 'prev') {\n return dir === \"next\" ?\n (s: string) => s.toUpperCase() :\n (s: string) => s.toLowerCase();\n}\n\nexport function lowerFactory(dir: 'next' | 'prev') {\n return dir === \"next\" ?\n (s: string) => s.toLowerCase() :\n (s: string) => s.toUpperCase();\n}\n\nexport function nextCasing(key, lowerKey, upperNeedle, lowerNeedle, cmp, dir) {\n var length = Math.min(key.length, lowerNeedle.length);\n var llp = -1;\n for (var i = 0; i < length; ++i) {\n var lwrKeyChar = lowerKey[i];\n if (lwrKeyChar !== lowerNeedle[i]) {\n if (cmp(key[i], upperNeedle[i]) < 0) return key.substr(0, i) + upperNeedle[i] + upperNeedle.substr(i + 1);\n if (cmp(key[i], lowerNeedle[i]) < 0) return key.substr(0, i) + lowerNeedle[i] + upperNeedle.substr(i + 1);\n if (llp >= 0) return key.substr(0, llp) + lowerKey[llp] + upperNeedle.substr(llp + 1);\n return null;\n }\n if (cmp(key[i], lwrKeyChar) < 0) llp = i;\n }\n if (length < lowerNeedle.length && dir === \"next\") return key + upperNeedle.substr(key.length);\n if (length < key.length && dir === \"prev\") return key.substr(0, upperNeedle.length);\n return (llp < 0 ? null : key.substr(0, llp) + lowerNeedle[llp] + upperNeedle.substr(llp + 1));\n}\n\nexport function addIgnoreCaseAlgorithm(whereClause: WhereClause, match, needles, suffix) {\n /// \n var upper, lower, compare, upperNeedles, lowerNeedles, direction, nextKeySuffix,\n needlesLen = needles.length;\n if (!needles.every(s => typeof s === 'string')) {\n return fail(whereClause, STRING_EXPECTED);\n }\n function initDirection(dir) {\n upper = upperFactory(dir);\n lower = lowerFactory(dir);\n compare = (dir === \"next\" ? simpleCompare : simpleCompareReverse);\n var needleBounds = needles.map(function (needle){\n return {lower: lower(needle), upper: upper(needle)};\n }).sort(function(a,b) {\n return compare(a.lower, b.lower);\n });\n upperNeedles = needleBounds.map(function (nb){ return nb.upper; });\n lowerNeedles = needleBounds.map(function (nb){ return nb.lower; });\n direction = dir;\n nextKeySuffix = (dir === \"next\" ? \"\" : suffix);\n }\n initDirection(\"next\");\n\n var c = new whereClause.Collection (\n whereClause,\n ()=>createRange(upperNeedles[0], lowerNeedles[needlesLen-1] + suffix)\n );\n\n c._ondirectionchange = function (direction) {\n // This event onlys occur before filter is called the first time.\n initDirection(direction);\n };\n\n var firstPossibleNeedle = 0;\n\n c._addAlgorithm(function (cursor, advance, resolve) {\n /// \n /// \n /// \n var key = cursor.key;\n if (typeof key !== 'string') return false;\n var lowerKey = lower(key);\n if (match(lowerKey, lowerNeedles, firstPossibleNeedle)) {\n return true;\n } else {\n var lowestPossibleCasing = null;\n for (var i=firstPossibleNeedle; i 0) {\n lowestPossibleCasing = casing;\n }\n }\n if (lowestPossibleCasing !== null) {\n advance(function () { cursor.continue(lowestPossibleCasing + nextKeySuffix); });\n } else {\n advance(resolve);\n }\n return false;\n }\n });\n return c;\n}\n\nexport function createRange (lower: IndexableType, upper: IndexableType, lowerOpen?: boolean, upperOpen?: boolean): DBCoreKeyRange {\n return {\n type: DBCoreRangeType.Range,\n lower,\n upper,\n lowerOpen,\n upperOpen\n };\n}\n\nexport function rangeEqual (value: IndexableType) : DBCoreKeyRange {\n return {\n type: DBCoreRangeType.Equal,\n lower: value,\n upper: value\n };\n}\n","import { WhereClause as IWhereClause } from \"../../public/types/where-clause\";\nimport { Collection } from \"../collection\";\nimport { Table } from \"../table\";\nimport { IndexableType } from \"../../public/types/indexable-type\";\nimport { emptyCollection, fail, addIgnoreCaseAlgorithm, createRange, rangeEqual } from './where-clause-helpers';\nimport { INVALID_KEY_ARGUMENT, STRING_EXPECTED, maxString, minKey } from '../../globals/constants';\nimport { getArrayOf, NO_CHAR_ARRAY } from '../../functions/utils';\nimport { exceptions } from '../../errors';\nimport { Dexie } from '../dexie';\nimport { Collection as ICollection} from \"../../public/types/collection\";\n\n/** class WhereClause\n * \n * https://dexie.org/docs/WhereClause/WhereClause\n */\nexport class WhereClause implements IWhereClause {\n db: Dexie;\n _IDBKeyRange: typeof IDBKeyRange;\n _ctx: {\n table: Table;\n index: string;\n or: Collection;\n }\n _cmp: (a: IndexableType, b: IndexableType) => number;\n _ascending: (a: IndexableType, b: IndexableType) => number;\n _descending: (a: IndexableType, b: IndexableType) => number;\n _min: (a: IndexableType, b: IndexableType) => IndexableType;\n _max: (a: IndexableType, b: IndexableType) => IndexableType;\n\n get Collection() {\n return this._ctx.table.db.Collection;\n }\n\n /** WhereClause.between()\n * \n * https://dexie.org/docs/WhereClause/WhereClause.between()\n * \n **/\n between(lower: IndexableType, upper: IndexableType, includeLower?: boolean, includeUpper?: boolean) {\n includeLower = includeLower !== false; // Default to true\n includeUpper = includeUpper === true; // Default to false\n try {\n if ((this._cmp(lower, upper) > 0) ||\n (this._cmp(lower, upper) === 0 && (includeLower || includeUpper) && !(includeLower && includeUpper)))\n return emptyCollection(this); // Workaround for idiotic W3C Specification that DataError must be thrown if lower > upper. The natural result would be to return an empty collection.\n return new this.Collection(this, ()=>createRange(lower, upper, !includeLower, !includeUpper));\n } catch (e) {\n return fail(this, INVALID_KEY_ARGUMENT);\n }\n }\n\n /** WhereClause.equals()\n * \n * https://dexie.org/docs/WhereClause/WhereClause.equals()\n * \n **/\n equals(value: IndexableType) {\n if (value == null) return fail(this, INVALID_KEY_ARGUMENT);\n return new this.Collection(this, () => rangeEqual(value)) as ICollection;\n }\n\n /** WhereClause.above()\n * \n * https://dexie.org/docs/WhereClause/WhereClause.above()\n * \n **/\n above(value: IndexableType) {\n if (value == null) return fail(this, INVALID_KEY_ARGUMENT);\n return new this.Collection(this, () => createRange(value, undefined, true));\n }\n\n /** WhereClause.aboveOrEqual()\n * \n * https://dexie.org/docs/WhereClause/WhereClause.aboveOrEqual()\n * \n **/\n aboveOrEqual(value: IndexableType) {\n if (value == null) return fail(this, INVALID_KEY_ARGUMENT);\n return new this.Collection(this, () => createRange(value, undefined, false));\n }\n\n /** WhereClause.below()\n * \n * https://dexie.org/docs/WhereClause/WhereClause.below()\n * \n **/\n below(value: IndexableType) {\n if (value == null) return fail(this, INVALID_KEY_ARGUMENT);\n return new this.Collection(this, () => createRange(undefined, value, false, true));\n }\n\n /** WhereClause.belowOrEqual()\n * \n * https://dexie.org/docs/WhereClause/WhereClause.belowOrEqual()\n * \n **/\n belowOrEqual(value: IndexableType) {\n if (value == null) return fail(this, INVALID_KEY_ARGUMENT);\n return new this.Collection(this, () => createRange(undefined, value));\n }\n\n /** WhereClause.startsWith()\n * \n * https://dexie.org/docs/WhereClause/WhereClause.startsWith()\n * \n **/\n startsWith(str: string) {\n if (typeof str !== 'string') return fail(this, STRING_EXPECTED);\n return this.between(str, str + maxString, true, true);\n }\n\n /** WhereClause.startsWithIgnoreCase()\n * \n * https://dexie.org/docs/WhereClause/WhereClause.startsWithIgnoreCase()\n * \n **/\n startsWithIgnoreCase(str: string) {\n if (str === \"\") return this.startsWith(str);\n return addIgnoreCaseAlgorithm(this, (x, a) => x.indexOf(a[0]) === 0, [str], maxString);\n }\n\n /** WhereClause.equalsIgnoreCase()\n * \n * https://dexie.org/docs/WhereClause/WhereClause.equalsIgnoreCase()\n * \n **/\n equalsIgnoreCase(str: string) {\n return addIgnoreCaseAlgorithm(this, (x, a) => x === a[0], [str], \"\");\n }\n\n /** WhereClause.anyOfIgnoreCase()\n * \n * https://dexie.org/docs/WhereClause/WhereClause.anyOfIgnoreCase()\n * \n **/\n anyOfIgnoreCase(...values: string[]): Collection;\n anyOfIgnoreCase(values: string[]): Collection;\n anyOfIgnoreCase() {\n var set = getArrayOf.apply(NO_CHAR_ARRAY, arguments);\n if (set.length === 0) return emptyCollection(this);\n return addIgnoreCaseAlgorithm(this, (x, a) => a.indexOf(x) !== -1, set, \"\");\n }\n\n /** WhereClause.startsWithAnyOfIgnoreCase()\n * \n * https://dexie.org/docs/WhereClause/WhereClause.startsWithAnyOfIgnoreCase()\n * \n **/\n startsWithAnyOfIgnoreCase(...values: string[]): Collection;\n startsWithAnyOfIgnoreCase(values: string[]): Collection;\n startsWithAnyOfIgnoreCase() {\n var set = getArrayOf.apply(NO_CHAR_ARRAY, arguments);\n if (set.length === 0) return emptyCollection(this);\n return addIgnoreCaseAlgorithm(this, (x, a) => a.some(n => x.indexOf(n) === 0), set, maxString);\n }\n\n /** WhereClause.anyOf()\n * \n * https://dexie.org/docs/WhereClause/WhereClause.anyOf()\n * \n **/\n anyOf(...values: string[]): Collection;\n anyOf(values: string[]): Collection;\n anyOf() {\n const set = getArrayOf.apply(NO_CHAR_ARRAY, arguments);\n let compare = this._cmp;\n try { set.sort(compare); } catch (e) { return fail(this, INVALID_KEY_ARGUMENT); }\n if (set.length === 0) return emptyCollection(this);\n const c = new this.Collection(this, () => createRange(set[0], set[set.length - 1]));\n\n c._ondirectionchange = direction => {\n compare = (direction === \"next\" ?\n this._ascending :\n this._descending);\n set.sort(compare);\n };\n\n let i = 0;\n c._addAlgorithm((cursor, advance, resolve) => {\n const key = cursor.key;\n while (compare(key, set[i]) > 0) {\n // The cursor has passed beyond this key. Check next.\n ++i;\n if (i === set.length) {\n // There is no next. Stop searching.\n advance(resolve);\n return false;\n }\n }\n if (compare(key, set[i]) === 0) {\n // The current cursor value should be included and we should continue a single step in case next item has the same key or possibly our next key in set.\n return true;\n } else {\n // cursor.key not yet at set[i]. Forward cursor to the next key to hunt for.\n advance(() => { cursor.continue(set[i]); });\n return false;\n }\n });\n return c;\n }\n\n /** WhereClause.notEqual()\n * \n * https://dexie.org/docs/WhereClause/WhereClause.notEqual()\n * \n **/\n notEqual(value: IndexableType) {\n return this.inAnyRange([[minKey, value], [value, this.db._maxKey]], { includeLowers: false, includeUppers: false });\n }\n\n /** WhereClause.noneOf()\n * \n * https://dexie.org/docs/WhereClause/WhereClause.noneOf()\n * \n **/\n noneOf(...values: string[]): Collection;\n noneOf(values: string[]): Collection;\n noneOf() {\n const set = getArrayOf.apply(NO_CHAR_ARRAY, arguments);\n if (set.length === 0) return new this.Collection(this); // Return entire collection.\n try { set.sort(this._ascending); } catch (e) { return fail(this, INVALID_KEY_ARGUMENT); }\n // Transform [\"a\",\"b\",\"c\"] to a set of ranges for between/above/below: [[minKey,\"a\"], [\"a\",\"b\"], [\"b\",\"c\"], [\"c\",maxKey]]\n const ranges = set.reduce(\n (res, val) => res ?\n res.concat([[res[res.length - 1][1], val]]) :\n [[minKey, val]],\n null);\n ranges.push([set[set.length - 1], this.db._maxKey]);\n return this.inAnyRange(ranges, { includeLowers: false, includeUppers: false });\n }\n\n /** WhereClause.inAnyRange()\n * \n * https://dexie.org/docs/WhereClause/WhereClause.inAnyRange()\n * \n **/\n inAnyRange(\n ranges: ReadonlyArray<{ 0: IndexableType, 1: IndexableType }>,\n options?: { includeLowers?: boolean, includeUppers?: boolean })\n {\n const cmp = this._cmp,\n ascending = this._ascending,\n descending = this._descending,\n min = this._min,\n max = this._max;\n\n if (ranges.length === 0) return emptyCollection(this);\n if (!ranges.every(range =>\n range[0] !== undefined &&\n range[1] !== undefined &&\n ascending(range[0], range[1]) <= 0)) {\n return fail(\n this,\n \"First argument to inAnyRange() must be an Array of two-value Arrays [lower,upper] where upper must not be lower than lower\",\n exceptions.InvalidArgument);\n }\n const includeLowers = !options || options.includeLowers !== false; // Default to true\n const includeUppers = options && options.includeUppers === true; // Default to false\n\n function addRange(ranges, newRange) {\n let i = 0, l = ranges.length;\n for (; i < l; ++i) {\n const range = ranges[i];\n if (cmp(newRange[0], range[1]) < 0 && cmp(newRange[1], range[0]) > 0) {\n range[0] = min(range[0], newRange[0]);\n range[1] = max(range[1], newRange[1]);\n break;\n }\n }\n if (i === l)\n ranges.push(newRange);\n return ranges;\n }\n\n let sortDirection = ascending;\n function rangeSorter(a, b) { return sortDirection(a[0], b[0]); }\n\n // Join overlapping ranges\n let set;\n try {\n set = ranges.reduce(addRange, []);\n set.sort(rangeSorter);\n } catch (ex) {\n return fail(this, INVALID_KEY_ARGUMENT);\n }\n\n let rangePos = 0;\n const keyIsBeyondCurrentEntry = includeUppers ?\n key => ascending(key, set[rangePos][1]) > 0 :\n key => ascending(key, set[rangePos][1]) >= 0;\n\n const keyIsBeforeCurrentEntry = includeLowers ?\n key => descending(key, set[rangePos][0]) > 0 :\n key => descending(key, set[rangePos][0]) >= 0;\n\n function keyWithinCurrentRange(key) {\n return !keyIsBeyondCurrentEntry(key) && !keyIsBeforeCurrentEntry(key);\n }\n\n let checkKey = keyIsBeyondCurrentEntry;\n\n const c = new this.Collection(\n this,\n () => createRange(set[0][0], set[set.length - 1][1], !includeLowers, !includeUppers));\n\n c._ondirectionchange = direction => {\n if (direction === \"next\") {\n checkKey = keyIsBeyondCurrentEntry;\n sortDirection = ascending;\n } else {\n checkKey = keyIsBeforeCurrentEntry;\n sortDirection = descending;\n }\n set.sort(rangeSorter);\n };\n\n c._addAlgorithm((cursor, advance, resolve) => {\n var key = cursor.key;\n while (checkKey(key)) {\n // The cursor has passed beyond this key. Check next.\n ++rangePos;\n if (rangePos === set.length) {\n // There is no next. Stop searching.\n advance(resolve);\n return false;\n }\n }\n if (keyWithinCurrentRange(key)) {\n // The current cursor value should be included and we should continue a single step in case next item has the same key or possibly our next key in set.\n return true;\n } else if (this._cmp(key, set[rangePos][1]) === 0 || this._cmp(key, set[rangePos][0]) === 0) {\n // includeUpper or includeLower is false so keyWithinCurrentRange() returns false even though we are at range border.\n // Continue to next key but don't include this one.\n return false;\n } else {\n // cursor.key not yet at set[i]. Forward cursor to the next key to hunt for.\n advance(() => {\n if (sortDirection === ascending) cursor.continue(set[rangePos][0]);\n else cursor.continue(set[rangePos][1]);\n });\n return false;\n }\n });\n return c;\n }\n\n /** WhereClause.startsWithAnyOf()\n * \n * https://dexie.org/docs/WhereClause/WhereClause.startsWithAnyOf()\n * \n **/\n startsWithAnyOf(...prefixes: string[]): Collection;\n startsWithAnyOf(prefixes: string[]): Collection;\n startsWithAnyOf() {\n const set = getArrayOf.apply(NO_CHAR_ARRAY, arguments);\n\n if (!set.every(s => typeof s === 'string')) {\n return fail(this, \"startsWithAnyOf() only works with strings\");\n }\n if (set.length === 0) return emptyCollection(this);\n\n return this.inAnyRange(set.map((str: string) => [str, str + maxString]));\n }\n\n}\n","import { Dexie } from '../dexie';\nimport { makeClassConstructor } from '../../functions/make-class-constructor';\nimport { WhereClause } from './where-clause';\nimport { Table } from '../table';\nimport { Collection } from '../collection';\nimport { exceptions } from '../../errors';\nimport { cmp } from '../../functions/cmp';\n\nexport interface WhereClauseConstructor {\n new(table: Table, index?: string, orCollection?: Collection): WhereClause;\n prototype: WhereClause;\n}\n\n/** Generates a WhereClause constructor.\n * \n * The purpose of having dynamically created constructors, is to allow\n * addons to extend classes for a certain Dexie instance without affecting\n * other db instances.\n */\nexport function createWhereClauseConstructor(db: Dexie) {\n return makeClassConstructor(\n WhereClause.prototype,\n\n function WhereClause(this: WhereClause, table: Table, index?: string, orCollection?: Collection) {\n this.db = db;\n this._ctx = {\n table: table,\n index: index === \":id\" ? null : index,\n or: orCollection\n };\n this._cmp = this._ascending = cmp;\n this._descending = (a, b) => cmp(b, a);\n this._max = (a, b) => cmp(a,b) > 0 ? a : b;\n this._min = (a, b) => cmp(a,b) < 0 ? a : b;\n this._IDBKeyRange = db._deps.IDBKeyRange;\n if (!this._IDBKeyRange) throw new exceptions.MissingAPI();\n }\n );\n}\n","import { wrap } from \"../helpers/promise\";\n\nexport function eventRejectHandler(reject) {\n return wrap(function (event) {\n preventDefault(event);\n reject (event.target.error);\n return false;\n });\n}\n\nexport function eventSuccessHandler (resolve) {\n return wrap(function (event){\n resolve(event.target.result);\n });\n}\n\nexport function hookedEventRejectHandler (reject) {\n return wrap(function (event) {\n // See comment on hookedEventSuccessHandler() why wrap() is needed only when supporting hooks.\n \n var req = event.target,\n err = req.error,\n ctx = req._hookCtx,// Contains the hook error handler. Put here instead of closure to boost performance.\n hookErrorHandler = ctx && ctx.onerror;\n hookErrorHandler && hookErrorHandler(err);\n preventDefault(event);\n reject (err);\n return false;\n });\n}\n\nexport function hookedEventSuccessHandler(resolve) {\n // wrap() is needed when calling hooks because the rare scenario of:\n // * hook does a db operation that fails immediately (IDB throws exception)\n // For calling db operations on correct transaction, wrap makes sure to set PSD correctly.\n // wrap() will also execute in a virtual tick.\n // * If not wrapped in a virtual tick, direct exception will launch a new physical tick.\n // * If this was the last event in the bulk, the promise will resolve after a physical tick\n // and the transaction will have committed already.\n // If no hook, the virtual tick will be executed in the reject()/resolve of the final promise,\n // because it is always marked with _lib = true when created using Transaction._promise().\n return wrap(function(event) {\n var req = event.target,\n ctx = req._hookCtx,// Contains the hook error handler. Put here instead of closure to boost performance.\n result = ctx.value || req.result, // Pass the object value on updates. The result from IDB is the primary key.\n hookSuccessHandler = ctx && ctx.onsuccess;\n hookSuccessHandler && hookSuccessHandler(result);\n resolve && resolve(result);\n }, resolve);\n}\n\n\nexport function preventDefault(event) {\n if (event.stopPropagation) // IndexedDBShim doesnt support this on Safari 8 and below.\n event.stopPropagation();\n if (event.preventDefault) // IndexedDBShim doesnt support this on Safari 8 and below.\n event.preventDefault();\n}\n\nexport function BulkErrorHandlerCatchAll(errorList, done?, supportHooks?) {\n return (supportHooks ? hookedEventRejectHandler : eventRejectHandler)(e => {\n errorList.push(e);\n done && done();\n });\n}\n\n","import Events from '../helpers/Events';\nimport { GlobalDexieEvents } from '../public/types/db-events';\n\nexport const DEXIE_STORAGE_MUTATED_EVENT_NAME = 'storagemutated' as 'storagemutated';\n\n// Name of the global event fired using DOM dispatchEvent (if not in node).\n// Reason for propagating this as a DOM event is for getting reactivity across\n// multiple versions of Dexie within the same app (as long as they are\n// compatible with regards to the event data).\n// If the ObservabilitySet protocol change in a way that would not be backward\n// compatible, make sure also update the event name to a new number at the end\n// so that two Dexie instances of different versions continue to work together\n// - maybe not able to communicate but won't fail due to unexpected data in\n// the detail property of the CustomEvent. If so, also make sure to udpate\n// docs and explain at which Dexie version the new name and format of the event\n// is being used.\nexport const STORAGE_MUTATED_DOM_EVENT_NAME = 'x-storagemutated-1';\n\nexport const globalEvents = Events(null, DEXIE_STORAGE_MUTATED_EVENT_NAME) as GlobalDexieEvents;\n","import { Transaction as ITransaction } from '../../public/types/transaction';\nimport { DexiePromise, wrap, rejection } from \"../../helpers/promise\";\nimport { DbSchema } from '../../public/types/db-schema';\nimport { assert, hasOwn } from '../../functions/utils';\nimport { PSD, usePSD } from '../../helpers/promise';\nimport { Dexie } from '../dexie';\nimport { exceptions } from '../../errors';\nimport { safariMultiStoreFix } from '../../functions/quirks';\nimport { preventDefault } from '../../functions/event-wrappers';\nimport { newScope } from '../../helpers/promise';\nimport * as Debug from '../../helpers/debug';\nimport { Table } from '../table';\nimport { globalEvents } from '../../globals/global-events';\n\n/** Transaction\n * \n * https://dexie.org/docs/Transaction/Transaction\n * \n **/\nexport class Transaction implements ITransaction {\n db: Dexie;\n active: boolean;\n mode: IDBTransactionMode;\n chromeTransactionDurability: ChromeTransactionDurability;\n idbtrans: IDBTransaction;\n storeNames: string[];\n explicit?: boolean;\n on: any;\n parent?: Transaction;\n schema: DbSchema;\n _memoizedTables: {[tableName: string]: Table};\n\n _reculock: number;\n _blockedFuncs: { 0: () => any, 1: any }[];\n _resolve: () => void;\n _reject: (Error) => void;\n _waitingFor: DexiePromise; // for waitFor()\n _waitingQueue: Function[]; // for waitFor()\n _spinCount: number; // Just for debugging waitFor()\n _completion: DexiePromise;\n\n //\n // Transaction internal methods (not required by API users, but needed internally and eventually by dexie extensions)\n //\n\n /** Transaction._lock()\n * \n * Internal method.\n */\n _lock() {\n assert(!PSD.global); // Locking and unlocking reuires to be within a PSD scope.\n // Temporary set all requests into a pending queue if they are called before database is ready.\n ++this._reculock; // Recursive read/write lock pattern using PSD (Promise Specific Data) instead of TLS (Thread Local Storage)\n if (this._reculock === 1 && !PSD.global) PSD.lockOwnerFor = this;\n return this;\n }\n\n /** Transaction._unlock()\n * \n * Internal method.\n */\n _unlock() {\n assert(!PSD.global); // Locking and unlocking reuires to be within a PSD scope.\n if (--this._reculock === 0) {\n if (!PSD.global) PSD.lockOwnerFor = null;\n while (this._blockedFuncs.length > 0 && !this._locked()) {\n var fnAndPSD = this._blockedFuncs.shift();\n try { usePSD(fnAndPSD[1], fnAndPSD[0]); } catch (e) { }\n }\n }\n return this;\n }\n\n /** Transaction._lock()\n * \n * Internal method.\n */\n _locked() {\n // Checks if any write-lock is applied on this transaction.\n // To simplify the Dexie API for extension implementations, we support recursive locks.\n // This is accomplished by using \"Promise Specific Data\" (PSD).\n // PSD data is bound to a Promise and any child Promise emitted through then() or resolve( new Promise() ).\n // PSD is local to code executing on top of the call stacks of any of any code executed by Promise():\n // * callback given to the Promise() constructor (function (resolve, reject){...})\n // * callbacks given to then()/catch()/finally() methods (function (value){...})\n // If creating a new independant Promise instance from within a Promise call stack, the new Promise will derive the PSD from the call stack of the parent Promise.\n // Derivation is done so that the inner PSD __proto__ points to the outer PSD.\n // PSD.lockOwnerFor will point to current transaction object if the currently executing PSD scope owns the lock.\n return this._reculock && PSD.lockOwnerFor !== this;\n }\n\n /** Transaction.create()\n * \n * Internal method.\n * \n */\n create(idbtrans?: IDBTransaction & {[prop: string]: any}) {\n if (!this.mode) return this;\n const idbdb = this.db.idbdb;\n const dbOpenError = this.db._state.dbOpenError;\n assert(!this.idbtrans);\n if (!idbtrans && !idbdb) {\n switch (dbOpenError && dbOpenError.name) {\n case \"DatabaseClosedError\":\n // Errors where it is no difference whether it was caused by the user operation or an earlier call to db.open()\n throw new exceptions.DatabaseClosed(dbOpenError);\n case \"MissingAPIError\":\n // Errors where it is no difference whether it was caused by the user operation or an earlier call to db.open()\n throw new exceptions.MissingAPI(dbOpenError.message, dbOpenError);\n default:\n // Make it clear that the user operation was not what caused the error - the error had occurred earlier on db.open()!\n throw new exceptions.OpenFailed(dbOpenError);\n }\n }\n if (!this.active) throw new exceptions.TransactionInactive();\n assert(this._completion._state === null); // Completion Promise must still be pending.\n\n idbtrans = this.idbtrans = idbtrans ||\n (this.db.core \n ? this.db.core.transaction(this.storeNames, this.mode as 'readwrite' | 'readonly', { durability: this.chromeTransactionDurability })\n : idbdb.transaction(this.storeNames, this.mode, { durability: this.chromeTransactionDurability })\n ) as IDBTransaction;\n\n idbtrans.onerror = wrap(ev => {\n preventDefault(ev);// Prohibit default bubbling to window.error\n this._reject(idbtrans.error);\n });\n idbtrans.onabort = wrap(ev => {\n preventDefault(ev);\n this.active && this._reject(new exceptions.Abort(idbtrans.error));\n this.active = false;\n this.on(\"abort\").fire(ev);\n });\n idbtrans.oncomplete = wrap(() => {\n this.active = false;\n this._resolve();\n if ('mutatedParts' in idbtrans) {\n globalEvents.storagemutated.fire(idbtrans[\"mutatedParts\"]);\n }\n });\n return this;\n }\n\n /** Transaction._promise()\n * \n * Internal method.\n */\n _promise(\n mode: IDBTransactionMode,\n fn: (resolve, reject, trans: Transaction) => PromiseLike | void,\n bWriteLock?: string | boolean): DexiePromise\n {\n if (mode === 'readwrite' && this.mode !== 'readwrite')\n return rejection(new exceptions.ReadOnly(\"Transaction is readonly\"));\n\n if (!this.active)\n return rejection(new exceptions.TransactionInactive());\n\n if (this._locked()) {\n return new DexiePromise((resolve, reject) => {\n this._blockedFuncs.push([() => {\n this._promise(mode, fn, bWriteLock).then(resolve, reject);\n }, PSD]);\n });\n\n } else if (bWriteLock) {\n return newScope(() => {\n var p = new DexiePromise((resolve, reject) => {\n this._lock();\n const rv = fn(resolve, reject, this);\n if (rv && rv.then) rv.then(resolve, reject);\n });\n p.finally(() => this._unlock());\n p._lib = true;\n return p;\n });\n\n } else {\n var p = new DexiePromise((resolve, reject) => {\n var rv = fn(resolve, reject, this);\n if (rv && rv.then) rv.then(resolve, reject);\n });\n p._lib = true;\n return p;\n }\n }\n\n /** Transaction._root()\n * \n * Internal method. Retrieves the root transaction in the tree of sub transactions.\n */\n _root() {\n return this.parent ? this.parent._root() : this;\n }\n\n /** Transaction.waitFor()\n * \n * Internal method. Can be accessed from the public API through\n * Dexie.waitFor(): https://dexie.org/docs/Dexie/Dexie.waitFor()\n * \n **/\n waitFor(promiseLike: PromiseLike) {\n // Always operate on the root transaction (in case this is a sub stransaction)\n var root = this._root();\n // For stability reasons, convert parameter to promise no matter what type is passed to waitFor().\n // (We must be able to call .then() on it.)\n const promise = DexiePromise.resolve(promiseLike);\n if (root._waitingFor) {\n // Already called waitFor(). Wait for both to complete.\n root._waitingFor = root._waitingFor.then(() => promise);\n } else {\n // We're not in waiting state. Start waiting state.\n root._waitingFor = promise;\n root._waitingQueue = [];\n // Start interacting with indexedDB until promise completes:\n var store = root.idbtrans.objectStore(root.storeNames[0]);\n (function spin() {\n ++root._spinCount; // For debugging only\n while (root._waitingQueue.length) (root._waitingQueue.shift())();\n if (root._waitingFor) store.get(-Infinity).onsuccess = spin;\n }());\n }\n var currentWaitPromise = root._waitingFor;\n return new DexiePromise((resolve, reject) => {\n promise.then(\n res => root._waitingQueue.push(wrap(resolve.bind(null, res))),\n err => root._waitingQueue.push(wrap(reject.bind(null, err)))\n ).finally(() => {\n if (root._waitingFor === currentWaitPromise) {\n // No one added a wait after us. Safe to stop the spinning.\n root._waitingFor = null;\n }\n });\n });\n } \n\n /** Transaction.abort()\n * \n * https://dexie.org/docs/Transaction/Transaction.abort()\n */\n abort() {\n if (this.active) {\n this.active = false;\n if (this.idbtrans) this.idbtrans.abort();\n this._reject(new exceptions.Abort());\n }\n }\n\n /** Transaction.table()\n * \n * https://dexie.org/docs/Transaction/Transaction.table()\n */\n table(tableName: string) {\n const memoizedTables = (this._memoizedTables || (this._memoizedTables = {}));\n if (hasOwn(memoizedTables, tableName))\n return memoizedTables[tableName];\n const tableSchema = this.schema[tableName];\n if (!tableSchema) {\n throw new exceptions.NotFound(\"Table \" + tableName + \" not part of transaction\"); \n }\n\n const transactionBoundTable = new this.db.Table(tableName, tableSchema, this);\n transactionBoundTable.core = this.db.core.table(tableName);\n memoizedTables[tableName] = transactionBoundTable;\n return transactionBoundTable;\n }\n}\n","import { Dexie } from '../dexie';\nimport { makeClassConstructor } from '../../functions/make-class-constructor';\nimport { Transaction } from './transaction';\nimport { DbSchema } from '../../public/types/db-schema';\nimport Events from '../../helpers/Events';\nimport Promise, { rejection } from '../../helpers/promise';\n\nexport interface TransactionConstructor {\n new (\n mode: IDBTransactionMode,\n storeNames: string[],\n dbschema: DbSchema,\n chromeTransactionDurability: ChromeTransactionDurability,\n parent?: Transaction) : T;\n prototype: T;\n}\n\n/** Generates a Transaction constructor bound to given Dexie instance.\n * \n * The purpose of having dynamically created constructors, is to allow\n * addons to extend classes for a certain Dexie instance without affecting\n * other db instances.\n */\nexport function createTransactionConstructor(db: Dexie) {\n return makeClassConstructor>(\n Transaction.prototype,\n function Transaction (\n this: Transaction,\n mode: IDBTransactionMode,\n storeNames: string[],\n dbschema: DbSchema,\n chromeTransactionDurability: ChromeTransactionDurability,\n parent?: Transaction)\n {\n this.db = db;\n this.mode = mode;\n this.storeNames = storeNames;\n this.schema = dbschema;\n this.chromeTransactionDurability = chromeTransactionDurability;\n this.idbtrans = null;\n this.on = Events(this, \"complete\", \"error\", \"abort\");\n this.parent = parent || null;\n this.active = true;\n this._reculock = 0;\n this._blockedFuncs = [];\n this._resolve = null;\n this._reject = null;\n this._waitingFor = null;\n this._waitingQueue = null;\n this._spinCount = 0; // Just for debugging waitFor()\n this._completion = new Promise ((resolve, reject) => {\n this._resolve = resolve;\n this._reject = reject;\n });\n \n this._completion.then(\n ()=> {\n this.active = false;\n this.on.complete.fire();\n },\n e => {\n var wasActive = this.active;\n this.active = false;\n this.on.error.fire(e);\n this.parent ?\n this.parent._reject(e) :\n wasActive && this.idbtrans && this.idbtrans.abort();\n return rejection(e); // Indicate we actually DO NOT catch this error.\n });\n \n });\n}\n","import { IndexSpec } from '../public/types/index-spec';\n\nexport function createIndexSpec(\n name: string,\n keyPath: string | string[],\n unique: boolean,\n multi: boolean,\n auto: boolean,\n compound: boolean,\n isPrimKey: boolean\n): IndexSpec {\n return {\n name,\n keyPath,\n unique,\n multi,\n auto,\n compound,\n src: (unique && !isPrimKey ? '&' : '') + (multi ? '*' : '') + (auto ? \"++\" : \"\") + nameFromKeyPath(keyPath)\n }\n}\n\nexport function nameFromKeyPath (keyPath?: string | string[]): string {\n return typeof keyPath === 'string' ?\n keyPath :\n keyPath ? ('[' + [].join.call(keyPath, '+') + ']') : \"\";\n}\n","import { IndexSpec } from '../public/types/index-spec';\nimport { TableSchema } from '../public/types/table-schema';\nimport { createIndexSpec } from './index-spec';\nimport { arrayToObject } from '../functions/utils';\n\nexport function createTableSchema (\n name: string,\n primKey: IndexSpec,\n indexes: IndexSpec[]\n): TableSchema {\n return {\n name,\n primKey,\n indexes,\n mappedClass: null,\n idxByName: arrayToObject(indexes, index => [index.name, index])\n };\n}\n","import { maxString } from '../globals/constants';\n\nexport function safariMultiStoreFix(storeNames: string[]) {\n return storeNames.length === 1 ? storeNames[0] : storeNames;\n}\n\nexport function getNativeGetDatabaseNamesFn(indexedDB) {\n var fn = indexedDB && (indexedDB.getDatabaseNames || indexedDB.webkitGetDatabaseNames);\n return fn && fn.bind(indexedDB);\n}\n\nexport let getMaxKey = (IdbKeyRange: typeof IDBKeyRange) => {\n try {\n IdbKeyRange.only([[]]);\n getMaxKey = () => [[]];\n return [[]];\n } catch (e) {\n getMaxKey = () => maxString;\n return maxString;\n }\n}\n","import { getByKeyPath } from '../functions/utils';\n\nexport function getKeyExtractor (keyPath: null | string | string[]) : (a: any) => any {\n if (keyPath == null) {\n return () => undefined;\n } else if (typeof keyPath === 'string') {\n return getSinglePathKeyExtractor(keyPath);\n } else {\n return obj => getByKeyPath(obj, keyPath);\n }\n}\n\nexport function getSinglePathKeyExtractor(keyPath: string) {\n const split = keyPath.split('.');\n if (split.length === 1) {\n return obj => obj[keyPath];\n } else {\n return obj => getByKeyPath(obj, keyPath);\n }\n}\n","import {\n DBCore,\n DBCoreCursor,\n DBCoreOpenCursorRequest,\n DBCoreQueryRequest,\n DBCoreIndex,\n DBCoreKeyRange,\n DBCoreQueryResponse,\n DBCoreRangeType,\n DBCoreSchema,\n DBCoreTableSchema,\n DBCoreTable,\n DBCoreMutateResponse,\n} from \"../public/types/dbcore\";\nimport { isArray } from '../functions/utils';\nimport { eventRejectHandler, preventDefault } from '../functions/event-wrappers';\nimport { wrap } from '../helpers/promise';\nimport { getMaxKey } from '../functions/quirks';\nimport { getKeyExtractor } from './get-key-extractor';\n\nexport function arrayify(arrayLike: {length: number, [index: number]: T}): T[] {\n return [].slice.call(arrayLike);\n}\nexport function pick(obj: T, props: Prop[]): Pick {\n const result = {} as Pick;\n props.forEach(prop => result[prop] = obj[prop]);\n return result;\n}\n\nlet _id_counter = 0;\n\nexport function getKeyPathAlias(keyPath: null | string | string[]) {\n return keyPath == null ?\n \":id\" :\n typeof keyPath === 'string' ?\n keyPath :\n `[${keyPath.join('+')}]`;\n}\n\nexport function createDBCore (\n db: IDBDatabase,\n IdbKeyRange: typeof IDBKeyRange,\n tmpTrans: IDBTransaction) : DBCore\n{\n function extractSchema(db: IDBDatabase, trans: IDBTransaction) : {schema: DBCoreSchema, hasGetAll: boolean} {\n const tables = arrayify(db.objectStoreNames);\n return {\n schema: {\n name: db.name,\n tables: tables.map(table => trans.objectStore(table)).map(store => {\n const {keyPath, autoIncrement} = store;\n const compound = isArray(keyPath);\n const outbound = keyPath == null;\n const indexByKeyPath: {[keyPathAlias: string]: DBCoreIndex} = {};\n const result = {\n name: store.name,\n primaryKey: {\n name: null,\n isPrimaryKey: true,\n outbound,\n compound,\n keyPath,\n autoIncrement,\n unique: true,\n extractKey: getKeyExtractor(keyPath)\n } as DBCoreIndex,\n indexes: arrayify(store.indexNames).map(indexName => store.index(indexName))\n .map(index => {\n const {name, unique, multiEntry, keyPath} = index;\n const compound = isArray(keyPath);\n const result: DBCoreIndex = {\n name,\n compound,\n keyPath,\n unique,\n multiEntry,\n extractKey: getKeyExtractor(keyPath)\n };\n indexByKeyPath[getKeyPathAlias(keyPath)] = result;\n return result;\n }),\n getIndexByKeyPath: (keyPath: null | string | string[]) => indexByKeyPath[getKeyPathAlias(keyPath)]\n };\n indexByKeyPath[\":id\"] = result.primaryKey;\n if (keyPath != null) {\n indexByKeyPath[getKeyPathAlias(keyPath)] = result.primaryKey;\n }\n return result;\n })\n },\n hasGetAll: tables.length > 0 && ('getAll' in trans.objectStore(tables[0])) &&\n !(typeof navigator !== 'undefined' && /Safari/.test(navigator.userAgent) &&\n !/(Chrome\\/|Edge\\/)/.test(navigator.userAgent) &&\n [].concat(navigator.userAgent.match(/Safari\\/(\\d*)/))[1] < 604) // Bug with getAll() on Safari ver<604. See discussion following PR #579\n };\n }\n\n function makeIDBKeyRange (range: DBCoreKeyRange) : IDBKeyRange | null {\n if (range.type === DBCoreRangeType.Any) return null;\n if (range.type === DBCoreRangeType.Never) throw new Error(\"Cannot convert never type to IDBKeyRange\");\n const {lower, upper, lowerOpen, upperOpen} = range;\n const idbRange = lower === undefined ?\n upper === undefined ?\n null : //IDBKeyRange.lowerBound(-Infinity, false) : // Any range (TODO: Should we return null instead?)\n IdbKeyRange.upperBound(upper, !!upperOpen) : // below\n upper === undefined ?\n IdbKeyRange.lowerBound(lower, !!lowerOpen) : // above\n IdbKeyRange.bound(lower, upper, !!lowerOpen, !!upperOpen);\n return idbRange;\n }\n\n function createDbCoreTable(tableSchema: DBCoreTableSchema): DBCoreTable {\n const tableName = tableSchema.name;\n\n function mutate ({trans, type, keys, values, range}) {\n return new Promise((resolve, reject) => {\n resolve = wrap(resolve);\n const store = (trans as IDBTransaction).objectStore(tableName);\n const outbound = store.keyPath == null;\n const isAddOrPut = type === \"put\" || type === \"add\";\n if (!isAddOrPut && type !== 'delete' && type !== 'deleteRange')\n throw new Error (\"Invalid operation type: \" + type);\n\n const {length} = keys || values || {length: 1}; // keys.length if keys. values.length if values. 1 if range.\n if (keys && values && keys.length !== values.length) {\n throw new Error(\"Given keys array must have same length as given values array.\");\n }\n if (length === 0)\n // No items to write. Don't even bother!\n return resolve({numFailures: 0, failures: {}, results: [], lastResult: undefined});\n\n let req: IDBRequest;\n const reqs: IDBRequest[] = [];\n \n const failures: {[operationNumber: number]: Error} = [];\n let numFailures = 0;\n const errorHandler = \n event => {\n ++numFailures;\n preventDefault(event);\n };\n \n if (type === 'deleteRange') {\n // Here the argument is the range\n if (range.type === DBCoreRangeType.Never)\n return resolve({numFailures, failures, results: [], lastResult: undefined}); // Deleting the Never range shoulnt do anything.\n if (range.type === DBCoreRangeType.Any)\n reqs.push(req = store.clear()); // Deleting the Any range is equivalent to store.clear()\n else\n reqs.push(req = store.delete(makeIDBKeyRange(range)));\n } else {\n // No matter add, put or delete - find out arrays of first and second arguments to it.\n const [args1, args2] = isAddOrPut ?\n outbound ?\n [values, keys] :\n [values, null] :\n [keys, null];\n\n if (isAddOrPut) {\n for (let i=0; i {\n const lastResult = event.target.result;\n reqs.forEach((req, i) => req.error != null && (failures[i] = req.error));\n resolve({\n numFailures,\n failures,\n results: type === \"delete\" ? keys : reqs.map(req => req.result),\n lastResult\n });\n };\n \n req.onerror = event => { // wrap() not needed. All paths calling outside will wrap!\n errorHandler(event);\n done(event);\n };\n \n req.onsuccess = done;\n });\n }\n \n function openCursor ({trans, values, query, reverse, unique}: DBCoreOpenCursorRequest): Promise\n {\n return new Promise((resolve, reject) => {\n resolve = wrap(resolve);\n const {index, range} = query;\n const store = (trans as IDBTransaction).objectStore(tableName);\n // source\n const source = index.isPrimaryKey ?\n store :\n store.index(index.name);\n // direction\n const direction = reverse ?\n unique ?\n \"prevunique\" :\n \"prev\" :\n unique ?\n \"nextunique\" :\n \"next\";\n // request\n const req = values || !('openKeyCursor' in source) ?\n source.openCursor(makeIDBKeyRange(range), direction) :\n source.openKeyCursor(makeIDBKeyRange(range), direction);\n \n // iteration\n req.onerror = eventRejectHandler(reject);\n req.onsuccess = wrap(ev => {\n\n const cursor = req.result as unknown as DBCoreCursor;\n if (!cursor) {\n resolve(null);\n return;\n }\n (cursor as any).___id = ++_id_counter;\n (cursor as any).done = false;\n const _cursorContinue = cursor.continue.bind(cursor);\n let _cursorContinuePrimaryKey = cursor.continuePrimaryKey;\n if (_cursorContinuePrimaryKey) _cursorContinuePrimaryKey = _cursorContinuePrimaryKey.bind(cursor);\n const _cursorAdvance = cursor.advance.bind(cursor);\n const doThrowCursorIsNotStarted = ()=>{throw new Error(\"Cursor not started\");}\n const doThrowCursorIsStopped = ()=>{throw new Error(\"Cursor not stopped\");}\n (cursor as any).trans = trans;\n cursor.stop = cursor.continue = cursor.continuePrimaryKey = cursor.advance = doThrowCursorIsNotStarted;\n cursor.fail = wrap(reject);\n cursor.next = function (this: DBCoreCursor) {\n // next() must work with \"this\" pointer in order to function correctly for ProxyCursors (derived objects)\n // without having to re-define next() on each child.\n let gotOne = 1;\n return this.start(() => gotOne-- ? this.continue() : this.stop()).then(() => this);\n };\n cursor.start = (callback) => {\n //console.log(\"Starting cursor\", (cursor as any).___id);\n const iterationPromise = new Promise((resolveIteration, rejectIteration) =>{\n resolveIteration = wrap(resolveIteration);\n req.onerror = eventRejectHandler(rejectIteration);\n cursor.fail = rejectIteration;\n cursor.stop = value => {\n //console.log(\"Cursor stop\", cursor);\n cursor.stop = cursor.continue = cursor.continuePrimaryKey = cursor.advance = doThrowCursorIsStopped;\n resolveIteration(value);\n };\n });\n // Now change req.onsuccess to a callback that doesn't call initCursor but just observer.next()\n const guardedCallback = () => {\n if (req.result) {\n //console.log(\"Next result\", cursor);\n try {\n callback();\n } catch (err) {\n cursor.fail(err);\n }\n } else {\n (cursor as any).done = true;\n cursor.start = ()=>{throw new Error(\"Cursor behind last entry\");}\n cursor.stop();\n }\n }\n req.onsuccess = wrap(ev => {\n //cursor.continue = _cursorContinue;\n //cursor.continuePrimaryKey = _cursorContinuePrimaryKey;\n //cursor.advance = _cursorAdvance;\n req.onsuccess = guardedCallback;\n guardedCallback();\n });\n cursor.continue = _cursorContinue;\n cursor.continuePrimaryKey = _cursorContinuePrimaryKey;\n cursor.advance = _cursorAdvance;\n guardedCallback();\n return iterationPromise;\n };\n resolve(cursor);\n }, reject); \n });\n }\n \n function query (hasGetAll: boolean) {\n return (request: DBCoreQueryRequest) => {\n return new Promise((resolve, reject) => {\n resolve = wrap(resolve);\n const {trans, values, limit, query} = request;\n const nonInfinitLimit = limit === Infinity ? undefined : limit;\n const {index, range} = query;\n const store = (trans as IDBTransaction).objectStore(tableName);\n const source = index.isPrimaryKey ? store : store.index(index.name);\n const idbKeyRange = makeIDBKeyRange(range);\n if (limit === 0) return resolve({result: []});\n if (hasGetAll) {\n const req = values ?\n (source as any).getAll(idbKeyRange, nonInfinitLimit) :\n (source as any).getAllKeys(idbKeyRange, nonInfinitLimit);\n req.onsuccess = event => resolve({result: event.target.result});\n req.onerror = eventRejectHandler(reject);\n } else {\n let count = 0;\n const req = values || !('openKeyCursor' in source) ?\n source.openCursor(idbKeyRange) :\n source.openKeyCursor(idbKeyRange)\n const result = [];\n req.onsuccess = event => {\n const cursor = req.result as IDBCursorWithValue;\n if (!cursor) return resolve({result});\n result.push(values ? cursor.value : cursor.primaryKey);\n if (++count === limit) return resolve({result});\n cursor.continue();\n };\n req.onerror = eventRejectHandler(reject);\n }\n });\n };\n }\n \n return {\n name: tableName,\n schema: tableSchema,\n \n mutate,\n\n getMany ({trans, keys}) {\n return new Promise((resolve, reject) => {\n resolve = wrap(resolve);\n const store = (trans as IDBTransaction).objectStore(tableName);\n const length = keys.length;\n const result = new Array(length);\n let keyCount = 0;\n let callbackCount = 0;\n let valueCount = 0;\n let req: IDBRequest & {_pos?: number};\n \n const successHandler = event => {\n const req = event.target;\n if ((result[req._pos] = req.result) != null) ++valueCount;\n if (++callbackCount === keyCount) resolve(result);\n };\n const errorHandler = eventRejectHandler(reject);\n \n for (let i=0; i((resolve, reject) => {\n resolve = wrap (resolve);\n const store = (trans as IDBTransaction).objectStore(tableName);\n const req = store.get(key);\n req.onsuccess = event => resolve((event.target as any).result);\n req.onerror = eventRejectHandler(reject);\n });\n },\n\n query: query(hasGetAll),\n \n openCursor,\n\n count ({query, trans}) {\n const {index, range} = query;\n return new Promise((resolve, reject) => {\n const store = (trans as IDBTransaction).objectStore(tableName);\n const source = index.isPrimaryKey ? store : store.index(index.name);\n const idbKeyRange = makeIDBKeyRange(range);\n const req = idbKeyRange ? source.count(idbKeyRange) : source.count();\n req.onsuccess = wrap(ev => resolve((ev.target as IDBRequest).result));\n req.onerror = eventRejectHandler(reject);\n });\n }\n };\n }\n\n const {schema, hasGetAll} = extractSchema(db, tmpTrans);\n const tables = schema.tables.map(tableSchema => createDbCoreTable(tableSchema));\n const tableMap: {[name: string]: DBCoreTable} = {};\n tables.forEach(table => tableMap[table.name] = table);\n return {\n stack: \"dbcore\",\n \n transaction: db.transaction.bind(db),\n\n table(name: string) {\n const result = tableMap[name];\n if (!result) throw new Error(`Table '${name}' not found`);\n return tableMap[name];\n },\n\n MIN_KEY: -Infinity,\n\n MAX_KEY: getMaxKey(IdbKeyRange),\n\n schema\n\n };\n}\n","import { Dexie } from './';\nimport { createDBCore } from '../../dbcore/dbcore-indexeddb';\nimport { DBCore } from '../../public/types/dbcore';\nimport { DexieDOMDependencies } from '../../public/types/dexie-dom-dependencies';\nimport { DexieStacks, Middleware } from '../../public/types/middleware';\nimport { exceptions } from '../../errors';\n\nfunction createMiddlewareStack(\n stackImpl: {stack: string},\n middlewares: Middleware<{stack: string}>[]): TStack {\n return middlewares.reduce((down, {create}) => ({...down, ...create(down)}), stackImpl) as TStack;\n} \n\nfunction createMiddlewareStacks(\n middlewares: {[StackName in keyof DexieStacks]?: Middleware[]},\n idbdb: IDBDatabase,\n {IDBKeyRange, indexedDB}: DexieDOMDependencies,\n tmpTrans: IDBTransaction): {[StackName in keyof DexieStacks]?: DexieStacks[StackName]}\n{\n const dbcore = createMiddlewareStack(\n createDBCore(idbdb, IDBKeyRange, tmpTrans),\n middlewares.dbcore);\n \n // TODO: Create other stacks the same way as above. They might be dependant on the result\n // of creating dbcore stack.\n\n return {\n dbcore\n };\n}\n\nexport function generateMiddlewareStacks({_novip: db}: Dexie, tmpTrans: IDBTransaction) {\n const idbdb = tmpTrans.db;\n const stacks = createMiddlewareStacks(db._middlewares, idbdb, db._deps, tmpTrans);\n db.core = stacks.dbcore!;\n db.tables.forEach(table => {\n const tableName = table.name;\n if (db.core.schema.tables.some(tbl => tbl.name === tableName)) {\n table.core = db.core.table(tableName);\n if (db[tableName] instanceof db.Table) {\n db[tableName].core = table.core;\n }\n }\n });\n}\n","import { Dexie } from '../dexie';\nimport { DbSchema } from '../../public/types/db-schema';\nimport { _global } from \"../../globals/global\";\nimport { setProp, keys, slice, isArray, shallowClone, isAsyncFunction, defineProperty, getPropertyDescriptor } from '../../functions/utils';\nimport { Transaction } from '../transaction';\nimport { Version } from './version';\nimport Promise, { PSD, newScope, NativePromise, decrementExpectedAwaits, incrementExpectedAwaits } from '../../helpers/promise';\nimport { exceptions } from '../../errors';\nimport { TableSchema } from '../../public/types/table-schema';\nimport { IndexSpec } from '../../public/types/index-spec';\nimport { hasIEDeleteObjectStoreBug, isIEOrEdge } from '../../globals/constants';\nimport { safariMultiStoreFix } from '../../functions/quirks';\nimport { createIndexSpec, nameFromKeyPath } from '../../helpers/index-spec';\nimport { createTableSchema } from '../../helpers/table-schema';\nimport { generateMiddlewareStacks } from '../dexie/generate-middleware-stacks';\n\nexport function setApiOnPlace({_novip: db}: Dexie, objs: Object[], tableNames: string[], dbschema: DbSchema) {\n tableNames.forEach(tableName => {\n const schema = dbschema[tableName];\n objs.forEach(obj => {\n const propDesc = getPropertyDescriptor(obj, tableName);\n if (!propDesc || (\"value\" in propDesc && propDesc.value === undefined)) {\n // Either the prop is not declared, or it is initialized to undefined.\n if (obj === db.Transaction.prototype || obj instanceof db.Transaction) {\n // obj is a Transaction prototype (or prototype of a subclass to Transaction)\n // Make the API a getter that returns this.table(tableName)\n setProp(obj, tableName, {\n get(this: Transaction) { return this.table(tableName); },\n set(value: any) {\n // Issue #1039\n // Let \"this.schema = dbschema;\" and other props in transaction constructor work even if there's a name collision with the table name.\n defineProperty(this, tableName, {value, writable: true, configurable: true, enumerable: true});\n }\n });\n } else {\n // Table will not be bound to a transaction (will use Dexie.currentTransaction)\n obj[tableName] = new db.Table(tableName, schema);\n }\n }\n });\n });\n}\n\nexport function removeTablesApi({_novip: db}: Dexie, objs: Object[]) {\n objs.forEach(obj => {\n for (let key in obj) {\n if (obj[key] instanceof db.Table) delete obj[key];\n }\n });\n}\n\nexport function lowerVersionFirst(a: Version, b: Version) {\n return a._cfg.version - b._cfg.version;\n}\n\nexport function runUpgraders(db: Dexie, oldVersion: number, idbUpgradeTrans: IDBTransaction, reject) {\n const globalSchema = db._dbSchema;\n const trans = db._createTransaction('readwrite', db._storeNames, globalSchema);\n trans.create(idbUpgradeTrans);\n trans._completion.catch(reject);\n const rejectTransaction = trans._reject.bind(trans);\n const transless = PSD.transless || PSD;\n newScope(() => {\n PSD.trans = trans;\n PSD.transless = transless;\n if (oldVersion === 0) {\n // Create tables:\n keys(globalSchema).forEach(tableName => {\n createTable(idbUpgradeTrans, tableName, globalSchema[tableName].primKey, globalSchema[tableName].indexes);\n });\n generateMiddlewareStacks(db, idbUpgradeTrans);\n Promise.follow(() => db.on.populate.fire(trans)).catch(rejectTransaction);\n } else\n updateTablesAndIndexes(db, oldVersion, trans, idbUpgradeTrans).catch(rejectTransaction);\n });\n}\n\nexport type UpgradeQueueItem = (idbtrans: IDBTransaction) => PromiseLike | void;\n\nexport function updateTablesAndIndexes(\n {_novip: db}: Dexie,\n oldVersion: number,\n trans: Transaction,\n idbUpgradeTrans: IDBTransaction)\n{\n // Upgrade version to version, step-by-step from oldest to newest version.\n // Each transaction object will contain the table set that was current in that version (but also not-yet-deleted tables from its previous version)\n const queue: UpgradeQueueItem[] = [];\n const versions = db._versions;\n let globalSchema = db._dbSchema = buildGlobalSchema(db, db.idbdb, idbUpgradeTrans);\n let anyContentUpgraderHasRun = false;\n\n const versToRun = versions.filter(v => v._cfg.version >= oldVersion);\n versToRun.forEach(version => {\n queue.push(() => {\n const oldSchema = globalSchema;\n const newSchema = version._cfg.dbschema;\n adjustToExistingIndexNames(db, oldSchema, idbUpgradeTrans);\n adjustToExistingIndexNames(db, newSchema, idbUpgradeTrans);\n\n globalSchema = db._dbSchema = newSchema;\n\n const diff = getSchemaDiff(oldSchema, newSchema);\n // Add tables \n diff.add.forEach(tuple => {\n createTable(idbUpgradeTrans, tuple[0], tuple[1].primKey, tuple[1].indexes);\n });\n // Change tables\n diff.change.forEach(change => {\n if (change.recreate) {\n throw new exceptions.Upgrade(\"Not yet support for changing primary key\");\n } else {\n const store = idbUpgradeTrans.objectStore(change.name);\n // Add indexes\n change.add.forEach(idx => addIndex(store, idx));\n // Update indexes\n change.change.forEach(idx => {\n store.deleteIndex(idx.name);\n addIndex(store, idx);\n });\n // Delete indexes\n change.del.forEach(idxName => store.deleteIndex(idxName));\n }\n });\n\n const contentUpgrade = version._cfg.contentUpgrade;\n\n if (contentUpgrade && version._cfg.version > oldVersion) {\n // Update db.core with new tables and indexes:\n generateMiddlewareStacks(db, idbUpgradeTrans);\n trans._memoizedTables = {}; // Invalidate memoization as transaction shape may change between versions.\n\n anyContentUpgraderHasRun = true;\n\n // Add to-be-deleted tables to contentUpgrade transaction\n let upgradeSchema = shallowClone(newSchema);\n diff.del.forEach(table => {\n upgradeSchema[table] = oldSchema[table];\n });\n\n // Safe to affect Transaction.prototype globally in this moment,\n // because when this code runs, there may not be any other code\n // that can access any transaction instance, else than this particular\n // upgrader function.\n removeTablesApi(db, [db.Transaction.prototype]);\n setApiOnPlace(db, [db.Transaction.prototype], keys(upgradeSchema), upgradeSchema);\n trans.schema = upgradeSchema;\n\n // Support for native async await.\n const contentUpgradeIsAsync = isAsyncFunction(contentUpgrade);\n if (contentUpgradeIsAsync) {\n incrementExpectedAwaits();\n }\n \n let returnValue: any;\n const promiseFollowed = Promise.follow(() => {\n // Finally, call the scope function with our table and transaction arguments.\n returnValue = contentUpgrade(trans);\n if (returnValue) {\n if (contentUpgradeIsAsync) {\n // contentUpgrade is a native async function - we know for sure returnValue is native promise.\n var decrementor = decrementExpectedAwaits.bind(null, null);\n returnValue.then(decrementor, decrementor);\n }\n }\n });\n return (returnValue && typeof returnValue.then === 'function' ?\n Promise.resolve(returnValue) : promiseFollowed.then(()=>returnValue));\n }\n });\n queue.push(idbtrans => {\n if (!anyContentUpgraderHasRun || !hasIEDeleteObjectStoreBug) { // Dont delete old tables if ieBug is present and a content upgrader has run. Let tables be left in DB so far. This needs to be taken care of.\n const newSchema = version._cfg.dbschema;\n // Delete old tables\n deleteRemovedTables(newSchema, idbtrans);\n }\n // Restore the final API\n removeTablesApi(db, [db.Transaction.prototype]);\n setApiOnPlace(db, [db.Transaction.prototype], db._storeNames, db._dbSchema);\n trans.schema = db._dbSchema;\n });\n });\n\n // Now, create a queue execution engine\n function runQueue() {\n return queue.length ? Promise.resolve(queue.shift()(trans.idbtrans)).then(runQueue) :\n Promise.resolve();\n }\n\n return runQueue().then(() => {\n createMissingTables(globalSchema, idbUpgradeTrans); // At last, make sure to create any missing tables. (Needed by addons that add stores to DB without specifying version)\n });\n}\n\nexport interface SchemaDiff {\n del: string[],\n add: [string, TableSchema][];\n change: TableSchemaDiff[];\n}\n\nexport interface TableSchemaDiff {\n name: string,\n recreate: boolean,\n del: string[],\n add: IndexSpec[],\n change: IndexSpec[]\n}\n\nexport function getSchemaDiff(oldSchema: DbSchema, newSchema: DbSchema): SchemaDiff {\n const diff: SchemaDiff = {\n del: [], // Array of table names\n add: [], // Array of [tableName, newDefinition]\n change: [] // Array of {name: tableName, recreate: newDefinition, del: delIndexNames, add: newIndexDefs, change: changedIndexDefs}\n };\n let table: string;\n for (table in oldSchema) {\n if (!newSchema[table]) diff.del.push(table);\n }\n for (table in newSchema) {\n const oldDef = oldSchema[table],\n newDef = newSchema[table];\n if (!oldDef) {\n diff.add.push([table, newDef]);\n } else {\n const change = {\n name: table,\n def: newDef,\n recreate: false,\n del: [],\n add: [],\n change: []\n };\n if (\n (\n // compare keyPaths no matter if string or string[]\n // compare falsy keypaths same no matter if they are null or empty string.\n ''+(oldDef.primKey.keyPath||'')\n ) !== (\n ''+(newDef.primKey.keyPath||'')\n ) ||\n // Compare the autoIncrement flag also\n (oldDef.primKey.auto !== newDef.primKey.auto && !isIEOrEdge)) // IE has bug reading autoIncrement prop.\n {\n // Primary key has changed. Remove and re-add table.\n change.recreate = true;\n diff.change.push(change);\n } else {\n // Same primary key. Just find out what differs:\n const oldIndexes = oldDef.idxByName;\n const newIndexes = newDef.idxByName;\n let idxName: string;\n for (idxName in oldIndexes) {\n if (!newIndexes[idxName]) change.del.push(idxName);\n }\n for (idxName in newIndexes) {\n const oldIdx = oldIndexes[idxName],\n newIdx = newIndexes[idxName];\n if (!oldIdx) change.add.push(newIdx);\n else if (oldIdx.src !== newIdx.src) change.change.push(newIdx);\n }\n if (change.del.length > 0 || change.add.length > 0 || change.change.length > 0) {\n diff.change.push(change);\n }\n }\n }\n }\n return diff;\n}\n\nexport function createTable(\n idbtrans: IDBTransaction,\n tableName: string,\n primKey: IndexSpec,\n indexes: IndexSpec[]\n) {\n const store = idbtrans.db.createObjectStore(\n tableName,\n primKey.keyPath ?\n { keyPath: primKey.keyPath, autoIncrement: primKey.auto } :\n { autoIncrement: primKey.auto }\n );\n indexes.forEach(idx => addIndex(store, idx));\n return store;\n}\n\nexport function createMissingTables(newSchema: DbSchema, idbtrans: IDBTransaction) {\n keys(newSchema).forEach(tableName => {\n if (!idbtrans.db.objectStoreNames.contains(tableName)) {\n createTable(idbtrans, tableName, newSchema[tableName].primKey, newSchema[tableName].indexes);\n }\n });\n}\n\nexport function deleteRemovedTables(newSchema: DbSchema, idbtrans: IDBTransaction) {\n [].slice.call(idbtrans.db.objectStoreNames).forEach(storeName =>\n newSchema[storeName] == null && idbtrans.db.deleteObjectStore(storeName));\n}\n\nexport function addIndex(store: IDBObjectStore, idx: IndexSpec) {\n store.createIndex(idx.name, idx.keyPath, { unique: idx.unique, multiEntry: idx.multi });\n}\n\nfunction buildGlobalSchema(\n db: Dexie,\n idbdb: IDBDatabase,\n tmpTrans: IDBTransaction\n) {\n const globalSchema = {};\n const dbStoreNames = slice(idbdb.objectStoreNames, 0);\n dbStoreNames.forEach(storeName => {\n const store = tmpTrans.objectStore(storeName);\n let keyPath = store.keyPath;\n const primKey = createIndexSpec(\n nameFromKeyPath(keyPath),\n keyPath || \"\",\n false,\n false,\n !!store.autoIncrement,\n keyPath && typeof keyPath !== \"string\",\n true\n );\n const indexes: IndexSpec[] = [];\n for (let j = 0; j < store.indexNames.length; ++j) {\n const idbindex = store.index(store.indexNames[j]);\n keyPath = idbindex.keyPath;\n var index = createIndexSpec(\n idbindex.name,\n keyPath,\n !!idbindex.unique,\n !!idbindex.multiEntry,\n false,\n keyPath && typeof keyPath !== \"string\",\n false\n );\n indexes.push(index);\n }\n globalSchema[storeName] = createTableSchema(storeName, primKey, indexes);\n });\n return globalSchema;\n}\n\nexport function readGlobalSchema({_novip: db}: Dexie, idbdb: IDBDatabase, tmpTrans: IDBTransaction) {\n db.verno = idbdb.version / 10;\n const globalSchema = db._dbSchema = buildGlobalSchema(db, idbdb, tmpTrans);\n db._storeNames = slice(idbdb.objectStoreNames, 0);\n setApiOnPlace(db, [db._allTables], keys(globalSchema), globalSchema);\n}\n\nexport function verifyInstalledSchema(db: Dexie, tmpTrans: IDBTransaction): boolean {\n const installedSchema = buildGlobalSchema(db, db.idbdb, tmpTrans);\n const diff = getSchemaDiff(installedSchema, db._dbSchema);\n return !(diff.add.length || diff.change.some(ch => ch.add.length || ch.change.length));\n}\n\nexport function adjustToExistingIndexNames({_novip: db}: Dexie, schema: DbSchema, idbtrans: IDBTransaction) {\n // Issue #30 Problem with existing db - adjust to existing index names when migrating from non-dexie db\n const storeNames = idbtrans.db.objectStoreNames;\n\n for (let i = 0; i < storeNames.length; ++i) {\n const storeName = storeNames[i];\n const store = idbtrans.objectStore(storeName);\n db._hasGetAll = 'getAll' in store;\n\n for (let j = 0; j < store.indexNames.length; ++j) {\n const indexName = store.indexNames[j];\n const keyPath = store.index(indexName).keyPath;\n const dexieName = typeof keyPath === 'string' ? keyPath : \"[\" + slice(keyPath).join('+') + \"]\";\n if (schema[storeName]) {\n const indexSpec = schema[storeName].idxByName[dexieName];\n if (indexSpec) {\n indexSpec.name = indexName;\n delete schema[storeName].idxByName[dexieName];\n schema[storeName].idxByName[indexName] = indexSpec;\n }\n }\n }\n }\n\n // Bug with getAll() on Safari ver<604 on Workers only, see discussion following PR #579\n if (typeof navigator !== 'undefined' && /Safari/.test(navigator.userAgent) &&\n !/(Chrome\\/|Edge\\/)/.test(navigator.userAgent) &&\n _global.WorkerGlobalScope && _global instanceof _global.WorkerGlobalScope &&\n [].concat(navigator.userAgent.match(/Safari\\/(\\d*)/))[1] < 604)\n {\n db._hasGetAll = false;\n }\n}\n\nexport function parseIndexSyntax(primKeyAndIndexes: string): IndexSpec[] {\n return primKeyAndIndexes.split(',').map((index, indexNum) => {\n index = index.trim();\n const name = index.replace(/([&*]|\\+\\+)/g, \"\"); // Remove \"&\", \"++\" and \"*\"\n // Let keyPath of \"[a+b]\" be [\"a\",\"b\"]:\n const keyPath = /^\\[/.test(name) ? name.match(/^\\[(.*)\\]$/)[1].split('+') : name;\n\n return createIndexSpec(\n name,\n keyPath || null,\n /\\&/.test(index),\n /\\*/.test(index),\n /\\+\\+/.test(index),\n isArray(keyPath),\n indexNum === 0\n );\n });\n}\n","import { Version as IVersion } from '../../public/types/version';\nimport { DbSchema } from '../../public/types/db-schema';\nimport { extend, keys } from '../../functions/utils';\nimport { Dexie } from '../dexie';\nimport { Transaction } from '../transaction';\nimport { removeTablesApi, setApiOnPlace, parseIndexSyntax } from './schema-helpers';\nimport { exceptions } from '../../errors';\nimport { createTableSchema } from '../../helpers/table-schema';\nimport { nop, promisableChain } from '../../functions/chaining-functions';\n\n/** class Version\n *\n * https://dexie.org/docs/Version/Version\n */\nexport class Version implements IVersion {\n db: Dexie;\n _cfg: {\n version: number,\n storesSource: { [tableName: string]: string | null },\n dbschema: DbSchema,\n tables: {},\n contentUpgrade: Function | null\n }\n\n _parseStoresSpec(stores: { [tableName: string]: string | null }, outSchema: DbSchema): any {\n keys(stores).forEach(tableName => {\n if (stores[tableName] !== null) {\n var indexes = parseIndexSyntax(stores[tableName]);\n var primKey = indexes.shift();\n if (primKey.multi) throw new exceptions.Schema(\"Primary key cannot be multi-valued\");\n indexes.forEach(idx => {\n if (idx.auto) throw new exceptions.Schema(\"Only primary key can be marked as autoIncrement (++)\");\n if (!idx.keyPath) throw new exceptions.Schema(\"Index must have a name and cannot be an empty string\");\n });\n outSchema[tableName] = createTableSchema(tableName, primKey, indexes);\n }\n });\n }\n\n stores(stores: { [key: string]: string | null; }): IVersion {\n const db = this.db;\n this._cfg.storesSource = this._cfg.storesSource ?\n extend(this._cfg.storesSource, stores) :\n stores;\n const versions = db._versions;\n\n // Derive stores from earlier versions if they are not explicitely specified as null or a new syntax.\n const storesSpec: { [key: string]: string; } = {};\n let dbschema = {};\n versions.forEach(version => { // 'versions' is always sorted by lowest version first.\n extend(storesSpec, version._cfg.storesSource);\n dbschema = (version._cfg.dbschema = {});\n version._parseStoresSpec(storesSpec, dbschema);\n });\n // Update the latest schema to this version\n db._dbSchema = dbschema;\n // Update APIs\n removeTablesApi(db, [db._allTables, db, db.Transaction.prototype]);\n setApiOnPlace(db, [db._allTables, db, db.Transaction.prototype, this._cfg.tables], keys(dbschema), dbschema);\n db._storeNames = keys(dbschema);\n return this;\n }\n\n upgrade(upgradeFunction: (trans: Transaction) => PromiseLike | void): Version {\n this._cfg.contentUpgrade = promisableChain(this._cfg.contentUpgrade || nop, upgradeFunction);\n return this;\n }\n}\n","import { Dexie } from '../dexie';\nimport { makeClassConstructor } from '../../functions/make-class-constructor';\nimport { Version } from './version';\n\nexport interface VersionConstructor {\n new(versionNumber: number): Version;\n prototype: Version;\n}\n\n/** Generates a Version constructor bound to given Dexie instance.\n * \n * The purpose of having dynamically created constructors, is to allow\n * addons to extend classes for a certain Dexie instance without affecting\n * other db instances.\n */\nexport function createVersionConstructor(db: Dexie) {\n return makeClassConstructor(\n Version.prototype,\n\n function Version(this: Version, versionNumber: number) {\n this.db = db;\n this._cfg = {\n version: versionNumber,\n storesSource: null,\n dbschema: {},\n tables: {},\n contentUpgrade: null\n };\n });\n\n}\n","import { Dexie } from \"../classes/dexie/dexie\";\nimport { Table } from \"../public/types/table\";\nimport { DBNAMES_DB } from \"../globals/constants\";\nimport { DexieDOMDependencies } from \"../public/types/dexie-dom-dependencies\";\nimport { nop } from \"../functions/chaining-functions\";\n\ntype IDBKeyNamesVar = typeof IDBKeyRange;\n\nfunction getDbNamesTable(indexedDB: IDBFactory, IDBKeyRange: IDBKeyNamesVar) {\n let dbNamesDB = indexedDB[\"_dbNamesDB\"];\n if (!dbNamesDB) {\n dbNamesDB = indexedDB[\"_dbNamesDB\"] = new Dexie(DBNAMES_DB, {\n addons: [],\n indexedDB,\n IDBKeyRange,\n });\n dbNamesDB.version(1).stores({ dbnames: \"name\" });\n }\n return dbNamesDB.table(\"dbnames\") as Table<{ name: string }, string>;\n}\n\nfunction hasDatabasesNative(indexedDB: IDBFactory) {\n return indexedDB && typeof indexedDB.databases === \"function\";\n}\n\nexport function getDatabaseNames({\n indexedDB,\n IDBKeyRange,\n}: DexieDOMDependencies) {\n return hasDatabasesNative(indexedDB)\n ? Promise.resolve(indexedDB.databases()).then((infos) =>\n infos\n // Select name prop of infos:\n .map((info) => info.name)\n // Filter out DBNAMES_DB as previous Dexie or browser version would not have included it in the result.\n .filter((name) => name !== DBNAMES_DB)\n )\n : getDbNamesTable(indexedDB, IDBKeyRange).toCollection().primaryKeys();\n}\n\nexport function _onDatabaseCreated(\n { indexedDB, IDBKeyRange }: DexieDOMDependencies,\n name: string\n) {\n !hasDatabasesNative(indexedDB) &&\n name !== DBNAMES_DB &&\n getDbNamesTable(indexedDB, IDBKeyRange).put({name}).catch(nop);\n}\n\nexport function _onDatabaseDeleted(\n { indexedDB, IDBKeyRange }: DexieDOMDependencies,\n name: string\n) {\n !hasDatabasesNative(indexedDB) &&\n name !== DBNAMES_DB &&\n getDbNamesTable(indexedDB, IDBKeyRange).delete(name).catch(nop);\n}\n","import { newScope } from '../../helpers/promise';\nimport { PSD } from '../../helpers/promise';\n\nexport function vip (fn) {\n // To be used by subscribers to the on('ready') event.\n // This will let caller through to access DB even when it is blocked while the db.ready() subscribers are firing.\n // This would have worked automatically if we were certain that the Provider was using Dexie.Promise for all asyncronic operations. The promise PSD\n // from the provider.connect() call would then be derived all the way to when provider would call localDatabase.applyChanges(). But since\n // the provider more likely is using non-promise async APIs or other thenable implementations, we cannot assume that.\n // Note that this method is only useful for on('ready') subscribers that is returning a Promise from the event. If not using vip()\n // the database could deadlock since it wont open until the returned Promise is resolved, and any non-VIPed operation started by\n // the caller will not resolve until database is opened.\n return newScope(function () {\n PSD.letThrough = true; // Make sure we are let through if still blocking db due to onready is firing.\n return fn();\n });\n}\n\n","/**\n * Work around Safari 14 IndexedDB open bug.\n *\n * Safari has a horrible bug where IDB requests can hang while the browser is starting up. https://bugs.webkit.org/show_bug.cgi?id=226547\n * The only solution is to keep nudging it until it's awake.\n */\nfunction idbReady() {\n var isSafari = !navigator.userAgentData &&\n /Safari\\//.test(navigator.userAgent) &&\n !/Chrom(e|ium)\\//.test(navigator.userAgent);\n // No point putting other browsers or older versions of Safari through this mess.\n if (!isSafari || !indexedDB.databases)\n return Promise.resolve();\n var intervalId;\n return new Promise(function (resolve) {\n var tryIdb = function () { return indexedDB.databases().finally(resolve); };\n intervalId = setInterval(tryIdb, 100);\n tryIdb();\n }).finally(function () { return clearInterval(intervalId); });\n}\n\nexport default idbReady;\n","import { Dexie } from './dexie';\nimport * as Debug from '../../helpers/debug';\nimport { rejection } from '../../helpers/promise';\nimport { exceptions } from '../../errors';\nimport { eventRejectHandler, preventDefault } from '../../functions/event-wrappers';\nimport Promise, { wrap } from '../../helpers/promise';\nimport { connections } from '../../globals/constants';\nimport { runUpgraders, readGlobalSchema, adjustToExistingIndexNames, verifyInstalledSchema } from '../version/schema-helpers';\nimport { safariMultiStoreFix } from '../../functions/quirks';\nimport { _onDatabaseCreated } from '../../helpers/database-enumerator';\nimport { vip } from './vip';\nimport { promisableChain, nop } from '../../functions/chaining-functions';\nimport { generateMiddlewareStacks } from './generate-middleware-stacks';\nimport { slice } from '../../functions/utils';\nimport safari14Workaround from 'safari-14-idb-fix';\n\nexport function dexieOpen (db: Dexie) {\n const state = db._state;\n const {indexedDB} = db._deps;\n if (state.isBeingOpened || db.idbdb)\n return state.dbReadyPromise.then(() => state.dbOpenError ?\n rejection (state.dbOpenError) :\n db);\n Debug.debug && (state.openCanceller._stackHolder = Debug.getErrorWithStack()); // Let stacks point to when open() was called rather than where new Dexie() was called.\n state.isBeingOpened = true;\n state.dbOpenError = null;\n state.openComplete = false;\n const openCanceller = state.openCanceller;\n\n function throwIfCancelled() {\n // If state.openCanceller object reference is replaced, it means db.close() has been called,\n // meaning this open flow should be cancelled.\n if (state.openCanceller !== openCanceller) throw new exceptions.DatabaseClosed('db.open() was cancelled');\n }\n \n // Function pointers to call when the core opening process completes.\n let resolveDbReady = state.dbReadyResolve,\n // upgradeTransaction to abort on failure.\n upgradeTransaction: (IDBTransaction | null) = null,\n wasCreated = false;\n \n // safari14Workaround = Workaround by jakearchibald for new nasty bug in safari 14.\n return Promise.race([openCanceller, (typeof navigator === 'undefined' ? Promise.resolve() : safari14Workaround()).then(() => new Promise((resolve, reject) => {\n // Multiply db.verno with 10 will be needed to workaround upgrading bug in IE:\n // IE fails when deleting objectStore after reading from it.\n // A future version of Dexie.js will stopover an intermediate version to workaround this.\n // At that point, we want to be backward compatible. Could have been multiplied with 2, but by using 10, it is easier to map the number to the real version number.\n \n throwIfCancelled();\n // If no API, throw!\n if (!indexedDB) throw new exceptions.MissingAPI();\n const dbName = db.name;\n \n const req = state.autoSchema ?\n indexedDB.open(dbName) :\n indexedDB.open(dbName, Math.round(db.verno * 10));\n if (!req) throw new exceptions.MissingAPI(); // May happen in Safari private mode, see https://github.com/dfahlander/Dexie.js/issues/134\n req.onerror = eventRejectHandler(reject);\n req.onblocked = wrap(db._fireOnBlocked);\n req.onupgradeneeded = wrap (e => {\n upgradeTransaction = req.transaction;\n if (state.autoSchema && !db._options.allowEmptyDB) { // Unless an addon has specified db._allowEmptyDB, lets make the call fail.\n // Caller did not specify a version or schema. Doing that is only acceptable for opening alread existing databases.\n // If onupgradeneeded is called it means database did not exist. Reject the open() promise and make sure that we\n // do not create a new database by accident here.\n req.onerror = preventDefault; // Prohibit onabort error from firing before we're done!\n upgradeTransaction.abort(); // Abort transaction (would hope that this would make DB disappear but it doesnt.)\n // Close database and delete it.\n req.result.close();\n const delreq = indexedDB.deleteDatabase(dbName); // The upgrade transaction is atomic, and javascript is single threaded - meaning that there is no risk that we delete someone elses database here!\n delreq.onsuccess = delreq.onerror = wrap(() => {\n reject (new exceptions.NoSuchDatabase(`Database ${dbName} doesnt exist`));\n });\n } else {\n upgradeTransaction.onerror = eventRejectHandler(reject);\n var oldVer = e.oldVersion > Math.pow(2, 62) ? 0 : e.oldVersion; // Safari 8 fix.\n wasCreated = oldVer < 1;\n db._novip.idbdb = req.result;// db._novip is because db can be an Object.create(origDb).\n runUpgraders(db, oldVer / 10, upgradeTransaction, reject);\n }\n }, reject);\n \n req.onsuccess = wrap (() => {\n // Core opening procedure complete. Now let's just record some stuff.\n upgradeTransaction = null;\n const idbdb = db._novip.idbdb = req.result; // db._novip is because db can be an Object.create(origDb).\n\n const objectStoreNames = slice(idbdb.objectStoreNames);\n if (objectStoreNames.length > 0) try {\n const tmpTrans = idbdb.transaction(safariMultiStoreFix(objectStoreNames), 'readonly');\n if (state.autoSchema) readGlobalSchema(db, idbdb, tmpTrans);\n else {\n adjustToExistingIndexNames(db, db._dbSchema, tmpTrans);\n if (!verifyInstalledSchema(db, tmpTrans)) {\n console.warn(`Dexie SchemaDiff: Schema was extended without increasing the number passed to db.version(). Some queries may fail.`);\n }\n }\n generateMiddlewareStacks(db, tmpTrans);\n } catch (e) {\n // Safari 8 may bail out if > 1 store names. However, this shouldnt be a showstopper. Issue #120.\n // BUGBUG: It will bail out anyway as of Dexie 3.\n // Should we support Safari 8 anymore? Believe all\n // Dexie users use the shim for that platform anyway?!\n // If removing Safari 8 support, go ahead and remove the safariMultiStoreFix() function\n // as well as absurd upgrade version quirk for Safari.\n }\n \n connections.push(db); // Used for emulating versionchange event on IE/Edge/Safari.\n \n idbdb.onversionchange = wrap(ev => {\n state.vcFired = true; // detect implementations that not support versionchange (IE/Edge/Safari)\n db.on(\"versionchange\").fire(ev);\n });\n \n idbdb.onclose = wrap(ev => {\n db.on(\"close\").fire(ev);\n });\n\n if (wasCreated) _onDatabaseCreated(db._deps, dbName);\n\n resolve();\n\n }, reject);\n }))]).then(() => {\n // Before finally resolving the dbReadyPromise and this promise,\n // call and await all on('ready') subscribers:\n // Dexie.vip() makes subscribers able to use the database while being opened.\n // This is a must since these subscribers take part of the opening procedure.\n throwIfCancelled();\n state.onReadyBeingFired = [];\n return Promise.resolve(vip(()=>db.on.ready.fire(db.vip))).then(function fireRemainders() {\n if (state.onReadyBeingFired.length > 0) {\n // In case additional subscribers to db.on('ready') were added during the time db.on.ready.fire was executed.\n let remainders = state.onReadyBeingFired.reduce(promisableChain, nop);\n state.onReadyBeingFired = [];\n return Promise.resolve(vip(()=>remainders(db.vip))).then(fireRemainders)\n }\n });\n }).finally(()=>{\n state.onReadyBeingFired = null;\n state.isBeingOpened = false;\n }).then(()=>{\n // Resolve the db.open() with the db instance.\n return db;\n }).catch(err => {\n state.dbOpenError = err; // Record the error. It will be used to reject further promises of db operations.\n try {\n // Did we fail within onupgradeneeded? Make sure to abort the upgrade transaction so it doesnt commit.\n upgradeTransaction && upgradeTransaction.abort();\n } catch { }\n if (openCanceller === state.openCanceller) {\n // Still in the same open flow - The error reason was not due to external call to db.close().\n // Make sure to call db.close() to finalize resources.\n db._close(); // Closes and resets idbdb, removes connections, resets dbReadyPromise and openCanceller so that a later db.open() is fresh.\n }\n return rejection (err);\n }).finally(()=>{\n state.openComplete = true;\n resolveDbReady(); // dbReadyPromise is resolved no matter if open() rejects or resolved. It's just to wake up waiters.\n });\n}\n","import { isArray } from '../functions/utils';\n\nexport function awaitIterator (iterator: Iterator) {\n var callNext = result => iterator.next(result),\n doThrow = error => iterator.throw(error),\n onSuccess = step(callNext),\n onError = step(doThrow);\n\n function step(getNext: (any)=>any) {\n return (val?) => {\n var next = getNext(val),\n value = next.value;\n\n return next.done ? value :\n (!value || typeof value.then !== 'function' ?\n isArray(value) ? Promise.all(value).then(onSuccess, onError) : onSuccess(value) :\n value.then(onSuccess, onError));\n };\n }\n\n return step(callNext)();\n}\n","import { TransactionMode } from '../../public/types/transaction-mode';\nimport { errnames, exceptions } from '../../errors';\nimport { flatten, isAsyncFunction } from '../../functions/utils';\nimport { Dexie } from './dexie';\nimport { Transaction } from '../transaction';\nimport { awaitIterator } from '../../helpers/yield-support';\nimport Promise, {\n PSD,\n NativePromise,\n decrementExpectedAwaits,\n rejection,\n incrementExpectedAwaits\n} from '../../helpers/promise';\n\nexport function extractTransactionArgs(mode: TransactionMode, _tableArgs_, scopeFunc) {\n // Let table arguments be all arguments between mode and last argument.\n var i = arguments.length;\n if (i < 2) throw new exceptions.InvalidArgument(\"Too few arguments\");\n // Prevent optimzation killer (https://github.com/petkaantonov/bluebird/wiki/Optimization-killers#32-leaking-arguments)\n // and clone arguments except the first one into local var 'args'.\n var args = new Array(i - 1);\n while (--i) args[i - 1] = arguments[i];\n // Let scopeFunc be the last argument and pop it so that args now only contain the table arguments.\n scopeFunc = args.pop();\n var tables = flatten(args); // Support using array as middle argument, or a mix of arrays and non-arrays.\n return [mode, tables, scopeFunc];\n}\n\nexport function enterTransactionScope(\n db: Dexie,\n mode: IDBTransactionMode,\n storeNames: string[],\n parentTransaction: Transaction | undefined,\n scopeFunc: ()=>PromiseLike | any\n) {\n return Promise.resolve().then(() => {\n // Keep a pointer to last non-transactional PSD to use if someone calls Dexie.ignoreTransaction().\n const transless = PSD.transless || PSD;\n // Our transaction.\n //return new Promise((resolve, reject) => {\n const trans = db._createTransaction(mode, storeNames, db._dbSchema, parentTransaction);\n trans.explicit = true;\n // Let the transaction instance be part of a Promise-specific data (PSD) value.\n const zoneProps = {\n trans: trans,\n transless: transless\n };\n\n if (parentTransaction) {\n // Emulate transaction commit awareness for inner transaction (must 'commit' when the inner transaction has no more operations ongoing)\n trans.idbtrans = parentTransaction.idbtrans;\n } else {\n try {\n trans.create(); // Create the native transaction so that complete() or error() will trigger even if no operation is made upon it.\n db._state.PR1398_maxLoop = 3;\n } catch (ex) {\n if (ex.name === errnames.InvalidState && db.isOpen() && --db._state.PR1398_maxLoop > 0) {\n console.warn('Dexie: Need to reopen db');\n db._close();\n return db.open().then(() => enterTransactionScope(\n db,\n mode,\n storeNames,\n null,\n scopeFunc\n ));\n }\n return rejection(ex);\n }\n }\n\n // Support for native async await.\n const scopeFuncIsAsync = isAsyncFunction(scopeFunc);\n if (scopeFuncIsAsync) {\n incrementExpectedAwaits();\n }\n\n let returnValue;\n const promiseFollowed = Promise.follow(() => {\n // Finally, call the scope function with our table and transaction arguments.\n returnValue = scopeFunc.call(trans, trans);\n if (returnValue) {\n if (scopeFuncIsAsync) {\n // scopeFunc is a native async function - we know for sure returnValue is native promise.\n var decrementor = decrementExpectedAwaits.bind(null, null);\n returnValue.then(decrementor, decrementor);\n } else if (typeof returnValue.next === 'function' && typeof returnValue.throw === 'function') {\n // scopeFunc returned an iterator with throw-support. Handle yield as await.\n returnValue = awaitIterator(returnValue);\n }\n }\n }, zoneProps);\n return (returnValue && typeof returnValue.then === 'function' ?\n // Promise returned. User uses promise-style transactions.\n Promise.resolve(returnValue).then(x => trans.active ?\n x // Transaction still active. Continue.\n : rejection(new exceptions.PrematureCommit(\n \"Transaction committed too early. See http://bit.ly/2kdckMn\")))\n // No promise returned. Wait for all outstanding promises before continuing. \n : promiseFollowed.then(() => returnValue)\n ).then(x => {\n // sub transactions don't react to idbtrans.oncomplete. We must trigger a completion:\n if (parentTransaction) trans._resolve();\n // wait for trans._completion\n // (if root transaction, this means 'complete' event. If sub-transaction, we've just fired it ourselves)\n return trans._completion.then(() => x);\n }).catch(e => {\n trans._reject(e); // Yes, above then-handler were maybe not called because of an unhandled rejection in scopeFunc!\n return rejection(e);\n });\n });\n}\n","import {\n DBCore,\n DBCoreIndex,\n DBCoreKeyRange,\n DBCoreQueryRequest,\n DBCoreRangeType,\n DBCoreOpenCursorRequest,\n DBCoreCountRequest,\n DBCoreCursor,\n DBCoreTable,\n} from \"../public/types/dbcore\";\nimport { isArray } from '../functions/utils';\nimport { getKeyExtractor } from './get-key-extractor';\nimport { getKeyPathAlias } from './dbcore-indexeddb';\nimport { Middleware } from '../public/types/middleware';\n\ninterface VirtualIndex extends DBCoreIndex {\n /** True if this index is virtual, i.e. represents a compound index internally,\n * but makes it act as as having a subset of its keyPaths.\n */\n isVirtual: boolean;\n\n /** Number of keypaths that this index comprises. Can be 0..N.\n * Note: This is the length of the *virtual index*, not the real index.\n */\n keyLength: number;\n\n /** Number of popped keypaths from the real index.\n */\n keyTail: number;\n}\n\n// Move into some util:\nexport function pad (a: any | any[], value: any, count: number) {\n const result = isArray(a) ? a.slice() : [a];\n for (let i=0; i 0;\n const virtualIndex = {\n ...lowLevelIndex,\n isVirtual,\n keyTail,\n keyLength,\n extractKey: getKeyExtractor(keyPath),\n unique: !isVirtual && lowLevelIndex.unique\n };\n indexList.push(virtualIndex);\n if (!virtualIndex.isPrimaryKey) {\n allVirtualIndexes.push(virtualIndex);\n }\n if (keyLength > 1) {\n const virtualKeyPath = keyLength === 2 ?\n keyPath[0] : // This is a compound [a, b]. Add a virtual normal index a.\n keyPath.slice(0, keyLength - 1); // This is compound [a,b,c]. Add virtual compound [a,b].\n addVirtualIndexes(virtualKeyPath, keyTail + 1, lowLevelIndex);\n }\n indexList.sort((a,b) => a.keyTail - b.keyTail); // Shortest keyTail is the best one (represents real index)\n return virtualIndex;\n }\n \n const primaryKey = addVirtualIndexes(schema.primaryKey.keyPath, 0, schema.primaryKey);\n indexLookup[\":id\"] = [primaryKey];\n for (const index of schema.indexes) {\n addVirtualIndexes(index.keyPath, 0, index);\n }\n \n function findBestIndex(keyPath: null | string | string[]): VirtualIndex {\n const result = indexLookup[getKeyPathAlias(keyPath)];\n return result && result[0];\n }\n \n function translateRange (range: DBCoreKeyRange, keyTail: number): DBCoreKeyRange {\n return {\n type: range.type === DBCoreRangeType.Equal ?\n DBCoreRangeType.Range :\n range.type,\n lower: pad(range.lower, range.lowerOpen ? down.MAX_KEY : down.MIN_KEY, keyTail),\n lowerOpen: true, // doesn't matter true or false\n upper: pad(range.upper, range.upperOpen ? down.MIN_KEY : down.MAX_KEY, keyTail),\n upperOpen: true // doesn't matter true or false\n };\n }\n \n function translateRequest (req: DBCoreQueryRequest): DBCoreQueryRequest;\n function translateRequest (req: DBCoreOpenCursorRequest): DBCoreOpenCursorRequest;\n function translateRequest (req: DBCoreCountRequest): DBCoreCountRequest {\n const index = req.query.index as VirtualIndex;\n return index.isVirtual ? {\n ...req,\n query: {\n index,\n range: translateRange(req.query.range, index.keyTail)\n }\n } : req;\n }\n \n const result: DBCoreTable = {\n ...table,\n schema: {\n ...schema,\n primaryKey,\n indexes: allVirtualIndexes,\n getIndexByKeyPath: findBestIndex\n },\n\n count(req) {\n return table.count(translateRequest(req));\n }, \n \n query(req) {\n return table.query(translateRequest(req));\n },\n \n openCursor(req) {\n const {keyTail, isVirtual, keyLength} = (req.query.index as VirtualIndex);\n if (!isVirtual) return table.openCursor(req);\n \n function createVirtualCursor(cursor: DBCoreCursor) : DBCoreCursor {\n function _continue (key?: any) {\n key != null ?\n cursor.continue(pad(key, req.reverse ? down.MAX_KEY : down.MIN_KEY, keyTail)) :\n req.unique ?\n cursor.continue(\n cursor.key.slice(0, keyLength)\n .concat(req.reverse\n ? down.MIN_KEY\n : down.MAX_KEY, keyTail)\n ) :\n cursor.continue()\n }\n const virtualCursor = Object.create(cursor, {\n continue: {value: _continue},\n continuePrimaryKey: {\n value(key: any, primaryKey: any) {\n cursor.continuePrimaryKey(pad(key, down.MAX_KEY, keyTail), primaryKey);\n }\n },\n primaryKey: {\n get() {\n return cursor.primaryKey;\n }\n },\n key: {\n get() {\n const key = cursor.key as any[]; // A virtual cursor always operates on compound key\n return keyLength === 1 ?\n key[0] : // Cursor.key should not be an array.\n key.slice(0, keyLength); // Cursor.key should be first part of array.\n }\n },\n value: {\n get() {\n return cursor.value;\n }\n }\n });\n return virtualCursor;\n }\n \n return table.openCursor(translateRequest(req))\n .then(cursor => cursor && createVirtualCursor(cursor));\n }\n };\n return result;\n }\n }\n}\n\nexport const virtualIndexMiddleware : Middleware = {\n stack: \"dbcore\",\n name: \"VirtualIndexMiddleware\",\n level: 1,\n create: createVirtualIndexMiddleware\n};\n\n","import { keys, hasOwn, toStringTag } from './utils';\n\nexport function getObjectDiff(a: any, b: any, rv?: any, prfx?: string) {\n // Compares objects a and b and produces a diff object.\n rv = rv || {};\n prfx = prfx || '';\n keys(a).forEach((prop) => {\n if (!hasOwn(b, prop)) {\n // Property removed\n rv[prfx + prop] = undefined;\n } else {\n var ap = a[prop],\n bp = b[prop];\n if (typeof ap === 'object' && typeof bp === 'object' && ap && bp) {\n const apTypeName = toStringTag(ap);\n const bpTypeName = toStringTag(bp);\n\n if (apTypeName !== bpTypeName) {\n rv[prfx + prop] = b[prop]; // Property changed to other type\n } else if (apTypeName === 'Object') {\n // Pojo objects (not Date, ArrayBuffer, Array etc). Go deep.\n getObjectDiff(ap, bp, rv, prfx + prop + '.');\n } else if (ap !== bp) {\n // Values differ.\n // Could have checked if Date, arrays or binary types have same\n // content here but I think that would be a suboptimation.\n // Prefer simplicity.\n rv[prfx + prop] = b[prop];\n }\n } else if (ap !== bp) rv[prfx + prop] = b[prop]; // Primitive value changed\n }\n });\n keys(b).forEach((prop) => {\n if (!hasOwn(a, prop)) {\n rv[prfx + prop] = b[prop]; // Property added\n }\n });\n return rv;\n}\n","import {\n DBCoreAddRequest,\n DBCorePutRequest,\n DBCoreDeleteRequest,\n DBCoreIndex,\n DBCoreTable,\n} from \"../public/types/dbcore\";\n\nexport function getEffectiveKeys (\n primaryKey: DBCoreIndex,\n req: (Pick & {keys?: any[]}) | Pick)\n{\n //const {outbound} = primaryKey;\n if (req.type === 'delete') return req.keys;\n return req.keys || req.values.map(primaryKey.extractKey)\n}\n","import {\n DBCore,\n DBCoreTable,\n DBCoreMutateResponse,\n DBCoreDeleteRangeRequest,\n DBCoreAddRequest,\n DBCorePutRequest,\n DBCoreDeleteRequest,\n DBCoreTransaction,\n DBCoreKeyRange\n} from \"../public/types/dbcore\";\nimport { nop } from '../functions/chaining-functions';\nimport { hasOwn, setByKeyPath } from '../functions/utils';\nimport { getObjectDiff } from \"../functions/get-object-diff\";\nimport { PSD } from '../helpers/promise';\n//import { LockableTableMiddleware } from '../dbcore/lockable-table-middleware';\nimport { getEffectiveKeys } from '../dbcore/get-effective-keys';\nimport { Middleware } from '../public/types/middleware';\nimport { Transaction } from '../classes/transaction';\n\nexport const hooksMiddleware: Middleware = {\n stack: \"dbcore\",\n name: \"HooksMiddleware\",\n level: 2,\n create: (downCore: DBCore) => ({\n ...downCore,\n table(tableName: string) {\n const downTable = downCore.table(tableName);\n const {primaryKey} = downTable.schema;\n \n const tableMiddleware: DBCoreTable = {\n ...downTable,\n mutate(req):Promise {\n const dxTrans = PSD.trans as Transaction;\n // Hooks can be transaction-bound. Need to grab them from transaction.table and not\n // db.table!\n const {deleting, creating, updating} = dxTrans.table(tableName).hook;\n switch (req.type) {\n case 'add':\n if (creating.fire === nop) break;\n return dxTrans._promise('readwrite', ()=>addPutOrDelete(req), true);\n case 'put':\n if (creating.fire === nop && updating.fire === nop) break;\n return dxTrans._promise('readwrite', ()=>addPutOrDelete(req), true);\n case 'delete':\n if (deleting.fire === nop) break;\n return dxTrans._promise('readwrite', ()=>addPutOrDelete(req), true);\n case 'deleteRange':\n if (deleting.fire === nop) break;\n return dxTrans._promise('readwrite', ()=>deleteRange(req), true);\n }\n // Any of the breaks above happened (no hooks) - do the default:\n return downTable.mutate(req);\n\n\n function addPutOrDelete(req: DBCoreAddRequest | DBCorePutRequest | DBCoreDeleteRequest): Promise {\n const dxTrans = PSD.trans;\n const keys = req.keys || getEffectiveKeys(primaryKey, req);\n if (!keys) throw new Error(\"Keys missing\");\n // Clone Request and set keys arg\n req = req.type === 'add' || req.type === 'put' ?\n {...req, keys} :\n {...req};\n if (req.type !== 'delete') req.values = [...req.values];\n if (req.keys) req.keys = [...req.keys];\n \n return getExistingValues(downTable, req, keys).then (existingValues => {\n const contexts = keys.map((key, i) => {\n const existingValue = existingValues[i];\n const ctx = { onerror: null, onsuccess: null };\n if (req.type === 'delete') {\n // delete operation\n deleting.fire.call(ctx, key, existingValue, dxTrans);\n } else if (req.type === 'add' || existingValue === undefined) {\n // The add() or put() resulted in a create\n const generatedPrimaryKey = creating.fire.call(ctx, key, req.values[i], dxTrans);\n if (key == null && generatedPrimaryKey != null) {\n key = generatedPrimaryKey;\n req.keys[i] = key;\n if (!primaryKey.outbound) {\n setByKeyPath(req.values[i], primaryKey.keyPath, key);\n }\n }\n } else {\n // The put() operation resulted in an update\n const objectDiff = getObjectDiff(existingValue, req.values[i]);\n const additionalChanges = updating.fire.call(ctx, objectDiff, key, existingValue, dxTrans);\n if (additionalChanges) {\n const requestedValue = req.values[i];\n Object.keys(additionalChanges).forEach(keyPath => {\n if (hasOwn(requestedValue, keyPath)) {\n // keyPath is already present as a literal property of the object\n requestedValue[keyPath] = additionalChanges[keyPath];\n } else {\n // keyPath represents a new or existing path into the object\n setByKeyPath(requestedValue, keyPath, additionalChanges[keyPath]);\n }\n });\n }\n }\n return ctx;\n });\n return downTable.mutate(req).then(({failures, results, numFailures, lastResult}) => {\n for (let i=0; i {\n contexts.forEach(ctx => ctx.onerror && ctx.onerror(error));\n return Promise.reject(error);\n });\n });\n }\n \n function deleteRange(req: DBCoreDeleteRangeRequest): Promise {\n return deleteNextChunk(req.trans, req.range, 10000);\n }\n \n function deleteNextChunk(trans: DBCoreTransaction, range: DBCoreKeyRange, limit: number) {\n // Query what keys in the DB within the given range\n return downTable.query({trans, values: false, query: {index: primaryKey, range}, limit})\n .then(({result}) => {\n // Given a set of keys, bulk delete those using the same procedure as in addPutOrDelete().\n // This will make sure that deleting hook is called.\n return addPutOrDelete({type: 'delete', keys: result, trans}).then(res => {\n if (res.numFailures > 0) return Promise.reject(res.failures[0]);\n if (result.length < limit) {\n return {failures: [], numFailures: 0, lastResult: undefined} as DBCoreMutateResponse;\n } else {\n return deleteNextChunk(trans, {...range, lower: result[result.length - 1], lowerOpen: true}, limit);\n }\n });\n })\n }\n }\n };\n //const {lock, lockableMiddleware} = LockableTableMiddleware(tableMiddleware);\n\n return tableMiddleware;\n },\n }) as DBCore\n};\n\nfunction getExistingValues(\n table: DBCoreTable,\n req: DBCoreAddRequest | DBCorePutRequest | DBCoreDeleteRequest,\n effectiveKeys: any[]\n) {\n return req.type === \"add\"\n ? Promise.resolve([])\n : table.getMany({ trans: req.trans, keys: effectiveKeys, cache: \"immutable\" });\n}\n","import { deepClone } from \"../functions/utils\";\nimport { DBCore } from \"../public/types/dbcore\";\nimport { Middleware } from \"../public/types/middleware\";\nimport Promise from \"../helpers/promise\";\nimport { cmp } from '../functions/cmp';\n\nexport function getFromTransactionCache(\n keys: readonly any[],\n cache: { keys: any[]; values: any[] } | undefined | null,\n clone?: boolean\n) {\n try {\n if (!cache) return null;\n if (cache.keys.length < keys.length) return null;\n const result: any[] = [];\n // Compare if the exact same order of keys was retrieved in same transaction:\n // Allow some cached keys to be omitted from provided set of keys\n // Use case: 1. getMany(keys) 2. update a subset of those 3. call put with the updated ones ==> middlewares should be able to find old values\n for (let i = 0, j = 0; i < cache.keys.length && j < keys.length; ++i) {\n if (cmp(cache.keys[i], keys[j]) !== 0) continue;\n result.push(clone ? deepClone(cache.values[i]) : cache.values[i]);\n ++j;\n }\n // If got all keys caller was looking for, return result.\n return result.length === keys.length ? result : null;\n } catch {\n return null;\n }\n}\n\nexport const cacheExistingValuesMiddleware: Middleware = {\n stack: \"dbcore\",\n level: -1,\n create: (core) => {\n return {\n table: (tableName) => {\n const table = core.table(tableName);\n return {\n ...table,\n getMany: (req) => {\n if (!req.cache) {\n return table.getMany(req);\n }\n const cachedResult = getFromTransactionCache(\n req.keys,\n req.trans[\"_cache\"],\n req.cache === \"clone\"\n );\n if (cachedResult) {\n return Promise.resolve(cachedResult);\n }\n return table.getMany(req).then((res) => {\n req.trans[\"_cache\"] = {\n keys: req.keys,\n values: req.cache === \"clone\" ? deepClone(res) : res,\n };\n return res;\n });\n },\n mutate: (req) => {\n // Invalidate cache on any mutate except \"add\" which can't change existing values:\n if (req.type !== \"add\") req.trans[\"_cache\"] = null;\n return table.mutate(req);\n },\n };\n },\n };\n },\n};\n","import { cmp } from \"../functions/cmp\";\nimport { extend, iteratorSymbol, props } from '../functions/utils';\nimport { IndexableType } from '../public';\nimport {\n EmptyRange,\n IntervalTree,\n IntervalTreeNode,\n RangeSetConstructor,\n RangeSetPrototype,\n} from \"../public/types/rangeset\";\n\n/* An interval tree implementation to efficiently detect overlapping ranges of queried indexes.\n *\n * https://en.wikipedia.org/wiki/Interval_tree\n * \n */\n\nfunction isEmptyRange(node: IntervalTree | {from: IndexableType, to: IndexableType}): node is EmptyRange {\n return !(\"from\" in node);\n}\n\nexport type RangeSet = RangeSetPrototype & IntervalTree;\n\nexport const RangeSet = function(fromOrTree: any, to?: any) {\n if (this) {\n // Called with new()\n extend(this, arguments.length ? {d:1, from: fromOrTree, to: arguments.length > 1 ? to : fromOrTree} : {d:0});\n } else {\n // Called without new()\n const rv = new RangeSet();\n if (fromOrTree && (\"d\" in fromOrTree)) {\n extend(rv, fromOrTree);\n }\n return rv;\n }\n} as RangeSetConstructor;\n\nprops(RangeSet.prototype, {\n add(rangeSet: IntervalTree | {from: IndexableType, to: IndexableType}) {\n mergeRanges(this, rangeSet);\n return this;\n },\n addKey(key: IndexableType) {\n addRange(this, key, key);\n return this;\n },\n addKeys(keys: IndexableType[]) {\n keys.forEach(key => addRange(this, key, key));\n return this;\n },\n\n [iteratorSymbol](): Iterator {\n return getRangeSetIterator(this);\n }\n});\n\nfunction addRange(target: IntervalTree, from: IndexableType, to: IndexableType) {\n const diff = cmp(from, to);\n // cmp() returns NaN if one of the args are IDB-invalid keys.\n // Avoid storing invalid keys in rangeset:\n if (isNaN(diff)) return;\n\n // Caller is trying to add a range where from is greater than to:\n if (diff > 0) throw RangeError();\n \n if (isEmptyRange(target)) return extend(target, { from, to, d: 1 });\n const left = target.l;\n const right = target.r;\n if (cmp(to, target.from) < 0) {\n left\n ? addRange(left, from, to)\n : (target.l = { from, to, d: 1, l: null, r: null });\n return rebalance(target);\n }\n if (cmp(from, target.to) > 0) {\n right\n ? addRange(right, from, to)\n : (target.r = { from, to, d: 1, l: null, r: null });\n return rebalance(target);\n }\n // Now we have some kind of overlap. We will be able to merge the new range into the node or let it be swallowed.\n\n // Grow left?\n if (cmp(from, target.from) < 0) {\n target.from = from;\n target.l = null; // Cut off for now. Re-add later.\n target.d = right ? right.d + 1 : 1;\n }\n // Grow right?\n if (cmp(to, target.to) > 0) {\n target.to = to;\n target.r = null; // Cut off for now. Re-add later.\n target.d = target.l ? target.l.d + 1 : 1;\n }\n const rightWasCutOff = !target.r;\n // Re-add left?\n if (left && !target.l) {\n //Ranges to the left may be swallowed. Cut it of and re-add all.\n //Could probably be done more efficiently!\n mergeRanges(target, left);\n }\n // Re-add right?\n if (right && rightWasCutOff) {\n //Ranges to the right may be swallowed. Cut it of and re-add all.\n //Could probably be done more efficiently!\n mergeRanges(target, right);\n }\n}\n\nexport function mergeRanges(target: IntervalTree, newSet: IntervalTree | {from: IndexableType, to: IndexableType}) {\n function _addRangeSet(\n target: IntervalTree,\n { from, to, l, r }: IntervalTreeNode | {from: IndexableType, to: IndexableType, l?: undefined, r?: undefined}\n ) {\n addRange(target, from, to);\n if (l) _addRangeSet(target, l);\n if (r) _addRangeSet(target, r);\n }\n\n if(!isEmptyRange(newSet)) _addRangeSet(target, newSet);\n}\n\nexport function rangesOverlap(\n rangeSet1: IntervalTree,\n rangeSet2: IntervalTree\n): boolean {\n // Start iterating other from scratch.\n const i1 = getRangeSetIterator(rangeSet2);\n let nextResult1 = i1.next();\n if (nextResult1.done) return false;\n let a = nextResult1.value;\n\n // Start iterating this from start of other\n const i2 = getRangeSetIterator(rangeSet1);\n let nextResult2 = i2.next(a.from); // Start from beginning of other range\n let b = nextResult2.value;\n\n while (!nextResult1.done && !nextResult2.done) {\n if (cmp(b!.from, a.to) <= 0 && cmp(b!.to, a.from) >= 0) return true;\n cmp(a.from, b!.from) < 0\n ? (a = (nextResult1 = i1.next(b!.from)).value!) // a is behind. forward it to beginning of next b-range\n : (b = (nextResult2 = i2.next(a.from)).value); // b is behind. forward it to beginning of next a-range\n }\n return false;\n}\n\ntype RangeSetIteratorState =\n | {\n up?: RangeSetIteratorState;\n n: IntervalTreeNode;\n s: 0 | 1 | 2 | 3;\n }\n | undefined\n | null;\nexport function getRangeSetIterator(\n node: EmptyRange | IntervalTreeNode\n): Generator {\n let state: RangeSetIteratorState = isEmptyRange(node) ? null : { s: 0, n: node };\n\n return {\n next(key?) {\n const keyProvided = arguments.length > 0;\n while (state) {\n switch (state.s) {\n case 0:\n // Initial state for node.\n // Fast forward to leftmost node.\n state.s = 1;\n if (keyProvided) {\n while (state.n.l && cmp(key, state.n.from) < 0)\n state = { up: state, n: state.n.l, s: 1 };\n } else {\n while (state.n.l) state = { up: state, n: state.n.l, s: 1 };\n }\n // intentionally fall into case 1:\n case 1:\n // We're on a node where it's left part is already handled or does not exist.\n state.s = 2;\n if (!keyProvided || cmp(key, state.n.to) <= 0)\n return { value: state.n, done: false };\n case 2:\n // We've emitted our node and should continue with the right part or let parent take over from it's state 1\n if (state.n.r) {\n state.s = 3; // So when child is done, we know we're done.\n state = { up: state, n: state.n.r, s: 0 };\n continue; // Will fall in to case 0 with fast forward to left leaf of this subtree.\n }\n // intentionally fall into case 3:\n case 3:\n state = state.up;\n }\n }\n return { done: true };\n },\n } as Generator;\n}\n\nfunction rebalance(target: IntervalTreeNode) {\n const diff = (target.r?.d || 0) - (target.l?.d || 0);\n const r = diff > 1 ? \"r\" : diff < -1 ? \"l\" : \"\";\n if (r) {\n\n // Rotate (https://en.wikipedia.org/wiki/Tree_rotation)\n //\n // \n // [OLDROOT]\n // [OLDROOT.L] [NEWROOT]\n // [NEWROOT.L] [NEWROOT.R]\n //\n // Is going to become:\n //\n // \n // [NEWROOT]\n // [OLDROOT] [NEWROOT.R]\n // [OLDROOT.L] [NEWROOT.L] \n\n // * clone now has the props of OLDROOT\n // Plan:\n // * target must be given the props of NEWROOT\n // * target[l] must point to a new OLDROOT\n // * target[r] must point to NEWROOT.R\n // * OLDROOT[r] must point to NEWROOT.L\n const l = r === \"r\" ? \"l\" : \"r\"; // Support both left/right rotation\n const rootClone = { ...target };\n // We're gonna copy props from target's right node into target so that target will\n // have same range as old target[r] (instead of changing pointers, we copy values.\n // that way we do not need to adjust pointers in parents).\n const oldRootRight = target[r]; \n target.from = oldRootRight.from;\n target.to = oldRootRight.to;\n target[r] = oldRootRight[r];\n rootClone[r] = oldRootRight[l];\n target[l] = rootClone;\n rootClone.d = computeDepth(rootClone);\n }\n target.d = computeDepth(target);\n}\n\nfunction computeDepth({ r, l }: Pick) {\n return (r ? (l ? Math.max(r.d, l.d) : r.d) : l ? l.d : 0) + 1;\n}\n","import { DBCore, DBCoreTable } from '../../public/types/dbcore';\nimport { LiveQueryContext } from '../live-query';\n\nexport function isCachableContext(ctx: LiveQueryContext, table: DBCoreTable) {\n return (\n ctx.trans.mode === 'readonly' &&\n !!ctx.subscr &&\n !ctx.trans.explicit &&\n ctx.trans.db._options.cache !== 'disabled' &&\n !table.schema.primaryKey.outbound\n );\n}\n\n","import { DBCoreCountRequest, DBCoreGetManyRequest, DBCoreGetRequest, DBCoreOpenCursorRequest, DBCoreQueryRequest } from '../../public/types/dbcore';\n\n\nexport function isCachableRequest(type: string, req: Partial) {\n switch (type) {\n case 'query':\n return req.values && !req.unique;\n case 'get':\n return false;\n case 'getMany':\n return false;\n case 'count':\n return false;\n case 'openCursor':\n return false;\n }\n}\n","import { deepClone, keys } from \"../functions/utils\";\nimport { mergeRanges, RangeSet } from \"../helpers/rangeset\";\nimport { ObservabilitySet } from \"../public/types/db-events\";\n\nexport function extendObservabilitySet(\n target: ObservabilitySet,\n newSet: ObservabilitySet\n): ObservabilitySet {\n keys(newSet).forEach(part => {\n const rangeSet = target[part] || (target[part] = new RangeSet());\n mergeRanges(rangeSet, newSet[part]);\n });\n return target;\n}\n","import { LiveQueryContext } from \".\";\nimport { getFromTransactionCache } from \"../dbcore/cache-existing-values-middleware\";\nimport { getEffectiveKeys } from \"../dbcore/get-effective-keys\";\nimport { exceptions } from \"../errors\";\nimport { cmp } from \"../functions/cmp\";\nimport { isArray, keys } from \"../functions/utils\";\nimport { PSD } from \"../helpers/promise\";\nimport { RangeSet } from \"../helpers/rangeset\";\nimport { ObservabilitySet } from \"../public/types/db-events\";\nimport {\n DBCore,\n DBCoreCountRequest,\n DBCoreCursor,\n DBCoreGetManyRequest,\n DBCoreGetRequest,\n DBCoreIndex,\n DBCoreOpenCursorRequest,\n DBCoreQueryRequest,\n DBCoreQueryResponse,\n DBCoreTable,\n DBCoreTableSchema,\n DBCoreTransaction,\n} from \"../public/types/dbcore\";\nimport { Middleware } from \"../public/types/middleware\";\nimport { isCachableContext } from \"./cache/is-cachable-context\";\nimport { isCachableRequest } from \"./cache/is-cachable-request\";\nimport { extendObservabilitySet } from \"./extend-observability-set\";\n\nexport const observabilityMiddleware: Middleware = {\n stack: \"dbcore\",\n level: 0,\n name: \"Observability\",\n create: (core) => {\n const dbName = core.schema.name;\n const FULL_RANGE = new RangeSet(core.MIN_KEY, core.MAX_KEY);\n\n return {\n ...core,\n transaction: (stores, mode, options) => {\n if (!PSD.subscr) return core.transaction(stores, mode, options);\n if (mode !== 'readonly') throw new exceptions.ReadOnly('write transaction not allowed within liveQueries');\n return core.transaction(stores, mode, options) as IDBTransaction;\n },\n table: (tableName) => {\n const table = core.table(tableName);\n const { schema } = table;\n const { primaryKey } = schema;\n const { extractKey, outbound } = primaryKey;\n const tableClone: DBCoreTable = {\n ...table,\n mutate: (req) => {\n const trans = req.trans as DBCoreTransaction & {\n mutatedParts?: ObservabilitySet;\n };\n const mutatedParts = req.mutatedParts || (req.mutatedParts = {});\n const getRangeSet = (indexName: string) => {\n const part = `idb://${dbName}/${tableName}/${indexName}`;\n return (mutatedParts[part] ||\n (mutatedParts[part] = new RangeSet())) as RangeSet;\n };\n const pkRangeSet = getRangeSet(\"\");\n const delsRangeSet = getRangeSet(\":dels\");\n\n const { type } = req;\n let [keys, newObjs] =\n req.type === \"deleteRange\"\n ? [req.range] // keys will be an DBCoreKeyRange object - transformed later on to a [from,to]-style range.\n : req.type === \"delete\"\n ? [req.keys] // keys known already here. newObjs will be undefined.\n : req.values.length < 50\n ? [getEffectiveKeys(primaryKey, req).filter(id => id), req.values] // keys except autoIncremented - but they are future keys not listened to.\n : []; // keys and newObjs will both be undefined - changeSpec will become true (changed for entire table)\n\n const oldCache = req.trans[\"_cache\"];\n\n // Add the mutated table and optionally keys to the mutatedTables set on the transaction.\n // Used by subscribers to txcommit event and for Collection.prototype.subscribe().\n if (isArray(keys)) {\n // keys is an array - delete, add or put of less than 50 rows.\n // Individual keys (add put or delete)\n pkRangeSet.addKeys(keys);\n // Only get oldObjs if they have been cached recently\n // (This applies to Collection.modify() only, but also if updating/deleting hooks have subscribers)\n const oldObjs = type === 'delete' || keys.length === newObjs.length ? getFromTransactionCache(keys, oldCache) : null;\n\n // Supply detailed values per index for both old and new objects:\n if (!oldObjs && type !== \"add\") {\n // delete or put and we don't know old values.\n // Indicate this in the \":dels\" part, for the sake of count() queries only!\n delsRangeSet.addKeys(keys);\n }\n if (oldObjs || newObjs) {\n // No matter if knowning oldObjs or not, track the indices if it's a put, add or delete.\n trackAffectedIndexes(getRangeSet, schema, oldObjs, newObjs);\n }\n } else if (keys) {\n // keys is a DBCoreKeyRange object. Transform it to [from,to]-style range.\n // As we can't know deleted index ranges, mark index-based subscriptions must trigger.\n const range = { from: keys.lower, to: keys.upper };\n delsRangeSet.add(range);\n // deleteRange. keys is a DBCoreKeyRange objects. Transform it to [from,to]-style range.\n pkRangeSet.add(range);\n } else {\n // Too many requests to record the details without slowing down write performance.\n // Let's just record a generic large range on primary key, the virtual :dels index and\n // all secondary indices:\n pkRangeSet.add(FULL_RANGE);\n delsRangeSet.add(FULL_RANGE);\n schema.indexes.forEach(idx => getRangeSet(idx.name).add(FULL_RANGE));\n }\n\n return table.mutate(req).then((res) => {\n // Merge the mutated parts from the request into the transaction's mutatedParts\n // now when the request went fine.\n if (keys && primaryKey.autoIncrement && (req.type === 'add' || req.type === 'put')) {\n // Less than 50 requests (keys truthy) (otherwise we've added full range anyway)\n // autoincrement means we might not have got all keys until now\n pkRangeSet.addKeys(res.results);\n }\n trans.mutatedParts = extendObservabilitySet (\n trans.mutatedParts || {},\n mutatedParts\n );\n return res;\n });\n },\n };\n\n const getRange: (req: any) => [DBCoreIndex, RangeSet] = ({\n query: { index, range },\n }:\n | DBCoreQueryRequest\n | DBCoreCountRequest\n | DBCoreOpenCursorRequest) => [\n index,\n new RangeSet(range.lower ?? core.MIN_KEY, range.upper ?? core.MAX_KEY),\n ];\n\n const readSubscribers: {[method in\n Exclude]: \n (req: any) => [DBCoreIndex, RangeSet]\n } = {\n get: (req) => [primaryKey, new RangeSet(req.key)],\n getMany: (req) => [primaryKey, new RangeSet().addKeys(req.keys)],\n count: getRange,\n query: getRange,\n openCursor: getRange,\n }\n\n keys(readSubscribers).forEach(method => {\n tableClone[method] = function (\n req:\n | DBCoreGetRequest\n | DBCoreGetManyRequest\n | DBCoreQueryRequest\n | DBCoreCountRequest\n | DBCoreOpenCursorRequest\n ) {\n const { subscr } = PSD as LiveQueryContext;\n const isLiveQuery = !!subscr;\n let cachable = isCachableContext(PSD as LiveQueryContext, table) && isCachableRequest(method, req);\n const obsSet = cachable\n ? req.obsSet = {} // Implicit read transaction - track changes for this query only for the request's duration\n : subscr; // Explicit read transaction - track changes across entire live query\n\n if (isLiveQuery) {\n // Abort handling\n const { signal } = PSD as LiveQueryContext;\n if (signal && signal.aborted) throw new exceptions.Abort();\n // Current zone want's to track all queries so they can be subscribed to.\n // (The query is executed within a \"liveQuery\" zone)\n // Check whether the query applies to a certain set of ranges:\n // Track what we should be observing:\n const getRangeSet = (indexName: string) => {\n const part = `idb://${dbName}/${tableName}/${indexName}`;\n return (obsSet[part] ||\n (obsSet[part] = new RangeSet())) as RangeSet;\n };\n const pkRangeSet = getRangeSet(\"\");\n const delsRangeSet = getRangeSet(\":dels\");\n const [queriedIndex, queriedRanges] = readSubscribers[method](req);\n // A generic rule here: queried ranges should always be subscribed to.\n getRangeSet(queriedIndex.name || \"\").add(queriedRanges);\n if (!queriedIndex.isPrimaryKey) {\n // Only count(), query() and openCursor() operates on secondary indices.\n // Since put(), delete() and deleteRange() mutations may happen without knowing oldObjs,\n // the mutate() method will be missing what secondary indices that are being deleted from\n // the subscribed range. We are working around this issue by recording all the resulting\n // primary keys from the queries. This only works for those kinds of queries where we can\n // derive the primary key from the result.\n // In this block we are accomplishing this using various strategies depending on the properties\n // of the query result.\n\n if (method === \"count\") {\n // We've got a problem! Delete and put mutations happen without known the oldObjs.\n // Those mutation could change the count.\n // Solution: Dedicated \":dels\" url represends a subscription to all mutations without oldObjs\n // (specially triggered in the mutators put(), delete() and deleteRange() when they don't know oldObject)\n delsRangeSet.add(FULL_RANGE);\n } else {\n // openCursor() or query()\n\n // Prepare a keysPromise in case the we're doing an IDBIndex.getAll() on a store with outbound keys.\n const keysPromise =\n method === \"query\" &&\n outbound &&\n (req as DBCoreQueryRequest).values &&\n table.query({\n ...(req as DBCoreQueryRequest),\n values: false,\n });\n\n return table[method].apply(this, arguments).then((res) => {\n if (method === \"query\") {\n if (outbound && (req as DBCoreQueryRequest).values) {\n // If keys are outbound, we can't use extractKey to map what keys to observe.\n // We've queried an index (like 'dateTime') on an outbound table\n // and retrieve a list of objects\n // from who we cannot know their primary keys.\n // \"Luckily\" though, we've prepared the keysPromise to assist us in exact this condition.\n return keysPromise.then(\n ({ result: resultingKeys }: DBCoreQueryResponse) => {\n pkRangeSet.addKeys(resultingKeys);\n return res;\n }\n );\n }\n // query() inbound values, keys or outbound keys. Secondary indexes only since\n // for primary keys we would only add results within the already registered range.\n const pKeys = (req as DBCoreQueryRequest).values\n ? (res as DBCoreQueryResponse).result.map(extractKey)\n : (res as DBCoreQueryResponse).result;\n if ((req as DBCoreQueryRequest).values) {\n // Subscribe to any mutation made on the returned keys,\n // so that we detect both deletions and updated properties.\n pkRangeSet.addKeys(pKeys);\n } else {\n // Subscribe only to mutations on the returned keys\n // in case the mutator was unable to know oldObjs.\n // If it has oldObj, the mutator won't put anything in \":dels\" because\n // it can more fine-grained put the exact removed and added index value in the correct\n // index range that we subscribe to in the queried range sets.\n // We don't load values so a change on a property outside our index will not\n // require us to re-execute the query.\n delsRangeSet.addKeys(pKeys);\n }\n } else if (method === \"openCursor\") {\n // Caller requests a cursor.\n // For the same reason as when method===\"query\", we only need to observe\n // those keys whose values are possibly used or rendered - which could\n // only happen on keys where they get the cursor's key, primaryKey or value.\n const cursor: DBCoreCursor | null = res;\n const wantValues = (req as DBCoreOpenCursorRequest).values;\n return (\n cursor &&\n Object.create(cursor, {\n key: {\n get() {\n delsRangeSet.addKey(cursor.primaryKey);\n return cursor.key;\n },\n },\n primaryKey: {\n get() {\n const pkey = cursor.primaryKey;\n delsRangeSet.addKey(pkey);\n return pkey;\n },\n },\n value: {\n get() {\n wantValues && pkRangeSet.addKey(cursor.primaryKey);\n return cursor.value;\n },\n },\n })\n );\n }\n return res;\n });\n }\n }\n }\n return table[method].apply(this, arguments);\n };\n });\n return tableClone;\n },\n };\n },\n};\n\nfunction trackAffectedIndexes(\n getRangeSet: (index: string) => RangeSet,\n schema: DBCoreTableSchema,\n oldObjs: readonly any[] | undefined,\n newObjs: readonly any[] | undefined\n) {\n function addAffectedIndex(ix: DBCoreIndex) {\n const rangeSet = getRangeSet(ix.name || \"\");\n function extractKey(obj: any) {\n return obj != null ? ix.extractKey(obj) : null;\n }\n const addKeyOrKeys = (key: any) => ix.multiEntry && isArray(key)\n // multiEntry and the old property was an array - add each array entry to the rangeSet:\n ? key.forEach(key => rangeSet.addKey(key))\n // Not multiEntry or the old property was not an array - add each array entry to the rangeSet:\n : rangeSet.addKey(key);\n\n (oldObjs || newObjs).forEach((_, i) => {\n const oldKey = oldObjs && extractKey(oldObjs[i]);\n const newKey = newObjs && extractKey(newObjs[i]);\n if (cmp(oldKey, newKey) !== 0) {\n // The index has changed. Add both old and new value of the index.\n if (oldKey != null) addKeyOrKeys(oldKey); // If oldKey is invalid key, addKey() will be a noop.\n if (newKey != null) addKeyOrKeys(newKey); // If newKey is invalid key, addKey() will be a noop.\n }\n });\n }\n schema.indexes.forEach(addAffectedIndex);\n}\n","import { cmp } from '../../functions/cmp';\nimport { IndexableType } from '../../public';\nimport { DBCoreKeyRange } from '../../public/types/dbcore';\n\nexport function isAboveLower(key: IndexableType, range: DBCoreKeyRange) {\n return range.lower === undefined\n ? true // lower is less than anything because it is undefined\n : range.lowerOpen\n ? cmp(key, range.lower) > 0 // lowerOpen: Exclude lower bound\n : cmp(key, range.lower) >= 0; // !lowerOpen: Include lower bound\n}\n\nexport function isBelowUpper(key: IndexableType, range: DBCoreKeyRange) {\n return range.upper === undefined\n ? true // upper is greater than anything because it is undefined\n : range.upperOpen\n ? cmp(key, range.upper) < 0 // upperOpen: Exclude upper bound\n : cmp(key, range.upper) <= 0; // !upperOpen: Include upper bound\n}\n\nexport function isWithinRange(key: IndexableType, range: DBCoreKeyRange) {\n return isAboveLower(key, range) && isBelowUpper(key, range);\n}\n","import { cmp } from '../../functions/cmp';\nimport { deepClone } from '../../functions/utils';\nimport { RangeSet, rangesOverlap } from '../../helpers/rangeset';\nimport { CacheEntry } from '../../public/types/cache';\nimport {\n DBCoreMutateRequest,\n DBCoreQueryRequest,\n DBCoreTable,\n} from '../../public/types/dbcore';\nimport { isWithinRange } from './is-within-range';\n\nexport function applyOptimisticOps(\n result: any[],\n req: DBCoreQueryRequest,\n ops: DBCoreMutateRequest[] | undefined,\n table: DBCoreTable,\n cacheEntry: CacheEntry,\n immutable: boolean\n): any[] {\n if (!ops || ops.length === 0) return result;\n const sortIndex = req.query.index;\n const primaryKey = table.schema.primaryKey;\n const extractPrimKey = primaryKey.extractKey;\n const extractIndex = sortIndex.extractKey;\n\n let finalResult = ops.reduce((result, op) => {\n let modifedResult = result;\n const includedValues =\n op.type === 'add' || op.type === 'put'\n ? op.values.filter((v) =>\n isWithinRange(extractIndex(v), req.query.range)\n ).map(v => {\n v = deepClone(v);// v might come from user so we can't just freeze it.\n if (immutable) Object.freeze(v);\n return v;\n }) \n : [];\n switch (op.type) {\n case 'add':\n modifedResult = result.concat(\n req.values\n ? includedValues\n : includedValues.map((v) => extractPrimKey(v))\n );\n break;\n case 'put':\n const keySet = new RangeSet().addKeys(\n op.values.map((v) => extractPrimKey(v))\n );\n modifedResult = result\n .filter((item) => {\n const key = req.values ? extractPrimKey(item) : item;\n return !rangesOverlap(new RangeSet(key), keySet);\n })\n .concat(\n req.values\n ? includedValues\n : includedValues.map((v) => extractPrimKey(v))\n );\n break;\n case 'delete':\n const keysToDelete = new RangeSet().addKeys(op.keys);\n modifedResult = result.filter((item) => {\n const key = req.values ? extractPrimKey(item) : item;\n return !rangesOverlap(new RangeSet(key), keysToDelete);\n });\n\n break;\n case 'deleteRange':\n const range = op.range;\n const rangeSet = new RangeSet(range.lower, range.upper);\n modifedResult = result.filter((item) => {\n const key = primaryKey.extractKey(item);\n return !(\n (\n rangesOverlap(new RangeSet(key), rangeSet) &&\n isWithinRange(key, range)\n ) // isWithinRange is needed because RangeSet does not care about openness.\n );\n });\n break;\n }\n return modifedResult;\n }, result);\n\n // If no changes were made, we can return the original result.\n if (finalResult === result) return result;\n\n // Sort the result on sortIndex:\n finalResult.sort((a, b) =>\n cmp(sortIndex.extractKey(a), sortIndex.extractKey(b))\n );\n\n // If we have a limit we need to respect it:\n if (req.limit) {\n if (finalResult.length > req.limit) {\n finalResult.length = req.limit; // Cut of any extras after sorting correctly.\n } else if (result.length === req.limit && finalResult.length < req.limit) {\n // We're missing some items because of the limit. We need to add them back.\n // The easiest way is to mark the cache entry as dirty, which will cause\n // it to be requeried after the write-transaction successfully completes.\n cacheEntry.dirty = true;\n }\n }\n return immutable ? Object.freeze(finalResult) as any[] : finalResult;\n}\n","import { GlobalQueryCache } from \"../../public/types/cache\";\n\nexport const cache: GlobalQueryCache = {}\n","import { cmp } from '../../functions/cmp';\nimport { DBCoreKeyRange } from '../../public/types/dbcore';\n\nexport function areRangesEqual(r1: DBCoreKeyRange, r2: DBCoreKeyRange) {\n return (\n cmp(r1.lower, r2.lower) === 0 &&\n cmp(r1.upper, r2.upper) === 0 &&\n !!r1.lowerOpen === !!r2.lowerOpen &&\n !!r1.upperOpen === !!r2.upperOpen\n );\n}\n","import { cmp } from '../../functions/cmp';\nimport { DBCoreKeyRange } from '../../public/types/dbcore';\n\nexport function compareLowers(lower1: any, lower2: any, lowerOpen1: boolean, lowerOpen2: boolean) {\n if (lower1 === undefined) return lower2 !== undefined ? -1 : 0;\n if (lower2 === undefined) return 1; // since lower1 !== undefined\n const c = cmp(lower1, lower2);\n if (c === 0) {\n if (lowerOpen1 && lowerOpen2) return 0;\n if (lowerOpen1) return 1\n if (lowerOpen2) return -1;\n }\n return c;\n}\n\nexport function compareUppers(upper1: any, upper2: any, upperOpen1: boolean, upperOpen2: boolean) {\n if (upper1 === undefined) return upper2 !== undefined ? 1 : 0;\n if (upper2 === undefined) return -1; // since upper1 !== undefined\n const c = cmp(upper1, upper2);\n if (c === 0) {\n if (upperOpen1 && upperOpen2) return 0;\n if (upperOpen1) return -1\n if (upperOpen2) return 1;\n }\n return c;\n}\n\nexport function isSuperRange(r1: DBCoreKeyRange, r2: DBCoreKeyRange) {\n return (\n compareLowers(r1.lower, r2.lower, r1.lowerOpen, r2.lowerOpen) <= 0 &&\n compareUppers(r1.upper, r2.upper, r1.upperOpen, r2.upperOpen) >= 0\n );\n}","import { CacheEntry, TblQueryCache } from '../../public/types/cache';\nimport {\n DBCoreCountRequest,\n DBCoreQueryRequest,\n} from '../../public/types/dbcore';\nimport { areRangesEqual } from './are-ranges-equal';\nimport { cache } from './cache';\nimport { isSuperRange } from './is-super-range';\n\nexport function findCompatibleQuery(\n dbName: string,\n tableName: string,\n type: 'query',\n req: DBCoreQueryRequest\n): [] | [CacheEntry, boolean, TblQueryCache, CacheEntry[]];\nexport function findCompatibleQuery(\n dbName: string,\n tableName: string,\n type: 'count',\n req: DBCoreCountRequest\n): [] | [CacheEntry, boolean, TblQueryCache, CacheEntry[]];\nexport function findCompatibleQuery(\n dbName: string,\n tableName: string,\n type: 'query' | 'count',\n req: Partial & Partial\n): [] | [CacheEntry, boolean, TblQueryCache, CacheEntry[]] {\n const tblCache = cache[`idb://${dbName}/${tableName}`];\n if (!tblCache) return [];\n const queries = tblCache.queries[type];\n if (!queries) return [null, false, tblCache, null];\n const indexName = req.query ? req.query.index.name : null;\n const entries = queries[indexName || ''];\n if (!entries) return [null, false, tblCache, null];\n\n switch (type) {\n case 'query':\n const equalEntry = entries.find(\n (entry) =>\n (entry.req as DBCoreQueryRequest).limit === req.limit &&\n (entry.req as DBCoreQueryRequest).values === req.values &&\n areRangesEqual(entry.req.query.range, req.query.range)\n );\n if (equalEntry)\n return [\n equalEntry,\n true, // exact match\n tblCache,\n entries,\n ];\n const superEntry = entries.find((entry) => {\n const limit = 'limit' in entry.req ? entry.req.limit : Infinity;\n return (\n limit >= req.limit &&\n (req.values ? (entry.req as DBCoreQueryRequest).values : true) &&\n isSuperRange(entry.req.query.range, req.query.range)\n );\n });\n return [superEntry, false, tblCache, entries];\n case 'count':\n const countQuery = entries.find((entry) =>\n areRangesEqual(entry.req.query.range, req.query.range)\n );\n return [countQuery, !!countQuery, tblCache, entries];\n }\n}\n","import { rangesOverlap } from '../helpers/rangeset';\nimport { ObservabilitySet } from '../public/types/db-events';\n\nexport function obsSetsOverlap(os1: ObservabilitySet, os2: ObservabilitySet) {\n return Object.keys(os1).some(\n (key) => os2[key] && rangesOverlap(os2[key], os1[key])\n );\n}\n","import { TblQueryCache } from '../../public/types/cache';\nimport { ObservabilitySet } from '../../public/types/db-events';\nimport { extendObservabilitySet } from '../extend-observability-set';\nimport { obsSetsOverlap } from '../obs-sets-overlap';\n\n\nexport function signalSubscribers(tblCache: TblQueryCache, mutatedParts: ObservabilitySet) {\n extendObservabilitySet(tblCache.unsignaledParts, mutatedParts);\n if (!tblCache.signalTimer) {\n tblCache.signalTimer = setTimeout(() => {\n tblCache.signalTimer = null;\n signalSubscribersNow(tblCache);\n }, 0);\n }\n}\nfunction signalSubscribersNow(tblCache: TblQueryCache) {\n const collectedSubscribers = new Set<() => void>(); // Collect all and then call to reduce risk of requerying same query twice.\n for (const entries of Object.values(tblCache.queries.query)) {\n for (const entry of entries) {\n if (entry.obsSet && obsSetsOverlap(entry.obsSet, tblCache.unsignaledParts)) {\n entry.subscribers.forEach((requery) => collectedSubscribers.add(requery));\n }\n }\n }\n tblCache.unsignaledParts = {};\n collectedSubscribers.forEach((requery) => requery()); // try..catch not needed. subscriber is in live-query.ts \n}\n","import { delArrayItem } from \"../../functions/utils\";\nimport { CacheEntry } from \"../../public/types/cache\";\n\nexport function subscribeToCacheEntry(cacheEntry: CacheEntry, container: CacheEntry[], requery: ()=>void, signal: AbortSignal) {\n cacheEntry.subscribers.add(requery);\n signal.addEventListener(\"abort\", () => {\n cacheEntry.subscribers.delete(requery);\n if (cacheEntry.subscribers.size === 0) {\n enqueForDeletion(cacheEntry, container);\n }\n });\n}\n\n\nfunction enqueForDeletion(cacheEntry: CacheEntry, container: CacheEntry[]) {\n setTimeout(() => {\n if (cacheEntry.subscribers.size === 0) { // Still empty (no new subscribers readded after grace time)\n delArrayItem(container, cacheEntry);\n }\n }, 3000);\n}\n","import { LiveQueryContext } from '..';\nimport { getEffectiveKeys } from '../../dbcore/get-effective-keys';\nimport { exceptions } from '../../errors';\nimport { deepClone, delArrayItem, isArray, keys, setByKeyPath } from '../../functions/utils';\nimport DexiePromise, { PSD } from '../../helpers/promise';\nimport { ObservabilitySet } from '../../public/types/db-events';\nimport {\n DBCore,\n DBCoreCountRequest,\n DBCoreGetManyRequest,\n DBCoreGetRequest,\n DBCoreQueryRequest,\n DBCoreQueryResponse,\n} from '../../public/types/dbcore';\nimport { Middleware } from '../../public/types/middleware';\nimport { applyOptimisticOps } from './apply-optimistic-ops';\nimport { cache } from './cache';\nimport { findCompatibleQuery } from './find-compatible-query';\nimport { isCachableContext } from './is-cachable-context';\nimport { isCachableRequest } from './is-cachable-request';\nimport { signalSubscribers } from './signalSubscribers';\nimport { subscribeToCacheEntry } from './subscribe-cachentry';\n\nexport const cacheMiddleware: Middleware = {\n stack: 'dbcore',\n level: 0,\n name: 'Cache',\n create: (core) => {\n const dbName = core.schema.name;\n const coreMW: DBCore = {\n ...core,\n transaction: (stores, mode, options) => {\n const idbtrans = core.transaction(\n stores,\n mode,\n options\n ) as IDBTransaction & {\n mutatedParts?: ObservabilitySet;\n };\n // Maintain TblQueryCache.ops array when transactions commit or abort\n const { txs } = PSD as LiveQueryContext;\n if (txs || mode === 'readwrite') {\n if (txs) txs.push(idbtrans);\n const ac = new AbortController();\n const { signal } = ac;\n const endTransaction = (wasCommitted: boolean) => () => {\n if (txs) delArrayItem(txs, idbtrans);\n ac.abort();\n if (mode === 'readwrite') {\n for (const storeName of stores) {\n const tblCache = cache[`idb://${dbName}/${storeName}`];\n const table = core.table(storeName);\n if (tblCache) {\n // Pick optimistic ops that are part of this transaction\n const ops = tblCache.optimisticOps.filter(\n (op) => op.trans === idbtrans\n );\n if (ops.length > 0) {\n // Remove them from the optimisticOps array\n tblCache.optimisticOps = tblCache.optimisticOps.filter(\n (op) => op.trans !== idbtrans\n );\n // Commit or abort the optimistic updates\n for (const entries of Object.values(\n tblCache.queries.query\n )) {\n for (const entry of entries.slice()) {\n if (\n entry.res != null && // if entry.promise but not entry.res, we're fine. Query will resume now and get the result.\n idbtrans.mutatedParts/* &&\n obsSetsOverlap(entry.obsSet, idbtrans.mutatedParts)*/\n ) {\n if (wasCommitted && !entry.dirty) {\n const freezeResults = Object.isFrozen(entry.res);\n const modRes = applyOptimisticOps(\n entry.res as any[],\n entry.req,\n ops,\n table,\n entry,\n freezeResults\n );\n if (entry.dirty) {\n // Found out at this point that the entry is dirty - not to rely on!\n delArrayItem(entries, entry);\n entry.subscribers.forEach((requery) => requery());\n } else if (modRes !== entry.res) {\n entry.res = modRes;\n // Update promise\n entry.promise = DexiePromise.resolve({result: modRes} satisfies DBCoreQueryResponse);\n \n // No need to notify subscribers. They already have this value.\n // We have just updated the value of the cache without having to\n // requery the database - because we know the result for this\n // query based on computing the operations and applying them\n // to the previous result.\n }\n } else {\n if (entry.dirty) {\n // If the entry is dirty we need to get rid of it so that\n // a new entry will be created when the query is run again.\n delArrayItem(entries, entry);\n }\n // If we're not committing, we need to notify subscribers that the\n // optimistic updates are no longer valid.\n entry.subscribers.forEach((requery) => requery()); // TODO: Call signalSubscribers instead somehow (or is the subscriber or obsSet already reset at this point)\n }\n }\n }\n }\n }\n }\n }\n }\n };\n idbtrans.addEventListener('abort', endTransaction(false), {\n signal,\n });\n idbtrans.addEventListener('error', endTransaction(false), {\n signal,\n });\n idbtrans.addEventListener('complete', endTransaction(true), {\n signal,\n });\n }\n return idbtrans;\n },\n table(tableName: string) {\n const downTable = core.table(tableName);\n const primKey = downTable.schema.primaryKey;\n const tableMW = {\n ...downTable,\n mutate(req) {\n if (\n primKey.outbound || // Non-inbound tables are harded to apply optimistic updates on because we can't know primary key of results\n PSD.trans.db._options.cache === 'disabled' // User has opted-out from caching\n ) {\n // Just forward the request to the core.\n return downTable.mutate(req);\n }\n // Find the TblQueryCache for this table:\n const tblCache = cache[`idb://${dbName}/${tableName}`];\n if (!tblCache) return downTable.mutate(req);\n\n const promise = downTable.mutate(req);\n if (primKey.autoIncrement && (req.type === 'add' || req.type === 'put') && (req.values.length < 50 || getEffectiveKeys(primKey, req).some(key => key == null))) {\n // There are some autoIncremented keys not set yet. Need to wait for completion before we can reliably enqueue the operation.\n // (or there are too many objects so we lazy out to avoid performance bottleneck for large bulk inserts)\n promise.then((res) => { // We need to extract result keys and generate cloned values with the keys set (so that applyOptimisticOps can work)\n // But we have a problem! The req.mutatedParts is still not complete so we have to actively add the keys to the unsignaledParts set manually.\n const reqWithResolvedKeys = {\n ...req,\n values: req.values.map((value, i) => {\n const valueWithKey = primKey.keyPath.includes('.')\n ? deepClone(value)\n : {\n ...value,\n };\n setByKeyPath(valueWithKey, primKey.keyPath, res.results[i]);\n return valueWithKey;\n })\n };\n tblCache.optimisticOps.push(reqWithResolvedKeys);\n // Signal subscribers after the observability middleware has complemented req.mutatedParts with the new keys.\n queueMicrotask(()=>signalSubscribers(tblCache, req.mutatedParts));\n });\n } else {\n // Enque the operation immediately\n tblCache.optimisticOps.push(req);\n // Signal subscribers that there are mutated parts\n signalSubscribers(tblCache, req.mutatedParts);\n promise.catch(()=> {\n // In case the operation failed, we need to remove it from the optimisticOps array.\n delArrayItem(tblCache.optimisticOps, req);\n signalSubscribers(tblCache, req.mutatedParts); // Signal the rolling back of the operation.\n });\n }\n return promise;\n },\n query(req: DBCoreQueryRequest): Promise {\n if (!isCachableContext(PSD, downTable) || !isCachableRequest(\"query\", req)) return downTable.query(req);\n const freezeResults =\n (PSD as LiveQueryContext).trans.db._options.cache === 'immutable';\n const { requery, signal } = PSD as LiveQueryContext;\n let [cacheEntry, exactMatch, tblCache, container] =\n findCompatibleQuery(dbName, tableName, 'query', req);\n if (cacheEntry && exactMatch) {\n cacheEntry.obsSet = req.obsSet; // So that optimistic result is monitored.\n // How? - because observability-middleware will track result where optimistic\n // mutations are applied and record it in the cacheEntry.\n // TODO: CHANGE THIS! The difference is resultKeys only.\n // Wanted behavior:\n // * cacheEntry obsSet should represent the obsSet without optimistic updates (so it can be checked when merging ops in tx commit)\n // * cacheEntry optimisticObsSet should represent the obsSet with current optimistic updates. It should be updated when adding an op\n // by adding the primary keys of the put/add/delete operation to the set.\n // * observability-middleware should stop recording req.obsSet when a cache entry exact match is found because it won't be used anyway.\n // I'm thinking of merging observability-middleware with cache-middleware into one single middleware because the dependencies are too\n // tight between them.\n } else {\n // --> TODO here: If not exact match, check if we have a superset to extract\n // the data from.\n\n // No cached result found. We need to query the database and cache the result.\n const promise = downTable.query(req).then((res) => {\n // Freeze or clone results\n const result = res.result;\n cacheEntry.res = result;\n if (freezeResults) {\n // For performance reasons don't deep freeze.\n // Only freeze the top-level array and its items.\n // This is good enough to teach users that the result must be treated as immutable\n // without enforcing it recursively on the entire result (which is not even possible\n // for things like Date objects and typed arrays)\n for (let i = 0, l = result.length; i < l; ++i) {\n Object.freeze(result[i]);\n }\n Object.freeze(result);\n } else {\n // If not frozen, we need to clone the result to avoid user mutating the cache\n // When we do this, user's must feel conformable with the fact that the result\n // can be mutated deeply - user is not expected to have any respect for immutability.\n res.result = deepClone(result);\n }\n return res;\n }).catch(error => {\n // In case the query operation failed, we need to remove it from the cache\n // so that subsequent calls does not get the same error but re-evaluate\n // the query.\n if (container && cacheEntry) delArrayItem(container, cacheEntry);\n return Promise.reject(error);\n });\n cacheEntry = {\n obsSet: req.obsSet,\n promise: promise.catch(error => {\n // In case the query operation failed to to have been aborted, we need\n // redo the query (without cache this time and with a brand new transaction)\n if ((req.trans as IDBTransaction & {aborted?: boolean}).aborted) {\n const trans = coreMW.transaction([tableName], 'readonly');\n return tableMW.query({...req, trans});\n }\n return Promise.reject(error);\n }),\n subscribers: new Set(),\n type: 'query',\n req,\n dirty: false,\n };\n if (container) {\n container.push(cacheEntry);\n } else {\n container = [cacheEntry];\n if (!tblCache) {\n tblCache = cache[`idb://${dbName}/${tableName}`] = {\n queries: {\n query: {},\n count: {},\n },\n objs: new Map(),\n optimisticOps: [],\n unsignaledParts: {}\n };\n }\n tblCache.queries.query[req.query.index.name || ''] = container;\n }\n }\n subscribeToCacheEntry(cacheEntry, container, requery, signal);\n return cacheEntry.promise.then((res: DBCoreQueryResponse) => {\n return {\n result: applyOptimisticOps(\n res.result,\n req,\n tblCache?.optimisticOps,\n downTable,\n cacheEntry,\n freezeResults\n ) as any[], // readonly any[]\n };\n });\n },\n };\n return tableMW;\n },\n };\n return coreMW;\n },\n};\n\n\n","// Import types from the public API\nimport { Dexie as IDexie } from \"../../public/types/dexie\";\nimport { DexieOptions, DexieConstructor } from \"../../public/types/dexie-constructor\";\nimport { DbEvents } from \"../../public/types/db-events\";\n//import { PromiseExtended, PromiseExtendedConstructor } from '../../public/types/promise-extended';\nimport { Table as ITable } from '../../public/types/table';\nimport { TableSchema } from \"../../public/types/table-schema\";\nimport { DbSchema } from '../../public/types/db-schema';\n\n// Internal imports\nimport { Table, TableConstructor, createTableConstructor } from \"../table\";\nimport { Collection, CollectionConstructor, createCollectionConstructor } from '../collection';\nimport { WhereClause } from '../where-clause/where-clause';\nimport { WhereClauseConstructor, createWhereClauseConstructor } from '../where-clause/where-clause-constructor';\nimport { Transaction } from '../transaction';\nimport { TransactionConstructor, createTransactionConstructor } from '../transaction/transaction-constructor';\nimport { Version } from \"../version/version\";\nimport { VersionConstructor, createVersionConstructor } from '../version/version-constructor';\n\n// Other imports...\nimport { DexieEventSet } from '../../public/types/dexie-event-set';\nimport { DexieExceptionClasses } from '../../public/types/errors';\nimport { DexieDOMDependencies } from '../../public/types/dexie-dom-dependencies';\nimport { nop, promisableChain } from '../../functions/chaining-functions';\nimport Promise, { PSD } from '../../helpers/promise';\nimport { extend, override, keys, hasOwn } from '../../functions/utils';\nimport Events from '../../helpers/Events';\nimport { maxString, connections, READONLY, READWRITE } from '../../globals/constants';\nimport { getMaxKey } from '../../functions/quirks';\nimport { exceptions } from '../../errors';\nimport { lowerVersionFirst } from '../version/schema-helpers';\nimport { dexieOpen } from './dexie-open';\nimport { wrap } from '../../helpers/promise';\nimport { _onDatabaseDeleted } from '../../helpers/database-enumerator';\nimport { eventRejectHandler } from '../../functions/event-wrappers';\nimport { extractTransactionArgs, enterTransactionScope } from './transaction-helpers';\nimport { TransactionMode } from '../../public/types/transaction-mode';\nimport { rejection } from '../../helpers/promise';\nimport { usePSD } from '../../helpers/promise';\nimport { DBCore } from '../../public/types/dbcore';\nimport { Middleware, DexieStacks } from '../../public/types/middleware';\nimport { virtualIndexMiddleware } from '../../dbcore/virtual-index-middleware';\nimport { hooksMiddleware } from '../../hooks/hooks-middleware';\nimport { IndexableType } from '../../public';\nimport { observabilityMiddleware } from '../../live-query/observability-middleware';\nimport { cacheExistingValuesMiddleware } from '../../dbcore/cache-existing-values-middleware';\nimport { cacheMiddleware } from \"../../live-query/cache/cache-middleware\";\n\nexport interface DbReadyState {\n dbOpenError: any;\n isBeingOpened: boolean;\n onReadyBeingFired: undefined | Function[];\n openComplete: boolean;\n dbReadyResolve: () => void;\n dbReadyPromise: Promise;\n cancelOpen: (reason?: Error) => void;\n openCanceller: Promise & { _stackHolder?: Error };\n autoSchema: boolean;\n vcFired?: boolean;\n PR1398_maxLoop?: number;\n}\n\nexport class Dexie implements IDexie {\n _options: DexieOptions;\n _state: DbReadyState;\n _versions: Version[];\n _storeNames: string[];\n _deps: DexieDOMDependencies;\n _allTables: { [name: string]: Table; };\n _createTransaction: (this: Dexie, mode: IDBTransactionMode, storeNames: ArrayLike, dbschema: { [tableName: string]: TableSchema; }, parentTransaction?: Transaction) => Transaction;\n _dbSchema: { [tableName: string]: TableSchema; };\n _hasGetAll?: boolean;\n _maxKey: IndexableType;\n _fireOnBlocked: (ev: Event) => void;\n _middlewares: {[StackName in keyof DexieStacks]?: Middleware[]} = {};\n _vip?: boolean;\n _novip: Dexie;// db._novip is to escape to orig db from db.vip.\n core: DBCore;\n\n name: string;\n verno: number = 0;\n idbdb: IDBDatabase | null;\n vip: Dexie;\n on: DbEvents;\n\n Table: TableConstructor;\n WhereClause: WhereClauseConstructor;\n Collection: CollectionConstructor;\n Version: VersionConstructor;\n Transaction: TransactionConstructor;\n\n constructor(name: string, options?: DexieOptions) {\n const deps = (Dexie as any as DexieConstructor).dependencies;\n this._options = options = {\n // Default Options\n addons: (Dexie as any as DexieConstructor).addons, // Pick statically registered addons by default\n autoOpen: true, // Don't require db.open() explicitely.\n // Default DOM dependency implementations from static prop.\n indexedDB: deps.indexedDB, // Backend IndexedDB api. Default to browser env.\n IDBKeyRange: deps.IDBKeyRange, // Backend IDBKeyRange api. Default to browser env.\n cache: 'cloned', // Default to cloned for backward compatibility. For best performance and least memory consumption use 'immutable'.\n ...options\n }; \n this._deps = {\n indexedDB: options.indexedDB as IDBFactory,\n IDBKeyRange: options.IDBKeyRange as typeof IDBKeyRange\n };\n const {\n addons,\n } = options;\n this._dbSchema = {};\n this._versions = [];\n this._storeNames = [];\n this._allTables = {};\n this.idbdb = null;\n this._novip = this;\n const state: DbReadyState = {\n dbOpenError: null,\n isBeingOpened: false,\n onReadyBeingFired: null,\n openComplete: false,\n dbReadyResolve: nop,\n dbReadyPromise: null as Promise,\n cancelOpen: nop,\n openCanceller: null as Promise,\n autoSchema: true,\n PR1398_maxLoop: 3\n };\n state.dbReadyPromise = new Promise(resolve => {\n state.dbReadyResolve = resolve;\n });\n state.openCanceller = new Promise((_, reject) => {\n state.cancelOpen = reject;\n });\n this._state = state;\n this.name = name;\n this.on = Events(this, \"populate\", \"blocked\", \"versionchange\", \"close\", { ready: [promisableChain, nop] }) as DbEvents;\n this.on.ready.subscribe = override(this.on.ready.subscribe, subscribe => {\n return (subscriber, bSticky) => {\n (Dexie as any as DexieConstructor).vip(() => {\n const state = this._state;\n if (state.openComplete) {\n // Database already open. Call subscriber asap.\n if (!state.dbOpenError) Promise.resolve().then(subscriber);\n // bSticky: Also subscribe to future open sucesses (after close / reopen) \n if (bSticky) subscribe(subscriber);\n } else if (state.onReadyBeingFired) {\n // db.on('ready') subscribers are currently being executed and have not yet resolved or rejected\n state.onReadyBeingFired.push(subscriber);\n if (bSticky) subscribe(subscriber);\n } else {\n // Database not yet open. Subscribe to it.\n subscribe(subscriber);\n // If bSticky is falsy, make sure to unsubscribe subscriber when fired once.\n const db = this;\n if (!bSticky) subscribe(function unsubscribe() {\n db.on.ready.unsubscribe(subscriber);\n db.on.ready.unsubscribe(unsubscribe);\n });\n }\n });\n }\n });\n\n // Create derived classes bound to this instance of Dexie:\n this.Collection = createCollectionConstructor(this);\n this.Table = createTableConstructor(this);\n this.Transaction = createTransactionConstructor(this);\n this.Version = createVersionConstructor(this);\n this.WhereClause = createWhereClauseConstructor(this);\n\n // Default subscribers to \"versionchange\" and \"blocked\".\n // Can be overridden by custom handlers. If custom handlers return false, these default\n // behaviours will be prevented.\n this.on(\"versionchange\", ev => {\n // Default behavior for versionchange event is to close database connection.\n // Caller can override this behavior by doing db.on(\"versionchange\", function(){ return false; });\n // Let's not block the other window from making it's delete() or open() call.\n // NOTE! This event is never fired in IE,Edge or Safari.\n if (ev.newVersion > 0)\n console.warn(`Another connection wants to upgrade database '${this.name}'. Closing db now to resume the upgrade.`);\n else\n console.warn(`Another connection wants to delete database '${this.name}'. Closing db now to resume the delete request.`);\n this.close();\n // In many web applications, it would be recommended to force window.reload()\n // when this event occurs. To do that, subscribe to the versionchange event\n // and call window.location.reload(true) if ev.newVersion > 0 (not a deletion)\n // The reason for this is that your current web app obviously has old schema code that needs\n // to be updated. Another window got a newer version of the app and needs to upgrade DB but\n // your window is blocking it unless we close it here.\n });\n this.on(\"blocked\", ev => {\n if (!ev.newVersion || ev.newVersion < ev.oldVersion)\n console.warn(`Dexie.delete('${this.name}') was blocked`);\n else\n console.warn(`Upgrade '${this.name}' blocked by other connection holding version ${ev.oldVersion / 10}`);\n });\n\n this._maxKey = getMaxKey(options.IDBKeyRange as typeof IDBKeyRange);\n\n this._createTransaction = (\n mode: IDBTransactionMode,\n storeNames: string[],\n dbschema: DbSchema,\n parentTransaction?: Transaction) => new this.Transaction(mode, storeNames, dbschema, this._options.chromeTransactionDurability, parentTransaction);\n\n this._fireOnBlocked = ev => {\n this.on(\"blocked\").fire(ev);\n // Workaround (not fully*) for missing \"versionchange\" event in IE,Edge and Safari:\n connections\n .filter(c => c.name === this.name && c !== this && !c._state.vcFired)\n .map(c => c.on(\"versionchange\").fire(ev));\n }\n\n // Default middlewares:\n this.use(virtualIndexMiddleware);\n this.use(hooksMiddleware);\n this.use(cacheMiddleware);\n this.use(observabilityMiddleware);\n this.use(cacheExistingValuesMiddleware);\n\n this.vip = Object.create(this, {_vip: {value: true}}) as Dexie;\n\n // Call each addon:\n addons.forEach(addon => addon(this));\n }\n\n version(versionNumber: number): Version {\n if (isNaN(versionNumber) || versionNumber < 0.1) throw new exceptions.Type(`Given version is not a positive number`);\n versionNumber = Math.round(versionNumber * 10) / 10;\n if (this.idbdb || this._state.isBeingOpened)\n throw new exceptions.Schema(\"Cannot add version when database is open\");\n this.verno = Math.max(this.verno, versionNumber);\n const versions = this._versions;\n var versionInstance = versions.filter(\n v => v._cfg.version === versionNumber)[0];\n if (versionInstance) return versionInstance;\n versionInstance = new this.Version(versionNumber);\n versions.push(versionInstance);\n versions.sort(lowerVersionFirst);\n versionInstance.stores({}); // Derive earlier schemas by default.\n // Disable autoschema mode, as at least one version is specified.\n this._state.autoSchema = false;\n return versionInstance;\n }\n\n _whenReady(fn: () => Promise): Promise {\n return (this.idbdb && (this._state.openComplete || PSD.letThrough || this._vip)) ? fn() : new Promise((resolve, reject) => {\n if (this._state.openComplete) {\n // idbdb is falsy but openComplete is true. Must have been an exception durin open.\n // Don't wait for openComplete as it would lead to infinite loop.\n return reject(new exceptions.DatabaseClosed(this._state.dbOpenError));\n }\n if (!this._state.isBeingOpened) {\n if (!this._options.autoOpen) {\n reject(new exceptions.DatabaseClosed());\n return;\n }\n this.open().catch(nop); // Open in background. If if fails, it will be catched by the final promise anyway.\n }\n this._state.dbReadyPromise.then(resolve, reject);\n }).then(fn);\n }\n\n use({stack, create, level, name}: Middleware): this {\n if (name) this.unuse({stack, name}); // Be able to replace existing middleware.\n const middlewares = this._middlewares[stack] || (this._middlewares[stack] = []);\n middlewares.push({stack, create, level: level == null ? 10 : level, name});\n middlewares.sort((a, b) => a.level - b.level);\n // Todo update db.core and db.tables...core ? Or should be expect this to have effect\n // only after next open()?\n return this;\n }\n\n unuse({stack, create}: Middleware<{stack: keyof DexieStacks}>): this;\n unuse({stack, name}: {stack: keyof DexieStacks, name: string}): this;\n unuse({stack, name, create}: {stack: keyof DexieStacks, name?: string, create?: Function}) {\n if (stack && this._middlewares[stack]) {\n this._middlewares[stack] = this._middlewares[stack].filter(mw =>\n create ? mw.create !== create : // Given middleware has a create method. Match that exactly.\n name ? mw.name !== name : // Given middleware spec \n false);\n }\n return this;\n }\n\n open() {\n return dexieOpen(this);\n }\n\n _close(): void {\n const state = this._state;\n const idx = connections.indexOf(this);\n if (idx >= 0) connections.splice(idx, 1);\n if (this.idbdb) {\n try { this.idbdb.close(); } catch (e) { }\n this._novip.idbdb = null; // db._novip is because db can be an Object.create(origDb).\n } \n // Reset dbReadyPromise promise:\n state.dbReadyPromise = new Promise(resolve => {\n state.dbReadyResolve = resolve;\n });\n state.openCanceller = new Promise((_, reject) => {\n state.cancelOpen = reject;\n });\n }\n\n close(): void {\n this._close();\n const state = this._state;\n this._options.autoOpen = false;\n state.dbOpenError = new exceptions.DatabaseClosed();\n if (state.isBeingOpened)\n state.cancelOpen(state.dbOpenError);\n }\n\n delete(): Promise {\n const hasArguments = arguments.length > 0;\n const state = this._state;\n return new Promise((resolve, reject) => {\n const doDelete = () => {\n this.close();\n var req = this._deps.indexedDB.deleteDatabase(this.name);\n req.onsuccess = wrap(() => {\n _onDatabaseDeleted(this._deps, this.name);\n resolve();\n });\n req.onerror = eventRejectHandler(reject);\n req.onblocked = this._fireOnBlocked;\n }\n\n if (hasArguments) throw new exceptions.InvalidArgument(\"Arguments not allowed in db.delete()\");\n if (state.isBeingOpened) {\n state.dbReadyPromise.then(doDelete);\n } else {\n doDelete();\n }\n });\n }\n\n backendDB() {\n return this.idbdb;\n }\n\n isOpen() {\n return this.idbdb !== null;\n }\n\n hasBeenClosed() {\n const dbOpenError = this._state.dbOpenError;\n return dbOpenError && (dbOpenError.name === 'DatabaseClosed');\n }\n\n hasFailed() {\n return this._state.dbOpenError !== null;\n }\n\n dynamicallyOpened() {\n return this._state.autoSchema;\n }\n\n get tables () {\n return keys(this._allTables).map(name => this._allTables[name]);\n }\n\n transaction(): Promise {\n const args = extractTransactionArgs.apply(this, arguments);\n return this._transaction.apply(this, args);\n }\n\n _transaction(mode: TransactionMode, tables: Array, scopeFunc: Function) {\n let parentTransaction = PSD.trans as Transaction | undefined;\n // Check if parent transactions is bound to this db instance, and if caller wants to reuse it\n if (!parentTransaction || parentTransaction.db !== this || mode.indexOf('!') !== -1) parentTransaction = null;\n const onlyIfCompatible = mode.indexOf('?') !== -1;\n mode = mode.replace('!', '').replace('?', '') as TransactionMode; // Ok. Will change arguments[0] as well but we wont touch arguments henceforth.\n let idbMode: IDBTransactionMode,\n storeNames;\n\n try {\n //\n // Get storeNames from arguments. Either through given table instances, or through given table names.\n //\n storeNames = tables.map(table => {\n var storeName = table instanceof this.Table ? table.name : table;\n if (typeof storeName !== 'string') throw new TypeError(\"Invalid table argument to Dexie.transaction(). Only Table or String are allowed\");\n return storeName;\n });\n\n //\n // Resolve mode. Allow shortcuts \"r\" and \"rw\".\n //\n if (mode == \"r\" || mode === READONLY)\n idbMode = READONLY;\n else if (mode == \"rw\" || mode == READWRITE)\n idbMode = READWRITE;\n else\n throw new exceptions.InvalidArgument(\"Invalid transaction mode: \" + mode);\n\n if (parentTransaction) {\n // Basic checks\n if (parentTransaction.mode === READONLY && idbMode === READWRITE) {\n if (onlyIfCompatible) {\n // Spawn new transaction instead.\n parentTransaction = null; \n }\n else throw new exceptions.SubTransaction(\"Cannot enter a sub-transaction with READWRITE mode when parent transaction is READONLY\");\n }\n if (parentTransaction) {\n storeNames.forEach(storeName => {\n if (parentTransaction && parentTransaction.storeNames.indexOf(storeName) === -1) {\n if (onlyIfCompatible) {\n // Spawn new transaction instead.\n parentTransaction = null; \n }\n else throw new exceptions.SubTransaction(\"Table \" + storeName +\n \" not included in parent transaction.\");\n }\n });\n }\n if (onlyIfCompatible && parentTransaction && !parentTransaction.active) {\n // '?' mode should not keep using an inactive transaction.\n parentTransaction = null;\n }\n }\n } catch (e) {\n return parentTransaction ?\n parentTransaction._promise(null, (_, reject) => {reject(e);}) :\n rejection (e);\n }\n // If this is a sub-transaction, lock the parent and then launch the sub-transaction.\n const enterTransaction = enterTransactionScope.bind(null, this, idbMode, storeNames, parentTransaction, scopeFunc);\n return (parentTransaction ?\n parentTransaction._promise(idbMode, enterTransaction, \"lock\") :\n PSD.trans ?\n // no parent transaction despite PSD.trans exists. Make sure also\n // that the zone we create is not a sub-zone of current, because\n // Promise.follow() should not wait for it if so.\n usePSD(PSD.transless, ()=>this._whenReady(enterTransaction)) :\n this._whenReady (enterTransaction));\n }\n\n table(tableName: string): Table;\n table(tableName: string): ITable;\n table(tableName: string): Table {\n if (!hasOwn(this._allTables, tableName)) {\n throw new exceptions.InvalidTable(`Table ${tableName} does not exist`); }\n return this._allTables[tableName];\n }\n}\n","import {\n Observable as IObservable,\n Observer,\n Subscription,\n} from \"../../public/types/observable\";\n\nconst symbolObservable: typeof Symbol.observable =\n typeof Symbol !== \"undefined\" && \"observable\" in Symbol\n ? Symbol.observable\n : \"@@observable\" as any;\n\nexport class Observable implements IObservable {\n private _subscribe: (observer: Observer) => Subscription;\n hasValue?: ()=>boolean;\n getValue?: ()=>T;\n\n constructor(subscribe: (observer: Observer) => Subscription) {\n this._subscribe = subscribe;\n }\n\n subscribe(\n onNext?: ((value: T) => void) | null,\n onError?: ((error: any) => void) | null,\n onComplete?: (() => void) | null\n ): Subscription;\n subscribe(observer?: Observer | null): Subscription;\n subscribe(x?: any, error?: any, complete?: any): Subscription {\n return this._subscribe(\n !x || typeof x === \"function\" ? { next: x, error, complete } : x\n );\n }\n\n [symbolObservable]() {\n return this;\n }\n}\n","import { _global } from '../../globals/global';\nimport { DexieDOMDependencies } from '../../public/types/dexie-dom-dependencies';\n\nexport let domDeps: DexieDOMDependencies\n\ntry {\n domDeps = {\n // Required:\n indexedDB: _global.indexedDB || _global.mozIndexedDB || _global.webkitIndexedDB || _global.msIndexedDB,\n IDBKeyRange: _global.IDBKeyRange || _global.webkitIDBKeyRange\n };\n} catch (e) {\n domDeps = { indexedDB: null, IDBKeyRange: null };\n}\n","import { isAsyncFunction, keys } from '../functions/utils';\nimport {\n globalEvents,\n DEXIE_STORAGE_MUTATED_EVENT_NAME,\n} from '../globals/global-events';\nimport {\n decrementExpectedAwaits,\n incrementExpectedAwaits,\n newScope,\n PSD,\n usePSD,\n} from '../helpers/promise';\nimport { ObservabilitySet } from '../public/types/db-events';\nimport {\n Observable as IObservable,\n Subscription,\n} from '../public/types/observable';\nimport { Observable } from '../classes/observable/observable';\nimport { extendObservabilitySet } from './extend-observability-set';\nimport { rangesOverlap } from '../helpers/rangeset';\nimport { domDeps } from '../classes/dexie/dexie-dom-dependencies';\nimport { Transaction } from '../classes/transaction';\nimport { obsSetsOverlap } from './obs-sets-overlap';\n\nexport interface LiveQueryContext {\n subscr: ObservabilitySet;\n txs: IDBTransaction[];\n signal: AbortSignal;\n requery: () => void;\n trans: null | Transaction;\n}\n\nexport function liveQuery(querier: () => T | Promise): IObservable {\n let hasValue = false;\n let currentValue: T = undefined as any;\n const observable = new Observable((observer) => {\n const scopeFuncIsAsync = isAsyncFunction(querier);\n function execute(ctx: LiveQueryContext) {\n if (scopeFuncIsAsync) {\n incrementExpectedAwaits();\n }\n const rv = newScope(querier, ctx);\n if (scopeFuncIsAsync) {\n (rv as Promise).then(\n decrementExpectedAwaits,\n decrementExpectedAwaits\n );\n }\n return rv;\n }\n\n let closed = false;\n let abortController: AbortController;\n const txs: IDBTransaction[] = [];\n\n let accumMuts: ObservabilitySet = {};\n let currentObs: ObservabilitySet = {};\n\n const subscription: Subscription = {\n get closed() {\n return closed;\n },\n unsubscribe: () => {\n closed = true;\n if (abortController) abortController.abort();\n globalEvents.storagemutated.unsubscribe(mutationListener);\n txs.forEach(idbtrans => {\n //@ts-ignore\n idbtrans.aborted = true;\n try { idbtrans.abort(); } catch {}});\n },\n };\n\n observer.start && observer.start(subscription); // https://github.com/tc39/proposal-observable\n\n let startedListening = false;\n\n function shouldNotify() {\n return obsSetsOverlap(currentObs, accumMuts);\n }\n\n const mutationListener = (parts: ObservabilitySet) => {\n extendObservabilitySet(accumMuts, parts);\n if (shouldNotify()) {\n doQuery();\n }\n };\n\n const doQuery = () => {\n if (\n closed || // closed - don't run!\n !domDeps.indexedDB) // SSR in sveltekit, nextjs etc\n {\n return;\n }\n accumMuts = {};\n const subscr: ObservabilitySet = {};\n // Abort signal fill three purposes:\n // 1. Abort the query if the observable is unsubscribed.\n // 2. Abort the query if a new query is made before the previous one has completed.\n // 3. For cached queries to know if they should remain in memory or could be enqued for being freed up.\n // (they will remain in memory for a short time and if noone needs them again, they will eventually be freed up)\n if (abortController) abortController.abort(); // Cancel previous query. Last query will be cancelled on unsubscribe().\n abortController = new AbortController();\n \n if (txs.length) {\n txs.forEach(idbtrans => {\n //@ts-ignore\n idbtrans.aborted = true;\n try {idbtrans.abort();} catch {}});\n txs.length = 0;\n }\n const ctx: LiveQueryContext = {\n subscr,\n txs,\n signal: abortController.signal,\n requery: doQuery,\n trans: null // Make the scope transactionless (don't reuse transaction from outer scope of the caller of subscribe())\n }\n const ret = execute(ctx);\n if (!startedListening) {\n globalEvents(DEXIE_STORAGE_MUTATED_EVENT_NAME, mutationListener);\n startedListening = true;\n }\n Promise.resolve(ret).then(\n (result) => {\n hasValue = true;\n currentValue = result;\n if (closed || ctx.signal.aborted) {\n // closed - no subscriber anymore.\n // signal.aborted - new query was made before this one completed and\n // the querier might have catched AbortError and return successful result.\n // If so, we should not rely in that result because we know we have aborted\n // this run, which means there's another run going on that will handle accumMuts\n // and we must not base currentObs on the half-baked subscr.\n return;\n }\n accumMuts = {};\n // Update what we are subscribing for based on this last run:\n currentObs = subscr;\n observer.next && observer.next(result);\n },\n (err) => {\n hasValue = false;\n if (!['DatabaseClosedError', 'AbortError'].includes(err?.name)) {\n if (closed) return;\n observer.error && observer.error(err);\n }\n }\n );\n };\n\n doQuery();\n return subscription;\n });\n observable.hasValue = () => hasValue;\n observable.getValue = () => currentValue;\n return observable;\n}\n","import { Dexie as _Dexie } from './dexie';\nimport { _global } from '../../globals/global';\nimport { props, derive, extend, override, getByKeyPath, setByKeyPath, delByKeyPath, shallowClone, deepClone, asap } from '../../functions/utils';\nimport { getObjectDiff } from \"../../functions/get-object-diff\";\nimport { fullNameExceptions } from '../../errors';\nimport { DexieConstructor } from '../../public/types/dexie-constructor';\nimport { getDatabaseNames } from '../../helpers/database-enumerator';\nimport { PSD } from '../../helpers/promise';\nimport { usePSD } from '../../helpers/promise';\nimport { newScope } from '../../helpers/promise';\nimport { rejection } from '../../helpers/promise';\nimport { awaitIterator } from '../../helpers/yield-support';\nimport Promise from '../../helpers/promise';\nimport * as Debug from '../../helpers/debug';\nimport { dexieStackFrameFilter, minKey, connections, DEXIE_VERSION } from '../../globals/constants';\nimport Events from '../../helpers/Events';\nimport { exceptions } from '../../errors';\nimport { errnames } from '../../errors';\nimport { getMaxKey } from '../../functions/quirks';\nimport { vip } from './vip';\nimport { globalEvents } from '../../globals/global-events';\nimport { liveQuery } from '../../live-query/live-query';\nimport { extendObservabilitySet } from '../../live-query/extend-observability-set';\nimport { domDeps } from './dexie-dom-dependencies';\nimport { cmp } from '../../functions/cmp';\nimport { cache } from '../../live-query/cache/cache';\n\n/* (Dexie) is an instance of DexieConstructor, as defined in public/types/dexie-constructor.d.ts\n* (new Dexie()) is an instance of Dexie, as defined in public/types/dexie.d.ts\n* \n* Why we're doing this?\n\n* Because we've choosen to define the public Dexie API using a DexieConstructor interface\n* rather than declaring a class. On that interface, all static props are defined.\n* In practice, class Dexie's constructor implements DexieConstructor and all member props\n* are defined in interface Dexie. We could say, it's a typescript limitation of not being\n* able to define a static interface that forces us to do the cast below.\n*/\nconst Dexie = _Dexie as any as DexieConstructor;\n\n//\n// Set all static methods and properties onto Dexie:\n// \nprops(Dexie, {\n\n // Dexie.BulkError = class BulkError {...};\n // Dexie.XXXError = class XXXError {...};\n ...fullNameExceptions,\n\n //\n // Static delete() method.\n //\n delete(databaseName: string) {\n const db = new Dexie(databaseName, {addons: []});\n return db.delete();\n },\n\n //\n // Static exists() method.\n //\n exists(name: string) {\n return new Dexie(name, { addons: [] }).open().then(db => {\n db.close();\n return true;\n }).catch('NoSuchDatabaseError', () => false);\n },\n\n //\n // Static method for retrieving a list of all existing databases at current host.\n //\n getDatabaseNames(cb) {\n try {\n return getDatabaseNames(Dexie.dependencies).then(cb);\n } catch {\n return rejection(new exceptions.MissingAPI());\n }\n },\n\n /** @deprecated */\n defineClass() {\n function Class(content) {\n extend(this, content);\n }\n return Class;\n },\n\n ignoreTransaction(scopeFunc) {\n // In case caller is within a transaction but needs to create a separate transaction.\n // Example of usage:\n //\n // Let's say we have a logger function in our app. Other application-logic should be unaware of the\n // logger function and not need to include the 'logentries' table in all transaction it performs.\n // The logging should always be done in a separate transaction and not be dependant on the current\n // running transaction context. Then you could use Dexie.ignoreTransaction() to run code that starts a new transaction.\n //\n // Dexie.ignoreTransaction(function() {\n // db.logentries.add(newLogEntry);\n // });\n //\n // Unless using Dexie.ignoreTransaction(), the above example would try to reuse the current transaction\n // in current Promise-scope.\n //\n // An alternative to Dexie.ignoreTransaction() would be setImmediate() or setTimeout(). The reason we still provide an\n // API for this because\n // 1) The intention of writing the statement could be unclear if using setImmediate() or setTimeout().\n // 2) setTimeout() would wait unnescessary until firing. This is however not the case with setImmediate().\n // 3) setImmediate() is not supported in the ES standard.\n // 4) You might want to keep other PSD state that was set in a parent PSD, such as PSD.letThrough.\n return PSD.trans ?\n usePSD(PSD.transless, scopeFunc) : // Use the closest parent that was non-transactional.\n scopeFunc(); // No need to change scope because there is no ongoing transaction.\n },\n\n vip,\n\n async: function (generatorFn: Function) {\n return function () {\n try {\n var rv = awaitIterator(generatorFn.apply(this, arguments));\n if (!rv || typeof rv.then !== 'function')\n return Promise.resolve(rv);\n return rv;\n } catch (e) {\n return rejection(e);\n }\n };\n },\n\n spawn: function (generatorFn, args, thiz) {\n try {\n var rv = awaitIterator(generatorFn.apply(thiz, args || []));\n if (!rv || typeof rv.then !== 'function')\n return Promise.resolve(rv);\n return rv;\n } catch (e) {\n return rejection(e);\n }\n },\n\n // Dexie.currentTransaction property\n currentTransaction: {\n get: () => PSD.trans || null\n },\n\n waitFor: function (promiseOrFunction, optionalTimeout) {\n // If a function is provided, invoke it and pass the returning value to Transaction.waitFor()\n const promise = Promise.resolve(\n typeof promiseOrFunction === 'function' ?\n Dexie.ignoreTransaction(promiseOrFunction) :\n promiseOrFunction)\n .timeout(optionalTimeout || 60000); // Default the timeout to one minute. Caller may specify Infinity if required. \n\n // Run given promise on current transaction. If no current transaction, just return a Dexie promise based\n // on given value.\n return PSD.trans ?\n PSD.trans.waitFor(promise) :\n promise;\n },\n\n // Export our Promise implementation since it can be handy as a standalone Promise implementation\n Promise: Promise,\n\n // Dexie.debug proptery:\n // Dexie.debug = false\n // Dexie.debug = true\n // Dexie.debug = \"dexie\" - don't hide dexie's stack frames.\n debug: {\n get: () => Debug.debug,\n set: value => {\n Debug.setDebug(value, value === 'dexie' ? () => true : dexieStackFrameFilter);\n }\n },\n\n // Export our derive/extend/override methodology\n derive: derive, // Deprecate?\n extend: extend, // Deprecate?\n props: props,\n override: override, // Deprecate?\n // Export our Events() function - can be handy as a toolkit\n Events: Events,\n on: globalEvents,\n liveQuery,\n extendObservabilitySet,\n // Utilities\n getByKeyPath: getByKeyPath,\n setByKeyPath: setByKeyPath,\n delByKeyPath: delByKeyPath,\n shallowClone: shallowClone,\n deepClone: deepClone,\n getObjectDiff: getObjectDiff,\n cmp,\n asap: asap,\n //maxKey: new Dexie('',{addons:[]})._maxKey,\n minKey: minKey,\n // Addon registry\n addons: [],\n // Global DB connection list\n connections: connections,\n\n //MultiModifyError: exceptions.Modify, // Obsolete!\n errnames: errnames,\n\n // Export other static classes\n //IndexSpec: IndexSpec, Obsolete!\n //TableSchema: TableSchema, Obsolete!\n\n //\n // Dependencies\n //\n // These will automatically work in browsers with indexedDB support, or where an indexedDB polyfill has been included.\n //\n // In node.js, however, these properties must be set \"manually\" before instansiating a new Dexie().\n // For node.js, you need to require indexeddb-js or similar and then set these deps.\n //\n dependencies: domDeps,\n cache,\n\n // API Version Number: Type Number, make sure to always set a version number that can be comparable correctly. Example: 0.9, 0.91, 0.92, 1.0, 1.01, 1.1, 1.2, 1.21, etc.\n semVer: DEXIE_VERSION,\n version: DEXIE_VERSION.split('.')\n .map(n => parseInt(n))\n .reduce((p, c, i) => p + (c / Math.pow(10, i * 2))),\n\n // https://github.com/dfahlander/Dexie.js/issues/186\n // typescript compiler tsc in mode ts-->es5 & commonJS, will expect require() to return\n // x.default. Workaround: Set Dexie.default = Dexie.\n // default: Dexie, // Commented because solved in index-umd.ts instead.\n // Make it possible to import {Dexie} (non-default import)\n // Reason 1: May switch to that in future.\n // Reason 2: We declare it both default and named exported in d.ts to make it possible\n // to let addons extend the Dexie interface with Typescript 2.1 (works only when explicitely\n // exporting the symbol, not just default exporting)\n // Dexie: Dexie // Commented because solved in index-umd.ts instead.\n});\n\nDexie.maxKey = getMaxKey(Dexie.dependencies.IDBKeyRange);\n","import { isIEOrEdge } from '../globals/constants';\nimport { globalEvents, DEXIE_STORAGE_MUTATED_EVENT_NAME, STORAGE_MUTATED_DOM_EVENT_NAME } from '../globals/global-events';\nimport { ObservabilitySet } from \"../public/types/db-events\";\n\nif (typeof dispatchEvent !== 'undefined' && typeof addEventListener !== 'undefined') {\n globalEvents(DEXIE_STORAGE_MUTATED_EVENT_NAME, updatedParts => {\n if (!propagatingLocally) {\n let event: CustomEvent;\n if (isIEOrEdge) {\n event = document.createEvent('CustomEvent');\n event.initCustomEvent(STORAGE_MUTATED_DOM_EVENT_NAME, true, true, updatedParts);\n } else {\n event = new CustomEvent(STORAGE_MUTATED_DOM_EVENT_NAME, {\n detail: updatedParts\n });\n }\n propagatingLocally = true;\n dispatchEvent(event);\n propagatingLocally = false;\n }\n });\n addEventListener(STORAGE_MUTATED_DOM_EVENT_NAME, ({detail}: CustomEvent) => {\n if (!propagatingLocally) {\n propagateLocally(detail);\n }\n });\n}\n\nexport function propagateLocally(updateParts: ObservabilitySet) {\n let wasMe = propagatingLocally;\n try {\n propagatingLocally = true;\n globalEvents.storagemutated.fire(updateParts);\n } finally {\n propagatingLocally = wasMe;\n }\n}\n\nexport let propagatingLocally = false;\n","import {\n globalEvents,\n STORAGE_MUTATED_DOM_EVENT_NAME,\n DEXIE_STORAGE_MUTATED_EVENT_NAME,\n} from '../globals/global-events';\nimport { propagateLocally, propagatingLocally } from './propagate-locally';\n\nif (typeof BroadcastChannel !== 'undefined') {\n const bc = new BroadcastChannel(STORAGE_MUTATED_DOM_EVENT_NAME);\n\n /**\n * The Node.js BroadcastChannel will prevent the node process from exiting\n * if the BroadcastChannel is not closed.\n * Therefore we have to call unref() which allows the process to finish\n * properly even when the BroadcastChannel is never closed.\n * @link https://nodejs.org/api/worker_threads.html#broadcastchannelunref\n * @link https://github.com/dexie/Dexie.js/pull/1576\n */\n if (typeof (bc as any).unref === 'function') {\n (bc as any).unref();\n }\n \n //\n // Propagate local changes to remote tabs, windows and workers via BroadcastChannel\n //\n globalEvents(DEXIE_STORAGE_MUTATED_EVENT_NAME, (changedParts) => {\n if (!propagatingLocally) {\n bc.postMessage(changedParts);\n }\n });\n\n //\n // Propagate remote changes locally via storage event:\n //\n bc.onmessage = (ev) => {\n if (ev.data) propagateLocally(ev.data);\n };\n} else if (typeof self !== 'undefined' && typeof navigator !== 'undefined') {\n // DOM verified - when typeof self !== \"undefined\", we are a window or worker. Not a Node process.\n\n //\n // Propagate local changes to remote tabs/windows via storage event and service worker\n // via messages. We have this code here because of https://bugs.webkit.org/show_bug.cgi?id=161472.\n //\n globalEvents(DEXIE_STORAGE_MUTATED_EVENT_NAME, (changedParts) => {\n try {\n if (!propagatingLocally) {\n if (typeof localStorage !== 'undefined') {\n // We're a browsing window or tab. Propagate to other windows/tabs via storage event:\n localStorage.setItem(\n STORAGE_MUTATED_DOM_EVENT_NAME,\n JSON.stringify({\n trig: Math.random(),\n changedParts,\n })\n );\n }\n if (typeof self['clients'] === 'object') {\n // We're a service worker. Propagate to our browser clients.\n [...self['clients'].matchAll({ includeUncontrolled: true })].forEach(\n (client) =>\n client.postMessage({\n type: STORAGE_MUTATED_DOM_EVENT_NAME,\n changedParts,\n })\n );\n }\n }\n } catch {}\n });\n\n //\n // Propagate remote changes locally via storage event:\n //\n if (typeof addEventListener !== 'undefined') {\n addEventListener('storage', (ev: StorageEvent) => {\n if (ev.key === STORAGE_MUTATED_DOM_EVENT_NAME) {\n const data = JSON.parse(ev.newValue);\n if (data) propagateLocally(data.changedParts);\n }\n });\n }\n\n //\n // Propagate messages from service worker\n //\n const swContainer = self.document && navigator.serviceWorker; // self.document is to verify we're not the SW ourself\n if (swContainer) {\n // We're a browser window and want to propagate message from the SW:\n swContainer.addEventListener('message', propagateMessageLocally);\n }\n}\n\nfunction propagateMessageLocally({ data }: MessageEvent) {\n if (data && data.type === STORAGE_MUTATED_DOM_EVENT_NAME) {\n propagateLocally(data.changedParts);\n }\n}\n","import { Dexie } from './classes/dexie';\nimport { DexieConstructor } from './public/types/dexie-constructor';\nimport { DexiePromise } from './helpers/promise';\nimport { mapError } from './errors';\nimport * as Debug from './helpers/debug';\nimport { dexieStackFrameFilter } from './globals/constants';\n\n// Generate all static properties such as Dexie.maxKey etc\n// (implement interface DexieConstructor):\nimport './classes/dexie/dexie-static-props';\nimport './live-query/enable-broadcast';\nimport { liveQuery } from './live-query/live-query';\nimport { Entity } from './classes/entity/Entity';\nimport { cmp } from './functions/cmp';\n\n// Set rejectionMapper of DexiePromise so that it generally tries to map\n// DOMErrors and DOMExceptions to a DexieError instance with same name but with\n// async stack support and with a prototypal inheritance from DexieError and Error.\n// of Map DOMErrors and DOMExceptions to corresponding Dexie errors.\nDexiePromise.rejectionMapper = mapError;\n\n// Let the async stack filter focus on app code and filter away frames from dexie.min.js:\nDebug.setDebug(Debug.debug, dexieStackFrameFilter);\n\nexport { RangeSet, mergeRanges, rangesOverlap } from \"./helpers/rangeset\";\nexport { Dexie, liveQuery }; // Comply with public/index.d.ts.\nexport { Entity };\nexport { cmp };\nexport default Dexie;\n","// Issue #1127. Need another index.ts for the UMD module with only a default export\n// like it was before.\n// In practice though, the UMD export will also export the named export in \n// https://github.com/dfahlander/Dexie.js/blob/c9187ae60c0d7a424f85bab3af179fbbc9901c8e/src/classes/dexie/dexie-static-props.ts#L223-L228\nimport Dexie from \"./index\";\nimport * as namedExports from \"./index\";\nimport { __assign } from 'tslib';\n__assign(Dexie, namedExports, {default: Dexie});\nexport default Dexie;\n"],"names":["asap","_a","Promise","Dexie","Debug.debug","Debug.getErrorWithStack","safari14Workaround","_Dexie","Debug.setDebug"],"mappings":"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"}
\ No newline at end of file
diff --git a/grails-app/assets/vendor/dexiejs/dexie.min.js b/grails-app/assets/vendor/dexiejs/dexie.min.js
new file mode 100644
index 000000000..ebcc0ad44
--- /dev/null
+++ b/grails-app/assets/vendor/dexiejs/dexie.min.js
@@ -0,0 +1,2 @@
+(function(e,t){"object"==typeof exports&&"undefined"!=typeof module?module.exports=t():"function"==typeof define&&define.amd?define(t):(e="undefined"!=typeof globalThis?globalThis:e||self).Dexie=t()})(this,function(){"use strict";var s=function(e,t){return(s=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var n in t)Object.prototype.hasOwnProperty.call(t,n)&&(e[n]=t[n])})(e,t)};var _=function(){return(_=Object.assign||function(e){for(var t,n=1,r=arguments.length;n.",yt="String expected.",vt=[],mt="undefined"!=typeof navigator&&/(MSIE|Trident|Edge)/.test(navigator.userAgent),bt=mt,gt=mt,wt="__dbnames",_t="readonly",xt="readwrite";function kt(e,t){return e?t?function(){return e.apply(this,arguments)&&t.apply(this,arguments)}:e:t}var Ot={type:3,lower:-1/0,lowerOpen:!1,upper:[[]],upperOpen:!1};function Pt(t){return"string"!=typeof t||/\./.test(t)?function(e){return e}:function(e){return void 0===e[t]&&t in e&&delete(e=A(e))[t],e}}function Et(){throw ee.Type()}function Kt(e,t){try{var n=St(e),r=St(t);if(n!==r)return"Array"===n?1:"Array"===r?-1:"binary"===n?1:"binary"===r?-1:"string"===n?1:"string"===r?-1:"Date"===n?1:"Date"!==r?NaN:-1;switch(n){case"number":case"Date":case"string":return tc+l&&h(c+g)})})}return h(0).then(function(){if(0=s}).forEach(function(u){t.push(function(){var t=h,e=u._cfg.dbschema;En(f,t,l),En(f,e,l),h=f._dbSchema=e;var n=xn(t,e);n.add.forEach(function(e){kn(l,e[0],e[1].primKey,e[1].indexes)}),n.change.forEach(function(e){if(e.recreate)throw new ee.Upgrade("Not yet support for changing primary key");var t=l.objectStore(e.name);e.add.forEach(function(e){return On(t,e)}),e.change.forEach(function(e){t.deleteIndex(e.name),On(t,e)}),e.del.forEach(function(e){return t.deleteIndex(e)})});var r=u._cfg.contentUpgrade;if(r&&u._cfg.version>s){mn(f,l),c._memoizedTables={},d=!0;var i=E(e);n.del.forEach(function(e){i[e]=t[e]}),gn(f,[f.Transaction.prototype]),bn(f,[f.Transaction.prototype],x(i),i),c.schema=i;var o,a=F(r);a&&tt();n=Te.follow(function(){var e;(o=r(c))&&a&&(e=nt.bind(null,null),o.then(e,e))});return o&&"function"==typeof o.then?Te.resolve(o):n.then(function(){return o})}}),t.push(function(e){var t,n,r;d&&bt||(t=u._cfg.dbschema,n=t,r=e,[].slice.call(r.db.objectStoreNames).forEach(function(e){return null==n[e]&&r.db.deleteObjectStore(e)})),gn(f,[f.Transaction.prototype]),bn(f,[f.Transaction.prototype],f._storeNames,f._dbSchema),c.schema=f._dbSchema})}),function e(){return t.length?Te.resolve(t.shift()(c.idbtrans)).then(e):Te.resolve()}().then(function(){var t,n;n=l,x(t=h).forEach(function(e){n.db.objectStoreNames.contains(e)||kn(n,e,t[e].primKey,t[e].indexes)})}).catch(u))})}function xn(e,t){var n,r={del:[],add:[],change:[]};for(n in e)t[n]||r.del.push(n);for(n in t){var i=e[n],o=t[n];if(i){var a={name:n,def:o,recreate:!1,del:[],add:[],change:[]};if(""+(i.primKey.keyPath||"")!=""+(o.primKey.keyPath||"")||i.primKey.auto!==o.primKey.auto&&!mt)a.recreate=!0,r.change.push(a);else{var u=i.idxByName,s=o.idxByName,c=void 0;for(c in u)s[c]||a.del.push(c);for(c in s){var l=u[c],f=s[c];l?l.src!==f.src&&a.change.push(f):a.add.push(f)}(0Math.pow(2,62)?0:e.oldVersion,p=e<1,f._novip.idbdb=l.result,_n(f,e/10,d,n))},n),l.onsuccess=Ge(function(){d=null;var e,t,n,r,i,o=f._novip.idbdb=l.result,a=y(o.objectStoreNames);if(0s.limit?t.length=s.limit:e.length===s.limit&&t.length=r.limit&&(!r.values||e.req.values)&&rr(e.req.query.range,r.query.range)}),!1,i,o];case"count":a=o.find(function(e){return nr(e.req.query.range,r.query.range)});return[a,!!a,i,o]}}(w,c,"query",n),a=o[0],e=o[1],u=o[2],s=o[3];return a&&e?a.obsSet=n.obsSet:(e=l.query(n).then(function(e){var t=e.result;if(a.res=t,i){for(var n=0,r=t.length;n2)
+pwa.map.area.help=Area of selected region on map in kilometers. You can only download map if it is below {0} km2.
+pwa.map.cache.title=Map tiles
+pwa.map.downloaded.regions=Downloaded map tiles
+pwa.map.downloaded.regions.serial=Serial number
+pwa.map.downloaded.regions.name=Name
+pwa.map.downloaded.regions.actions=Actions
+pwa.map.downloaded.regions.preview=View on map
+pwa.map.downloaded.regions.delete=Delete
+pwa.offline.no.maps=No cached maps found
+pwa.species.download=Species
+pwa.map.download.species.progress=Species download progress
+pwa.species.download.offline=Delete species and download again
+pwa.species.cached.count=Total species downloaded
+pwa.form.download=Survey form
+pwa.form.download.progress=Survey form need to be cached before you can use it offline. Once the download has begun, you can track its progress using progress bar.
+pwa.form.download.error=An error occurred while downloading survey form. Firstly, check if you are logged in. Lastly, check with project administrator if you have permission to access survey.
+pwa.download.status.error=An error occurred while downloading artefact
+pwa.download.status.success=Download completed successfully
+pwa.download.status.inprogress=Download in progress
+pwa.offline.checklist=Offline checklist
+pwa.offline.checklist.intro=A survey will work offline once all items in checklist are green.
+pwa.metadata.download=Survey metadata
+pwa.metadata.download.intro=Downloads survey metadata, sites associated with survey, project metadata etc.
+pwa.metadata.download.error=Error downloading metadata
+pwa.species.download.error=An error occurred while downloading species.
+pwa.species.download.intro=Downloads species information relevant to survey such as lists associated with a field or the whole species dataset. Downloading the whole species dataset can take several mintues.
+pwa.map.download.intro=Downloads map tiles for offline use. You atleast need one region downloaded to enable offline access.
+pwa.map.download.error=Cannot enable offline access since no map tiles has been downloaded. Scroll down to map download section below to download map.
+pwa.offline.options=Advanced options
+admin.species.catalog=Regenerate species
+admin.species.helptext=Downloads species catalog and transforms it into a downloadable format for PWA mobile clients.
+pwa.species.refresh=Refresh species database
+pwa.map.download.href=Scroll to map section
+pwa.map.download.help=Download map tiles for offline use. You need at least one downloaded region to enable offline access. \
+ Zoom in to the region of interest and give it a name. Then click the download button. Download progress are shown below. \
+ Download is restricted to a maximum area of {0} km2 because map tiles can take up a lot of space. However, you can download multiple regions.
+pwa.upload.all=Upload all
+pwa.add.records=Add record
+pwa.activities.empty.msg=Unpublished records not found
+pwa.unpublished.heading=Unpublished records
+pwa.buttons.actions=Actions
+pwa.view.record=View record
+pwa.edit.record=Create record
+pwa.btn.back=Back to records
\ No newline at end of file
diff --git a/grails-app/services/au/org/ala/biocollect/ProjectActivityService.groovy b/grails-app/services/au/org/ala/biocollect/ProjectActivityService.groovy
index bfb276626..2b1824255 100644
--- a/grails-app/services/au/org/ala/biocollect/ProjectActivityService.groovy
+++ b/grails-app/services/au/org/ala/biocollect/ProjectActivityService.groovy
@@ -265,11 +265,11 @@ class ProjectActivityService {
* @param dataFieldName Identity of field for specific configuration.
* @return json structure containing search results suitable for use by the species autocomplete widget on a survey form.
*/
- def searchSpecies(String id, String q, Integer limit, String output, String dataFieldName) {
+ def searchSpecies(String id, String q, Integer limit, String output, String dataFieldName, Integer offset = 0) {
def pActivity = get(id)
Map speciesConfig = getSpeciesConfigForProjectActivity(pActivity, output, dataFieldName)
if (speciesConfig) {
- def result = speciesService.searchSpeciesForConfig(speciesConfig, q, limit)
+ def result = speciesService.searchSpeciesForConfig(speciesConfig, q, limit, offset)
speciesService.formatSpeciesNameInAutocompleteList(speciesConfig.speciesDisplayFormat, result)
}
}
diff --git a/grails-app/services/au/org/ala/biocollect/merit/SpeciesService.groovy b/grails-app/services/au/org/ala/biocollect/merit/SpeciesService.groovy
index ec6f814a5..6f26718ad 100644
--- a/grails-app/services/au/org/ala/biocollect/merit/SpeciesService.groovy
+++ b/grails-app/services/au/org/ala/biocollect/merit/SpeciesService.groovy
@@ -1,5 +1,15 @@
package au.org.ala.biocollect.merit
+import com.opencsv.CSVParser
+import com.opencsv.CSVReader
+import com.opencsv.CSVReaderBuilder
+import com.opencsv.CSVParserBuilder
+import grails.converters.JSON
+import grails.plugin.cache.Cacheable
+
+import java.util.zip.ZipEntry
+import java.util.zip.ZipFile
+
class SpeciesService {
def webService, grailsApplication
@@ -35,10 +45,10 @@ class SpeciesService {
* @param speciesConfig
* @return
*/
- def searchSpeciesInLists(String searchTerm, Map speciesConfig = [:], limit = 10){
+ def searchSpeciesInLists(String searchTerm, Map speciesConfig = [:], limit = 10, offset = 0){
List druids = speciesConfig.speciesLists?.collect{it.dataResourceUid}
Map fields = getSpeciesListAutocompleteLookupFields(speciesConfig)
- List listResults = searchSpeciesListOnFields(searchTerm, druids, fields.fieldList, limit)
+ List listResults = searchSpeciesListOnFields(searchTerm, druids, fields.fieldList, limit, offset)
formatSpeciesListResultToAutocompleteFormat(listResults, fields.fieldMap)
}
@@ -123,8 +133,8 @@ class SpeciesService {
* @param listId the id of the list to search.
* @return
*/
- private def searchSpeciesListOnFields(String query, List listId = [], List fields = [], limit = 10) {
- def listContents = webService.getJson("${grailsApplication.config.lists.baseURL}/ws/queryListItemOrKVP?druid=${listId.join(',')}&fields=${URLEncoder.encode(fields.join(','), "UTF-8")}&q=${URLEncoder.encode(query, "UTF-8")}&includeKVP=true&limit=${limit}")
+ private def searchSpeciesListOnFields(String query, List listId = [], List fields = [], limit = 10, offset = 0) {
+ def listContents = webService.getJson("${grailsApplication.config.lists.baseURL}/ws/queryListItemOrKVP?druid=${listId.join(',')}&fields=${URLEncoder.encode(fields.join(','), "UTF-8")}&q=${URLEncoder.encode(query, "UTF-8")}&includeKVP=true&max=${limit}&offset=${offset}")
if(listContents.hasProperty('error')){
throw new Exception(listContents.error)
@@ -213,7 +223,7 @@ class SpeciesService {
name
}
- Object searchSpeciesForConfig(Map speciesConfig, String q, Integer limit) {
+ Object searchSpeciesForConfig(Map speciesConfig, String q, Integer limit, Integer offset = 0) {
def result
switch (speciesConfig?.type) {
case 'SINGLE_SPECIES':
@@ -225,7 +235,7 @@ class SpeciesService {
break
case 'GROUP_OF_SPECIES':
- result = searchSpeciesInLists(q, speciesConfig, limit)
+ result = searchSpeciesInLists(q, speciesConfig, limit, offset)
break
default:
result = [autoCompleteList: []]
@@ -288,4 +298,237 @@ class SpeciesService {
def url = "${grailsApplication.config.bieWs.baseURL}/ws/species/shortProfile/${id}"
webService.getJson(url)
}
+
+ Map constructSpeciesFiles (Boolean force = false) {
+ def config = grailsApplication.config,
+ result
+ String taxonFileName = config.getProperty('speciesCatalog.taxonFileName'),
+ guidHeaderName = config.getProperty('speciesCatalog.taxon.headerNames.guid'),
+ scientificNameHeaderName = config.getProperty('speciesCatalog.taxon.headerNames.scientificName'),
+ rankStringHeaderName = config.getProperty('speciesCatalog.taxon.headerNames.rankString'),
+ directory = config.getProperty('speciesCatalog.dir'),
+ taxonID, commonName
+ List
+