@wlydfe/pro-ui 0.2.27 → 0.2.28

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (125) hide show
  1. package/es/components/check-card/index.d.ts +4 -4
  2. package/es/components/check-card/src/index.vue.d.ts +1 -1
  3. package/es/components/check-card-group/index.d.ts +4 -4
  4. package/es/components/check-card-group/src/index.vue.d.ts +1 -1
  5. package/es/components/date-picker/index.d.ts +11 -11
  6. package/es/components/date-picker/src/index.vue.d.ts +11 -11
  7. package/es/components/descriptions/index.d.ts +19 -19
  8. package/es/components/descriptions/src/index.vue.d.ts +1 -1
  9. package/es/components/dialog/index.d.ts +30 -30
  10. package/es/components/dialog/src/index.vue.d.ts +2 -2
  11. package/es/components/dialog-form/index.d.ts +6 -6
  12. package/es/components/dialog-form/src/index.vue.d.ts +3 -3
  13. package/es/components/display-item/index.d.ts +25 -25
  14. package/es/components/display-item/src/index.vue.d.ts +7 -7
  15. package/es/components/drawer-form/index.d.ts +36 -36
  16. package/es/components/drawer-form/src/index.vue.d.ts +5 -5
  17. package/es/components/form/index.d.ts +88 -88
  18. package/es/components/form/src/form-content.vue.d.ts +9 -9
  19. package/es/components/form/src/index.vue.d.ts +11 -11
  20. package/es/components/form-item/index.d.ts +84 -84
  21. package/es/components/form-item/src/index.vue.d.ts +10 -10
  22. package/es/components/input-tag/index.d.ts +6 -6
  23. package/es/components/input-tag/src/index.vue.d.ts +3 -3
  24. package/es/components/page/index.d.ts +988 -988
  25. package/es/components/page/src/index.vue.d.ts +331 -331
  26. package/es/components/pagination/index.d.ts +27 -27
  27. package/es/components/pagination/src/index.vue.d.ts +3 -3
  28. package/es/components/popover/index.d.ts +49 -49
  29. package/es/components/popover/src/index.vue.d.ts +3 -3
  30. package/es/components/radio/index.d.ts +10 -10
  31. package/es/components/radio/src/index.vue.d.ts +2 -2
  32. package/es/components/render/index.d.ts +14 -14
  33. package/es/components/render/src/index.vue.d.ts +1 -1
  34. package/es/components/search/index.d.ts +266 -266
  35. package/es/components/search/src/index.vue.d.ts +77 -77
  36. package/es/components/sidebar/index.d.ts +16 -16
  37. package/es/components/steps-form/index.d.ts +23 -23
  38. package/es/components/steps-form/src/index.vue.d.ts +2 -2
  39. package/es/components/table/index.d.ts +164 -164
  40. package/es/components/table/src/index.vue.d.ts +13 -13
  41. package/es/components/table/src/index.vue2.mjs +17 -6
  42. package/es/components/table/src/table-column-drag-sort.vue.d.ts +2 -2
  43. package/es/components/table/src/table-column-index.vue.d.ts +1 -1
  44. package/es/components/table/src/table-column.vue.d.ts +22 -22
  45. package/es/components/table/src/table-title-bar.vue.d.ts +1 -1
  46. package/es/components/table/src/table-title-bar.vue.mjs +2 -1
  47. package/es/components/table/src/table-title-bar.vue2.mjs +10 -9
  48. package/es/components/table/src/table-title-bar.vue3.mjs +3 -0
  49. package/es/index.css +14 -13
  50. package/index.css +5 -1
  51. package/index.js +2861 -19
  52. package/index.min.css +1 -0
  53. package/index.min.js +7 -2
  54. package/index.min.mjs +7 -2
  55. package/index.mjs +2862 -20
  56. package/lib/components/check-card/index.d.ts +4 -4
  57. package/lib/components/check-card/src/index.vue.d.ts +1 -1
  58. package/lib/components/check-card-group/index.d.ts +4 -4
  59. package/lib/components/check-card-group/src/index.vue.d.ts +1 -1
  60. package/lib/components/date-picker/index.d.ts +11 -11
  61. package/lib/components/date-picker/src/index.vue.d.ts +11 -11
  62. package/lib/components/descriptions/index.d.ts +19 -19
  63. package/lib/components/descriptions/src/index.vue.d.ts +1 -1
  64. package/lib/components/dialog/index.d.ts +30 -30
  65. package/lib/components/dialog/src/index.vue.d.ts +2 -2
  66. package/lib/components/dialog-form/index.d.ts +6 -6
  67. package/lib/components/dialog-form/src/index.vue.d.ts +3 -3
  68. package/lib/components/display-item/index.d.ts +25 -25
  69. package/lib/components/display-item/src/index.vue.d.ts +7 -7
  70. package/lib/components/drawer-form/index.d.ts +36 -36
  71. package/lib/components/drawer-form/src/index.vue.d.ts +5 -5
  72. package/lib/components/form/index.d.ts +88 -88
  73. package/lib/components/form/src/form-content.vue.d.ts +9 -9
  74. package/lib/components/form/src/index.vue.d.ts +11 -11
  75. package/lib/components/form-item/index.d.ts +84 -84
  76. package/lib/components/form-item/src/index.vue.d.ts +10 -10
  77. package/lib/components/input-tag/index.d.ts +6 -6
  78. package/lib/components/input-tag/src/index.vue.d.ts +3 -3
  79. package/lib/components/page/index.d.ts +988 -988
  80. package/lib/components/page/src/index.vue.d.ts +331 -331
  81. package/lib/components/pagination/index.d.ts +27 -27
  82. package/lib/components/pagination/src/index.vue.d.ts +3 -3
  83. package/lib/components/popover/index.d.ts +49 -49
  84. package/lib/components/popover/src/index.vue.d.ts +3 -3
  85. package/lib/components/radio/index.d.ts +10 -10
  86. package/lib/components/radio/src/index.vue.d.ts +2 -2
  87. package/lib/components/render/index.d.ts +14 -14
  88. package/lib/components/render/src/index.vue.d.ts +1 -1
  89. package/lib/components/search/index.d.ts +266 -266
  90. package/lib/components/search/src/index.vue.d.ts +77 -77
  91. package/lib/components/sidebar/index.d.ts +16 -16
  92. package/lib/components/steps-form/index.d.ts +23 -23
  93. package/lib/components/steps-form/src/index.vue.d.ts +2 -2
  94. package/lib/components/table/index.d.ts +164 -164
  95. package/lib/components/table/src/index.vue.d.ts +13 -13
  96. package/lib/components/table/src/index.vue2.js +17 -6
  97. package/lib/components/table/src/table-column-drag-sort.vue.d.ts +2 -2
  98. package/lib/components/table/src/table-column-index.vue.d.ts +1 -1
  99. package/lib/components/table/src/table-column.vue.d.ts +22 -22
  100. package/lib/components/table/src/table-title-bar.vue.d.ts +1 -1
  101. package/lib/components/table/src/table-title-bar.vue.js +2 -1
  102. package/lib/components/table/src/table-title-bar.vue2.js +9 -8
  103. package/lib/components/table/src/table-title-bar.vue3.js +7 -0
  104. package/lib/index.css +16 -15
  105. package/locale/en.js +1 -1
  106. package/locale/en.min.js +1 -1
  107. package/locale/en.min.mjs +1 -1
  108. package/locale/en.mjs +1 -1
  109. package/locale/ja.js +1 -1
  110. package/locale/ja.min.js +1 -1
  111. package/locale/ja.min.mjs +1 -1
  112. package/locale/ja.mjs +1 -1
  113. package/locale/ko.js +1 -1
  114. package/locale/ko.min.js +1 -1
  115. package/locale/ko.min.mjs +1 -1
  116. package/locale/ko.mjs +1 -1
  117. package/locale/zh-cn.js +1 -1
  118. package/locale/zh-cn.min.js +1 -1
  119. package/locale/zh-cn.min.mjs +1 -1
  120. package/locale/zh-cn.mjs +1 -1
  121. package/locale/zh-tw.js +1 -1
  122. package/locale/zh-tw.min.js +1 -1
  123. package/locale/zh-tw.min.mjs +1 -1
  124. package/locale/zh-tw.mjs +1 -1
  125. package/package.json +3 -2
package/index.mjs CHANGED
@@ -1,5 +1,5 @@
1
- /*! @wlydfe/pro-ui v0.2.27 */
2
- import { unref, isRef, ref, isReactive, watch, computed, inject, shallowRef, defineComponent, watchEffect, openBlock, createBlock, mergeProps, createSlots, withCtx, createElementVNode, renderSlot, normalizeStyle, createVNode, createTextVNode, toDisplayString, createElementBlock, createCommentVNode, reactive, useAttrs, Fragment, renderList, resolveDynamicComponent, normalizeProps, guardReactiveProps, h, withDirectives, isVNode, normalizeClass, withKeys, withModifiers, TransitionGroup, toHandlers, provide, resolveComponent, onMounted, onBeforeUnmount, toRefs, nextTick, useSlots, getCurrentInstance } from 'vue';
1
+ /*! @wlydfe/pro-ui v0.2.28 */
2
+ import { unref, isRef, ref, isReactive, watch, computed, inject, shallowRef, defineComponent, watchEffect, openBlock, createBlock, mergeProps, createSlots, withCtx, createElementVNode, renderSlot, normalizeStyle, createVNode, createTextVNode, toDisplayString, createElementBlock, createCommentVNode, reactive, useAttrs, Fragment, renderList, resolveDynamicComponent, normalizeProps, guardReactiveProps, h, withDirectives, isVNode, normalizeClass, withKeys, withModifiers, TransitionGroup, toHandlers, provide, resolveComponent, onMounted, pushScopeId, popScopeId, onBeforeUnmount, toRefs, nextTick, useSlots, getCurrentInstance } from 'vue';
3
3
  import { dayjs, localeContextKey, ElDialog, ElButton, ElPagination, ElRadioGroup, ElRadio, ElTableColumn, ElDropdown, ElDropdownMenu, ElDropdownItem, ElIcon, ElTooltip, ElPopconfirm, ElLink, ElMessageBox, useFormDisabled, ElDatePicker, ClickOutside, ElTag, ElInput, ElAutocomplete, ElCascader, ElCheckboxGroup, ElCheckbox, ElColorPicker, ElInputNumber, ElRate, ElSelect, ElOption, ElSlider, ElSwitch, ElTimePicker, ElTimeSelect, ElTransfer, ElTreeSelect, ElSelectV2, ElText, ElDivider, ElFormItem, ElRow, ElCol, ElForm, ElCard, ElMessage, ElImage, ElProgress, ElAvatar, ElPopover, ElTable, vLoading, ElDescriptions, ElDescriptionsItem, ElDrawer, ElSteps, ElStep, ElBreadcrumb, ElBreadcrumbItem, ElMenuItem, ElSubMenu, ElMenu, ElScrollbar, ElHeader, ElContainer, ElMain, ElBacktop } from 'element-plus';
4
4
 
5
5
  const makeInstaller = (components = []) => {
@@ -2323,7 +2323,7 @@ function initCloneArray(array) {
2323
2323
  }
2324
2324
 
2325
2325
  /** Built-in value references. */
2326
- var Uint8Array = root$1.Uint8Array;
2326
+ var Uint8Array$1 = root$1.Uint8Array;
2327
2327
 
2328
2328
  /**
2329
2329
  * Creates a clone of `arrayBuffer`.
@@ -2334,7 +2334,7 @@ var Uint8Array = root$1.Uint8Array;
2334
2334
  */
2335
2335
  function cloneArrayBuffer(arrayBuffer) {
2336
2336
  var result = new arrayBuffer.constructor(arrayBuffer.byteLength);
2337
- new Uint8Array(result).set(new Uint8Array(arrayBuffer));
2337
+ new Uint8Array$1(result).set(new Uint8Array$1(arrayBuffer));
2338
2338
  return result;
2339
2339
  }
2340
2340
 
@@ -2969,7 +2969,7 @@ function equalByTag(object, other, tag, bitmask, customizer, equalFunc, stack) {
2969
2969
 
2970
2970
  case arrayBufferTag:
2971
2971
  if ((object.byteLength != other.byteLength) ||
2972
- !equalFunc(new Uint8Array(object), new Uint8Array(other))) {
2972
+ !equalFunc(new Uint8Array$1(object), new Uint8Array$1(other))) {
2973
2973
  return false;
2974
2974
  }
2975
2975
  return true;
@@ -11112,11 +11112,12 @@ var Popover = /* @__PURE__ */ _export_sfc(_sfc_main$f, [["__file", "index.vue"]]
11112
11112
 
11113
11113
  const PlusPopover = Popover;
11114
11114
 
11115
+ const _withScopeId = (n) => (pushScopeId("data-v-fe832672"), n = n(), popScopeId(), n);
11115
11116
  const _hoisted_1$8 = { class: "plus-table-title-bar" };
11116
11117
  const _hoisted_2$4 = { class: "plus-table-title-bar__title" };
11117
11118
  const _hoisted_3$2 = { class: "plus-table-title-bar__toolbar" };
11118
11119
  const _hoisted_4$2 = { class: "plus-table-title-bar__toolbar__density" };
11119
- const _hoisted_5$2 = /* @__PURE__ */ createElementVNode(
11120
+ const _hoisted_5$2 = /* @__PURE__ */ _withScopeId(() => /* @__PURE__ */ createElementVNode(
11120
11121
  "svg",
11121
11122
  {
11122
11123
  viewBox: "0 0 1024 1024",
@@ -11130,7 +11131,7 @@ const _hoisted_5$2 = /* @__PURE__ */ createElementVNode(
11130
11131
  ],
11131
11132
  -1
11132
11133
  /* HOISTED */
11133
- );
11134
+ ));
11134
11135
  const _hoisted_6$1 = { class: "plus-table-checkbox-checkAll" };
11135
11136
  const _hoisted_7$1 = {
11136
11137
  key: 0,
@@ -11296,10 +11297,10 @@ var _sfc_main$e = /* @__PURE__ */ defineComponent({
11296
11297
  1
11297
11298
  /* TEXT */
11298
11299
  )
11299
- ])
11300
+ ], true)
11300
11301
  ]),
11301
11302
  createElementVNode("div", _hoisted_3$2, [
11302
- renderSlot(_ctx.$slots, "toolbar"),
11303
+ renderSlot(_ctx.$slots, "toolbar", {}, void 0, true),
11303
11304
  ((_a = titleBarConfig.value) == null ? void 0 : _a.refresh) === true ? (openBlock(), createElementBlock("span", {
11304
11305
  key: 0,
11305
11306
  class: "plus-table-title-bar__toolbar__refresh",
@@ -11323,7 +11324,7 @@ var _sfc_main$e = /* @__PURE__ */ defineComponent({
11323
11324
  _: 1
11324
11325
  /* STABLE */
11325
11326
  }, 8, ["size", "color"])
11326
- ])
11327
+ ], true)
11327
11328
  ]),
11328
11329
  _: 3
11329
11330
  /* FORWARDED */
@@ -11356,7 +11357,7 @@ var _sfc_main$e = /* @__PURE__ */ defineComponent({
11356
11357
  _: 1
11357
11358
  /* STABLE */
11358
11359
  }, 8, ["size", "color"])
11359
- ])
11360
+ ], true)
11360
11361
  ]),
11361
11362
  _: 3
11362
11363
  /* FORWARDED */
@@ -11421,7 +11422,7 @@ var _sfc_main$e = /* @__PURE__ */ defineComponent({
11421
11422
  _: 1
11422
11423
  /* STABLE */
11423
11424
  }, 8, ["size", "color"])
11424
- ])
11425
+ ], true)
11425
11426
  ]),
11426
11427
  _: 3
11427
11428
  /* FORWARDED */
@@ -11492,7 +11493,7 @@ var _sfc_main$e = /* @__PURE__ */ defineComponent({
11492
11493
  ((_a3 = columnSetting.value) == null ? void 0 : _a3.dragSort) !== false ? (openBlock(), createElementBlock("div", _hoisted_7$1, [
11493
11494
  renderSlot(_ctx.$slots, "drag-sort-icon", {}, () => [
11494
11495
  createTextVNode("\u2637")
11495
- ])
11496
+ ], true)
11496
11497
  ])) : createCommentVNode("v-if", true),
