Welcome to mirror list, hosted at ThFree Co, Russian Federation.

photos-vendors-node_modules_vue-virtual-grid_dist_vue-virtual-grid_es_js-node_modules_vue-material-d-e842b4.js.map « js - github.com/nextcloud/photos.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
blob: db34b26eec66ac71a05012ecc0c903ab92843bb5 (plain)
1
{"version":3,"file":"photos-vendors-node_modules_vue-virtual-grid_dist_vue-virtual-grid_es_js-node_modules_vue-material-d-e842b4.js?v=93137da1878b9b5e0ed0","mappings":";;;;;;;;;;;;;;;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;;;;;;;;;;ACl9BA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAkBA;AACA;;;;;;;;;;;;;;ACtCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;;;;;;;;ACpCA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;ACAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA","sources":["webpack:///photos/node_modules/vue-virtual-grid/dist/vue-virtual-grid.es.js","webpack:///photos/node_modules/vue-material-design-icons/ArrowLeft.vue","webpack:///photos/node_modules/vue-material-design-icons/ArrowLeft.vue?vue&type=script&lang=js&","webpack://photos/./node_modules/vue-material-design-icons/ArrowLeft.vue?de8a","webpack://photos/./node_modules/vue-material-design-icons/ArrowLeft.vue?33df"],"sourcesContent":["var __defProp = Object.defineProperty;\nvar __defProps = Object.defineProperties;\nvar __getOwnPropDescs = Object.getOwnPropertyDescriptors;\nvar __getOwnPropSymbols = Object.getOwnPropertySymbols;\nvar __hasOwnProp = Object.prototype.hasOwnProperty;\nvar __propIsEnum = Object.prototype.propertyIsEnumerable;\n\nvar __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, {\n  enumerable: true,\n  configurable: true,\n  writable: true,\n  value\n}) : obj[key] = value;\n\nvar __spreadValues = (a, b) => {\n  for (var prop in b || (b = {})) if (__hasOwnProp.call(b, prop)) __defNormalProp(a, prop, b[prop]);\n\n  if (__getOwnPropSymbols) for (var prop of __getOwnPropSymbols(b)) {\n    if (__propIsEnum.call(b, prop)) __defNormalProp(a, prop, b[prop]);\n  }\n  return a;\n};\n\nvar __spreadProps = (a, b) => __defProps(a, __getOwnPropDescs(b));\n\nimport Vue from \"vue\";\n/**\n  * vue-class-component v7.2.6\n  * (c) 2015-present Evan You\n  * @license MIT\n  */\n\nfunction _typeof(obj) {\n  if (typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\") {\n    _typeof = function (obj2) {\n      return typeof obj2;\n    };\n  } else {\n    _typeof = function (obj2) {\n      return obj2 && typeof Symbol === \"function\" && obj2.constructor === Symbol && obj2 !== Symbol.prototype ? \"symbol\" : typeof obj2;\n    };\n  }\n\n  return _typeof(obj);\n}\n\nfunction _defineProperty(obj, key, value) {\n  if (key in obj) {\n    Object.defineProperty(obj, key, {\n      value,\n      enumerable: true,\n      configurable: true,\n      writable: true\n    });\n  } else {\n    obj[key] = value;\n  }\n\n  return obj;\n}\n\nfunction _toConsumableArray(arr) {\n  return _arrayWithoutHoles(arr) || _iterableToArray(arr) || _nonIterableSpread();\n}\n\nfunction _arrayWithoutHoles(arr) {\n  if (Array.isArray(arr)) {\n    for (var i = 0, arr2 = new Array(arr.length); i < arr.length; i++) arr2[i] = arr[i];\n\n    return arr2;\n  }\n}\n\nfunction _iterableToArray(iter) {\n  if (Symbol.iterator in Object(iter) || Object.prototype.toString.call(iter) === \"[object Arguments]\") return Array.from(iter);\n}\n\nfunction _nonIterableSpread() {\n  throw new TypeError(\"Invalid attempt to spread non-iterable instance\");\n}\n\nfunction reflectionIsSupported() {\n  return typeof Reflect !== \"undefined\" && Reflect.defineMetadata && Reflect.getOwnMetadataKeys;\n}\n\nfunction copyReflectionMetadata(to, from) {\n  forwardMetadata(to, from);\n  Object.getOwnPropertyNames(from.prototype).forEach(function (key) {\n    forwardMetadata(to.prototype, from.prototype, key);\n  });\n  Object.getOwnPropertyNames(from).forEach(function (key) {\n    forwardMetadata(to, from, key);\n  });\n}\n\nfunction forwardMetadata(to, from, propertyKey) {\n  var metaKeys = propertyKey ? Reflect.getOwnMetadataKeys(from, propertyKey) : Reflect.getOwnMetadataKeys(from);\n  metaKeys.forEach(function (metaKey) {\n    var metadata = propertyKey ? Reflect.getOwnMetadata(metaKey, from, propertyKey) : Reflect.getOwnMetadata(metaKey, from);\n\n    if (propertyKey) {\n      Reflect.defineMetadata(metaKey, metadata, to, propertyKey);\n    } else {\n      Reflect.defineMetadata(metaKey, metadata, to);\n    }\n  });\n}\n\nvar fakeArray = {\n  __proto__: []\n};\nvar hasProto = fakeArray instanceof Array;\n\nfunction createDecorator(factory) {\n  return function (target, key, index) {\n    var Ctor = typeof target === \"function\" ? target : target.constructor;\n\n    if (!Ctor.__decorators__) {\n      Ctor.__decorators__ = [];\n    }\n\n    if (typeof index !== \"number\") {\n      index = void 0;\n    }\n\n    Ctor.__decorators__.push(function (options) {\n      return factory(options, key, index);\n    });\n  };\n}\n\nfunction isPrimitive(value) {\n  var type = _typeof(value);\n\n  return value == null || type !== \"object\" && type !== \"function\";\n}\n\nfunction collectDataFromConstructor(vm, Component2) {\n  var originalInit = Component2.prototype._init;\n\n  Component2.prototype._init = function () {\n    var _this = this;\n\n    var keys = Object.getOwnPropertyNames(vm);\n\n    if (vm.$options.props) {\n      for (var key in vm.$options.props) {\n        if (!vm.hasOwnProperty(key)) {\n          keys.push(key);\n        }\n      }\n    }\n\n    keys.forEach(function (key2) {\n      Object.defineProperty(_this, key2, {\n        get: function get() {\n          return vm[key2];\n        },\n        set: function set(value) {\n          vm[key2] = value;\n        },\n        configurable: true\n      });\n    });\n  };\n\n  var data = new Component2();\n  Component2.prototype._init = originalInit;\n  var plainData = {};\n  Object.keys(data).forEach(function (key) {\n    if (data[key] !== void 0) {\n      plainData[key] = data[key];\n    }\n  });\n  return plainData;\n}\n\nvar $internalHooks = [\"data\", \"beforeCreate\", \"created\", \"beforeMount\", \"mounted\", \"beforeDestroy\", \"destroyed\", \"beforeUpdate\", \"updated\", \"activated\", \"deactivated\", \"render\", \"errorCaptured\", \"serverPrefetch\"];\n\nfunction componentFactory(Component2) {\n  var options = arguments.length > 1 && arguments[1] !== void 0 ? arguments[1] : {};\n  options.name = options.name || Component2._componentTag || Component2.name;\n  var proto = Component2.prototype;\n  Object.getOwnPropertyNames(proto).forEach(function (key) {\n    if (key === \"constructor\") {\n      return;\n    }\n\n    if ($internalHooks.indexOf(key) > -1) {\n      options[key] = proto[key];\n      return;\n    }\n\n    var descriptor = Object.getOwnPropertyDescriptor(proto, key);\n\n    if (descriptor.value !== void 0) {\n      if (typeof descriptor.value === \"function\") {\n        (options.methods || (options.methods = {}))[key] = descriptor.value;\n      } else {\n        (options.mixins || (options.mixins = [])).push({\n          data: function data() {\n            return _defineProperty({}, key, descriptor.value);\n          }\n        });\n      }\n    } else if (descriptor.get || descriptor.set) {\n      (options.computed || (options.computed = {}))[key] = {\n        get: descriptor.get,\n        set: descriptor.set\n      };\n    }\n  });\n  (options.mixins || (options.mixins = [])).push({\n    data: function data() {\n      return collectDataFromConstructor(this, Component2);\n    }\n  });\n  var decorators = Component2.__decorators__;\n\n  if (decorators) {\n    decorators.forEach(function (fn) {\n      return fn(options);\n    });\n    delete Component2.__decorators__;\n  }\n\n  var superProto = Object.getPrototypeOf(Component2.prototype);\n  var Super = superProto instanceof Vue ? superProto.constructor : Vue;\n  var Extended = Super.extend(options);\n  forwardStaticMembers(Extended, Component2, Super);\n\n  if (reflectionIsSupported()) {\n    copyReflectionMetadata(Extended, Component2);\n  }\n\n  return Extended;\n}\n\nvar shouldIgnore = {\n  prototype: true,\n  arguments: true,\n  callee: true,\n  caller: true\n};\n\nfunction forwardStaticMembers(Extended, Original, Super) {\n  Object.getOwnPropertyNames(Original).forEach(function (key) {\n    if (shouldIgnore[key]) {\n      return;\n    }\n\n    var extendedDescriptor = Object.getOwnPropertyDescriptor(Extended, key);\n\n    if (extendedDescriptor && !extendedDescriptor.configurable) {\n      return;\n    }\n\n    var descriptor = Object.getOwnPropertyDescriptor(Original, key);\n\n    if (!hasProto) {\n      if (key === \"cid\") {\n        return;\n      }\n\n      var superDescriptor = Object.getOwnPropertyDescriptor(Super, key);\n\n      if (!isPrimitive(descriptor.value) && superDescriptor && superDescriptor.value === descriptor.value) {\n        return;\n      }\n    }\n\n    Object.defineProperty(Extended, key, descriptor);\n  });\n}\n\nfunction Component(options) {\n  if (typeof options === \"function\") {\n    return componentFactory(options);\n  }\n\n  return function (Component2) {\n    return componentFactory(Component2, options);\n  };\n}\n\nComponent.registerHooks = function registerHooks(keys) {\n  $internalHooks.push.apply($internalHooks, _toConsumableArray(keys));\n};\n\nglobalThis && globalThis.__spreadArrays || function () {\n  for (var s = 0, i = 0, il = arguments.length; i < il; i++) s += arguments[i].length;\n\n  for (var r = Array(s), k = 0, i = 0; i < il; i++) for (var a = arguments[i], j = 0, jl = a.length; j < jl; j++, k++) r[k] = a[j];\n\n  return r;\n};\n\nfunction needToProduceProvide(original) {\n  return typeof original !== \"function\" || !original.managed && !original.managedReactive;\n}\n\nfunction produceProvide(original) {\n  var provide = function () {\n    var _this = this;\n\n    var rv = typeof original === \"function\" ? original.call(this) : original;\n    rv = Object.create(rv || null);\n    rv[reactiveInjectKey] = Object.create(this[reactiveInjectKey] || {});\n\n    for (var i in provide.managed) {\n      rv[provide.managed[i]] = this[i];\n    }\n\n    var _loop_1 = function (i2) {\n      rv[provide.managedReactive[i2]] = this_1[i2];\n      Object.defineProperty(rv[reactiveInjectKey], provide.managedReactive[i2], {\n        enumerable: true,\n        configurable: true,\n        get: function () {\n          return _this[i2];\n        }\n      });\n    };\n\n    var this_1 = this;\n\n    for (var i in provide.managedReactive) {\n      _loop_1(i);\n    }\n\n    return rv;\n  };\n\n  provide.managed = {};\n  provide.managedReactive = {};\n  return provide;\n}\n\nvar reactiveInjectKey = \"__reactiveInject__\";\n\nfunction inheritInjected(componentOptions) {\n  if (!Array.isArray(componentOptions.inject)) {\n    componentOptions.inject = componentOptions.inject || {};\n    componentOptions.inject[reactiveInjectKey] = {\n      from: reactiveInjectKey,\n      default: {}\n    };\n  }\n}\n\nvar reflectMetadataIsSupported = typeof Reflect !== \"undefined\" && typeof Reflect.getMetadata !== \"undefined\";\n\nfunction applyMetadata(options, target, key) {\n  if (reflectMetadataIsSupported) {\n    if (!Array.isArray(options) && typeof options !== \"function\" && !options.hasOwnProperty(\"type\") && typeof options.type === \"undefined\") {\n      var type = Reflect.getMetadata(\"design:type\", target, key);\n\n      if (type !== Object) {\n        options.type = type;\n      }\n    }\n  }\n}\n\nfunction Prop(options) {\n  if (options === void 0) {\n    options = {};\n  }\n\n  return function (target, key) {\n    applyMetadata(options, target, key);\n    createDecorator(function (componentOptions, k) {\n      (componentOptions.props || (componentOptions.props = {}))[k] = options;\n    })(target, key);\n  };\n}\n\nfunction ProvideReactive(key) {\n  return createDecorator(function (componentOptions, k) {\n    var provide = componentOptions.provide;\n    inheritInjected(componentOptions);\n\n    if (needToProduceProvide(provide)) {\n      provide = componentOptions.provide = produceProvide(provide);\n    }\n\n    provide.managedReactive[k] = key || k;\n  });\n}\n\nfunction Watch(path, options) {\n  if (options === void 0) {\n    options = {};\n  }\n\n  var _a = options.deep,\n      deep = _a === void 0 ? false : _a,\n      _b = options.immediate,\n      immediate = _b === void 0 ? false : _b;\n  return createDecorator(function (componentOptions, handler) {\n    if (typeof componentOptions.watch !== \"object\") {\n      componentOptions.watch = /* @__PURE__ */Object.create(null);\n    }\n\n    var watch = componentOptions.watch;\n\n    if (typeof watch[path] === \"object\" && !Array.isArray(watch[path])) {\n      watch[path] = [watch[path]];\n    } else if (typeof watch[path] === \"undefined\") {\n      watch[path] = [];\n    }\n\n    watch[path].push({\n      handler,\n      deep,\n      immediate\n    });\n  });\n}\n\nconst getGridGapDefault = (elementWidth, windowHeight) => {\n  if (elementWidth > 720 && windowHeight > 480) {\n    return 10;\n  } else {\n    return 5;\n  }\n};\n\nconst getColumnCountDefault = elementWidth => {\n  return Math.floor(elementWidth / 250);\n};\n\nconst getWindowMarginDefault = windowHeight => {\n  return Math.round(windowHeight * 1.5);\n};\n\nconst getItemRatioHeightDefault = (height, width, columnWidth) => {\n  const imageRatio = height / width;\n  return Math.round(columnWidth * imageRatio);\n};\n\nconst debugLog = function (condition) {\n  if (condition) {\n    for (var _len = arguments.length, args = new Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) {\n      args[_key - 1] = arguments[_key];\n    }\n\n    console.debug(...args);\n  }\n};\n\nvar __defProp2 = Object.defineProperty;\nvar __getOwnPropDesc = Object.getOwnPropertyDescriptor;\n\nvar __decorateClass = (decorators, target, key, kind) => {\n  var result = kind > 1 ? void 0 : kind ? __getOwnPropDesc(target, key) : target;\n\n  for (var i = decorators.length - 1, decorator; i >= 0; i--) if (decorator = decorators[i]) result = (kind ? decorator(target, key, result) : decorator(result)) || result;\n\n  if (kind && result) __defProp2(target, key, result);\n  return result;\n};\n\nlet VirtualGrid$1 = class extends Vue {\n  constructor() {\n    super(...arguments);\n    this.updateLock = false;\n    this.bottomReached = false;\n    this.ref = null;\n    this.containerData = {\n      windowSize: {\n        height: 0,\n        width: 0\n      },\n      windowScroll: {\n        x: 0,\n        y: 0\n      },\n      elementWindowOffset: 0,\n      elementSize: {\n        height: 0,\n        width: 0\n      }\n    };\n  }\n\n  get loadingBatch() {\n    return this.loader && this.updateLock;\n  }\n\n  get configData() {\n    return this.computeConfigData(this.containerData, this.items);\n  }\n\n  get layoutData() {\n    return this.computeLayoutData(this.configData);\n  }\n\n  get renderData() {\n    return this.computeRenderData(this.configData, this.containerData, this.layoutData);\n  }\n\n  mounted() {\n    var _a;\n\n    this.ref = this.$refs.virtualGrid;\n    this.initiliazeGrid();\n    window.addEventListener(\"resize\", this.resize);\n    ((_a = this.scrollElement) != null ? _a : window).addEventListener(\"scroll\", this.scroll);\n  }\n\n  beforeDestroy() {\n    var _a;\n\n    window.removeEventListener(\"resize\", this.resize);\n    ((_a = this.scrollElement) != null ? _a : window).removeEventListener(\"scroll\", this.scroll);\n  }\n\n  onScrollElementChanged(scrollElement, oldScrollElement) {\n    (oldScrollElement != null ? oldScrollElement : window).removeEventListener(\"scroll\", this.scroll);\n    (scrollElement != null ? scrollElement : window).addEventListener(\"scroll\", this.scroll);\n  }\n\n  resize() {\n    this.loadMoreData();\n  }\n\n  scroll() {\n    this.loadMoreData();\n  }\n\n  initiliazeGrid() {\n    this.computeContainerData();\n    this.$nextTick(async () => {\n      this.loadMoreData();\n    });\n  }\n\n  loadMoreData() {\n    this.loadMoreDataAsync().catch(error => {\n      if (error) {\n        console.error(\"Fail to load next data batch\", error);\n      }\n    }).then();\n  }\n\n  async loadMoreDataAsync() {\n    this.computeContainerData();\n    const windowTop = this.containerData.windowScroll.y;\n    const windowBottom = windowTop + this.containerData.windowSize.height;\n    const bottomTrigger = Math.max(0, this.containerData.elementWindowOffset + this.containerData.elementSize.height - this.updateTriggerMargin);\n\n    if (!this.bottomReached && windowBottom >= bottomTrigger && !this.updateLock) {\n      this.updateLock = true;\n      debugLog(this.debug, \"Loading next batch\");\n      const isLastBatch = await this.updateFunction();\n\n      if (isLastBatch) {\n        debugLog(this.debug, \"Bottom reached\");\n        this.bottomReached = true;\n      }\n\n      this.updateLock = false;\n      await this.loadMoreDataAsync();\n    }\n\n    return;\n  }\n\n  computeContainerData() {\n    if (this.ref === null) {\n      return;\n    }\n\n    const windowSize = this.getWindowSize();\n    const windowScroll = this.getWindowScroll();\n    const elementWindowOffset = this.getElementOffset(this.ref);\n    const elementSize = this.getElementSize(this.ref);\n    this.containerData = {\n      windowSize,\n      windowScroll,\n      elementWindowOffset,\n      elementSize\n    };\n  }\n\n  computeConfigData(containerData, items) {\n    if (containerData === null || items === null) {\n      return {\n        windowMargin: 0,\n        gridGap: 0,\n        columnCount: 1,\n        entries: []\n      };\n    }\n\n    const elementWidth = containerData.elementSize ? containerData.elementSize.width : 0;\n    const windowMargin = this.getWindowMargin(containerData.windowSize.height);\n    const gridGap = this.getGridGap(elementWidth, containerData.windowSize.height);\n    const columnCount = this.getColumnCount(elementWidth);\n    const columnWidth = this.getColumnWidth(columnCount, gridGap, elementWidth);\n    const entries = items.map(item => {\n      if (!item.width) {\n        return item;\n      }\n\n      const imageWidth = columnWidth * item.columnSpan + gridGap * (item.columnSpan - 1);\n      return __spreadProps(__spreadValues({}, item), {\n        height: this.getItemRatioHeight(item.height, item.width, imageWidth),\n        width: imageWidth\n      });\n    });\n    return {\n      windowMargin,\n      gridGap,\n      columnCount,\n      entries\n    };\n  }\n\n  computeLayoutData(configData) {\n    if (configData === null) {\n      return {\n        cells: [],\n        totalHeight: 0\n      };\n    }\n\n    let currentRowNumber = 1;\n    let prevRowsTotalHeight = 0;\n    let currentRowMaxHeight = 0;\n    let columnShift = 0;\n    const cells = configData.entries.map((entry, index) => {\n      const {\n        columnCount,\n        gridGap\n      } = configData;\n      let columnSpanRecompute = entry.columnSpan;\n      let heightRecompute = entry.height;\n\n      if (columnSpanRecompute < 1) {\n        columnSpanRecompute = columnCount;\n      }\n\n      const distanceToRowStart = (index + columnShift) % columnCount;\n\n      if (entry.newRow && distanceToRowStart !== 0) {\n        columnShift += columnCount - distanceToRowStart;\n      }\n\n      const shiftedIndex = index + columnShift;\n      const columnNumber = shiftedIndex % columnCount + 1;\n      const rowNumber = Math.floor(shiftedIndex / columnCount) + 1;\n\n      if (columnNumber + columnSpanRecompute > columnCount + 1) {\n        const overlapNumber = columnNumber + columnSpanRecompute - columnCount - 1;\n        const overlapRatio = overlapNumber / columnSpanRecompute;\n        heightRecompute = heightRecompute * (1 - overlapRatio);\n        columnSpanRecompute -= overlapNumber;\n      }\n\n      if (columnSpanRecompute > 1) {\n        columnShift += columnSpanRecompute - 1;\n      }\n\n      if (rowNumber !== currentRowNumber) {\n        currentRowNumber = rowNumber;\n        prevRowsTotalHeight += currentRowMaxHeight + gridGap;\n        currentRowMaxHeight = 0;\n      }\n\n      const offset = prevRowsTotalHeight;\n      const height = Math.round(heightRecompute);\n      currentRowMaxHeight = Math.max(currentRowMaxHeight, height);\n      return __spreadProps(__spreadValues({}, entry), {\n        columnNumber,\n        rowNumber,\n        offset,\n        height,\n        columnSpan: columnSpanRecompute\n      });\n    });\n    const totalHeight = prevRowsTotalHeight + currentRowMaxHeight;\n    return {\n      cells,\n      totalHeight\n    };\n  }\n\n  computeRenderData(configData, containerData, layoutData) {\n    if (layoutData === null || configData === null) {\n      return {\n        cellsToRender: [],\n        firstRenderedRowNumber: 0,\n        firstRenderedRowOffset: 0\n      };\n    }\n\n    const cellsToRender = [];\n    let firstRenderedRowNumber = null;\n    let firstRenderedRowOffset = null;\n\n    if (containerData.elementWindowOffset !== null) {\n      const elementWindowOffset = containerData.elementWindowOffset;\n\n      for (const cell of layoutData.cells) {\n        const cellTop = elementWindowOffset + cell.offset;\n        const cellBottom = cellTop + cell.height;\n        const windowTop = containerData.windowScroll.y;\n        const windowBottom = windowTop + containerData.windowSize.height;\n        const renderTop = windowTop - configData.windowMargin;\n        const renderBottom = windowBottom + configData.windowMargin;\n\n        if (cellTop > renderBottom) {\n          continue;\n        }\n\n        if (cellBottom < renderTop) {\n          continue;\n        }\n\n        if (firstRenderedRowNumber === null) {\n          firstRenderedRowNumber = cell.rowNumber;\n        }\n\n        if (cell.rowNumber === firstRenderedRowNumber) {\n          firstRenderedRowOffset = firstRenderedRowOffset ? Math.min(firstRenderedRowOffset, cell.offset) : cell.offset;\n        }\n\n        cellsToRender.push(cell);\n      }\n    }\n\n    return {\n      cellsToRender,\n      firstRenderedRowNumber,\n      firstRenderedRowOffset\n    };\n  }\n\n  getColumnWidth(columnCount, gridGap, elementWidth) {\n    if (columnCount === null || gridGap === null || elementWidth === null) {\n      return 0;\n    }\n\n    const totalGapSpace = (columnCount - 1) * gridGap;\n    const columnWidth = Math.round((elementWidth - totalGapSpace) / columnCount);\n    return columnWidth;\n  }\n\n  getGridRowStart(cell, renderData) {\n    if (renderData === null) {\n      return void 0;\n    }\n\n    const offset = renderData.firstRenderedRowNumber !== null ? renderData.firstRenderedRowNumber - 1 : 0;\n    const gridRowStart = cell.rowNumber - offset;\n    return `${gridRowStart}`;\n  }\n\n  resetGrid() {\n    this.bottomReached = false;\n    this.loadMoreData();\n  }\n\n  isSameElementSize(a, b) {\n    return a.width === b.width && a.height === b.height;\n  }\n\n  getWindowSize() {\n    return {\n      width: window.innerWidth,\n      height: window.innerHeight\n    };\n  }\n\n  getElementSize(element) {\n    const rect = element.getBoundingClientRect();\n    return {\n      width: rect.width,\n      height: rect.height\n    };\n  }\n\n  isSameElementScroll(a, b) {\n    return a.x === b.x && a.y === b.y;\n  }\n\n  getWindowScroll() {\n    return {\n      x: window.scrollX,\n      y: window.scrollY\n    };\n  }\n\n  getElementOffset(element) {\n    return window.scrollY + element.getBoundingClientRect().top;\n  }\n\n};\n\n__decorateClass([Prop({\n  required: true\n})], VirtualGrid$1.prototype, \"items\", 2);\n\n__decorateClass([Prop({\n  default: () => () => true\n})], VirtualGrid$1.prototype, \"updateFunction\", 2);\n\n__decorateClass([Prop({\n  default: () => getGridGapDefault\n})], VirtualGrid$1.prototype, \"getGridGap\", 2);\n\n__decorateClass([Prop({\n  default: () => getColumnCountDefault\n})], VirtualGrid$1.prototype, \"getColumnCount\", 2);\n\n__decorateClass([Prop({\n  default: () => getWindowMarginDefault\n})], VirtualGrid$1.prototype, \"getWindowMargin\", 2);\n\n__decorateClass([Prop({\n  default: () => getItemRatioHeightDefault\n})], VirtualGrid$1.prototype, \"getItemRatioHeight\", 2);\n\n__decorateClass([Prop({\n  default: null\n})], VirtualGrid$1.prototype, \"scrollElement\", 2);\n\n__decorateClass([Prop({\n  default: 500\n})], VirtualGrid$1.prototype, \"updateTriggerMargin\", 2);\n\n__decorateClass([Prop({\n  default: null\n})], VirtualGrid$1.prototype, \"loader\", 2);\n\n__decorateClass([Prop({\n  default: false\n})], VirtualGrid$1.prototype, \"debug\", 2);\n\n__decorateClass([ProvideReactive()], VirtualGrid$1.prototype, \"updateLock\", 2);\n\n__decorateClass([ProvideReactive()], VirtualGrid$1.prototype, \"bottomReached\", 2);\n\n__decorateClass([ProvideReactive()], VirtualGrid$1.prototype, \"ref\", 2);\n\n__decorateClass([ProvideReactive()], VirtualGrid$1.prototype, \"containerData\", 2);\n\n__decorateClass([Watch(\"scrollElement\")], VirtualGrid$1.prototype, \"onScrollElementChanged\", 1);\n\nVirtualGrid$1 = __decorateClass([Component({\n  name: \"VirtualGrid\"\n})], VirtualGrid$1);\n\nvar render = function () {\n  var _vm = this;\n\n  var _h = _vm.$createElement;\n\n  var _c = _vm._self._c || _h;\n\n  return _c(\"div\", {\n    ref: \"virtualGrid\",\n    style: {\n      boxSizing: \"border-box\",\n      height: _vm.layoutData.totalHeight + \"px\",\n      paddingTop: _vm.renderData !== null && _vm.renderData.firstRenderedRowOffset !== null ? _vm.renderData.firstRenderedRowOffset + \"px\" : \"0px\"\n    }\n  }, [_c(\"div\", {\n    staticClass: \"grid\",\n    style: {\n      \"display\": \"-ms-grid\",\n      \"display\": \"grid\",\n      \"align-items\": \"center\",\n      \"grid-template-columns\": \"repeat(\" + _vm.configData.columnCount + \", 1fr)\",\n      \"gap\": _vm.configData.gridGap + \"px\"\n    }\n  }, _vm._l(_vm.renderData.cellsToRender, function (item) {\n    return _c(\"div\", {\n      key: item.id,\n      staticClass: \"grid-item-wrapper\",\n      style: {\n        \"height\": item.height + \"px\",\n        \"grid-column-start\": item.columnNumber,\n        \"grid-column-end\": item.columnNumber + item.columnSpan,\n        \"grid-row-start\": _vm.getGridRowStart(item, _vm.renderData)\n      }\n    }, [_c(item.renderComponent, _vm._g({\n      tag: \"component\",\n      attrs: {\n        \"item\": item\n      }\n    }, _vm.$listeners))], 1);\n  }), 0), _c(_vm.loadingBatch && _vm.loader, {\n    tag: \"component\"\n  })], 1);\n};\n\nvar staticRenderFns = [];\n\nfunction normalizeComponent(scriptExports, render2, staticRenderFns2, functionalTemplate, injectStyles, scopeId, moduleIdentifier, shadowMode) {\n  var options = typeof scriptExports === \"function\" ? scriptExports.options : scriptExports;\n\n  if (render2) {\n    options.render = render2;\n    options.staticRenderFns = staticRenderFns2;\n    options._compiled = true;\n  }\n\n  if (functionalTemplate) {\n    options.functional = true;\n  }\n\n  if (scopeId) {\n    options._scopeId = \"data-v-\" + scopeId;\n  }\n\n  var hook;\n\n  if (moduleIdentifier) {\n    hook = function (context) {\n      context = context || this.$vnode && this.$vnode.ssrContext || this.parent && this.parent.$vnode && this.parent.$vnode.ssrContext;\n\n      if (!context && typeof __VUE_SSR_CONTEXT__ !== \"undefined\") {\n        context = __VUE_SSR_CONTEXT__;\n      }\n\n      if (injectStyles) {\n        injectStyles.call(this, context);\n      }\n\n      if (context && context._registeredComponents) {\n        context._registeredComponents.add(moduleIdentifier);\n      }\n    };\n\n    options._ssrRegister = hook;\n  } else if (injectStyles) {\n    hook = shadowMode ? function () {\n      injectStyles.call(this, (options.functional ? this.parent : this).$root.$options.shadowRoot);\n    } : injectStyles;\n  }\n\n  if (hook) {\n    if (options.functional) {\n      options._injectStyles = hook;\n      var originalRender = options.render;\n\n      options.render = function renderWithStyleInjection(h, context) {\n        hook.call(context);\n        return originalRender(h, context);\n      };\n    } else {\n      var existing = options.beforeCreate;\n      options.beforeCreate = existing ? [].concat(existing, hook) : [hook];\n    }\n  }\n\n  return {\n    exports: scriptExports,\n    options\n  };\n}\n\nconst __cssModules = {};\n\nvar __component__ = /* @__PURE__ */normalizeComponent(VirtualGrid$1, render, staticRenderFns, false, __vue2_injectStyles, null, null, null);\n\nfunction __vue2_injectStyles(context) {\n  for (let o in __cssModules) {\n    this[o] = __cssModules[o];\n  }\n}\n\nvar VirtualGrid = /* @__PURE__ */function () {\n  return __component__.exports;\n}();\n\nexport { VirtualGrid as default };","import { render, staticRenderFns } from \"./ArrowLeft.vue?vue&type=template&id=b9ea0198&\"\nimport script from \"./ArrowLeft.vue?vue&type=script&lang=js&\"\nexport * from \"./ArrowLeft.vue?vue&type=script&lang=js&\"\n\n\n/* normalize component */\nimport normalizer from \"!../vue-loader/lib/runtime/componentNormalizer.js\"\nvar component = normalizer(\n  script,\n  render,\n  staticRenderFns,\n  false,\n  null,\n  null,\n  null\n  \n)\n\n/* hot reload */\nif (module.hot) {\n  var api = require(\"/home/louis/workspace/nextcloud/apps/photos/node_modules/vue-hot-reload-api/dist/index.js\")\n  api.install(require('vue'))\n  if (api.compatible) {\n    module.hot.accept()\n    if (!api.isRecorded('b9ea0198')) {\n      api.createRecord('b9ea0198', component.options)\n    } else {\n      api.reload('b9ea0198', component.options)\n    }\n    module.hot.accept(\"./ArrowLeft.vue?vue&type=template&id=b9ea0198&\", function () {\n      api.rerender('b9ea0198', {\n        render: render,\n        staticRenderFns: staticRenderFns\n      })\n    })\n  }\n}\ncomponent.options.__file = \"node_modules/vue-material-design-icons/ArrowLeft.vue\"\nexport default component.exports","//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n\nexport default {\n  name: \"ArrowLeftIcon\",\n  emits: ['click'],\n  props: {\n    title: {\n      type: String,\n    },\n    fillColor: {\n      type: String,\n      default: \"currentColor\"\n    },\n    size: {\n      type: Number,\n      default: 24\n    }\n  }\n}\n","import mod from \"-!../vue-loader/lib/index.js??vue-loader-options!./ArrowLeft.vue?vue&type=script&lang=js&\"; export default mod; export * from \"-!../vue-loader/lib/index.js??vue-loader-options!./ArrowLeft.vue?vue&type=script&lang=js&\"","var render = function () {\n  var _vm = this\n  var _h = _vm.$createElement\n  var _c = _vm._self._c || _h\n  return _c(\n    \"span\",\n    _vm._b(\n      {\n        staticClass: \"material-design-icon arrow-left-icon\",\n        attrs: {\n          \"aria-hidden\": !_vm.title,\n          \"aria-label\": _vm.title,\n          role: \"img\",\n        },\n        on: {\n          click: function ($event) {\n            return _vm.$emit(\"click\", $event)\n          },\n        },\n      },\n      \"span\",\n      _vm.$attrs,\n      false\n    ),\n    [\n      _c(\n        \"svg\",\n        {\n          staticClass: \"material-design-icon__svg\",\n          attrs: {\n            fill: _vm.fillColor,\n            width: _vm.size,\n            height: _vm.size,\n            viewBox: \"0 0 24 24\",\n          },\n        },\n        [\n          _c(\n            \"path\",\n            {\n              attrs: {\n                d: \"M20,11V13H8L13.5,18.5L12.08,19.92L4.16,12L12.08,4.08L13.5,5.5L8,11H20Z\",\n              },\n            },\n            [_vm.title ? _c(\"title\", [_vm._v(_vm._s(_vm.title))]) : _vm._e()]\n          ),\n        ]\n      ),\n    ]\n  )\n}\nvar staticRenderFns = []\nrender._withStripped = true\n\nexport { render, staticRenderFns }"],"names":[],"sourceRoot":""}