11497
11498
  createCommentVNode(" element-plus \u7248\u672C\u53F7\u5C0F\u4E8E2.6.0 "),
11498
11499
  unref(versionIsLessThan260) ? (openBlock(), createBlock(unref(ElCheckbox), {
@@ -11590,7 +11591,2838 @@ var _sfc_main$e = /* @__PURE__ */ defineComponent({
11590
11591
  }
11591
11592
  });
11592
11593
 
11593
- var PlusTableTitleBar = /* @__PURE__ */ _export_sfc(_sfc_main$e, [["__file", "table-title-bar.vue"]]);
11594
+ var PlusTableTitleBar = /* @__PURE__ */ _export_sfc(_sfc_main$e, [["__scopeId", "data-v-fe832672"], ["__file", "table-title-bar.vue"]]);
11595
+
11596
+ var commonjsGlobal = typeof globalThis !== 'undefined' ? globalThis : typeof window !== 'undefined' ? window : typeof global !== 'undefined' ? global : typeof self !== 'undefined' ? self : {};
11597
+
11598
+ function getDefaultExportFromCjs (x) {
11599
+ return x && x.__esModule && Object.prototype.hasOwnProperty.call(x, 'default') ? x['default'] : x;
11600
+ }
11601
+
11602
+ function commonjsRequire(path) {
11603
+ throw new Error('Could not dynamically require "' + path + '". Please configure the dynamicRequireTargets or/and ignoreDynamicRequires option of @rollup/plugin-commonjs appropriately for this require call to work.');
11604
+ }
11605
+
11606
+ var localforage = {exports: {}};
11607
+
11608
+ /*!
11609
+ localForage -- Offline Storage, Improved
11610
+ Version 1.10.0
11611
+ https://localforage.github.io/localForage
11612
+ (c) 2013-2017 Mozilla, Apache License 2.0
11613
+ */
11614
+
11615
+ (function (module, exports) {
11616
+ (function(f){{module.exports=f();}})(function(){return (function e(t,n,r){function s(o,u){if(!n[o]){if(!t[o]){var a=typeof commonjsRequire=="function"&&commonjsRequire;if(!u&&a)return a(o,!0);if(i)return i(o,!0);var f=new Error("Cannot find module '"+o+"'");throw (f.code="MODULE_NOT_FOUND", f)}var l=n[o]={exports:{}};t[o][0].call(l.exports,function(e){var n=t[o][1][e];return s(n?n:e)},l,l.exports,e,t,n,r);}return n[o].exports}var i=typeof commonjsRequire=="function"&&commonjsRequire;for(var o=0;o<r.length;o++)s(r[o]);return s})({1:[function(_dereq_,module,exports){
11617
+ (function (global){
11618
+ var Mutation = global.MutationObserver || global.WebKitMutationObserver;
11619
+
11620
+ var scheduleDrain;
11621
+
11622
+ {
11623
+ if (Mutation) {
11624
+ var called = 0;
11625
+ var observer = new Mutation(nextTick);
11626
+ var element = global.document.createTextNode('');
11627
+ observer.observe(element, {
11628
+ characterData: true
11629
+ });
11630
+ scheduleDrain = function () {
11631
+ element.data = (called = ++called % 2);
11632
+ };
11633
+ } else if (!global.setImmediate && typeof global.MessageChannel !== 'undefined') {
11634
+ var channel = new global.MessageChannel();
11635
+ channel.port1.onmessage = nextTick;
11636
+ scheduleDrain = function () {
11637
+ channel.port2.postMessage(0);
11638
+ };
11639
+ } else if ('document' in global && 'onreadystatechange' in global.document.createElement('script')) {
11640
+ scheduleDrain = function () {
11641
+
11642
+ // Create a <script> element; its readystatechange event will be fired asynchronously once it is inserted
11643
+ // into the document. Do so, thus queuing up the task. Remember to clean up once it's been called.
11644
+ var scriptEl = global.document.createElement('script');
11645
+ scriptEl.onreadystatechange = function () {
11646
+ nextTick();
11647
+
11648
+ scriptEl.onreadystatechange = null;
11649
+ scriptEl.parentNode.removeChild(scriptEl);
11650
+ scriptEl = null;
11651
+ };
11652
+ global.document.documentElement.appendChild(scriptEl);
11653
+ };
11654
+ } else {
11655
+ scheduleDrain = function () {
11656
+ setTimeout(nextTick, 0);
11657
+ };
11658
+ }
11659
+ }
11660
+
11661
+ var draining;
11662
+ var queue = [];
11663
+ //named nextTick for less confusing stack traces
11664
+ function nextTick() {
11665
+ draining = true;
11666
+ var i, oldQueue;
11667
+ var len = queue.length;
11668
+ while (len) {
11669
+ oldQueue = queue;
11670
+ queue = [];
11671
+ i = -1;
11672
+ while (++i < len) {
11673
+ oldQueue[i]();
11674
+ }
11675
+ len = queue.length;
11676
+ }
11677
+ draining = false;
11678
+ }
11679
+
11680
+ module.exports = immediate;
11681
+ function immediate(task) {
11682
+ if (queue.push(task) === 1 && !draining) {
11683
+ scheduleDrain();
11684
+ }
11685
+ }
11686
+
11687
+ }).call(this,typeof commonjsGlobal !== "undefined" ? commonjsGlobal : typeof self !== "undefined" ? self : typeof window !== "undefined" ? window : {});
11688
+ },{}],2:[function(_dereq_,module,exports){
11689
+ var immediate = _dereq_(1);
11690
+
11691
+ /* istanbul ignore next */
11692
+ function INTERNAL() {}
11693
+
11694
+ var handlers = {};
11695
+
11696
+ var REJECTED = ['REJECTED'];
11697
+ var FULFILLED = ['FULFILLED'];
11698
+ var PENDING = ['PENDING'];
11699
+
11700
+ module.exports = Promise;
11701
+
11702
+ function Promise(resolver) {
11703
+ if (typeof resolver !== 'function') {
11704
+ throw new TypeError('resolver must be a function');
11705
+ }
11706
+ this.state = PENDING;
11707
+ this.queue = [];
11708
+ this.outcome = void 0;
11709
+ if (resolver !== INTERNAL) {
11710
+ safelyResolveThenable(this, resolver);
11711
+ }
11712
+ }
11713
+
11714
+ Promise.prototype["catch"] = function (onRejected) {
11715
+ return this.then(null, onRejected);
11716
+ };
11717
+ Promise.prototype.then = function (onFulfilled, onRejected) {
11718
+ if (typeof onFulfilled !== 'function' && this.state === FULFILLED ||
11719
+ typeof onRejected !== 'function' && this.state === REJECTED) {
11720
+ return this;
11721
+ }
11722
+ var promise = new this.constructor(INTERNAL);
11723
+ if (this.state !== PENDING) {
11724
+ var resolver = this.state === FULFILLED ? onFulfilled : onRejected;
11725
+ unwrap(promise, resolver, this.outcome);
11726
+ } else {
11727
+ this.queue.push(new QueueItem(promise, onFulfilled, onRejected));
11728
+ }
11729
+
11730
+ return promise;
11731
+ };
11732
+ function QueueItem(promise, onFulfilled, onRejected) {
11733
+ this.promise = promise;
11734
+ if (typeof onFulfilled === 'function') {
11735
+ this.onFulfilled = onFulfilled;
11736
+ this.callFulfilled = this.otherCallFulfilled;
11737
+ }
11738
+ if (typeof onRejected === 'function') {
11739
+ this.onRejected = onRejected;
11740
+ this.callRejected = this.otherCallRejected;
11741
+ }
11742
+ }
11743
+ QueueItem.prototype.callFulfilled = function (value) {
11744
+ handlers.resolve(this.promise, value);
11745
+ };
11746
+ QueueItem.prototype.otherCallFulfilled = function (value) {
11747
+ unwrap(this.promise, this.onFulfilled, value);
11748
+ };
11749
+ QueueItem.prototype.callRejected = function (value) {
11750
+ handlers.reject(this.promise, value);
11751
+ };
11752
+ QueueItem.prototype.otherCallRejected = function (value) {
11753
+ unwrap(this.promise, this.onRejected, value);
11754
+ };
11755
+
11756
+ function unwrap(promise, func, value) {
11757
+ immediate(function () {
11758
+ var returnValue;
11759
+ try {
11760
+ returnValue = func(value);
11761
+ } catch (e) {
11762
+ return handlers.reject(promise, e);
11763
+ }
11764
+ if (returnValue === promise) {
11765
+ handlers.reject(promise, new TypeError('Cannot resolve promise with itself'));
11766
+ } else {
11767
+ handlers.resolve(promise, returnValue);
11768
+ }
11769
+ });
11770
+ }
11771
+
11772
+ handlers.resolve = function (self, value) {
11773
+ var result = tryCatch(getThen, value);
11774
+ if (result.status === 'error') {
11775
+ return handlers.reject(self, result.value);
11776
+ }
11777
+ var thenable = result.value;
11778
+
11779
+ if (thenable) {
11780
+ safelyResolveThenable(self, thenable);
11781
+ } else {
11782
+ self.state = FULFILLED;
11783
+ self.outcome = value;
11784
+ var i = -1;
11785
+ var len = self.queue.length;
11786
+ while (++i < len) {
11787
+ self.queue[i].callFulfilled(value);
11788
+ }
11789
+ }
11790
+ return self;
11791
+ };
11792
+ handlers.reject = function (self, error) {
11793
+ self.state = REJECTED;
11794
+ self.outcome = error;
11795
+ var i = -1;
11796
+ var len = self.queue.length;
11797
+ while (++i < len) {
11798
+ self.queue[i].callRejected(error);
11799
+ }
11800
+ return self;
11801
+ };
11802
+
11803
+ function getThen(obj) {
11804
+ // Make sure we only access the accessor once as required by the spec
11805
+ var then = obj && obj.then;
11806
+ if (obj && (typeof obj === 'object' || typeof obj === 'function') && typeof then === 'function') {
11807
+ return function appyThen() {
11808
+ then.apply(obj, arguments);
11809
+ };
11810
+ }
11811
+ }
11812
+
11813
+ function safelyResolveThenable(self, thenable) {
11814
+ // Either fulfill, reject or reject with error
11815
+ var called = false;
11816
+ function onError(value) {
11817
+ if (called) {
11818
+ return;
11819
+ }
11820
+ called = true;
11821
+ handlers.reject(self, value);
11822
+ }
11823
+
11824
+ function onSuccess(value) {
11825
+ if (called) {
11826
+ return;
11827
+ }
11828
+ called = true;
11829
+ handlers.resolve(self, value);
11830
+ }
11831
+
11832
+ function tryToUnwrap() {
11833
+ thenable(onSuccess, onError);
11834
+ }
11835
+
11836
+ var result = tryCatch(tryToUnwrap);
11837
+ if (result.status === 'error') {
11838
+ onError(result.value);
11839
+ }
11840
+ }
11841
+
11842
+ function tryCatch(func, value) {
11843
+ var out = {};
11844
+ try {
11845
+ out.value = func(value);
11846
+ out.status = 'success';
11847
+ } catch (e) {
11848
+ out.status = 'error';
11849
+ out.value = e;
11850
+ }
11851
+ return out;
11852
+ }
11853
+
11854
+ Promise.resolve = resolve;
11855
+ function resolve(value) {
11856
+ if (value instanceof this) {
11857
+ return value;
11858
+ }
11859
+ return handlers.resolve(new this(INTERNAL), value);
11860
+ }
11861
+
11862
+ Promise.reject = reject;
11863
+ function reject(reason) {
11864
+ var promise = new this(INTERNAL);
11865
+ return handlers.reject(promise, reason);
11866
+ }
11867
+
11868
+ Promise.all = all;
11869
+ function all(iterable) {
11870
+ var self = this;
11871
+ if (Object.prototype.toString.call(iterable) !== '[object Array]') {
11872
+ return this.reject(new TypeError('must be an array'));
11873
+ }
11874
+
11875
+ var len = iterable.length;
11876
+ var called = false;
11877
+ if (!len) {
11878
+ return this.resolve([]);
11879
+ }
11880
+
11881
+ var values = new Array(len);
11882
+ var resolved = 0;
11883
+ var i = -1;
11884
+ var promise = new this(INTERNAL);
11885
+
11886
+ while (++i < len) {
11887
+ allResolver(iterable[i], i);
11888
+ }
11889
+ return promise;
11890
+ function allResolver(value, i) {
11891
+ self.resolve(value).then(resolveFromAll, function (error) {
11892
+ if (!called) {
11893
+ called = true;
11894
+ handlers.reject(promise, error);
11895
+ }
11896
+ });
11897
+ function resolveFromAll(outValue) {
11898
+ values[i] = outValue;
11899
+ if (++resolved === len && !called) {
11900
+ called = true;
11901
+ handlers.resolve(promise, values);
11902
+ }
11903
+ }
11904
+ }
11905
+ }
11906
+
11907
+ Promise.race = race;
11908
+ function race(iterable) {
11909
+ var self = this;
11910
+ if (Object.prototype.toString.call(iterable) !== '[object Array]') {
11911
+ return this.reject(new TypeError('must be an array'));
11912
+ }
11913
+
11914
+ var len = iterable.length;
11915
+ var called = false;
11916
+ if (!len) {
11917
+ return this.resolve([]);
11918
+ }
11919
+
11920
+ var i = -1;
11921
+ var promise = new this(INTERNAL);
11922
+
11923
+ while (++i < len) {
11924
+ resolver(iterable[i]);
11925
+ }
11926
+ return promise;
11927
+ function resolver(value) {
11928
+ self.resolve(value).then(function (response) {
11929
+ if (!called) {
11930
+ called = true;
11931
+ handlers.resolve(promise, response);
11932
+ }
11933
+ }, function (error) {
11934
+ if (!called) {
11935
+ called = true;
11936
+ handlers.reject(promise, error);
11937
+ }
11938
+ });
11939
+ }
11940
+ }
11941
+
11942
+ },{"1":1}],3:[function(_dereq_,module,exports){
11943
+ (function (global){
11944
+ if (typeof global.Promise !== 'function') {
11945
+ global.Promise = _dereq_(2);
11946
+ }
11947
+
11948
+ }).call(this,typeof commonjsGlobal !== "undefined" ? commonjsGlobal : typeof self !== "undefined" ? self : typeof window !== "undefined" ? window : {});
11949
+ },{"2":2}],4:[function(_dereq_,module,exports){
11950
+
11951
+ var _typeof = typeof Symbol === "function" && typeof Symbol.iterator === "symbol" ? function (obj) { return typeof obj; } : function (obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; };
11952
+
11953
+ function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
11954
+
11955
+ function getIDB() {
11956
+ /* global indexedDB,webkitIndexedDB,mozIndexedDB,OIndexedDB,msIndexedDB */
11957
+ try {
11958
+ if (typeof indexedDB !== 'undefined') {
11959
+ return indexedDB;
11960
+ }
11961
+ if (typeof webkitIndexedDB !== 'undefined') {
11962
+ return webkitIndexedDB;
11963
+ }
11964
+ if (typeof mozIndexedDB !== 'undefined') {
11965
+ return mozIndexedDB;
11966
+ }
11967
+ if (typeof OIndexedDB !== 'undefined') {
11968
+ return OIndexedDB;
11969
+ }
11970
+ if (typeof msIndexedDB !== 'undefined') {
11971
+ return msIndexedDB;
11972
+ }
11973
+ } catch (e) {
11974
+ return;
11975
+ }
11976
+ }
11977
+
11978
+ var idb = getIDB();
11979
+
11980
+ function isIndexedDBValid() {
11981
+ try {
11982
+ // Initialize IndexedDB; fall back to vendor-prefixed versions
11983
+ // if needed.
11984
+ if (!idb || !idb.open) {
11985
+ return false;
11986
+ }
11987
+ // We mimic PouchDB here;
11988
+ //
11989
+ // We test for openDatabase because IE Mobile identifies itself
11990
+ // as Safari. Oh the lulz...
11991
+ var isSafari = typeof openDatabase !== 'undefined' && /(Safari|iPhone|iPad|iPod)/.test(navigator.userAgent) && !/Chrome/.test(navigator.userAgent) && !/BlackBerry/.test(navigator.platform);
11992
+
11993
+ var hasFetch = typeof fetch === 'function' && fetch.toString().indexOf('[native code') !== -1;
11994
+
11995
+ // Safari <10.1 does not meet our requirements for IDB support
11996
+ // (see: https://github.com/pouchdb/pouchdb/issues/5572).
11997
+ // Safari 10.1 shipped with fetch, we can use that to detect it.
11998
+ // Note: this creates issues with `window.fetch` polyfills and
11999
+ // overrides; see:
12000
+ // https://github.com/localForage/localForage/issues/856
12001
+ return (!isSafari || hasFetch) && typeof indexedDB !== 'undefined' &&
12002
+ // some outdated implementations of IDB that appear on Samsung
12003
+ // and HTC Android devices <4.4 are missing IDBKeyRange
12004
+ // See: https://github.com/mozilla/localForage/issues/128
12005
+ // See: https://github.com/mozilla/localForage/issues/272
12006
+ typeof IDBKeyRange !== 'undefined';
12007
+ } catch (e) {
12008
+ return false;
12009
+ }
12010
+ }
12011
+
12012
+ // Abstracts constructing a Blob object, so it also works in older
12013
+ // browsers that don't support the native Blob constructor. (i.e.
12014
+ // old QtWebKit versions, at least).
12015
+ // Abstracts constructing a Blob object, so it also works in older
12016
+ // browsers that don't support the native Blob constructor. (i.e.
12017
+ // old QtWebKit versions, at least).
12018
+ function createBlob(parts, properties) {
12019
+ /* global BlobBuilder,MSBlobBuilder,MozBlobBuilder,WebKitBlobBuilder */
12020
+ parts = parts || [];
12021
+ properties = properties || {};
12022
+ try {
12023
+ return new Blob(parts, properties);
12024
+ } catch (e) {
12025
+ if (e.name !== 'TypeError') {
12026
+ throw e;
12027
+ }
12028
+ var Builder = typeof BlobBuilder !== 'undefined' ? BlobBuilder : typeof MSBlobBuilder !== 'undefined' ? MSBlobBuilder : typeof MozBlobBuilder !== 'undefined' ? MozBlobBuilder : WebKitBlobBuilder;
12029
+ var builder = new Builder();
12030
+ for (var i = 0; i < parts.length; i += 1) {
12031
+ builder.append(parts[i]);
12032
+ }
12033
+ return builder.getBlob(properties.type);
12034
+ }
12035
+ }
12036
+
12037
+ // This is CommonJS because lie is an external dependency, so Rollup
12038
+ // can just ignore it.
12039
+ if (typeof Promise === 'undefined') {
12040
+ // In the "nopromises" build this will just throw if you don't have
12041
+ // a global promise object, but it would throw anyway later.
12042
+ _dereq_(3);
12043
+ }
12044
+ var Promise$1 = Promise;
12045
+
12046
+ function executeCallback(promise, callback) {
12047
+ if (callback) {
12048
+ promise.then(function (result) {
12049
+ callback(null, result);
12050
+ }, function (error) {
12051
+ callback(error);
12052
+ });
12053
+ }
12054
+ }
12055
+
12056
+ function executeTwoCallbacks(promise, callback, errorCallback) {
12057
+ if (typeof callback === 'function') {
12058
+ promise.then(callback);
12059
+ }
12060
+
12061
+ if (typeof errorCallback === 'function') {
12062
+ promise["catch"](errorCallback);
12063
+ }
12064
+ }
12065
+
12066
+ function normalizeKey(key) {
12067
+ // Cast the key to a string, as that's all we can set as a key.
12068
+ if (typeof key !== 'string') {
12069
+ console.warn(key + ' used as a key, but it is not a string.');
12070
+ key = String(key);
12071
+ }
12072
+
12073
+ return key;
12074
+ }
12075
+
12076
+ function getCallback() {
12077
+ if (arguments.length && typeof arguments[arguments.length - 1] === 'function') {
12078
+ return arguments[arguments.length - 1];
12079
+ }
12080
+ }
12081
+
12082
+ // Some code originally from async_storage.js in
12083
+ // [Gaia](https://github.com/mozilla-b2g/gaia).
12084
+
12085
+ var DETECT_BLOB_SUPPORT_STORE = 'local-forage-detect-blob-support';
12086
+ var supportsBlobs = void 0;
12087
+ var dbContexts = {};
12088
+ var toString = Object.prototype.toString;
12089
+
12090
+ // Transaction Modes
12091
+ var READ_ONLY = 'readonly';
12092
+ var READ_WRITE = 'readwrite';
12093
+
12094
+ // Transform a binary string to an array buffer, because otherwise
12095
+ // weird stuff happens when you try to work with the binary string directly.
12096
+ // It is known.
12097
+ // From http://stackoverflow.com/questions/14967647/ (continues on next line)
12098
+ // encode-decode-image-with-base64-breaks-image (2013-04-21)
12099
+ function _binStringToArrayBuffer(bin) {
12100
+ var length = bin.length;
12101
+ var buf = new ArrayBuffer(length);
12102
+ var arr = new Uint8Array(buf);
12103
+ for (var i = 0; i < length; i++) {
12104
+ arr[i] = bin.charCodeAt(i);
12105
+ }
12106
+ return buf;
12107
+ }
12108
+
12109
+ //
12110
+ // Blobs are not supported in all versions of IndexedDB, notably
12111
+ // Chrome <37 and Android <5. In those versions, storing a blob will throw.
12112
+ //
12113
+ // Various other blob bugs exist in Chrome v37-42 (inclusive).
12114
+ // Detecting them is expensive and confusing to users, and Chrome 37-42
12115
+ // is at very low usage worldwide, so we do a hacky userAgent check instead.
12116
+ //
12117
+ // content-type bug: https://code.google.com/p/chromium/issues/detail?id=408120
12118
+ // 404 bug: https://code.google.com/p/chromium/issues/detail?id=447916
12119
+ // FileReader bug: https://code.google.com/p/chromium/issues/detail?id=447836
12120
+ //
12121
+ // Code borrowed from PouchDB. See:
12122
+ // https://github.com/pouchdb/pouchdb/blob/master/packages/node_modules/pouchdb-adapter-idb/src/blobSupport.js
12123
+ //
12124
+ function _checkBlobSupportWithoutCaching(idb) {
12125
+ return new Promise$1(function (resolve) {
12126
+ var txn = idb.transaction(DETECT_BLOB_SUPPORT_STORE, READ_WRITE);
12127
+ var blob = createBlob(['']);
12128
+ txn.objectStore(DETECT_BLOB_SUPPORT_STORE).put(blob, 'key');
12129
+
12130
+ txn.onabort = function (e) {
12131
+ // If the transaction aborts now its due to not being able to
12132
+ // write to the database, likely due to the disk being full
12133
+ e.preventDefault();
12134
+ e.stopPropagation();
12135
+ resolve(false);
12136
+ };
12137
+
12138
+ txn.oncomplete = function () {
12139
+ var matchedChrome = navigator.userAgent.match(/Chrome\/(\d+)/);
12140
+ var matchedEdge = navigator.userAgent.match(/Edge\//);
12141
+ // MS Edge pretends to be Chrome 42:
12142
+ // https://msdn.microsoft.com/en-us/library/hh869301%28v=vs.85%29.aspx
12143
+ resolve(matchedEdge || !matchedChrome || parseInt(matchedChrome[1], 10) >= 43);
12144
+ };
12145
+ })["catch"](function () {
12146
+ return false; // error, so assume unsupported
12147
+ });
12148
+ }
12149
+
12150
+ function _checkBlobSupport(idb) {
12151
+ if (typeof supportsBlobs === 'boolean') {
12152
+ return Promise$1.resolve(supportsBlobs);
12153
+ }
12154
+ return _checkBlobSupportWithoutCaching(idb).then(function (value) {
12155
+ supportsBlobs = value;
12156
+ return supportsBlobs;
12157
+ });
12158
+ }
12159
+
12160
+ function _deferReadiness(dbInfo) {
12161
+ var dbContext = dbContexts[dbInfo.name];
12162
+
12163
+ // Create a deferred object representing the current database operation.
12164
+ var deferredOperation = {};
12165
+
12166
+ deferredOperation.promise = new Promise$1(function (resolve, reject) {
12167
+ deferredOperation.resolve = resolve;
12168
+ deferredOperation.reject = reject;
12169
+ });
12170
+
12171
+ // Enqueue the deferred operation.
12172
+ dbContext.deferredOperations.push(deferredOperation);
12173
+
12174
+ // Chain its promise to the database readiness.
12175
+ if (!dbContext.dbReady) {
12176
+ dbContext.dbReady = deferredOperation.promise;
12177
+ } else {
12178
+ dbContext.dbReady = dbContext.dbReady.then(function () {
12179
+ return deferredOperation.promise;
12180
+ });
12181
+ }
12182
+ }
12183
+
12184
+ function _advanceReadiness(dbInfo) {
12185
+ var dbContext = dbContexts[dbInfo.name];
12186
+
12187
+ // Dequeue a deferred operation.
12188
+ var deferredOperation = dbContext.deferredOperations.pop();
12189
+
12190
+ // Resolve its promise (which is part of the database readiness
12191
+ // chain of promises).
12192
+ if (deferredOperation) {
12193
+ deferredOperation.resolve();
12194
+ return deferredOperation.promise;
12195
+ }
12196
+ }
12197
+
12198
+ function _rejectReadiness(dbInfo, err) {
12199
+ var dbContext = dbContexts[dbInfo.name];
12200
+
12201
+ // Dequeue a deferred operation.
12202
+ var deferredOperation = dbContext.deferredOperations.pop();
12203
+
12204
+ // Reject its promise (which is part of the database readiness
12205
+ // chain of promises).
12206
+ if (deferredOperation) {
12207
+ deferredOperation.reject(err);
12208
+ return deferredOperation.promise;
12209
+ }
12210
+ }
12211
+
12212
+ function _getConnection(dbInfo, upgradeNeeded) {
12213
+ return new Promise$1(function (resolve, reject) {
12214
+ dbContexts[dbInfo.name] = dbContexts[dbInfo.name] || createDbContext();
12215
+
12216
+ if (dbInfo.db) {
12217
+ if (upgradeNeeded) {
12218
+ _deferReadiness(dbInfo);
12219
+ dbInfo.db.close();
12220
+ } else {
12221
+ return resolve(dbInfo.db);
12222
+ }
12223
+ }
12224
+
12225
+ var dbArgs = [dbInfo.name];
12226
+
12227
+ if (upgradeNeeded) {
12228
+ dbArgs.push(dbInfo.version);
12229
+ }
12230
+
12231
+ var openreq = idb.open.apply(idb, dbArgs);
12232
+
12233
+ if (upgradeNeeded) {
12234
+ openreq.onupgradeneeded = function (e) {
12235
+ var db = openreq.result;
12236
+ try {
12237
+ db.createObjectStore(dbInfo.storeName);
12238
+ if (e.oldVersion <= 1) {
12239
+ // Added when support for blob shims was added
12240
+ db.createObjectStore(DETECT_BLOB_SUPPORT_STORE);
12241
+ }
12242
+ } catch (ex) {
12243
+ if (ex.name === 'ConstraintError') {
12244
+ console.warn('The database "' + dbInfo.name + '"' + ' has been upgraded from version ' + e.oldVersion + ' to version ' + e.newVersion + ', but the storage "' + dbInfo.storeName + '" already exists.');
12245
+ } else {
12246
+ throw ex;
12247
+ }
12248
+ }
12249
+ };
12250
+ }
12251
+
12252
+ openreq.onerror = function (e) {
12253
+ e.preventDefault();
12254
+ reject(openreq.error);
12255
+ };
12256
+
12257
+ openreq.onsuccess = function () {
12258
+ var db = openreq.result;
12259
+ db.onversionchange = function (e) {
12260
+ // Triggered when the database is modified (e.g. adding an objectStore) or
12261
+ // deleted (even when initiated by other sessions in different tabs).
12262
+ // Closing the connection here prevents those operations from being blocked.
12263
+ // If the database is accessed again later by this instance, the connection
12264
+ // will be reopened or the database recreated as needed.
12265
+ e.target.close();
12266
+ };
12267
+ resolve(db);
12268
+ _advanceReadiness(dbInfo);
12269
+ };
12270
+ });
12271
+ }
12272
+
12273
+ function _getOriginalConnection(dbInfo) {
12274
+ return _getConnection(dbInfo, false);
12275
+ }
12276
+
12277
+ function _getUpgradedConnection(dbInfo) {
12278
+ return _getConnection(dbInfo, true);
12279
+ }
12280
+
12281
+ function _isUpgradeNeeded(dbInfo, defaultVersion) {
12282
+ if (!dbInfo.db) {
12283
+ return true;
12284
+ }
12285
+
12286
+ var isNewStore = !dbInfo.db.objectStoreNames.contains(dbInfo.storeName);
12287
+ var isDowngrade = dbInfo.version < dbInfo.db.version;
12288
+ var isUpgrade = dbInfo.version > dbInfo.db.version;
12289
+
12290
+ if (isDowngrade) {
12291
+ // If the version is not the default one
12292
+ // then warn for impossible downgrade.
12293
+ if (dbInfo.version !== defaultVersion) {
12294
+ console.warn('The database "' + dbInfo.name + '"' + " can't be downgraded from version " + dbInfo.db.version + ' to version ' + dbInfo.version + '.');
12295
+ }
12296
+ // Align the versions to prevent errors.
12297
+ dbInfo.version = dbInfo.db.version;
12298
+ }
12299
+
12300
+ if (isUpgrade || isNewStore) {
12301
+ // If the store is new then increment the version (if needed).
12302
+ // This will trigger an "upgradeneeded" event which is required
12303
+ // for creating a store.
12304
+ if (isNewStore) {
12305
+ var incVersion = dbInfo.db.version + 1;
12306
+ if (incVersion > dbInfo.version) {
12307
+ dbInfo.version = incVersion;
12308
+ }
12309
+ }
12310
+
12311
+ return true;
12312
+ }
12313
+
12314
+ return false;
12315
+ }
12316
+
12317
+ // encode a blob for indexeddb engines that don't support blobs
12318
+ function _encodeBlob(blob) {
12319
+ return new Promise$1(function (resolve, reject) {
12320
+ var reader = new FileReader();
12321
+ reader.onerror = reject;
12322
+ reader.onloadend = function (e) {
12323
+ var base64 = btoa(e.target.result || '');
12324
+ resolve({
12325
+ __local_forage_encoded_blob: true,
12326
+ data: base64,
12327
+ type: blob.type
12328
+ });
12329
+ };
12330
+ reader.readAsBinaryString(blob);
12331
+ });
12332
+ }
12333
+
12334
+ // decode an encoded blob
12335
+ function _decodeBlob(encodedBlob) {
12336
+ var arrayBuff = _binStringToArrayBuffer(atob(encodedBlob.data));
12337
+ return createBlob([arrayBuff], { type: encodedBlob.type });
12338
+ }
12339
+
12340
+ // is this one of our fancy encoded blobs?
12341
+ function _isEncodedBlob(value) {
12342
+ return value && value.__local_forage_encoded_blob;
12343
+ }
12344
+
12345
+ // Specialize the default `ready()` function by making it dependent
12346
+ // on the current database operations. Thus, the driver will be actually
12347
+ // ready when it's been initialized (default) *and* there are no pending
12348
+ // operations on the database (initiated by some other instances).
12349
+ function _fullyReady(callback) {
12350
+ var self = this;
12351
+
12352
+ var promise = self._initReady().then(function () {
12353
+ var dbContext = dbContexts[self._dbInfo.name];
12354
+
12355
+ if (dbContext && dbContext.dbReady) {
12356
+ return dbContext.dbReady;
12357
+ }
12358
+ });
12359
+
12360
+ executeTwoCallbacks(promise, callback, callback);
12361
+ return promise;
12362
+ }
12363
+
12364
+ // Try to establish a new db connection to replace the
12365
+ // current one which is broken (i.e. experiencing
12366
+ // InvalidStateError while creating a transaction).
12367
+ function _tryReconnect(dbInfo) {
12368
+ _deferReadiness(dbInfo);
12369
+
12370
+ var dbContext = dbContexts[dbInfo.name];
12371
+ var forages = dbContext.forages;
12372
+
12373
+ for (var i = 0; i < forages.length; i++) {
12374
+ var forage = forages[i];
12375
+ if (forage._dbInfo.db) {
12376
+ forage._dbInfo.db.close();
12377
+ forage._dbInfo.db = null;
12378
+ }
12379
+ }
12380
+ dbInfo.db = null;
12381
+
12382
+ return _getOriginalConnection(dbInfo).then(function (db) {
12383
+ dbInfo.db = db;
12384
+ if (_isUpgradeNeeded(dbInfo)) {
12385
+ // Reopen the database for upgrading.
12386
+ return _getUpgradedConnection(dbInfo);
12387
+ }
12388
+ return db;
12389
+ }).then(function (db) {
12390
+ // store the latest db reference
12391
+ // in case the db was upgraded
12392
+ dbInfo.db = dbContext.db = db;
12393
+ for (var i = 0; i < forages.length; i++) {
12394
+ forages[i]._dbInfo.db = db;
12395
+ }
12396
+ })["catch"](function (err) {
12397
+ _rejectReadiness(dbInfo, err);
12398
+ throw err;
12399
+ });
12400
+ }
12401
+
12402
+ // FF doesn't like Promises (micro-tasks) and IDDB store operations,
12403
+ // so we have to do it with callbacks
12404
+ function createTransaction(dbInfo, mode, callback, retries) {
12405
+ if (retries === undefined) {
12406
+ retries = 1;
12407
+ }
12408
+
12409
+ try {
12410
+ var tx = dbInfo.db.transaction(dbInfo.storeName, mode);
12411
+ callback(null, tx);
12412
+ } catch (err) {
12413
+ if (retries > 0 && (!dbInfo.db || err.name === 'InvalidStateError' || err.name === 'NotFoundError')) {
12414
+ return Promise$1.resolve().then(function () {
12415
+ if (!dbInfo.db || err.name === 'NotFoundError' && !dbInfo.db.objectStoreNames.contains(dbInfo.storeName) && dbInfo.version <= dbInfo.db.version) {
12416
+ // increase the db version, to create the new ObjectStore
12417
+ if (dbInfo.db) {
12418
+ dbInfo.version = dbInfo.db.version + 1;
12419
+ }
12420
+ // Reopen the database for upgrading.
12421
+ return _getUpgradedConnection(dbInfo);
12422
+ }
12423
+ }).then(function () {
12424
+ return _tryReconnect(dbInfo).then(function () {
12425
+ createTransaction(dbInfo, mode, callback, retries - 1);
12426
+ });
12427
+ })["catch"](callback);
12428
+ }
12429
+
12430
+ callback(err);
12431
+ }
12432
+ }
12433
+
12434
+ function createDbContext() {
12435
+ return {
12436
+ // Running localForages sharing a database.
12437
+ forages: [],
12438
+ // Shared database.
12439
+ db: null,
12440
+ // Database readiness (promise).
12441
+ dbReady: null,
12442
+ // Deferred operations on the database.
12443
+ deferredOperations: []
12444
+ };
12445
+ }
12446
+
12447
+ // Open the IndexedDB database (automatically creates one if one didn't
12448
+ // previously exist), using any options set in the config.
12449
+ function _initStorage(options) {
12450
+ var self = this;
12451
+ var dbInfo = {
12452
+ db: null
12453
+ };
12454
+
12455
+ if (options) {
12456
+ for (var i in options) {
12457
+ dbInfo[i] = options[i];
12458
+ }
12459
+ }
12460
+
12461
+ // Get the current context of the database;
12462
+ var dbContext = dbContexts[dbInfo.name];
12463
+
12464
+ // ...or create a new context.
12465
+ if (!dbContext) {
12466
+ dbContext = createDbContext();
12467
+ // Register the new context in the global container.
12468
+ dbContexts[dbInfo.name] = dbContext;
12469
+ }
12470
+
12471
+ // Register itself as a running localForage in the current context.
12472
+ dbContext.forages.push(self);
12473
+
12474
+ // Replace the default `ready()` function with the specialized one.
12475
+ if (!self._initReady) {
12476
+ self._initReady = self.ready;
12477
+ self.ready = _fullyReady;
12478
+ }
12479
+
12480
+ // Create an array of initialization states of the related localForages.
12481
+ var initPromises = [];
12482
+
12483
+ function ignoreErrors() {
12484
+ // Don't handle errors here,
12485
+ // just makes sure related localForages aren't pending.
12486
+ return Promise$1.resolve();
12487
+ }
12488
+
12489
+ for (var j = 0; j < dbContext.forages.length; j++) {
12490
+ var forage = dbContext.forages[j];
12491
+ if (forage !== self) {
12492
+ // Don't wait for itself...
12493
+ initPromises.push(forage._initReady()["catch"](ignoreErrors));
12494
+ }
12495
+ }
12496
+
12497
+ // Take a snapshot of the related localForages.
12498
+ var forages = dbContext.forages.slice(0);
12499
+
12500
+ // Initialize the connection process only when
12501
+ // all the related localForages aren't pending.
12502
+ return Promise$1.all(initPromises).then(function () {
12503
+ dbInfo.db = dbContext.db;
12504
+ // Get the connection or open a new one without upgrade.
12505
+ return _getOriginalConnection(dbInfo);
12506
+ }).then(function (db) {
12507
+ dbInfo.db = db;
12508
+ if (_isUpgradeNeeded(dbInfo, self._defaultConfig.version)) {
12509
+ // Reopen the database for upgrading.
12510
+ return _getUpgradedConnection(dbInfo);
12511
+ }
12512
+ return db;
12513
+ }).then(function (db) {
12514
+ dbInfo.db = dbContext.db = db;
12515
+ self._dbInfo = dbInfo;
12516
+ // Share the final connection amongst related localForages.
12517
+ for (var k = 0; k < forages.length; k++) {
12518
+ var forage = forages[k];
12519
+ if (forage !== self) {
12520
+ // Self is already up-to-date.
12521
+ forage._dbInfo.db = dbInfo.db;
12522
+ forage._dbInfo.version = dbInfo.version;
12523
+ }
12524
+ }
12525
+ });
12526
+ }
12527
+
12528
+ function getItem(key, callback) {
12529
+ var self = this;
12530
+
12531
+ key = normalizeKey(key);
12532
+
12533
+ var promise = new Promise$1(function (resolve, reject) {
12534
+ self.ready().then(function () {
12535
+ createTransaction(self._dbInfo, READ_ONLY, function (err, transaction) {
12536
+ if (err) {
12537
+ return reject(err);
12538
+ }
12539
+
12540
+ try {
12541
+ var store = transaction.objectStore(self._dbInfo.storeName);
12542
+ var req = store.get(key);
12543
+
12544
+ req.onsuccess = function () {
12545
+ var value = req.result;
12546
+ if (value === undefined) {
12547
+ value = null;
12548
+ }
12549
+ if (_isEncodedBlob(value)) {
12550
+ value = _decodeBlob(value);
12551
+ }
12552
+ resolve(value);
12553
+ };
12554
+
12555
+ req.onerror = function () {
12556
+ reject(req.error);
12557
+ };
12558
+ } catch (e) {
12559
+ reject(e);
12560
+ }
12561
+ });
12562
+ })["catch"](reject);
12563
+ });
12564
+
12565
+ executeCallback(promise, callback);
12566
+ return promise;
12567
+ }
12568
+
12569
+ // Iterate over all items stored in database.
12570
+ function iterate(iterator, callback) {
12571
+ var self = this;
12572
+
12573
+ var promise = new Promise$1(function (resolve, reject) {
12574
+ self.ready().then(function () {
12575
+ createTransaction(self._dbInfo, READ_ONLY, function (err, transaction) {
12576
+ if (err) {
12577
+ return reject(err);
12578
+ }
12579
+
12580
+ try {
12581
+ var store = transaction.objectStore(self._dbInfo.storeName);
12582
+ var req = store.openCursor();
12583
+ var iterationNumber = 1;
12584
+
12585
+ req.onsuccess = function () {
12586
+ var cursor = req.result;
12587
+
12588
+ if (cursor) {
12589
+ var value = cursor.value;
12590
+ if (_isEncodedBlob(value)) {
12591
+ value = _decodeBlob(value);
12592
+ }
12593
+ var result = iterator(value, cursor.key, iterationNumber++);
12594
+
12595
+ // when the iterator callback returns any
12596
+ // (non-`undefined`) value, then we stop
12597
+ // the iteration immediately
12598
+ if (result !== void 0) {
12599
+ resolve(result);
12600
+ } else {
12601
+ cursor["continue"]();
12602
+ }
12603
+ } else {
12604
+ resolve();
12605
+ }
12606
+ };
12607
+
12608
+ req.onerror = function () {
12609
+ reject(req.error);
12610
+ };
12611
+ } catch (e) {
12612
+ reject(e);
12613
+ }
12614
+ });
12615
+ })["catch"](reject);
12616
+ });
12617
+
12618
+ executeCallback(promise, callback);
12619
+
12620
+ return promise;
12621
+ }
12622
+
12623
+ function setItem(key, value, callback) {
12624
+ var self = this;
12625
+
12626
+ key = normalizeKey(key);
12627
+
12628
+ var promise = new Promise$1(function (resolve, reject) {
12629
+ var dbInfo;
12630
+ self.ready().then(function () {
12631
+ dbInfo = self._dbInfo;
12632
+ if (toString.call(value) === '[object Blob]') {
12633
+ return _checkBlobSupport(dbInfo.db).then(function (blobSupport) {
12634
+ if (blobSupport) {
12635
+ return value;
12636
+ }
12637
+ return _encodeBlob(value);
12638
+ });
12639
+ }
12640
+ return value;
12641
+ }).then(function (value) {
12642
+ createTransaction(self._dbInfo, READ_WRITE, function (err, transaction) {
12643
+ if (err) {
12644
+ return reject(err);
12645
+ }
12646
+
12647
+ try {
12648
+ var store = transaction.objectStore(self._dbInfo.storeName);
12649
+
12650
+ // The reason we don't _save_ null is because IE 10 does
12651
+ // not support saving the `null` type in IndexedDB. How
12652
+ // ironic, given the bug below!
12653
+ // See: https://github.com/mozilla/localForage/issues/161
12654
+ if (value === null) {
12655
+ value = undefined;
12656
+ }
12657
+
12658
+ var req = store.put(value, key);
12659
+
12660
+ transaction.oncomplete = function () {
12661
+ // Cast to undefined so the value passed to
12662
+ // callback/promise is the same as what one would get out
12663
+ // of `getItem()` later. This leads to some weirdness
12664
+ // (setItem('foo', undefined) will return `null`), but
12665
+ // it's not my fault localStorage is our baseline and that
12666
+ // it's weird.
12667
+ if (value === undefined) {
12668
+ value = null;
12669
+ }
12670
+
12671
+ resolve(value);
12672
+ };
12673
+ transaction.onabort = transaction.onerror = function () {
12674
+ var err = req.error ? req.error : req.transaction.error;
12675
+ reject(err);
12676
+ };
12677
+ } catch (e) {
12678
+ reject(e);
12679
+ }
12680
+ });
12681
+ })["catch"](reject);
12682
+ });
12683
+
12684
+ executeCallback(promise, callback);
12685
+ return promise;
12686
+ }
12687
+
12688
+ function removeItem(key, callback) {
12689
+ var self = this;
12690
+
12691
+ key = normalizeKey(key);
12692
+
12693
+ var promise = new Promise$1(function (resolve, reject) {
12694
+ self.ready().then(function () {
12695
+ createTransaction(self._dbInfo, READ_WRITE, function (err, transaction) {
12696
+ if (err) {
12697
+ return reject(err);
12698
+ }
12699
+
12700
+ try {
12701
+ var store = transaction.objectStore(self._dbInfo.storeName);
12702
+ // We use a Grunt task to make this safe for IE and some
12703
+ // versions of Android (including those used by Cordova).
12704
+ // Normally IE won't like `.delete()` and will insist on
12705
+ // using `['delete']()`, but we have a build step that
12706
+ // fixes this for us now.
12707
+ var req = store["delete"](key);
12708
+ transaction.oncomplete = function () {
12709
+ resolve();
12710
+ };
12711
+
12712
+ transaction.onerror = function () {
12713
+ reject(req.error);
12714
+ };
12715
+
12716
+ // The request will be also be aborted if we've exceeded our storage
12717
+ // space.
12718
+ transaction.onabort = function () {
12719
+ var err = req.error ? req.error : req.transaction.error;
12720
+ reject(err);
12721
+ };
12722
+ } catch (e) {
12723
+ reject(e);
12724
+ }
12725
+ });
12726
+ })["catch"](reject);
12727
+ });
12728
+
12729
+ executeCallback(promise, callback);
12730
+ return promise;
12731
+ }
12732
+
12733
+ function clear(callback) {
12734
+ var self = this;
12735
+
12736
+ var promise = new Promise$1(function (resolve, reject) {
12737
+ self.ready().then(function () {
12738
+ createTransaction(self._dbInfo, READ_WRITE, function (err, transaction) {
12739
+ if (err) {
12740
+ return reject(err);
12741
+ }
12742
+
12743
+ try {
12744
+ var store = transaction.objectStore(self._dbInfo.storeName);
12745
+ var req = store.clear();
12746
+
12747
+ transaction.oncomplete = function () {
12748
+ resolve();
12749
+ };
12750
+
12751
+ transaction.onabort = transaction.onerror = function () {
12752
+ var err = req.error ? req.error : req.transaction.error;
12753
+ reject(err);
12754
+ };
12755
+ } catch (e) {
12756
+ reject(e);
12757
+ }
12758
+ });
12759
+ })["catch"](reject);
12760
+ });
12761
+
12762
+ executeCallback(promise, callback);
12763
+ return promise;
12764
+ }
12765
+
12766
+ function length(callback) {
12767
+ var self = this;
12768
+
12769
+ var promise = new Promise$1(function (resolve, reject) {
12770
+ self.ready().then(function () {
12771
+ createTransaction(self._dbInfo, READ_ONLY, function (err, transaction) {
12772
+ if (err) {
12773
+ return reject(err);
12774
+ }
12775
+
12776
+ try {
12777
+ var store = transaction.objectStore(self._dbInfo.storeName);
12778
+ var req = store.count();
12779
+
12780
+ req.onsuccess = function () {
12781
+ resolve(req.result);
12782
+ };
12783
+
12784
+ req.onerror = function () {
12785
+ reject(req.error);
12786
+ };
12787
+ } catch (e) {
12788
+ reject(e);
12789
+ }
12790
+ });
12791
+ })["catch"](reject);
12792
+ });
12793
+
12794
+ executeCallback(promise, callback);
12795
+ return promise;
12796
+ }
12797
+
12798
+ function key(n, callback) {
12799
+ var self = this;
12800
+
12801
+ var promise = new Promise$1(function (resolve, reject) {
12802
+ if (n < 0) {
12803
+ resolve(null);
12804
+
12805
+ return;
12806
+ }
12807
+
12808
+ self.ready().then(function () {
12809
+ createTransaction(self._dbInfo, READ_ONLY, function (err, transaction) {
12810
+ if (err) {
12811
+ return reject(err);
12812
+ }
12813
+
12814
+ try {
12815
+ var store = transaction.objectStore(self._dbInfo.storeName);
12816
+ var advanced = false;
12817
+ var req = store.openKeyCursor();
12818
+
12819
+ req.onsuccess = function () {
12820
+ var cursor = req.result;
12821
+ if (!cursor) {
12822
+ // this means there weren't enough keys
12823
+ resolve(null);
12824
+
12825
+ return;
12826
+ }
12827
+
12828
+ if (n === 0) {
12829
+ // We have the first key, return it if that's what they
12830
+ // wanted.
12831
+ resolve(cursor.key);
12832
+ } else {
12833
+ if (!advanced) {
12834
+ // Otherwise, ask the cursor to skip ahead n
12835
+ // records.
12836
+ advanced = true;
12837
+ cursor.advance(n);
12838
+ } else {
12839
+ // When we get here, we've got the nth key.
12840
+ resolve(cursor.key);
12841
+ }
12842
+ }
12843
+ };
12844
+
12845
+ req.onerror = function () {
12846
+ reject(req.error);
12847
+ };
12848
+ } catch (e) {
12849
+ reject(e);
12850
+ }
12851
+ });
12852
+ })["catch"](reject);
12853
+ });
12854
+
12855
+ executeCallback(promise, callback);
12856
+ return promise;
12857
+ }
12858
+
12859
+ function keys(callback) {
12860
+ var self = this;
12861
+
12862
+ var promise = new Promise$1(function (resolve, reject) {
12863
+ self.ready().then(function () {
12864
+ createTransaction(self._dbInfo, READ_ONLY, function (err, transaction) {
12865
+ if (err) {
12866
+ return reject(err);
12867
+ }
12868
+
12869
+ try {
12870
+ var store = transaction.objectStore(self._dbInfo.storeName);
12871
+ var req = store.openKeyCursor();
12872
+ var keys = [];
12873
+
12874
+ req.onsuccess = function () {
12875
+ var cursor = req.result;
12876
+
12877
+ if (!cursor) {
12878
+ resolve(keys);
12879
+ return;
12880
+ }
12881
+
12882
+ keys.push(cursor.key);
12883
+ cursor["continue"]();
12884
+ };
12885
+
12886
+ req.onerror = function () {
12887
+ reject(req.error);
12888
+ };
12889
+ } catch (e) {
12890
+ reject(e);
12891
+ }
12892
+ });
12893
+ })["catch"](reject);
12894
+ });
12895
+
12896
+ executeCallback(promise, callback);
12897
+ return promise;
12898
+ }
12899
+
12900
+ function dropInstance(options, callback) {
12901
+ callback = getCallback.apply(this, arguments);
12902
+
12903
+ var currentConfig = this.config();
12904
+ options = typeof options !== 'function' && options || {};
12905
+ if (!options.name) {
12906
+ options.name = options.name || currentConfig.name;
12907
+ options.storeName = options.storeName || currentConfig.storeName;
12908
+ }
12909
+
12910
+ var self = this;
12911
+ var promise;
12912
+ if (!options.name) {
12913
+ promise = Promise$1.reject('Invalid arguments');
12914
+ } else {
12915
+ var isCurrentDb = options.name === currentConfig.name && self._dbInfo.db;
12916
+
12917
+ var dbPromise = isCurrentDb ? Promise$1.resolve(self._dbInfo.db) : _getOriginalConnection(options).then(function (db) {
12918
+ var dbContext = dbContexts[options.name];
12919
+ var forages = dbContext.forages;
12920
+ dbContext.db = db;
12921
+ for (var i = 0; i < forages.length; i++) {
12922
+ forages[i]._dbInfo.db = db;
12923
+ }
12924
+ return db;
12925
+ });
12926
+
12927
+ if (!options.storeName) {
12928
+ promise = dbPromise.then(function (db) {
12929
+ _deferReadiness(options);
12930
+
12931
+ var dbContext = dbContexts[options.name];
12932
+ var forages = dbContext.forages;
12933
+
12934
+ db.close();
12935
+ for (var i = 0; i < forages.length; i++) {
12936
+ var forage = forages[i];
12937
+ forage._dbInfo.db = null;
12938
+ }
12939
+
12940
+ var dropDBPromise = new Promise$1(function (resolve, reject) {
12941
+ var req = idb.deleteDatabase(options.name);
12942
+
12943
+ req.onerror = function () {
12944
+ var db = req.result;
12945
+ if (db) {
12946
+ db.close();
12947
+ }
12948
+ reject(req.error);
12949
+ };
12950
+
12951
+ req.onblocked = function () {
12952
+ // Closing all open connections in onversionchange handler should prevent this situation, but if
12953
+ // we do get here, it just means the request remains pending - eventually it will succeed or error
12954
+ console.warn('dropInstance blocked for database "' + options.name + '" until all open connections are closed');
12955
+ };
12956
+
12957
+ req.onsuccess = function () {
12958
+ var db = req.result;
12959
+ if (db) {
12960
+ db.close();
12961
+ }
12962
+ resolve(db);
12963
+ };
12964
+ });
12965
+
12966
+ return dropDBPromise.then(function (db) {
12967
+ dbContext.db = db;
12968
+ for (var i = 0; i < forages.length; i++) {
12969
+ var _forage = forages[i];
12970
+ _advanceReadiness(_forage._dbInfo);
12971
+ }
12972
+ })["catch"](function (err) {
12973
+ (_rejectReadiness(options, err) || Promise$1.resolve())["catch"](function () {});
12974
+ throw err;
12975
+ });
12976
+ });
12977
+ } else {
12978
+ promise = dbPromise.then(function (db) {
12979
+ if (!db.objectStoreNames.contains(options.storeName)) {
12980
+ return;
12981
+ }
12982
+
12983
+ var newVersion = db.version + 1;
12984
+
12985
+ _deferReadiness(options);
12986
+
12987
+ var dbContext = dbContexts[options.name];
12988
+ var forages = dbContext.forages;
12989
+
12990
+ db.close();
12991
+ for (var i = 0; i < forages.length; i++) {
12992
+ var forage = forages[i];
12993
+ forage._dbInfo.db = null;
12994
+ forage._dbInfo.version = newVersion;
12995
+ }
12996
+
12997
+ var dropObjectPromise = new Promise$1(function (resolve, reject) {
12998
+ var req = idb.open(options.name, newVersion);
12999
+
13000
+ req.onerror = function (err) {
13001
+ var db = req.result;
13002
+ db.close();
13003
+ reject(err);
13004
+ };
13005
+
13006
+ req.onupgradeneeded = function () {
13007
+ var db = req.result;
13008
+ db.deleteObjectStore(options.storeName);
13009
+ };
13010
+
13011
+ req.onsuccess = function () {
13012
+ var db = req.result;
13013
+ db.close();
13014
+ resolve(db);
13015
+ };
13016
+ });
13017
+
13018
+ return dropObjectPromise.then(function (db) {
13019
+ dbContext.db = db;
13020
+ for (var j = 0; j < forages.length; j++) {
13021
+ var _forage2 = forages[j];
13022
+ _forage2._dbInfo.db = db;
13023
+ _advanceReadiness(_forage2._dbInfo);
13024
+ }
13025
+ })["catch"](function (err) {
13026
+ (_rejectReadiness(options, err) || Promise$1.resolve())["catch"](function () {});
13027
+ throw err;
13028
+ });
13029
+ });
13030
+ }
13031
+ }
13032
+
13033
+ executeCallback(promise, callback);
13034
+ return promise;
13035
+ }
13036
+
13037
+ var asyncStorage = {
13038
+ _driver: 'asyncStorage',
13039
+ _initStorage: _initStorage,
13040
+ _support: isIndexedDBValid(),
13041
+ iterate: iterate,
13042
+ getItem: getItem,
13043
+ setItem: setItem,
13044
+ removeItem: removeItem,
13045
+ clear: clear,
13046
+ length: length,
13047
+ key: key,
13048
+ keys: keys,
13049
+ dropInstance: dropInstance
13050
+ };
13051
+
13052
+ function isWebSQLValid() {
13053
+ return typeof openDatabase === 'function';
13054
+ }
13055
+
13056
+ // Sadly, the best way to save binary data in WebSQL/localStorage is serializing
13057
+ // it to Base64, so this is how we store it to prevent very strange errors with less
13058
+ // verbose ways of binary <-> string data storage.
13059
+ var BASE_CHARS = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/';
13060
+
13061
+ var BLOB_TYPE_PREFIX = '~~local_forage_type~';
13062
+ var BLOB_TYPE_PREFIX_REGEX = /^~~local_forage_type~([^~]+)~/;
13063
+
13064
+ var SERIALIZED_MARKER = '__lfsc__:';
13065
+ var SERIALIZED_MARKER_LENGTH = SERIALIZED_MARKER.length;
13066
+
13067
+ // OMG the serializations!
13068
+ var TYPE_ARRAYBUFFER = 'arbf';
13069
+ var TYPE_BLOB = 'blob';
13070
+ var TYPE_INT8ARRAY = 'si08';
13071
+ var TYPE_UINT8ARRAY = 'ui08';
13072
+ var TYPE_UINT8CLAMPEDARRAY = 'uic8';
13073
+ var TYPE_INT16ARRAY = 'si16';
13074
+ var TYPE_INT32ARRAY = 'si32';
13075
+ var TYPE_UINT16ARRAY = 'ur16';
13076
+ var TYPE_UINT32ARRAY = 'ui32';
13077
+ var TYPE_FLOAT32ARRAY = 'fl32';
13078
+ var TYPE_FLOAT64ARRAY = 'fl64';
13079
+ var TYPE_SERIALIZED_MARKER_LENGTH = SERIALIZED_MARKER_LENGTH + TYPE_ARRAYBUFFER.length;
13080
+
13081
+ var toString$1 = Object.prototype.toString;
13082
+
13083
+ function stringToBuffer(serializedString) {
13084
+ // Fill the string into a ArrayBuffer.
13085
+ var bufferLength = serializedString.length * 0.75;
13086
+ var len = serializedString.length;
13087
+ var i;
13088
+ var p = 0;
13089
+ var encoded1, encoded2, encoded3, encoded4;
13090
+
13091
+ if (serializedString[serializedString.length - 1] === '=') {
13092
+ bufferLength--;
13093
+ if (serializedString[serializedString.length - 2] === '=') {
13094
+ bufferLength--;
13095
+ }
13096
+ }
13097
+
13098
+ var buffer = new ArrayBuffer(bufferLength);
13099
+ var bytes = new Uint8Array(buffer);
13100
+
13101
+ for (i = 0; i < len; i += 4) {
13102
+ encoded1 = BASE_CHARS.indexOf(serializedString[i]);
13103
+ encoded2 = BASE_CHARS.indexOf(serializedString[i + 1]);
13104
+ encoded3 = BASE_CHARS.indexOf(serializedString[i + 2]);
13105
+ encoded4 = BASE_CHARS.indexOf(serializedString[i + 3]);
13106
+
13107
+ /*jslint bitwise: true */
13108
+ bytes[p++] = encoded1 << 2 | encoded2 >> 4;
13109
+ bytes[p++] = (encoded2 & 15) << 4 | encoded3 >> 2;
13110
+ bytes[p++] = (encoded3 & 3) << 6 | encoded4 & 63;
13111
+ }
13112
+ return buffer;
13113
+ }
13114
+
13115
+ // Converts a buffer to a string to store, serialized, in the backend
13116
+ // storage library.
13117
+ function bufferToString(buffer) {
13118
+ // base64-arraybuffer
13119
+ var bytes = new Uint8Array(buffer);
13120
+ var base64String = '';
13121
+ var i;
13122
+
13123
+ for (i = 0; i < bytes.length; i += 3) {
13124
+ /*jslint bitwise: true */
13125
+ base64String += BASE_CHARS[bytes[i] >> 2];
13126
+ base64String += BASE_CHARS[(bytes[i] & 3) << 4 | bytes[i + 1] >> 4];
13127
+ base64String += BASE_CHARS[(bytes[i + 1] & 15) << 2 | bytes[i + 2] >> 6];
13128
+ base64String += BASE_CHARS[bytes[i + 2] & 63];
13129
+ }
13130
+
13131
+ if (bytes.length % 3 === 2) {
13132
+ base64String = base64String.substring(0, base64String.length - 1) + '=';
13133
+ } else if (bytes.length % 3 === 1) {
13134
+ base64String = base64String.substring(0, base64String.length - 2) + '==';
13135
+ }
13136
+
13137
+ return base64String;
13138
+ }
13139
+
13140
+ // Serialize a value, afterwards executing a callback (which usually
13141
+ // instructs the `setItem()` callback/promise to be executed). This is how
13142
+ // we store binary data with localStorage.
13143
+ function serialize(value, callback) {
13144
+ var valueType = '';
13145
+ if (value) {
13146
+ valueType = toString$1.call(value);
13147
+ }
13148
+
13149
+ // Cannot use `value instanceof ArrayBuffer` or such here, as these
13150
+ // checks fail when running the tests using casper.js...
13151
+ //
13152
+ // TODO: See why those tests fail and use a better solution.
13153
+ if (value && (valueType === '[object ArrayBuffer]' || value.buffer && toString$1.call(value.buffer) === '[object ArrayBuffer]')) {
13154
+ // Convert binary arrays to a string and prefix the string with
13155
+ // a special marker.
13156
+ var buffer;
13157
+ var marker = SERIALIZED_MARKER;
13158
+
13159
+ if (value instanceof ArrayBuffer) {
13160
+ buffer = value;
13161
+ marker += TYPE_ARRAYBUFFER;
13162
+ } else {
13163
+ buffer = value.buffer;
13164
+
13165
+ if (valueType === '[object Int8Array]') {
13166
+ marker += TYPE_INT8ARRAY;
13167
+ } else if (valueType === '[object Uint8Array]') {
13168
+ marker += TYPE_UINT8ARRAY;
13169
+ } else if (valueType === '[object Uint8ClampedArray]') {
13170
+ marker += TYPE_UINT8CLAMPEDARRAY;
13171
+ } else if (valueType === '[object Int16Array]') {
13172
+ marker += TYPE_INT16ARRAY;
13173
+ } else if (valueType === '[object Uint16Array]') {
13174
+ marker += TYPE_UINT16ARRAY;
13175
+ } else if (valueType === '[object Int32Array]') {
13176
+ marker += TYPE_INT32ARRAY;
13177
+ } else if (valueType === '[object Uint32Array]') {
13178
+ marker += TYPE_UINT32ARRAY;
13179
+ } else if (valueType === '[object Float32Array]') {
13180
+ marker += TYPE_FLOAT32ARRAY;
13181
+ } else if (valueType === '[object Float64Array]') {
13182
+ marker += TYPE_FLOAT64ARRAY;
13183
+ } else {
13184
+ callback(new Error('Failed to get type for BinaryArray'));
13185
+ }
13186
+ }
13187
+
13188
+ callback(marker + bufferToString(buffer));
13189
+ } else if (valueType === '[object Blob]') {
13190
+ // Conver the blob to a binaryArray and then to a string.
13191
+ var fileReader = new FileReader();
13192
+
13193
+ fileReader.onload = function () {
13194
+ // Backwards-compatible prefix for the blob type.
13195
+ var str = BLOB_TYPE_PREFIX + value.type + '~' + bufferToString(this.result);
13196
+
13197
+ callback(SERIALIZED_MARKER + TYPE_BLOB + str);
13198
+ };
13199
+
13200
+ fileReader.readAsArrayBuffer(value);
13201
+ } else {
13202
+ try {
13203
+ callback(JSON.stringify(value));
13204
+ } catch (e) {
13205
+ console.error("Couldn't convert value into a JSON string: ", value);
13206
+
13207
+ callback(null, e);
13208
+ }
13209
+ }
13210
+ }
13211
+
13212
+ // Deserialize data we've inserted into a value column/field. We place
13213
+ // special markers into our strings to mark them as encoded; this isn't
13214
+ // as nice as a meta field, but it's the only sane thing we can do whilst
13215
+ // keeping localStorage support intact.
13216
+ //
13217
+ // Oftentimes this will just deserialize JSON content, but if we have a
13218
+ // special marker (SERIALIZED_MARKER, defined above), we will extract
13219
+ // some kind of arraybuffer/binary data/typed array out of the string.
13220
+ function deserialize(value) {
13221
+ // If we haven't marked this string as being specially serialized (i.e.
13222
+ // something other than serialized JSON), we can just return it and be
13223
+ // done with it.
13224
+ if (value.substring(0, SERIALIZED_MARKER_LENGTH) !== SERIALIZED_MARKER) {
13225
+ return JSON.parse(value);
13226
+ }
13227
+
13228
+ // The following code deals with deserializing some kind of Blob or
13229
+ // TypedArray. First we separate out the type of data we're dealing
13230
+ // with from the data itself.
13231
+ var serializedString = value.substring(TYPE_SERIALIZED_MARKER_LENGTH);
13232
+ var type = value.substring(SERIALIZED_MARKER_LENGTH, TYPE_SERIALIZED_MARKER_LENGTH);
13233
+
13234
+ var blobType;
13235
+ // Backwards-compatible blob type serialization strategy.
13236
+ // DBs created with older versions of localForage will simply not have the blob type.
13237
+ if (type === TYPE_BLOB && BLOB_TYPE_PREFIX_REGEX.test(serializedString)) {
13238
+ var matcher = serializedString.match(BLOB_TYPE_PREFIX_REGEX);
13239
+ blobType = matcher[1];
13240
+ serializedString = serializedString.substring(matcher[0].length);
13241
+ }
13242
+ var buffer = stringToBuffer(serializedString);
13243
+
13244
+ // Return the right type based on the code/type set during
13245
+ // serialization.
13246
+ switch (type) {
13247
+ case TYPE_ARRAYBUFFER:
13248
+ return buffer;
13249
+ case TYPE_BLOB:
13250
+ return createBlob([buffer], { type: blobType });
13251
+ case TYPE_INT8ARRAY:
13252
+ return new Int8Array(buffer);
13253
+ case TYPE_UINT8ARRAY:
13254
+ return new Uint8Array(buffer);
13255
+ case TYPE_UINT8CLAMPEDARRAY:
13256
+ return new Uint8ClampedArray(buffer);
13257
+ case TYPE_INT16ARRAY:
13258
+ return new Int16Array(buffer);
13259
+ case TYPE_UINT16ARRAY:
13260
+ return new Uint16Array(buffer);
13261
+ case TYPE_INT32ARRAY:
13262
+ return new Int32Array(buffer);
13263
+ case TYPE_UINT32ARRAY:
13264
+ return new Uint32Array(buffer);
13265
+ case TYPE_FLOAT32ARRAY:
13266
+ return new Float32Array(buffer);
13267
+ case TYPE_FLOAT64ARRAY:
13268
+ return new Float64Array(buffer);
13269
+ default:
13270
+ throw new Error('Unkown type: ' + type);
13271
+ }
13272
+ }
13273
+
13274
+ var localforageSerializer = {
13275
+ serialize: serialize,
13276
+ deserialize: deserialize,
13277
+ stringToBuffer: stringToBuffer,
13278
+ bufferToString: bufferToString
13279
+ };
13280
+
13281
+ /*
13282
+ * Includes code from:
13283
+ *
13284
+ * base64-arraybuffer
13285
+ * https://github.com/niklasvh/base64-arraybuffer
13286
+ *
13287
+ * Copyright (c) 2012 Niklas von Hertzen
13288
+ * Licensed under the MIT license.
13289
+ */
13290
+
13291
+ function createDbTable(t, dbInfo, callback, errorCallback) {
13292
+ t.executeSql('CREATE TABLE IF NOT EXISTS ' + dbInfo.storeName + ' ' + '(id INTEGER PRIMARY KEY, key unique, value)', [], callback, errorCallback);
13293
+ }
13294
+
13295
+ // Open the WebSQL database (automatically creates one if one didn't
13296
+ // previously exist), using any options set in the config.
13297
+ function _initStorage$1(options) {
13298
+ var self = this;
13299
+ var dbInfo = {
13300
+ db: null
13301
+ };
13302
+
13303
+ if (options) {
13304
+ for (var i in options) {
13305
+ dbInfo[i] = typeof options[i] !== 'string' ? options[i].toString() : options[i];
13306
+ }
13307
+ }
13308
+
13309
+ var dbInfoPromise = new Promise$1(function (resolve, reject) {
13310
+ // Open the database; the openDatabase API will automatically
13311
+ // create it for us if it doesn't exist.
13312
+ try {
13313
+ dbInfo.db = openDatabase(dbInfo.name, String(dbInfo.version), dbInfo.description, dbInfo.size);
13314
+ } catch (e) {
13315
+ return reject(e);
13316
+ }
13317
+
13318
+ // Create our key/value table if it doesn't exist.
13319
+ dbInfo.db.transaction(function (t) {
13320
+ createDbTable(t, dbInfo, function () {
13321
+ self._dbInfo = dbInfo;
13322
+ resolve();
13323
+ }, function (t, error) {
13324
+ reject(error);
13325
+ });
13326
+ }, reject);
13327
+ });
13328
+
13329
+ dbInfo.serializer = localforageSerializer;
13330
+ return dbInfoPromise;
13331
+ }
13332
+
13333
+ function tryExecuteSql(t, dbInfo, sqlStatement, args, callback, errorCallback) {
13334
+ t.executeSql(sqlStatement, args, callback, function (t, error) {
13335
+ if (error.code === error.SYNTAX_ERR) {
13336
+ t.executeSql('SELECT name FROM sqlite_master ' + "WHERE type='table' AND name = ?", [dbInfo.storeName], function (t, results) {
13337
+ if (!results.rows.length) {
13338
+ // if the table is missing (was deleted)
13339
+ // re-create it table and retry
13340
+ createDbTable(t, dbInfo, function () {
13341
+ t.executeSql(sqlStatement, args, callback, errorCallback);
13342
+ }, errorCallback);
13343
+ } else {
13344
+ errorCallback(t, error);
13345
+ }
13346
+ }, errorCallback);
13347
+ } else {
13348
+ errorCallback(t, error);
13349
+ }
13350
+ }, errorCallback);
13351
+ }
13352
+
13353
+ function getItem$1(key, callback) {
13354
+ var self = this;
13355
+
13356
+ key = normalizeKey(key);
13357
+
13358
+ var promise = new Promise$1(function (resolve, reject) {
13359
+ self.ready().then(function () {
13360
+ var dbInfo = self._dbInfo;
13361
+ dbInfo.db.transaction(function (t) {
13362
+ tryExecuteSql(t, dbInfo, 'SELECT * FROM ' + dbInfo.storeName + ' WHERE key = ? LIMIT 1', [key], function (t, results) {
13363
+ var result = results.rows.length ? results.rows.item(0).value : null;
13364
+
13365
+ // Check to see if this is serialized content we need to
13366
+ // unpack.
13367
+ if (result) {
13368
+ result = dbInfo.serializer.deserialize(result);
13369
+ }
13370
+
13371
+ resolve(result);
13372
+ }, function (t, error) {
13373
+ reject(error);
13374
+ });
13375
+ });
13376
+ })["catch"](reject);
13377
+ });
13378
+
13379
+ executeCallback(promise, callback);
13380
+ return promise;
13381
+ }
13382
+
13383
+ function iterate$1(iterator, callback) {
13384
+ var self = this;
13385
+
13386
+ var promise = new Promise$1(function (resolve, reject) {
13387
+ self.ready().then(function () {
13388
+ var dbInfo = self._dbInfo;
13389
+
13390
+ dbInfo.db.transaction(function (t) {
13391
+ tryExecuteSql(t, dbInfo, 'SELECT * FROM ' + dbInfo.storeName, [], function (t, results) {
13392
+ var rows = results.rows;
13393
+ var length = rows.length;
13394
+
13395
+ for (var i = 0; i < length; i++) {
13396
+ var item = rows.item(i);
13397
+ var result = item.value;
13398
+
13399
+ // Check to see if this is serialized content
13400
+ // we need to unpack.
13401
+ if (result) {
13402
+ result = dbInfo.serializer.deserialize(result);
13403
+ }
13404
+
13405
+ result = iterator(result, item.key, i + 1);
13406
+
13407
+ // void(0) prevents problems with redefinition
13408
+ // of `undefined`.
13409
+ if (result !== void 0) {
13410
+ resolve(result);
13411
+ return;
13412
+ }
13413
+ }
13414
+
13415
+ resolve();
13416
+ }, function (t, error) {
13417
+ reject(error);
13418
+ });
13419
+ });
13420
+ })["catch"](reject);
13421
+ });
13422
+
13423
+ executeCallback(promise, callback);
13424
+ return promise;
13425
+ }
13426
+
13427
+ function _setItem(key, value, callback, retriesLeft) {
13428
+ var self = this;
13429
+
13430
+ key = normalizeKey(key);
13431
+
13432
+ var promise = new Promise$1(function (resolve, reject) {
13433
+ self.ready().then(function () {
13434
+ // The localStorage API doesn't return undefined values in an
13435
+ // "expected" way, so undefined is always cast to null in all
13436
+ // drivers. See: https://github.com/mozilla/localForage/pull/42
13437
+ if (value === undefined) {
13438
+ value = null;
13439
+ }
13440
+
13441
+ // Save the original value to pass to the callback.
13442
+ var originalValue = value;
13443
+
13444
+ var dbInfo = self._dbInfo;
13445
+ dbInfo.serializer.serialize(value, function (value, error) {
13446
+ if (error) {
13447
+ reject(error);
13448
+ } else {
13449
+ dbInfo.db.transaction(function (t) {
13450
+ tryExecuteSql(t, dbInfo, 'INSERT OR REPLACE INTO ' + dbInfo.storeName + ' ' + '(key, value) VALUES (?, ?)', [key, value], function () {
13451
+ resolve(originalValue);
13452
+ }, function (t, error) {
13453
+ reject(error);
13454
+ });
13455
+ }, function (sqlError) {
13456
+ // The transaction failed; check
13457
+ // to see if it's a quota error.
13458
+ if (sqlError.code === sqlError.QUOTA_ERR) {
13459
+ // We reject the callback outright for now, but
13460
+ // it's worth trying to re-run the transaction.
13461
+ // Even if the user accepts the prompt to use
13462
+ // more storage on Safari, this error will
13463
+ // be called.
13464
+ //
13465
+ // Try to re-run the transaction.
13466
+ if (retriesLeft > 0) {
13467
+ resolve(_setItem.apply(self, [key, originalValue, callback, retriesLeft - 1]));
13468
+ return;
13469
+ }
13470
+ reject(sqlError);
13471
+ }
13472
+ });
13473
+ }
13474
+ });
13475
+ })["catch"](reject);
13476
+ });
13477
+
13478
+ executeCallback(promise, callback);
13479
+ return promise;
13480
+ }
13481
+
13482
+ function setItem$1(key, value, callback) {
13483
+ return _setItem.apply(this, [key, value, callback, 1]);
13484
+ }
13485
+
13486
+ function removeItem$1(key, callback) {
13487
+ var self = this;
13488
+
13489
+ key = normalizeKey(key);
13490
+
13491
+ var promise = new Promise$1(function (resolve, reject) {
13492
+ self.ready().then(function () {
13493
+ var dbInfo = self._dbInfo;
13494
+ dbInfo.db.transaction(function (t) {
13495
+ tryExecuteSql(t, dbInfo, 'DELETE FROM ' + dbInfo.storeName + ' WHERE key = ?', [key], function () {
13496
+ resolve();
13497
+ }, function (t, error) {
13498
+ reject(error);
13499
+ });
13500
+ });
13501
+ })["catch"](reject);
13502
+ });
13503
+
13504
+ executeCallback(promise, callback);
13505
+ return promise;
13506
+ }
13507
+
13508
+ // Deletes every item in the table.
13509
+ // TODO: Find out if this resets the AUTO_INCREMENT number.
13510
+ function clear$1(callback) {
13511
+ var self = this;
13512
+
13513
+ var promise = new Promise$1(function (resolve, reject) {
13514
+ self.ready().then(function () {
13515
+ var dbInfo = self._dbInfo;
13516
+ dbInfo.db.transaction(function (t) {
13517
+ tryExecuteSql(t, dbInfo, 'DELETE FROM ' + dbInfo.storeName, [], function () {
13518
+ resolve();
13519
+ }, function (t, error) {
13520
+ reject(error);
13521
+ });
13522
+ });
13523
+ })["catch"](reject);
13524
+ });
13525
+
13526
+ executeCallback(promise, callback);
13527
+ return promise;
13528
+ }
13529
+
13530
+ // Does a simple `COUNT(key)` to get the number of items stored in
13531
+ // localForage.
13532
+ function length$1(callback) {
13533
+ var self = this;
13534
+
13535
+ var promise = new Promise$1(function (resolve, reject) {
13536
+ self.ready().then(function () {
13537
+ var dbInfo = self._dbInfo;
13538
+ dbInfo.db.transaction(function (t) {
13539
+ // Ahhh, SQL makes this one soooooo easy.
13540
+ tryExecuteSql(t, dbInfo, 'SELECT COUNT(key) as c FROM ' + dbInfo.storeName, [], function (t, results) {
13541
+ var result = results.rows.item(0).c;
13542
+ resolve(result);
13543
+ }, function (t, error) {
13544
+ reject(error);
13545
+ });
13546
+ });
13547
+ })["catch"](reject);
13548
+ });
13549
+
13550
+ executeCallback(promise, callback);
13551
+ return promise;
13552
+ }
13553
+
13554
+ // Return the key located at key index X; essentially gets the key from a
13555
+ // `WHERE id = ?`. This is the most efficient way I can think to implement
13556
+ // this rarely-used (in my experience) part of the API, but it can seem
13557
+ // inconsistent, because we do `INSERT OR REPLACE INTO` on `setItem()`, so
13558
+ // the ID of each key will change every time it's updated. Perhaps a stored
13559
+ // procedure for the `setItem()` SQL would solve this problem?
13560
+ // TODO: Don't change ID on `setItem()`.
13561
+ function key$1(n, callback) {
13562
+ var self = this;
13563
+
13564
+ var promise = new Promise$1(function (resolve, reject) {
13565
+ self.ready().then(function () {
13566
+ var dbInfo = self._dbInfo;
13567
+ dbInfo.db.transaction(function (t) {
13568
+ tryExecuteSql(t, dbInfo, 'SELECT key FROM ' + dbInfo.storeName + ' WHERE id = ? LIMIT 1', [n + 1], function (t, results) {
13569
+ var result = results.rows.length ? results.rows.item(0).key : null;
13570
+ resolve(result);
13571
+ }, function (t, error) {
13572
+ reject(error);
13573
+ });
13574
+ });
13575
+ })["catch"](reject);
13576
+ });
13577
+
13578
+ executeCallback(promise, callback);
13579
+ return promise;
13580
+ }
13581
+
13582
+ function keys$1(callback) {
13583
+ var self = this;
13584
+
13585
+ var promise = new Promise$1(function (resolve, reject) {
13586
+ self.ready().then(function () {
13587
+ var dbInfo = self._dbInfo;
13588
+ dbInfo.db.transaction(function (t) {
13589
+ tryExecuteSql(t, dbInfo, 'SELECT key FROM ' + dbInfo.storeName, [], function (t, results) {
13590
+ var keys = [];
13591
+
13592
+ for (var i = 0; i < results.rows.length; i++) {
13593
+ keys.push(results.rows.item(i).key);
13594
+ }
13595
+
13596
+ resolve(keys);
13597
+ }, function (t, error) {
13598
+ reject(error);
13599
+ });
13600
+ });
13601
+ })["catch"](reject);
13602
+ });
13603
+
13604
+ executeCallback(promise, callback);
13605
+ return promise;
13606
+ }
13607
+
13608
+ // https://www.w3.org/TR/webdatabase/#databases
13609
+ // > There is no way to enumerate or delete the databases available for an origin from this API.
13610
+ function getAllStoreNames(db) {
13611
+ return new Promise$1(function (resolve, reject) {
13612
+ db.transaction(function (t) {
13613
+ t.executeSql('SELECT name FROM sqlite_master ' + "WHERE type='table' AND name <> '__WebKitDatabaseInfoTable__'", [], function (t, results) {
13614
+ var storeNames = [];
13615
+
13616
+ for (var i = 0; i < results.rows.length; i++) {
13617
+ storeNames.push(results.rows.item(i).name);
13618
+ }
13619
+
13620
+ resolve({
13621
+ db: db,
13622
+ storeNames: storeNames
13623
+ });
13624
+ }, function (t, error) {
13625
+ reject(error);
13626
+ });
13627
+ }, function (sqlError) {
13628
+ reject(sqlError);
13629
+ });
13630
+ });
13631
+ }
13632
+
13633
+ function dropInstance$1(options, callback) {
13634
+ callback = getCallback.apply(this, arguments);
13635
+
13636
+ var currentConfig = this.config();
13637
+ options = typeof options !== 'function' && options || {};
13638
+ if (!options.name) {
13639
+ options.name = options.name || currentConfig.name;
13640
+ options.storeName = options.storeName || currentConfig.storeName;
13641
+ }
13642
+
13643
+ var self = this;
13644
+ var promise;
13645
+ if (!options.name) {
13646
+ promise = Promise$1.reject('Invalid arguments');
13647
+ } else {
13648
+ promise = new Promise$1(function (resolve) {
13649
+ var db;
13650
+ if (options.name === currentConfig.name) {
13651
+ // use the db reference of the current instance
13652
+ db = self._dbInfo.db;
13653
+ } else {
13654
+ db = openDatabase(options.name, '', '', 0);
13655
+ }
13656
+
13657
+ if (!options.storeName) {
13658
+ // drop all database tables
13659
+ resolve(getAllStoreNames(db));
13660
+ } else {
13661
+ resolve({
13662
+ db: db,
13663
+ storeNames: [options.storeName]
13664
+ });
13665
+ }
13666
+ }).then(function (operationInfo) {
13667
+ return new Promise$1(function (resolve, reject) {
13668
+ operationInfo.db.transaction(function (t) {
13669
+ function dropTable(storeName) {
13670
+ return new Promise$1(function (resolve, reject) {
13671
+ t.executeSql('DROP TABLE IF EXISTS ' + storeName, [], function () {
13672
+ resolve();
13673
+ }, function (t, error) {
13674
+ reject(error);
13675
+ });
13676
+ });
13677
+ }
13678
+
13679
+ var operations = [];
13680
+ for (var i = 0, len = operationInfo.storeNames.length; i < len; i++) {
13681
+ operations.push(dropTable(operationInfo.storeNames[i]));
13682
+ }
13683
+
13684
+ Promise$1.all(operations).then(function () {
13685
+ resolve();
13686
+ })["catch"](function (e) {
13687
+ reject(e);
13688
+ });
13689
+ }, function (sqlError) {
13690
+ reject(sqlError);
13691
+ });
13692
+ });
13693
+ });
13694
+ }
13695
+
13696
+ executeCallback(promise, callback);
13697
+ return promise;
13698
+ }
13699
+
13700
+ var webSQLStorage = {
13701
+ _driver: 'webSQLStorage',
13702
+ _initStorage: _initStorage$1,
13703
+ _support: isWebSQLValid(),
13704
+ iterate: iterate$1,
13705
+ getItem: getItem$1,
13706
+ setItem: setItem$1,
13707
+ removeItem: removeItem$1,
13708
+ clear: clear$1,
13709
+ length: length$1,
13710
+ key: key$1,
13711
+ keys: keys$1,
13712
+ dropInstance: dropInstance$1
13713
+ };
13714
+
13715
+ function isLocalStorageValid() {
13716
+ try {
13717
+ return typeof localStorage !== 'undefined' && 'setItem' in localStorage &&
13718
+ // in IE8 typeof localStorage.setItem === 'object'
13719
+ !!localStorage.setItem;
13720
+ } catch (e) {
13721
+ return false;
13722
+ }
13723
+ }
13724
+
13725
+ function _getKeyPrefix(options, defaultConfig) {
13726
+ var keyPrefix = options.name + '/';
13727
+
13728
+ if (options.storeName !== defaultConfig.storeName) {
13729
+ keyPrefix += options.storeName + '/';
13730
+ }
13731
+ return keyPrefix;
13732
+ }
13733
+
13734
+ // Check if localStorage throws when saving an item
13735
+ function checkIfLocalStorageThrows() {
13736
+ var localStorageTestKey = '_localforage_support_test';
13737
+
13738
+ try {
13739
+ localStorage.setItem(localStorageTestKey, true);
13740
+ localStorage.removeItem(localStorageTestKey);
13741
+
13742
+ return false;
13743
+ } catch (e) {
13744
+ return true;
13745
+ }
13746
+ }
13747
+
13748
+ // Check if localStorage is usable and allows to save an item
13749
+ // This method checks if localStorage is usable in Safari Private Browsing
13750
+ // mode, or in any other case where the available quota for localStorage
13751
+ // is 0 and there wasn't any saved items yet.
13752
+ function _isLocalStorageUsable() {
13753
+ return !checkIfLocalStorageThrows() || localStorage.length > 0;
13754
+ }
13755
+
13756
+ // Config the localStorage backend, using options set in the config.
13757
+ function _initStorage$2(options) {
13758
+ var self = this;
13759
+ var dbInfo = {};
13760
+ if (options) {
13761
+ for (var i in options) {
13762
+ dbInfo[i] = options[i];
13763
+ }
13764
+ }
13765
+
13766
+ dbInfo.keyPrefix = _getKeyPrefix(options, self._defaultConfig);
13767
+
13768
+ if (!_isLocalStorageUsable()) {
13769
+ return Promise$1.reject();
13770
+ }
13771
+
13772
+ self._dbInfo = dbInfo;
13773
+ dbInfo.serializer = localforageSerializer;
13774
+
13775
+ return Promise$1.resolve();
13776
+ }
13777
+
13778
+ // Remove all keys from the datastore, effectively destroying all data in
13779
+ // the app's key/value store!
13780
+ function clear$2(callback) {
13781
+ var self = this;
13782
+ var promise = self.ready().then(function () {
13783
+ var keyPrefix = self._dbInfo.keyPrefix;
13784
+
13785
+ for (var i = localStorage.length - 1; i >= 0; i--) {
13786
+ var key = localStorage.key(i);
13787
+
13788
+ if (key.indexOf(keyPrefix) === 0) {
13789
+ localStorage.removeItem(key);
13790
+ }
13791
+ }
13792
+ });
13793
+
13794
+ executeCallback(promise, callback);
13795
+ return promise;
13796
+ }
13797
+
13798
+ // Retrieve an item from the store. Unlike the original async_storage
13799
+ // library in Gaia, we don't modify return values at all. If a key's value
13800
+ // is `undefined`, we pass that value to the callback function.
13801
+ function getItem$2(key, callback) {
13802
+ var self = this;
13803
+
13804
+ key = normalizeKey(key);
13805
+
13806
+ var promise = self.ready().then(function () {
13807
+ var dbInfo = self._dbInfo;
13808
+ var result = localStorage.getItem(dbInfo.keyPrefix + key);
13809
+
13810
+ // If a result was found, parse it from the serialized
13811
+ // string into a JS object. If result isn't truthy, the key
13812
+ // is likely undefined and we'll pass it straight to the
13813
+ // callback.
13814
+ if (result) {
13815
+ result = dbInfo.serializer.deserialize(result);
13816
+ }
13817
+
13818
+ return result;
13819
+ });
13820
+
13821
+ executeCallback(promise, callback);
13822
+ return promise;
13823
+ }
13824
+
13825
+ // Iterate over all items in the store.
13826
+ function iterate$2(iterator, callback) {
13827
+ var self = this;
13828
+
13829
+ var promise = self.ready().then(function () {
13830
+ var dbInfo = self._dbInfo;
13831
+ var keyPrefix = dbInfo.keyPrefix;
13832
+ var keyPrefixLength = keyPrefix.length;
13833
+ var length = localStorage.length;
13834
+
13835
+ // We use a dedicated iterator instead of the `i` variable below
13836
+ // so other keys we fetch in localStorage aren't counted in
13837
+ // the `iterationNumber` argument passed to the `iterate()`
13838
+ // callback.
13839
+ //
13840
+ // See: github.com/mozilla/localForage/pull/435#discussion_r38061530
13841
+ var iterationNumber = 1;
13842
+
13843
+ for (var i = 0; i < length; i++) {
13844
+ var key = localStorage.key(i);
13845
+ if (key.indexOf(keyPrefix) !== 0) {
13846
+ continue;
13847
+ }
13848
+ var value = localStorage.getItem(key);
13849
+
13850
+ // If a result was found, parse it from the serialized
13851
+ // string into a JS object. If result isn't truthy, the
13852
+ // key is likely undefined and we'll pass it straight
13853
+ // to the iterator.
13854
+ if (value) {
13855
+ value = dbInfo.serializer.deserialize(value);
13856
+ }
13857
+
13858
+ value = iterator(value, key.substring(keyPrefixLength), iterationNumber++);
13859
+
13860
+ if (value !== void 0) {
13861
+ return value;
13862
+ }
13863
+ }
13864
+ });
13865
+
13866
+ executeCallback(promise, callback);
13867
+ return promise;
13868
+ }
13869
+
13870
+ // Same as localStorage's key() method, except takes a callback.
13871
+ function key$2(n, callback) {
13872
+ var self = this;
13873
+ var promise = self.ready().then(function () {
13874
+ var dbInfo = self._dbInfo;
13875
+ var result;
13876
+ try {
13877
+ result = localStorage.key(n);
13878
+ } catch (error) {
13879
+ result = null;
13880
+ }
13881
+
13882
+ // Remove the prefix from the key, if a key is found.
13883
+ if (result) {
13884
+ result = result.substring(dbInfo.keyPrefix.length);
13885
+ }
13886
+
13887
+ return result;
13888
+ });
13889
+
13890
+ executeCallback(promise, callback);
13891
+ return promise;
13892
+ }
13893
+
13894
+ function keys$2(callback) {
13895
+ var self = this;
13896
+ var promise = self.ready().then(function () {
13897
+ var dbInfo = self._dbInfo;
13898
+ var length = localStorage.length;
13899
+ var keys = [];
13900
+
13901
+ for (var i = 0; i < length; i++) {
13902
+ var itemKey = localStorage.key(i);
13903
+ if (itemKey.indexOf(dbInfo.keyPrefix) === 0) {
13904
+ keys.push(itemKey.substring(dbInfo.keyPrefix.length));
13905
+ }
13906
+ }
13907
+
13908
+ return keys;
13909
+ });
13910
+
13911
+ executeCallback(promise, callback);
13912
+ return promise;
13913
+ }
13914
+
13915
+ // Supply the number of keys in the datastore to the callback function.
13916
+ function length$2(callback) {
13917
+ var self = this;
13918
+ var promise = self.keys().then(function (keys) {
13919
+ return keys.length;
13920
+ });
13921
+
13922
+ executeCallback(promise, callback);
13923
+ return promise;
13924
+ }
13925
+
13926
+ // Remove an item from the store, nice and simple.
13927
+ function removeItem$2(key, callback) {
13928
+ var self = this;
13929
+
13930
+ key = normalizeKey(key);
13931
+
13932
+ var promise = self.ready().then(function () {
13933
+ var dbInfo = self._dbInfo;
13934
+ localStorage.removeItem(dbInfo.keyPrefix + key);
13935
+ });
13936
+
13937
+ executeCallback(promise, callback);
13938
+ return promise;
13939
+ }
13940
+
13941
+ // Set a key's value and run an optional callback once the value is set.
13942
+ // Unlike Gaia's implementation, the callback function is passed the value,
13943
+ // in case you want to operate on that value only after you're sure it
13944
+ // saved, or something like that.
13945
+ function setItem$2(key, value, callback) {
13946
+ var self = this;
13947
+
13948
+ key = normalizeKey(key);
13949
+
13950
+ var promise = self.ready().then(function () {
13951
+ // Convert undefined values to null.
13952
+ // https://github.com/mozilla/localForage/pull/42
13953
+ if (value === undefined) {
13954
+ value = null;
13955
+ }
13956
+
13957
+ // Save the original value to pass to the callback.
13958
+ var originalValue = value;
13959
+
13960
+ return new Promise$1(function (resolve, reject) {
13961
+ var dbInfo = self._dbInfo;
13962
+ dbInfo.serializer.serialize(value, function (value, error) {
13963
+ if (error) {
13964
+ reject(error);
13965
+ } else {
13966
+ try {
13967
+ localStorage.setItem(dbInfo.keyPrefix + key, value);
13968
+ resolve(originalValue);
13969
+ } catch (e) {
13970
+ // localStorage capacity exceeded.
13971
+ // TODO: Make this a specific error/event.
13972
+ if (e.name === 'QuotaExceededError' || e.name === 'NS_ERROR_DOM_QUOTA_REACHED') {
13973
+ reject(e);
13974
+ }
13975
+ reject(e);
13976
+ }
13977
+ }
13978
+ });
13979
+ });
13980
+ });
13981
+
13982
+ executeCallback(promise, callback);
13983
+ return promise;
13984
+ }
13985
+
13986
+ function dropInstance$2(options, callback) {
13987
+ callback = getCallback.apply(this, arguments);
13988
+
13989
+ options = typeof options !== 'function' && options || {};
13990
+ if (!options.name) {
13991
+ var currentConfig = this.config();
13992
+ options.name = options.name || currentConfig.name;
13993
+ options.storeName = options.storeName || currentConfig.storeName;
13994
+ }
13995
+
13996
+ var self = this;
13997
+ var promise;
13998
+ if (!options.name) {
13999
+ promise = Promise$1.reject('Invalid arguments');
14000
+ } else {
14001
+ promise = new Promise$1(function (resolve) {
14002
+ if (!options.storeName) {
14003
+ resolve(options.name + '/');
14004
+ } else {
14005
+ resolve(_getKeyPrefix(options, self._defaultConfig));
14006
+ }
14007
+ }).then(function (keyPrefix) {
14008
+ for (var i = localStorage.length - 1; i >= 0; i--) {
14009
+ var key = localStorage.key(i);
14010
+
14011
+ if (key.indexOf(keyPrefix) === 0) {
14012
+ localStorage.removeItem(key);
14013
+ }
14014
+ }
14015
+ });
14016
+ }
14017
+
14018
+ executeCallback(promise, callback);
14019
+ return promise;
14020
+ }
14021
+
14022
+ var localStorageWrapper = {
14023
+ _driver: 'localStorageWrapper',
14024
+ _initStorage: _initStorage$2,
14025
+ _support: isLocalStorageValid(),
14026
+ iterate: iterate$2,
14027
+ getItem: getItem$2,
14028
+ setItem: setItem$2,
14029
+ removeItem: removeItem$2,
14030
+ clear: clear$2,
14031
+ length: length$2,
14032
+ key: key$2,
14033
+ keys: keys$2,
14034
+ dropInstance: dropInstance$2
14035
+ };
14036
+
14037
+ var sameValue = function sameValue(x, y) {
14038
+ return x === y || typeof x === 'number' && typeof y === 'number' && isNaN(x) && isNaN(y);
14039
+ };
14040
+
14041
+ var includes = function includes(array, searchElement) {
14042
+ var len = array.length;
14043
+ var i = 0;
14044
+ while (i < len) {
14045
+ if (sameValue(array[i], searchElement)) {
14046
+ return true;
14047
+ }
14048
+ i++;
14049
+ }
14050
+
14051
+ return false;
14052
+ };
14053
+
14054
+ var isArray = Array.isArray || function (arg) {
14055
+ return Object.prototype.toString.call(arg) === '[object Array]';
14056
+ };
14057
+
14058
+ // Drivers are stored here when `defineDriver()` is called.
14059
+ // They are shared across all instances of localForage.
14060
+ var DefinedDrivers = {};
14061
+
14062
+ var DriverSupport = {};
14063
+
14064
+ var DefaultDrivers = {
14065
+ INDEXEDDB: asyncStorage,
14066
+ WEBSQL: webSQLStorage,
14067
+ LOCALSTORAGE: localStorageWrapper
14068
+ };
14069
+
14070
+ var DefaultDriverOrder = [DefaultDrivers.INDEXEDDB._driver, DefaultDrivers.WEBSQL._driver, DefaultDrivers.LOCALSTORAGE._driver];
14071
+
14072
+ var OptionalDriverMethods = ['dropInstance'];
14073
+
14074
+ var LibraryMethods = ['clear', 'getItem', 'iterate', 'key', 'keys', 'length', 'removeItem', 'setItem'].concat(OptionalDriverMethods);
14075
+
14076
+ var DefaultConfig = {
14077
+ description: '',
14078
+ driver: DefaultDriverOrder.slice(),
14079
+ name: 'localforage',
14080
+ // Default DB size is _JUST UNDER_ 5MB, as it's the highest size
14081
+ // we can use without a prompt.
14082
+ size: 4980736,
14083
+ storeName: 'keyvaluepairs',
14084
+ version: 1.0
14085
+ };
14086
+
14087
+ function callWhenReady(localForageInstance, libraryMethod) {
14088
+ localForageInstance[libraryMethod] = function () {
14089
+ var _args = arguments;
14090
+ return localForageInstance.ready().then(function () {
14091
+ return localForageInstance[libraryMethod].apply(localForageInstance, _args);
14092
+ });
14093
+ };
14094
+ }
14095
+
14096
+ function extend() {
14097
+ for (var i = 1; i < arguments.length; i++) {
14098
+ var arg = arguments[i];
14099
+
14100
+ if (arg) {
14101
+ for (var _key in arg) {
14102
+ if (arg.hasOwnProperty(_key)) {
14103
+ if (isArray(arg[_key])) {
14104
+ arguments[0][_key] = arg[_key].slice();
14105
+ } else {
14106
+ arguments[0][_key] = arg[_key];
14107
+ }
14108
+ }
14109
+ }
14110
+ }
14111
+ }
14112
+
14113
+ return arguments[0];
14114
+ }
14115
+
14116
+ var LocalForage = function () {
14117
+ function LocalForage(options) {
14118
+ _classCallCheck(this, LocalForage);
14119
+
14120
+ for (var driverTypeKey in DefaultDrivers) {
14121
+ if (DefaultDrivers.hasOwnProperty(driverTypeKey)) {
14122
+ var driver = DefaultDrivers[driverTypeKey];
14123
+ var driverName = driver._driver;
14124
+ this[driverTypeKey] = driverName;
14125
+
14126
+ if (!DefinedDrivers[driverName]) {
14127
+ // we don't need to wait for the promise,
14128
+ // since the default drivers can be defined
14129
+ // in a blocking manner
14130
+ this.defineDriver(driver);
14131
+ }
14132
+ }
14133
+ }
14134
+
14135
+ this._defaultConfig = extend({}, DefaultConfig);
14136
+ this._config = extend({}, this._defaultConfig, options);
14137
+ this._driverSet = null;
14138
+ this._initDriver = null;
14139
+ this._ready = false;
14140
+ this._dbInfo = null;
14141
+
14142
+ this._wrapLibraryMethodsWithReady();
14143
+ this.setDriver(this._config.driver)["catch"](function () {});
14144
+ }
14145
+
14146
+ // Set any config values for localForage; can be called anytime before
14147
+ // the first API call (e.g. `getItem`, `setItem`).
14148
+ // We loop through options so we don't overwrite existing config
14149
+ // values.
14150
+
14151
+
14152
+ LocalForage.prototype.config = function config(options) {
14153
+ // If the options argument is an object, we use it to set values.
14154
+ // Otherwise, we return either a specified config value or all
14155
+ // config values.
14156
+ if ((typeof options === 'undefined' ? 'undefined' : _typeof(options)) === 'object') {
14157
+ // If localforage is ready and fully initialized, we can't set
14158
+ // any new configuration values. Instead, we return an error.
14159
+ if (this._ready) {
14160
+ return new Error("Can't call config() after localforage " + 'has been used.');
14161
+ }
14162
+
14163
+ for (var i in options) {
14164
+ if (i === 'storeName') {
14165
+ options[i] = options[i].replace(/\W/g, '_');
14166
+ }
14167
+
14168
+ if (i === 'version' && typeof options[i] !== 'number') {
14169
+ return new Error('Database version must be a number.');
14170
+ }
14171
+
14172
+ this._config[i] = options[i];
14173
+ }
14174
+
14175
+ // after all config options are set and
14176
+ // the driver option is used, try setting it
14177
+ if ('driver' in options && options.driver) {
14178
+ return this.setDriver(this._config.driver);
14179
+ }
14180
+
14181
+ return true;
14182
+ } else if (typeof options === 'string') {
14183
+ return this._config[options];
14184
+ } else {
14185
+ return this._config;
14186
+ }
14187
+ };
14188
+
14189
+ // Used to define a custom driver, shared across all instances of
14190
+ // localForage.
14191
+
14192
+
14193
+ LocalForage.prototype.defineDriver = function defineDriver(driverObject, callback, errorCallback) {
14194
+ var promise = new Promise$1(function (resolve, reject) {
14195
+ try {
14196
+ var driverName = driverObject._driver;
14197
+ var complianceError = new Error('Custom driver not compliant; see ' + 'https://mozilla.github.io/localForage/#definedriver');
14198
+
14199
+ // A driver name should be defined and not overlap with the
14200
+ // library-defined, default drivers.
14201
+ if (!driverObject._driver) {
14202
+ reject(complianceError);
14203
+ return;
14204
+ }
14205
+
14206
+ var driverMethods = LibraryMethods.concat('_initStorage');
14207
+ for (var i = 0, len = driverMethods.length; i < len; i++) {
14208
+ var driverMethodName = driverMethods[i];
14209
+
14210
+ // when the property is there,
14211
+ // it should be a method even when optional
14212
+ var isRequired = !includes(OptionalDriverMethods, driverMethodName);
14213
+ if ((isRequired || driverObject[driverMethodName]) && typeof driverObject[driverMethodName] !== 'function') {
14214
+ reject(complianceError);
14215
+ return;
14216
+ }
14217
+ }
14218
+
14219
+ var configureMissingMethods = function configureMissingMethods() {
14220
+ var methodNotImplementedFactory = function methodNotImplementedFactory(methodName) {
14221
+ return function () {
14222
+ var error = new Error('Method ' + methodName + ' is not implemented by the current driver');
14223
+ var promise = Promise$1.reject(error);
14224
+ executeCallback(promise, arguments[arguments.length - 1]);
14225
+ return promise;
14226
+ };
14227
+ };
14228
+
14229
+ for (var _i = 0, _len = OptionalDriverMethods.length; _i < _len; _i++) {
14230
+ var optionalDriverMethod = OptionalDriverMethods[_i];
14231
+ if (!driverObject[optionalDriverMethod]) {
14232
+ driverObject[optionalDriverMethod] = methodNotImplementedFactory(optionalDriverMethod);
14233
+ }
14234
+ }
14235
+ };
14236
+
14237
+ configureMissingMethods();
14238
+
14239
+ var setDriverSupport = function setDriverSupport(support) {
14240
+ if (DefinedDrivers[driverName]) {
14241
+ console.info('Redefining LocalForage driver: ' + driverName);
14242
+ }
14243
+ DefinedDrivers[driverName] = driverObject;
14244
+ DriverSupport[driverName] = support;
14245
+ // don't use a then, so that we can define
14246
+ // drivers that have simple _support methods
14247
+ // in a blocking manner
14248
+ resolve();
14249
+ };
14250
+
14251
+ if ('_support' in driverObject) {
14252
+ if (driverObject._support && typeof driverObject._support === 'function') {
14253
+ driverObject._support().then(setDriverSupport, reject);
14254
+ } else {
14255
+ setDriverSupport(!!driverObject._support);
14256
+ }
14257
+ } else {
14258
+ setDriverSupport(true);
14259
+ }
14260
+ } catch (e) {
14261
+ reject(e);
14262
+ }
14263
+ });
14264
+
14265
+ executeTwoCallbacks(promise, callback, errorCallback);
14266
+ return promise;
14267
+ };
14268
+
14269
+ LocalForage.prototype.driver = function driver() {
14270
+ return this._driver || null;
14271
+ };
14272
+
14273
+ LocalForage.prototype.getDriver = function getDriver(driverName, callback, errorCallback) {
14274
+ var getDriverPromise = DefinedDrivers[driverName] ? Promise$1.resolve(DefinedDrivers[driverName]) : Promise$1.reject(new Error('Driver not found.'));
14275
+
14276
+ executeTwoCallbacks(getDriverPromise, callback, errorCallback);
14277
+ return getDriverPromise;
14278
+ };
14279
+
14280
+ LocalForage.prototype.getSerializer = function getSerializer(callback) {
14281
+ var serializerPromise = Promise$1.resolve(localforageSerializer);
14282
+ executeTwoCallbacks(serializerPromise, callback);
14283
+ return serializerPromise;
14284
+ };
14285
+
14286
+ LocalForage.prototype.ready = function ready(callback) {
14287
+ var self = this;
14288
+
14289
+ var promise = self._driverSet.then(function () {
14290
+ if (self._ready === null) {
14291
+ self._ready = self._initDriver();
14292
+ }
14293
+
14294
+ return self._ready;
14295
+ });
14296
+
14297
+ executeTwoCallbacks(promise, callback, callback);
14298
+ return promise;
14299
+ };
14300
+
14301
+ LocalForage.prototype.setDriver = function setDriver(drivers, callback, errorCallback) {
14302
+ var self = this;
14303
+
14304
+ if (!isArray(drivers)) {
14305
+ drivers = [drivers];
14306
+ }
14307
+
14308
+ var supportedDrivers = this._getSupportedDrivers(drivers);
14309
+
14310
+ function setDriverToConfig() {
14311
+ self._config.driver = self.driver();
14312
+ }
14313
+
14314
+ function extendSelfWithDriver(driver) {
14315
+ self._extend(driver);
14316
+ setDriverToConfig();
14317
+
14318
+ self._ready = self._initStorage(self._config);
14319
+ return self._ready;
14320
+ }
14321
+
14322
+ function initDriver(supportedDrivers) {
14323
+ return function () {
14324
+ var currentDriverIndex = 0;
14325
+
14326
+ function driverPromiseLoop() {
14327
+ while (currentDriverIndex < supportedDrivers.length) {
14328
+ var driverName = supportedDrivers[currentDriverIndex];
14329
+ currentDriverIndex++;
14330
+
14331
+ self._dbInfo = null;
14332
+ self._ready = null;
14333
+
14334
+ return self.getDriver(driverName).then(extendSelfWithDriver)["catch"](driverPromiseLoop);
14335
+ }
14336
+
14337
+ setDriverToConfig();
14338
+ var error = new Error('No available storage method found.');
14339
+ self._driverSet = Promise$1.reject(error);
14340
+ return self._driverSet;
14341
+ }
14342
+
14343
+ return driverPromiseLoop();
14344
+ };
14345
+ }
14346
+
14347
+ // There might be a driver initialization in progress
14348
+ // so wait for it to finish in order to avoid a possible
14349
+ // race condition to set _dbInfo
14350
+ var oldDriverSetDone = this._driverSet !== null ? this._driverSet["catch"](function () {
14351
+ return Promise$1.resolve();
14352
+ }) : Promise$1.resolve();
14353
+
14354
+ this._driverSet = oldDriverSetDone.then(function () {
14355
+ var driverName = supportedDrivers[0];
14356
+ self._dbInfo = null;
14357
+ self._ready = null;
14358
+
14359
+ return self.getDriver(driverName).then(function (driver) {
14360
+ self._driver = driver._driver;
14361
+ setDriverToConfig();
14362
+ self._wrapLibraryMethodsWithReady();
14363
+ self._initDriver = initDriver(supportedDrivers);
14364
+ });
14365
+ })["catch"](function () {
14366
+ setDriverToConfig();
14367
+ var error = new Error('No available storage method found.');
14368
+ self._driverSet = Promise$1.reject(error);
14369
+ return self._driverSet;
14370
+ });
14371
+
14372
+ executeTwoCallbacks(this._driverSet, callback, errorCallback);
14373
+ return this._driverSet;
14374
+ };
14375
+
14376
+ LocalForage.prototype.supports = function supports(driverName) {
14377
+ return !!DriverSupport[driverName];
14378
+ };
14379
+
14380
+ LocalForage.prototype._extend = function _extend(libraryMethodsAndProperties) {
14381
+ extend(this, libraryMethodsAndProperties);
14382
+ };
14383
+
14384
+ LocalForage.prototype._getSupportedDrivers = function _getSupportedDrivers(drivers) {
14385
+ var supportedDrivers = [];
14386
+ for (var i = 0, len = drivers.length; i < len; i++) {
14387
+ var driverName = drivers[i];
14388
+ if (this.supports(driverName)) {
14389
+ supportedDrivers.push(driverName);
14390
+ }
14391
+ }
14392
+ return supportedDrivers;
14393
+ };
14394
+
14395
+ LocalForage.prototype._wrapLibraryMethodsWithReady = function _wrapLibraryMethodsWithReady() {
14396
+ // Add a stub for each driver API method that delays the call to the
14397
+ // corresponding driver method until localForage is ready. These stubs
14398
+ // will be replaced by the driver methods as soon as the driver is
14399
+ // loaded, so there is no performance impact.
14400
+ for (var i = 0, len = LibraryMethods.length; i < len; i++) {
14401
+ callWhenReady(this, LibraryMethods[i]);
14402
+ }
14403
+ };
14404
+
14405
+ LocalForage.prototype.createInstance = function createInstance(options) {
14406
+ return new LocalForage(options);
14407
+ };
14408
+
14409
+ return LocalForage;
14410
+ }();
14411
+
14412
+ // The actual localForage object that we expose as a module or via a
14413
+ // global. It's extended by pulling in one of our other libraries.
14414
+
14415
+
14416
+ var localforage_js = new LocalForage();
14417
+
14418
+ module.exports = localforage_js;
14419
+
14420
+ },{"3":3}]},{},[4])(4)
14421
+ });
14422
+ } (localforage));
14423
+
14424
+ var localforageExports = localforage.exports;
14425
+ var localForage = /*@__PURE__*/getDefaultExportFromCjs(localforageExports);
11594
14426
 
11595
14427
  const _hoisted_1$7 = { class: "plus-table-expand-col" };
11596
14428
  var _sfc_main$d = /* @__PURE__ */ defineComponent({
@@ -11668,7 +14500,7 @@ var _sfc_main$d = /* @__PURE__ */ defineComponent({
11668
14500
  provide(TableFormFieldRefInjectionKey, formFieldRefs);
11669
14501
  watch(
11670
14502
  () => props.columns,
11671
- (val) => {
14503
+ async (val) => {
11672
14504
  let filterOriginColumns = val.filter((item) => unref(item.hideInTable) !== true);
11673
14505
  filterColumns.value = filterOriginColumns.map((item) => {
11674
14506
  var _a2;
@@ -11678,10 +14510,9 @@ var _sfc_main$d = /* @__PURE__ */ defineComponent({
11678
14510
  };
11679
14511
  });
11680
14512
  if (props.filterTableLocalKey) {
11681
- const localColumns = localStorage.getItem(props.filterTableLocalKey);
14513
+ let localColumns = await localForage.getItem(props.filterTableLocalKey);
11682
14514
  if (localColumns) {
11683
- filterColumns.value = JSON.parse(localColumns);
11684
- const columsMap = filterColumns.value.reduce((acc, item, order) => {
14515
+ const columsMap = localColumns.reduce((acc, item, order) => {
11685
14516
  acc[item.prop] = {
11686
14517
  visable: item.headerIsChecked,
11687
14518
  order
@@ -11693,7 +14524,11 @@ var _sfc_main$d = /* @__PURE__ */ defineComponent({
11693
14524
  item.headerIsChecked = columsMap[item.prop].visable;
11694
14525
  }
11695
14526
  });
11696
- filterOriginColumns.sort((a, b) => columsMap[a.prop].order - columsMap[b.prop].order);
14527
+ filterOriginColumns.sort((a, b) => {
14528
+ var _a2, _b2;
14529
+ return ((_a2 = columsMap[a.prop]) == null ? void 0 : _a2.order) - ((_b2 = columsMap[b.prop]) == null ? void 0 : _b2.order);
14530
+ });
14531
+ filterColumns.value = filterOriginColumns;
11697
14532
  }
11698
14533
  }
11699
14534
  subColumns.value = filterOriginColumns.filter((item) => unref(item.headerIsChecked) !== false);
@@ -11724,7 +14559,14 @@ var _sfc_main$d = /* @__PURE__ */ defineComponent({
11724
14559
  const handleFilterTableConfirm = (_columns, eventType) => {
11725
14560
  filterColumns.value = _columns;
11726
14561
  if (props.filterTableLocalKey) {
11727
- localStorage.setItem(props.filterTableLocalKey, JSON.stringify(filterColumns.value));
14562
+ const list = filterColumns.value.map(({ headerIsChecked, prop, width }) => {
14563
+ return {
14564
+ headerIsChecked,
14565
+ prop,
14566
+ width
14567
+ };
14568
+ });
14569
+ localForage.setItem(props.filterTableLocalKey, list);
11728
14570
  }
11729
14571
  emit("filterTableHeader", _columns, eventType);
11730
14572
  subColumns.value = _columns.filter(