wuffle 0.44.3 → 0.45.2
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.
package/public/bundle.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"bundle.js","sources":["../../board/node_modules/min-dash/dist/index.esm.js","../../board/node_modules/svelte/internal/index.mjs","../../board/src/util/Id.js","../../board/src/util/local-store.js","../../board/src/util/history.js","../../board/src/util/index.js","../../board/src/components/HintList.svelte","../../board/src/shortcuts.js","../../board/src/BoardFilter.svelte","../../board/src/components/Avatar.svelte","../../board/src/components/Loader.svelte","../../board/src/PoweredBy.svelte","../../board/src/components/Notifications.svelte","../../board/node_modules/svelte/easing/index.mjs","../../board/node_modules/svelte/transition/index.mjs","../../board/src/components/Notification.svelte","../../board/src/components/Tag.svelte","../../board/src/components/PullRequestIcon.svelte","../../board/src/components/EpicIcon.svelte","../../board/src/CardStatus.svelte","../../board/src/CollaboratorLinks.svelte","../../board/src/components/LinkIcon.svelte","../../board/src/CardLink.svelte","../../board/src/Card.svelte","../../board/src/RepositorySelect.svelte","../../board/src/CreateIssue.svelte","../../board/src/Api.js","../../board/node_modules/atoa/atoa.js","../../board/node_modules/ticky/ticky.js","../../board/node_modules/contra/debounce.js","../../board/node_modules/contra/emitter.js","../../board/node_modules/custom-event/index.js","../../board/node_modules/crossvent/src/eventmap.js","../../board/node_modules/crossvent/src/crossvent.js","../../board/node_modules/dragula/classes.js","../../board/node_modules/dragula/dragula.js","../../board/src/Taskboard.svelte","../../board/src/logo-gray.svg","../../board/src/error.svg","../../board/src/util/links.js","../../board/src/main.js"],"sourcesContent":["/**\n * Flatten array, one level deep.\n *\n * @param {Array<?>} arr\n *\n * @return {Array<?>}\n */\nfunction flatten(arr) {\n return Array.prototype.concat.apply([], arr);\n}\n\nvar nativeToString = Object.prototype.toString;\nvar nativeHasOwnProperty = Object.prototype.hasOwnProperty;\nfunction isUndefined(obj) {\n return obj === undefined;\n}\nfunction isDefined(obj) {\n return obj !== undefined;\n}\nfunction isNil(obj) {\n return obj == null;\n}\nfunction isArray(obj) {\n return nativeToString.call(obj) === '[object Array]';\n}\nfunction isObject(obj) {\n return nativeToString.call(obj) === '[object Object]';\n}\nfunction isNumber(obj) {\n return nativeToString.call(obj) === '[object Number]';\n}\nfunction isFunction(obj) {\n var tag = nativeToString.call(obj);\n return tag === '[object Function]' || tag === '[object AsyncFunction]' || tag === '[object GeneratorFunction]' || tag === '[object AsyncGeneratorFunction]' || tag === '[object Proxy]';\n}\nfunction isString(obj) {\n return nativeToString.call(obj) === '[object String]';\n}\n/**\n * Ensure collection is an array.\n *\n * @param {Object} obj\n */\n\nfunction ensureArray(obj) {\n if (isArray(obj)) {\n return;\n }\n\n throw new Error('must supply array');\n}\n/**\n * Return true, if target owns a property with the given key.\n *\n * @param {Object} target\n * @param {String} key\n *\n * @return {Boolean}\n */\n\nfunction has(target, key) {\n return nativeHasOwnProperty.call(target, key);\n}\n\n/**\n * Find element in collection.\n *\n * @param {Array|Object} collection\n * @param {Function|Object} matcher\n *\n * @return {Object}\n */\n\nfunction find(collection, matcher) {\n matcher = toMatcher(matcher);\n var match;\n forEach(collection, function (val, key) {\n if (matcher(val, key)) {\n match = val;\n return false;\n }\n });\n return match;\n}\n/**\n * Find element index in collection.\n *\n * @param {Array|Object} collection\n * @param {Function} matcher\n *\n * @return {Object}\n */\n\nfunction findIndex(collection, matcher) {\n matcher = toMatcher(matcher);\n var idx = isArray(collection) ? -1 : undefined;\n forEach(collection, function (val, key) {\n if (matcher(val, key)) {\n idx = key;\n return false;\n }\n });\n return idx;\n}\n/**\n * Find element in collection.\n *\n * @param {Array|Object} collection\n * @param {Function} matcher\n *\n * @return {Array} result\n */\n\nfunction filter(collection, matcher) {\n var result = [];\n forEach(collection, function (val, key) {\n if (matcher(val, key)) {\n result.push(val);\n }\n });\n return result;\n}\n/**\n * Iterate over collection; returning something\n * (non-undefined) will stop iteration.\n *\n * @param {Array|Object} collection\n * @param {Function} iterator\n *\n * @return {Object} return result that stopped the iteration\n */\n\nfunction forEach(collection, iterator) {\n var val, result;\n\n if (isUndefined(collection)) {\n return;\n }\n\n var convertKey = isArray(collection) ? toNum : identity;\n\n for (var key in collection) {\n if (has(collection, key)) {\n val = collection[key];\n result = iterator(val, convertKey(key));\n\n if (result === false) {\n return val;\n }\n }\n }\n}\n/**\n * Return collection without element.\n *\n * @param {Array} arr\n * @param {Function} matcher\n *\n * @return {Array}\n */\n\nfunction without(arr, matcher) {\n if (isUndefined(arr)) {\n return [];\n }\n\n ensureArray(arr);\n matcher = toMatcher(matcher);\n return arr.filter(function (el, idx) {\n return !matcher(el, idx);\n });\n}\n/**\n * Reduce collection, returning a single result.\n *\n * @param {Object|Array} collection\n * @param {Function} iterator\n * @param {Any} result\n *\n * @return {Any} result returned from last iterator\n */\n\nfunction reduce(collection, iterator, result) {\n forEach(collection, function (value, idx) {\n result = iterator(result, value, idx);\n });\n return result;\n}\n/**\n * Return true if every element in the collection\n * matches the criteria.\n *\n * @param {Object|Array} collection\n * @param {Function} matcher\n *\n * @return {Boolean}\n */\n\nfunction every(collection, matcher) {\n return !!reduce(collection, function (matches, val, key) {\n return matches && matcher(val, key);\n }, true);\n}\n/**\n * Return true if some elements in the collection\n * match the criteria.\n *\n * @param {Object|Array} collection\n * @param {Function} matcher\n *\n * @return {Boolean}\n */\n\nfunction some(collection, matcher) {\n return !!find(collection, matcher);\n}\n/**\n * Transform a collection into another collection\n * by piping each member through the given fn.\n *\n * @param {Object|Array} collection\n * @param {Function} fn\n *\n * @return {Array} transformed collection\n */\n\nfunction map(collection, fn) {\n var result = [];\n forEach(collection, function (val, key) {\n result.push(fn(val, key));\n });\n return result;\n}\n/**\n * Get the collections keys.\n *\n * @param {Object|Array} collection\n *\n * @return {Array}\n */\n\nfunction keys(collection) {\n return collection && Object.keys(collection) || [];\n}\n/**\n * Shorthand for `keys(o).length`.\n *\n * @param {Object|Array} collection\n *\n * @return {Number}\n */\n\nfunction size(collection) {\n return keys(collection).length;\n}\n/**\n * Get the values in the collection.\n *\n * @param {Object|Array} collection\n *\n * @return {Array}\n */\n\nfunction values(collection) {\n return map(collection, function (val) {\n return val;\n });\n}\n/**\n * Group collection members by attribute.\n *\n * @param {Object|Array} collection\n * @param {Function} extractor\n *\n * @return {Object} map with { attrValue => [ a, b, c ] }\n */\n\nfunction groupBy(collection, extractor) {\n var grouped = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {};\n extractor = toExtractor(extractor);\n forEach(collection, function (val) {\n var discriminator = extractor(val) || '_';\n var group = grouped[discriminator];\n\n if (!group) {\n group = grouped[discriminator] = [];\n }\n\n group.push(val);\n });\n return grouped;\n}\nfunction uniqueBy(extractor) {\n extractor = toExtractor(extractor);\n var grouped = {};\n\n for (var _len = arguments.length, collections = new Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) {\n collections[_key - 1] = arguments[_key];\n }\n\n forEach(collections, function (c) {\n return groupBy(c, extractor, grouped);\n });\n var result = map(grouped, function (val, key) {\n return val[0];\n });\n return result;\n}\nvar unionBy = uniqueBy;\n/**\n * Sort collection by criteria.\n *\n * @param {Object|Array} collection\n * @param {String|Function} extractor\n *\n * @return {Array}\n */\n\nfunction sortBy(collection, extractor) {\n extractor = toExtractor(extractor);\n var sorted = [];\n forEach(collection, function (value, key) {\n var disc = extractor(value, key);\n var entry = {\n d: disc,\n v: value\n };\n\n for (var idx = 0; idx < sorted.length; idx++) {\n var d = sorted[idx].d;\n\n if (disc < d) {\n sorted.splice(idx, 0, entry);\n return;\n }\n } // not inserted, append (!)\n\n\n sorted.push(entry);\n });\n return map(sorted, function (e) {\n return e.v;\n });\n}\n/**\n * Create an object pattern matcher.\n *\n * @example\n *\n * const matcher = matchPattern({ id: 1 });\n *\n * let element = find(elements, matcher);\n *\n * @param {Object} pattern\n *\n * @return {Function} matcherFn\n */\n\nfunction matchPattern(pattern) {\n return function (el) {\n return every(pattern, function (val, key) {\n return el[key] === val;\n });\n };\n}\n\nfunction toExtractor(extractor) {\n return isFunction(extractor) ? extractor : function (e) {\n return e[extractor];\n };\n}\n\nfunction toMatcher(matcher) {\n return isFunction(matcher) ? matcher : function (e) {\n return e === matcher;\n };\n}\n\nfunction identity(arg) {\n return arg;\n}\n\nfunction toNum(arg) {\n return Number(arg);\n}\n\n/**\n * Debounce fn, calling it only once if the given time\n * elapsed between calls.\n *\n * Lodash-style the function exposes methods to `#clear`\n * and `#flush` to control internal behavior.\n *\n * @param {Function} fn\n * @param {Number} timeout\n *\n * @return {Function} debounced function\n */\nfunction debounce(fn, timeout) {\n var timer;\n var lastArgs;\n var lastThis;\n var lastNow;\n\n function fire(force) {\n var now = Date.now();\n var scheduledDiff = force ? 0 : lastNow + timeout - now;\n\n if (scheduledDiff > 0) {\n return schedule(scheduledDiff);\n }\n\n fn.apply(lastThis, lastArgs);\n clear();\n }\n\n function schedule(timeout) {\n timer = setTimeout(fire, timeout);\n }\n\n function clear() {\n if (timer) {\n clearTimeout(timer);\n }\n\n timer = lastNow = lastArgs = lastThis = undefined;\n }\n\n function flush() {\n if (timer) {\n fire(true);\n }\n\n clear();\n }\n\n function callback() {\n lastNow = Date.now();\n\n for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {\n args[_key] = arguments[_key];\n }\n\n lastArgs = args;\n lastThis = this; // ensure an execution is scheduled\n\n if (!timer) {\n schedule(timeout);\n }\n }\n\n callback.flush = flush;\n callback.cancel = clear;\n return callback;\n}\n/**\n * Throttle fn, calling at most once\n * in the given interval.\n *\n * @param {Function} fn\n * @param {Number} interval\n *\n * @return {Function} throttled function\n */\n\nfunction throttle(fn, interval) {\n var throttling = false;\n return function () {\n if (throttling) {\n return;\n }\n\n fn.apply(void 0, arguments);\n throttling = true;\n setTimeout(function () {\n throttling = false;\n }, interval);\n };\n}\n/**\n * Bind function against target <this>.\n *\n * @param {Function} fn\n * @param {Object} target\n *\n * @return {Function} bound function\n */\n\nfunction bind(fn, target) {\n return fn.bind(target);\n}\n\nfunction _extends() {\n _extends = Object.assign || function (target) {\n for (var i = 1; i < arguments.length; i++) {\n var source = arguments[i];\n\n for (var key in source) {\n if (Object.prototype.hasOwnProperty.call(source, key)) {\n target[key] = source[key];\n }\n }\n }\n\n return target;\n };\n\n return _extends.apply(this, arguments);\n}\n\n/**\n * Convenience wrapper for `Object.assign`.\n *\n * @param {Object} target\n * @param {...Object} others\n *\n * @return {Object} the target\n */\n\nfunction assign(target) {\n for (var _len = arguments.length, others = new Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) {\n others[_key - 1] = arguments[_key];\n }\n\n return _extends.apply(void 0, [target].concat(others));\n}\n/**\n * Sets a nested property of a given object to the specified value.\n *\n * This mutates the object and returns it.\n *\n * @param {Object} target The target of the set operation.\n * @param {(string|number)[]} path The path to the nested value.\n * @param {any} value The value to set.\n */\n\nfunction set(target, path, value) {\n var currentTarget = target;\n forEach(path, function (key, idx) {\n if (key === '__proto__') {\n throw new Error('illegal key: __proto__');\n }\n\n var nextKey = path[idx + 1];\n var nextTarget = currentTarget[key];\n\n if (isDefined(nextKey) && isNil(nextTarget)) {\n nextTarget = currentTarget[key] = isNaN(+nextKey) ? {} : [];\n }\n\n if (isUndefined(nextKey)) {\n if (isUndefined(value)) {\n delete currentTarget[key];\n } else {\n currentTarget[key] = value;\n }\n } else {\n currentTarget = nextTarget;\n }\n });\n return target;\n}\n/**\n * Gets a nested property of a given object.\n *\n * @param {Object} target The target of the get operation.\n * @param {(string|number)[]} path The path to the nested value.\n * @param {any} [defaultValue] The value to return if no value exists.\n */\n\nfunction get(target, path, defaultValue) {\n var currentTarget = target;\n forEach(path, function (key) {\n // accessing nil property yields <undefined>\n if (isNil(currentTarget)) {\n currentTarget = undefined;\n return false;\n }\n\n currentTarget = currentTarget[key];\n });\n return isUndefined(currentTarget) ? defaultValue : currentTarget;\n}\n/**\n * Pick given properties from the target object.\n *\n * @param {Object} target\n * @param {Array} properties\n *\n * @return {Object} target\n */\n\nfunction pick(target, properties) {\n var result = {};\n var obj = Object(target);\n forEach(properties, function (prop) {\n if (prop in obj) {\n result[prop] = target[prop];\n }\n });\n return result;\n}\n/**\n * Pick all target properties, excluding the given ones.\n *\n * @param {Object} target\n * @param {Array} properties\n *\n * @return {Object} target\n */\n\nfunction omit(target, properties) {\n var result = {};\n var obj = Object(target);\n forEach(obj, function (prop, key) {\n if (properties.indexOf(key) === -1) {\n result[key] = prop;\n }\n });\n return result;\n}\n/**\n * Recursively merge `...sources` into given target.\n *\n * Does support merging objects; does not support merging arrays.\n *\n * @param {Object} target\n * @param {...Object} sources\n *\n * @return {Object} the target\n */\n\nfunction merge(target) {\n for (var _len2 = arguments.length, sources = new Array(_len2 > 1 ? _len2 - 1 : 0), _key2 = 1; _key2 < _len2; _key2++) {\n sources[_key2 - 1] = arguments[_key2];\n }\n\n if (!sources.length) {\n return target;\n }\n\n forEach(sources, function (source) {\n // skip non-obj sources, i.e. null\n if (!source || !isObject(source)) {\n return;\n }\n\n forEach(source, function (sourceVal, key) {\n if (key === '__proto__') {\n return;\n }\n\n var targetVal = target[key];\n\n if (isObject(sourceVal)) {\n if (!isObject(targetVal)) {\n // override target[key] with object\n targetVal = {};\n }\n\n target[key] = merge(targetVal, sourceVal);\n } else {\n target[key] = sourceVal;\n }\n });\n });\n return target;\n}\n\nexport { assign, bind, debounce, ensureArray, every, filter, find, findIndex, flatten, forEach, get, groupBy, has, isArray, isDefined, isFunction, isNil, isNumber, isObject, isString, isUndefined, keys, map, matchPattern, merge, omit, pick, reduce, set, size, some, sortBy, throttle, unionBy, uniqueBy, values, without };\n","function noop() { }\nconst identity = x => x;\nfunction assign(tar, src) {\n // @ts-ignore\n for (const k in src)\n tar[k] = src[k];\n return tar;\n}\nfunction is_promise(value) {\n return value && typeof value === 'object' && typeof value.then === 'function';\n}\nfunction add_location(element, file, line, column, char) {\n element.__svelte_meta = {\n loc: { file, line, column, char }\n };\n}\nfunction run(fn) {\n return fn();\n}\nfunction blank_object() {\n return Object.create(null);\n}\nfunction run_all(fns) {\n fns.forEach(run);\n}\nfunction is_function(thing) {\n return typeof thing === 'function';\n}\nfunction safe_not_equal(a, b) {\n return a != a ? b == b : a !== b || ((a && typeof a === 'object') || typeof a === 'function');\n}\nlet src_url_equal_anchor;\nfunction src_url_equal(element_src, url) {\n if (!src_url_equal_anchor) {\n src_url_equal_anchor = document.createElement('a');\n }\n src_url_equal_anchor.href = url;\n return element_src === src_url_equal_anchor.href;\n}\nfunction not_equal(a, b) {\n return a != a ? b == b : a !== b;\n}\nfunction is_empty(obj) {\n return Object.keys(obj).length === 0;\n}\nfunction validate_store(store, name) {\n if (store != null && typeof store.subscribe !== 'function') {\n throw new Error(`'${name}' is not a store with a 'subscribe' method`);\n }\n}\nfunction subscribe(store, ...callbacks) {\n if (store == null) {\n return noop;\n }\n const unsub = store.subscribe(...callbacks);\n return unsub.unsubscribe ? () => unsub.unsubscribe() : unsub;\n}\nfunction get_store_value(store) {\n let value;\n subscribe(store, _ => value = _)();\n return value;\n}\nfunction component_subscribe(component, store, callback) {\n component.$$.on_destroy.push(subscribe(store, callback));\n}\nfunction create_slot(definition, ctx, $$scope, fn) {\n if (definition) {\n const slot_ctx = get_slot_context(definition, ctx, $$scope, fn);\n return definition[0](slot_ctx);\n }\n}\nfunction get_slot_context(definition, ctx, $$scope, fn) {\n return definition[1] && fn\n ? assign($$scope.ctx.slice(), definition[1](fn(ctx)))\n : $$scope.ctx;\n}\nfunction get_slot_changes(definition, $$scope, dirty, fn) {\n if (definition[2] && fn) {\n const lets = definition[2](fn(dirty));\n if ($$scope.dirty === undefined) {\n return lets;\n }\n if (typeof lets === 'object') {\n const merged = [];\n const len = Math.max($$scope.dirty.length, lets.length);\n for (let i = 0; i < len; i += 1) {\n merged[i] = $$scope.dirty[i] | lets[i];\n }\n return merged;\n }\n return $$scope.dirty | lets;\n }\n return $$scope.dirty;\n}\nfunction update_slot_base(slot, slot_definition, ctx, $$scope, slot_changes, get_slot_context_fn) {\n if (slot_changes) {\n const slot_context = get_slot_context(slot_definition, ctx, $$scope, get_slot_context_fn);\n slot.p(slot_context, slot_changes);\n }\n}\nfunction update_slot(slot, slot_definition, ctx, $$scope, dirty, get_slot_changes_fn, get_slot_context_fn) {\n const slot_changes = get_slot_changes(slot_definition, $$scope, dirty, get_slot_changes_fn);\n update_slot_base(slot, slot_definition, ctx, $$scope, slot_changes, get_slot_context_fn);\n}\nfunction get_all_dirty_from_scope($$scope) {\n if ($$scope.ctx.length > 32) {\n const dirty = [];\n const length = $$scope.ctx.length / 32;\n for (let i = 0; i < length; i++) {\n dirty[i] = -1;\n }\n return dirty;\n }\n return -1;\n}\nfunction exclude_internal_props(props) {\n const result = {};\n for (const k in props)\n if (k[0] !== '$')\n result[k] = props[k];\n return result;\n}\nfunction compute_rest_props(props, keys) {\n const rest = {};\n keys = new Set(keys);\n for (const k in props)\n if (!keys.has(k) && k[0] !== '$')\n rest[k] = props[k];\n return rest;\n}\nfunction compute_slots(slots) {\n const result = {};\n for (const key in slots) {\n result[key] = true;\n }\n return result;\n}\nfunction once(fn) {\n let ran = false;\n return function (...args) {\n if (ran)\n return;\n ran = true;\n fn.call(this, ...args);\n };\n}\nfunction null_to_empty(value) {\n return value == null ? '' : value;\n}\nfunction set_store_value(store, ret, value) {\n store.set(value);\n return ret;\n}\nconst has_prop = (obj, prop) => Object.prototype.hasOwnProperty.call(obj, prop);\nfunction action_destroyer(action_result) {\n return action_result && is_function(action_result.destroy) ? action_result.destroy : noop;\n}\n\nconst is_client = typeof window !== 'undefined';\nlet now = is_client\n ? () => window.performance.now()\n : () => Date.now();\nlet raf = is_client ? cb => requestAnimationFrame(cb) : noop;\n// used internally for testing\nfunction set_now(fn) {\n now = fn;\n}\nfunction set_raf(fn) {\n raf = fn;\n}\n\nconst tasks = new Set();\nfunction run_tasks(now) {\n tasks.forEach(task => {\n if (!task.c(now)) {\n tasks.delete(task);\n task.f();\n }\n });\n if (tasks.size !== 0)\n raf(run_tasks);\n}\n/**\n * For testing purposes only!\n */\nfunction clear_loops() {\n tasks.clear();\n}\n/**\n * Creates a new task that runs on each raf frame\n * until it returns a falsy value or is aborted\n */\nfunction loop(callback) {\n let task;\n if (tasks.size === 0)\n raf(run_tasks);\n return {\n promise: new Promise(fulfill => {\n tasks.add(task = { c: callback, f: fulfill });\n }),\n abort() {\n tasks.delete(task);\n }\n };\n}\n\n// Track which nodes are claimed during hydration. Unclaimed nodes can then be removed from the DOM\n// at the end of hydration without touching the remaining nodes.\nlet is_hydrating = false;\nfunction start_hydrating() {\n is_hydrating = true;\n}\nfunction end_hydrating() {\n is_hydrating = false;\n}\nfunction upper_bound(low, high, key, value) {\n // Return first index of value larger than input value in the range [low, high)\n while (low < high) {\n const mid = low + ((high - low) >> 1);\n if (key(mid) <= value) {\n low = mid + 1;\n }\n else {\n high = mid;\n }\n }\n return low;\n}\nfunction init_hydrate(target) {\n if (target.hydrate_init)\n return;\n target.hydrate_init = true;\n // We know that all children have claim_order values since the unclaimed have been detached if target is not <head>\n let children = target.childNodes;\n // If target is <head>, there may be children without claim_order\n if (target.nodeName === 'HEAD') {\n const myChildren = [];\n for (let i = 0; i < children.length; i++) {\n const node = children[i];\n if (node.claim_order !== undefined) {\n myChildren.push(node);\n }\n }\n children = myChildren;\n }\n /*\n * Reorder claimed children optimally.\n * We can reorder claimed children optimally by finding the longest subsequence of\n * nodes that are already claimed in order and only moving the rest. The longest\n * subsequence subsequence of nodes that are claimed in order can be found by\n * computing the longest increasing subsequence of .claim_order values.\n *\n * This algorithm is optimal in generating the least amount of reorder operations\n * possible.\n *\n * Proof:\n * We know that, given a set of reordering operations, the nodes that do not move\n * always form an increasing subsequence, since they do not move among each other\n * meaning that they must be already ordered among each other. Thus, the maximal\n * set of nodes that do not move form a longest increasing subsequence.\n */\n // Compute longest increasing subsequence\n // m: subsequence length j => index k of smallest value that ends an increasing subsequence of length j\n const m = new Int32Array(children.length + 1);\n // Predecessor indices + 1\n const p = new Int32Array(children.length);\n m[0] = -1;\n let longest = 0;\n for (let i = 0; i < children.length; i++) {\n const current = children[i].claim_order;\n // Find the largest subsequence length such that it ends in a value less than our current value\n // upper_bound returns first greater value, so we subtract one\n // with fast path for when we are on the current longest subsequence\n const seqLen = ((longest > 0 && children[m[longest]].claim_order <= current) ? longest + 1 : upper_bound(1, longest, idx => children[m[idx]].claim_order, current)) - 1;\n p[i] = m[seqLen] + 1;\n const newLen = seqLen + 1;\n // We can guarantee that current is the smallest value. Otherwise, we would have generated a longer sequence.\n m[newLen] = i;\n longest = Math.max(newLen, longest);\n }\n // The longest increasing subsequence of nodes (initially reversed)\n const lis = [];\n // The rest of the nodes, nodes that will be moved\n const toMove = [];\n let last = children.length - 1;\n for (let cur = m[longest] + 1; cur != 0; cur = p[cur - 1]) {\n lis.push(children[cur - 1]);\n for (; last >= cur; last--) {\n toMove.push(children[last]);\n }\n last--;\n }\n for (; last >= 0; last--) {\n toMove.push(children[last]);\n }\n lis.reverse();\n // We sort the nodes being moved to guarantee that their insertion order matches the claim order\n toMove.sort((a, b) => a.claim_order - b.claim_order);\n // Finally, we move the nodes\n for (let i = 0, j = 0; i < toMove.length; i++) {\n while (j < lis.length && toMove[i].claim_order >= lis[j].claim_order) {\n j++;\n }\n const anchor = j < lis.length ? lis[j] : null;\n target.insertBefore(toMove[i], anchor);\n }\n}\nfunction append(target, node) {\n target.appendChild(node);\n}\nfunction append_styles(target, style_sheet_id, styles) {\n const append_styles_to = get_root_for_style(target);\n if (!append_styles_to.getElementById(style_sheet_id)) {\n const style = element('style');\n style.id = style_sheet_id;\n style.textContent = styles;\n append_stylesheet(append_styles_to, style);\n }\n}\nfunction get_root_for_style(node) {\n if (!node)\n return document;\n const root = node.getRootNode ? node.getRootNode() : node.ownerDocument;\n if (root && root.host) {\n return root;\n }\n return node.ownerDocument;\n}\nfunction append_empty_stylesheet(node) {\n const style_element = element('style');\n append_stylesheet(get_root_for_style(node), style_element);\n return style_element;\n}\nfunction append_stylesheet(node, style) {\n append(node.head || node, style);\n}\nfunction append_hydration(target, node) {\n if (is_hydrating) {\n init_hydrate(target);\n if ((target.actual_end_child === undefined) || ((target.actual_end_child !== null) && (target.actual_end_child.parentElement !== target))) {\n target.actual_end_child = target.firstChild;\n }\n // Skip nodes of undefined ordering\n while ((target.actual_end_child !== null) && (target.actual_end_child.claim_order === undefined)) {\n target.actual_end_child = target.actual_end_child.nextSibling;\n }\n if (node !== target.actual_end_child) {\n // We only insert if the ordering of this node should be modified or the parent node is not target\n if (node.claim_order !== undefined || node.parentNode !== target) {\n target.insertBefore(node, target.actual_end_child);\n }\n }\n else {\n target.actual_end_child = node.nextSibling;\n }\n }\n else if (node.parentNode !== target || node.nextSibling !== null) {\n target.appendChild(node);\n }\n}\nfunction insert(target, node, anchor) {\n target.insertBefore(node, anchor || null);\n}\nfunction insert_hydration(target, node, anchor) {\n if (is_hydrating && !anchor) {\n append_hydration(target, node);\n }\n else if (node.parentNode !== target || node.nextSibling != anchor) {\n target.insertBefore(node, anchor || null);\n }\n}\nfunction detach(node) {\n node.parentNode.removeChild(node);\n}\nfunction destroy_each(iterations, detaching) {\n for (let i = 0; i < iterations.length; i += 1) {\n if (iterations[i])\n iterations[i].d(detaching);\n }\n}\nfunction element(name) {\n return document.createElement(name);\n}\nfunction element_is(name, is) {\n return document.createElement(name, { is });\n}\nfunction object_without_properties(obj, exclude) {\n const target = {};\n for (const k in obj) {\n if (has_prop(obj, k)\n // @ts-ignore\n && exclude.indexOf(k) === -1) {\n // @ts-ignore\n target[k] = obj[k];\n }\n }\n return target;\n}\nfunction svg_element(name) {\n return document.createElementNS('http://www.w3.org/2000/svg', name);\n}\nfunction text(data) {\n return document.createTextNode(data);\n}\nfunction space() {\n return text(' ');\n}\nfunction empty() {\n return text('');\n}\nfunction listen(node, event, handler, options) {\n node.addEventListener(event, handler, options);\n return () => node.removeEventListener(event, handler, options);\n}\nfunction prevent_default(fn) {\n return function (event) {\n event.preventDefault();\n // @ts-ignore\n return fn.call(this, event);\n };\n}\nfunction stop_propagation(fn) {\n return function (event) {\n event.stopPropagation();\n // @ts-ignore\n return fn.call(this, event);\n };\n}\nfunction self(fn) {\n return function (event) {\n // @ts-ignore\n if (event.target === this)\n fn.call(this, event);\n };\n}\nfunction trusted(fn) {\n return function (event) {\n // @ts-ignore\n if (event.isTrusted)\n fn.call(this, event);\n };\n}\nfunction attr(node, attribute, value) {\n if (value == null)\n node.removeAttribute(attribute);\n else if (node.getAttribute(attribute) !== value)\n node.setAttribute(attribute, value);\n}\nfunction set_attributes(node, attributes) {\n // @ts-ignore\n const descriptors = Object.getOwnPropertyDescriptors(node.__proto__);\n for (const key in attributes) {\n if (attributes[key] == null) {\n node.removeAttribute(key);\n }\n else if (key === 'style') {\n node.style.cssText = attributes[key];\n }\n else if (key === '__value') {\n node.value = node[key] = attributes[key];\n }\n else if (descriptors[key] && descriptors[key].set) {\n node[key] = attributes[key];\n }\n else {\n attr(node, key, attributes[key]);\n }\n }\n}\nfunction set_svg_attributes(node, attributes) {\n for (const key in attributes) {\n attr(node, key, attributes[key]);\n }\n}\nfunction set_custom_element_data(node, prop, value) {\n if (prop in node) {\n node[prop] = typeof node[prop] === 'boolean' && value === '' ? true : value;\n }\n else {\n attr(node, prop, value);\n }\n}\nfunction xlink_attr(node, attribute, value) {\n node.setAttributeNS('http://www.w3.org/1999/xlink', attribute, value);\n}\nfunction get_binding_group_value(group, __value, checked) {\n const value = new Set();\n for (let i = 0; i < group.length; i += 1) {\n if (group[i].checked)\n value.add(group[i].__value);\n }\n if (!checked) {\n value.delete(__value);\n }\n return Array.from(value);\n}\nfunction to_number(value) {\n return value === '' ? null : +value;\n}\nfunction time_ranges_to_array(ranges) {\n const array = [];\n for (let i = 0; i < ranges.length; i += 1) {\n array.push({ start: ranges.start(i), end: ranges.end(i) });\n }\n return array;\n}\nfunction children(element) {\n return Array.from(element.childNodes);\n}\nfunction init_claim_info(nodes) {\n if (nodes.claim_info === undefined) {\n nodes.claim_info = { last_index: 0, total_claimed: 0 };\n }\n}\nfunction claim_node(nodes, predicate, processNode, createNode, dontUpdateLastIndex = false) {\n // Try to find nodes in an order such that we lengthen the longest increasing subsequence\n init_claim_info(nodes);\n const resultNode = (() => {\n // We first try to find an element after the previous one\n for (let i = nodes.claim_info.last_index; i < nodes.length; i++) {\n const node = nodes[i];\n if (predicate(node)) {\n const replacement = processNode(node);\n if (replacement === undefined) {\n nodes.splice(i, 1);\n }\n else {\n nodes[i] = replacement;\n }\n if (!dontUpdateLastIndex) {\n nodes.claim_info.last_index = i;\n }\n return node;\n }\n }\n // Otherwise, we try to find one before\n // We iterate in reverse so that we don't go too far back\n for (let i = nodes.claim_info.last_index - 1; i >= 0; i--) {\n const node = nodes[i];\n if (predicate(node)) {\n const replacement = processNode(node);\n if (replacement === undefined) {\n nodes.splice(i, 1);\n }\n else {\n nodes[i] = replacement;\n }\n if (!dontUpdateLastIndex) {\n nodes.claim_info.last_index = i;\n }\n else if (replacement === undefined) {\n // Since we spliced before the last_index, we decrease it\n nodes.claim_info.last_index--;\n }\n return node;\n }\n }\n // If we can't find any matching node, we create a new one\n return createNode();\n })();\n resultNode.claim_order = nodes.claim_info.total_claimed;\n nodes.claim_info.total_claimed += 1;\n return resultNode;\n}\nfunction claim_element_base(nodes, name, attributes, create_element) {\n return claim_node(nodes, (node) => node.nodeName === name, (node) => {\n const remove = [];\n for (let j = 0; j < node.attributes.length; j++) {\n const attribute = node.attributes[j];\n if (!attributes[attribute.name]) {\n remove.push(attribute.name);\n }\n }\n remove.forEach(v => node.removeAttribute(v));\n return undefined;\n }, () => create_element(name));\n}\nfunction claim_element(nodes, name, attributes) {\n return claim_element_base(nodes, name, attributes, element);\n}\nfunction claim_svg_element(nodes, name, attributes) {\n return claim_element_base(nodes, name, attributes, svg_element);\n}\nfunction claim_text(nodes, data) {\n return claim_node(nodes, (node) => node.nodeType === 3, (node) => {\n const dataStr = '' + data;\n if (node.data.startsWith(dataStr)) {\n if (node.data.length !== dataStr.length) {\n return node.splitText(dataStr.length);\n }\n }\n else {\n node.data = dataStr;\n }\n }, () => text(data), true // Text nodes should not update last index since it is likely not worth it to eliminate an increasing subsequence of actual elements\n );\n}\nfunction claim_space(nodes) {\n return claim_text(nodes, ' ');\n}\nfunction find_comment(nodes, text, start) {\n for (let i = start; i < nodes.length; i += 1) {\n const node = nodes[i];\n if (node.nodeType === 8 /* comment node */ && node.textContent.trim() === text) {\n return i;\n }\n }\n return nodes.length;\n}\nfunction claim_html_tag(nodes) {\n // find html opening tag\n const start_index = find_comment(nodes, 'HTML_TAG_START', 0);\n const end_index = find_comment(nodes, 'HTML_TAG_END', start_index);\n if (start_index === end_index) {\n return new HtmlTagHydration();\n }\n init_claim_info(nodes);\n const html_tag_nodes = nodes.splice(start_index, end_index + 1);\n detach(html_tag_nodes[0]);\n detach(html_tag_nodes[html_tag_nodes.length - 1]);\n const claimed_nodes = html_tag_nodes.slice(1, html_tag_nodes.length - 1);\n for (const n of claimed_nodes) {\n n.claim_order = nodes.claim_info.total_claimed;\n nodes.claim_info.total_claimed += 1;\n }\n return new HtmlTagHydration(claimed_nodes);\n}\nfunction set_data(text, data) {\n data = '' + data;\n if (text.wholeText !== data)\n text.data = data;\n}\nfunction set_input_value(input, value) {\n input.value = value == null ? '' : value;\n}\nfunction set_input_type(input, type) {\n try {\n input.type = type;\n }\n catch (e) {\n // do nothing\n }\n}\nfunction set_style(node, key, value, important) {\n node.style.setProperty(key, value, important ? 'important' : '');\n}\nfunction select_option(select, value) {\n for (let i = 0; i < select.options.length; i += 1) {\n const option = select.options[i];\n if (option.__value === value) {\n option.selected = true;\n return;\n }\n }\n select.selectedIndex = -1; // no option should be selected\n}\nfunction select_options(select, value) {\n for (let i = 0; i < select.options.length; i += 1) {\n const option = select.options[i];\n option.selected = ~value.indexOf(option.__value);\n }\n}\nfunction select_value(select) {\n const selected_option = select.querySelector(':checked') || select.options[0];\n return selected_option && selected_option.__value;\n}\nfunction select_multiple_value(select) {\n return [].map.call(select.querySelectorAll(':checked'), option => option.__value);\n}\n// unfortunately this can't be a constant as that wouldn't be tree-shakeable\n// so we cache the result instead\nlet crossorigin;\nfunction is_crossorigin() {\n if (crossorigin === undefined) {\n crossorigin = false;\n try {\n if (typeof window !== 'undefined' && window.parent) {\n void window.parent.document;\n }\n }\n catch (error) {\n crossorigin = true;\n }\n }\n return crossorigin;\n}\nfunction add_resize_listener(node, fn) {\n const computed_style = getComputedStyle(node);\n if (computed_style.position === 'static') {\n node.style.position = 'relative';\n }\n const iframe = element('iframe');\n iframe.setAttribute('style', 'display: block; position: absolute; top: 0; left: 0; width: 100%; height: 100%; ' +\n 'overflow: hidden; border: 0; opacity: 0; pointer-events: none; z-index: -1;');\n iframe.setAttribute('aria-hidden', 'true');\n iframe.tabIndex = -1;\n const crossorigin = is_crossorigin();\n let unsubscribe;\n if (crossorigin) {\n iframe.src = \"data:text/html,<script>onresize=function(){parent.postMessage(0,'*')}</script>\";\n unsubscribe = listen(window, 'message', (event) => {\n if (event.source === iframe.contentWindow)\n fn();\n });\n }\n else {\n iframe.src = 'about:blank';\n iframe.onload = () => {\n unsubscribe = listen(iframe.contentWindow, 'resize', fn);\n };\n }\n append(node, iframe);\n return () => {\n if (crossorigin) {\n unsubscribe();\n }\n else if (unsubscribe && iframe.contentWindow) {\n unsubscribe();\n }\n detach(iframe);\n };\n}\nfunction toggle_class(element, name, toggle) {\n element.classList[toggle ? 'add' : 'remove'](name);\n}\nfunction custom_event(type, detail, bubbles = false) {\n const e = document.createEvent('CustomEvent');\n e.initCustomEvent(type, bubbles, false, detail);\n return e;\n}\nfunction query_selector_all(selector, parent = document.body) {\n return Array.from(parent.querySelectorAll(selector));\n}\nclass HtmlTag {\n constructor() {\n this.e = this.n = null;\n }\n c(html) {\n this.h(html);\n }\n m(html, target, anchor = null) {\n if (!this.e) {\n this.e = element(target.nodeName);\n this.t = target;\n this.c(html);\n }\n this.i(anchor);\n }\n h(html) {\n this.e.innerHTML = html;\n this.n = Array.from(this.e.childNodes);\n }\n i(anchor) {\n for (let i = 0; i < this.n.length; i += 1) {\n insert(this.t, this.n[i], anchor);\n }\n }\n p(html) {\n this.d();\n this.h(html);\n this.i(this.a);\n }\n d() {\n this.n.forEach(detach);\n }\n}\nclass HtmlTagHydration extends HtmlTag {\n constructor(claimed_nodes) {\n super();\n this.e = this.n = null;\n this.l = claimed_nodes;\n }\n c(html) {\n if (this.l) {\n this.n = this.l;\n }\n else {\n super.c(html);\n }\n }\n i(anchor) {\n for (let i = 0; i < this.n.length; i += 1) {\n insert_hydration(this.t, this.n[i], anchor);\n }\n }\n}\nfunction attribute_to_object(attributes) {\n const result = {};\n for (const attribute of attributes) {\n result[attribute.name] = attribute.value;\n }\n return result;\n}\nfunction get_custom_elements_slots(element) {\n const result = {};\n element.childNodes.forEach((node) => {\n result[node.slot || 'default'] = true;\n });\n return result;\n}\n\nconst active_docs = new Set();\nlet active = 0;\n// https://github.com/darkskyapp/string-hash/blob/master/index.js\nfunction hash(str) {\n let hash = 5381;\n let i = str.length;\n while (i--)\n hash = ((hash << 5) - hash) ^ str.charCodeAt(i);\n return hash >>> 0;\n}\nfunction create_rule(node, a, b, duration, delay, ease, fn, uid = 0) {\n const step = 16.666 / duration;\n let keyframes = '{\\n';\n for (let p = 0; p <= 1; p += step) {\n const t = a + (b - a) * ease(p);\n keyframes += p * 100 + `%{${fn(t, 1 - t)}}\\n`;\n }\n const rule = keyframes + `100% {${fn(b, 1 - b)}}\\n}`;\n const name = `__svelte_${hash(rule)}_${uid}`;\n const doc = get_root_for_style(node);\n active_docs.add(doc);\n const stylesheet = doc.__svelte_stylesheet || (doc.__svelte_stylesheet = append_empty_stylesheet(node).sheet);\n const current_rules = doc.__svelte_rules || (doc.__svelte_rules = {});\n if (!current_rules[name]) {\n current_rules[name] = true;\n stylesheet.insertRule(`@keyframes ${name} ${rule}`, stylesheet.cssRules.length);\n }\n const animation = node.style.animation || '';\n node.style.animation = `${animation ? `${animation}, ` : ''}${name} ${duration}ms linear ${delay}ms 1 both`;\n active += 1;\n return name;\n}\nfunction delete_rule(node, name) {\n const previous = (node.style.animation || '').split(', ');\n const next = previous.filter(name\n ? anim => anim.indexOf(name) < 0 // remove specific animation\n : anim => anim.indexOf('__svelte') === -1 // remove all Svelte animations\n );\n const deleted = previous.length - next.length;\n if (deleted) {\n node.style.animation = next.join(', ');\n active -= deleted;\n if (!active)\n clear_rules();\n }\n}\nfunction clear_rules() {\n raf(() => {\n if (active)\n return;\n active_docs.forEach(doc => {\n const stylesheet = doc.__svelte_stylesheet;\n let i = stylesheet.cssRules.length;\n while (i--)\n stylesheet.deleteRule(i);\n doc.__svelte_rules = {};\n });\n active_docs.clear();\n });\n}\n\nfunction create_animation(node, from, fn, params) {\n if (!from)\n return noop;\n const to = node.getBoundingClientRect();\n if (from.left === to.left && from.right === to.right && from.top === to.top && from.bottom === to.bottom)\n return noop;\n const { delay = 0, duration = 300, easing = identity, \n // @ts-ignore todo: should this be separated from destructuring? Or start/end added to public api and documentation?\n start: start_time = now() + delay, \n // @ts-ignore todo:\n end = start_time + duration, tick = noop, css } = fn(node, { from, to }, params);\n let running = true;\n let started = false;\n let name;\n function start() {\n if (css) {\n name = create_rule(node, 0, 1, duration, delay, easing, css);\n }\n if (!delay) {\n started = true;\n }\n }\n function stop() {\n if (css)\n delete_rule(node, name);\n running = false;\n }\n loop(now => {\n if (!started && now >= start_time) {\n started = true;\n }\n if (started && now >= end) {\n tick(1, 0);\n stop();\n }\n if (!running) {\n return false;\n }\n if (started) {\n const p = now - start_time;\n const t = 0 + 1 * easing(p / duration);\n tick(t, 1 - t);\n }\n return true;\n });\n start();\n tick(0, 1);\n return stop;\n}\nfunction fix_position(node) {\n const style = getComputedStyle(node);\n if (style.position !== 'absolute' && style.position !== 'fixed') {\n const { width, height } = style;\n const a = node.getBoundingClientRect();\n node.style.position = 'absolute';\n node.style.width = width;\n node.style.height = height;\n add_transform(node, a);\n }\n}\nfunction add_transform(node, a) {\n const b = node.getBoundingClientRect();\n if (a.left !== b.left || a.top !== b.top) {\n const style = getComputedStyle(node);\n const transform = style.transform === 'none' ? '' : style.transform;\n node.style.transform = `${transform} translate(${a.left - b.left}px, ${a.top - b.top}px)`;\n }\n}\n\nlet current_component;\nfunction set_current_component(component) {\n current_component = component;\n}\nfunction get_current_component() {\n if (!current_component)\n throw new Error('Function called outside component initialization');\n return current_component;\n}\nfunction beforeUpdate(fn) {\n get_current_component().$$.before_update.push(fn);\n}\nfunction onMount(fn) {\n get_current_component().$$.on_mount.push(fn);\n}\nfunction afterUpdate(fn) {\n get_current_component().$$.after_update.push(fn);\n}\nfunction onDestroy(fn) {\n get_current_component().$$.on_destroy.push(fn);\n}\nfunction createEventDispatcher() {\n const component = get_current_component();\n return (type, detail) => {\n const callbacks = component.$$.callbacks[type];\n if (callbacks) {\n // TODO are there situations where events could be dispatched\n // in a server (non-DOM) environment?\n const event = custom_event(type, detail);\n callbacks.slice().forEach(fn => {\n fn.call(component, event);\n });\n }\n };\n}\nfunction setContext(key, context) {\n get_current_component().$$.context.set(key, context);\n}\nfunction getContext(key) {\n return get_current_component().$$.context.get(key);\n}\nfunction getAllContexts() {\n return get_current_component().$$.context;\n}\nfunction hasContext(key) {\n return get_current_component().$$.context.has(key);\n}\n// TODO figure out if we still want to support\n// shorthand events, or if we want to implement\n// a real bubbling mechanism\nfunction bubble(component, event) {\n const callbacks = component.$$.callbacks[event.type];\n if (callbacks) {\n // @ts-ignore\n callbacks.slice().forEach(fn => fn.call(this, event));\n }\n}\n\nconst dirty_components = [];\nconst intros = { enabled: false };\nconst binding_callbacks = [];\nconst render_callbacks = [];\nconst flush_callbacks = [];\nconst resolved_promise = Promise.resolve();\nlet update_scheduled = false;\nfunction schedule_update() {\n if (!update_scheduled) {\n update_scheduled = true;\n resolved_promise.then(flush);\n }\n}\nfunction tick() {\n schedule_update();\n return resolved_promise;\n}\nfunction add_render_callback(fn) {\n render_callbacks.push(fn);\n}\nfunction add_flush_callback(fn) {\n flush_callbacks.push(fn);\n}\nlet flushing = false;\nconst seen_callbacks = new Set();\nfunction flush() {\n if (flushing)\n return;\n flushing = true;\n do {\n // first, call beforeUpdate functions\n // and update components\n for (let i = 0; i < dirty_components.length; i += 1) {\n const component = dirty_components[i];\n set_current_component(component);\n update(component.$$);\n }\n set_current_component(null);\n dirty_components.length = 0;\n while (binding_callbacks.length)\n binding_callbacks.pop()();\n // then, once components are updated, call\n // afterUpdate functions. This may cause\n // subsequent updates...\n for (let i = 0; i < render_callbacks.length; i += 1) {\n const callback = render_callbacks[i];\n if (!seen_callbacks.has(callback)) {\n // ...so guard against infinite loops\n seen_callbacks.add(callback);\n callback();\n }\n }\n render_callbacks.length = 0;\n } while (dirty_components.length);\n while (flush_callbacks.length) {\n flush_callbacks.pop()();\n }\n update_scheduled = false;\n flushing = false;\n seen_callbacks.clear();\n}\nfunction update($$) {\n if ($$.fragment !== null) {\n $$.update();\n run_all($$.before_update);\n const dirty = $$.dirty;\n $$.dirty = [-1];\n $$.fragment && $$.fragment.p($$.ctx, dirty);\n $$.after_update.forEach(add_render_callback);\n }\n}\n\nlet promise;\nfunction wait() {\n if (!promise) {\n promise = Promise.resolve();\n promise.then(() => {\n promise = null;\n });\n }\n return promise;\n}\nfunction dispatch(node, direction, kind) {\n node.dispatchEvent(custom_event(`${direction ? 'intro' : 'outro'}${kind}`));\n}\nconst outroing = new Set();\nlet outros;\nfunction group_outros() {\n outros = {\n r: 0,\n c: [],\n p: outros // parent group\n };\n}\nfunction check_outros() {\n if (!outros.r) {\n run_all(outros.c);\n }\n outros = outros.p;\n}\nfunction transition_in(block, local) {\n if (block && block.i) {\n outroing.delete(block);\n block.i(local);\n }\n}\nfunction transition_out(block, local, detach, callback) {\n if (block && block.o) {\n if (outroing.has(block))\n return;\n outroing.add(block);\n outros.c.push(() => {\n outroing.delete(block);\n if (callback) {\n if (detach)\n block.d(1);\n callback();\n }\n });\n block.o(local);\n }\n}\nconst null_transition = { duration: 0 };\nfunction create_in_transition(node, fn, params) {\n let config = fn(node, params);\n let running = false;\n let animation_name;\n let task;\n let uid = 0;\n function cleanup() {\n if (animation_name)\n delete_rule(node, animation_name);\n }\n function go() {\n const { delay = 0, duration = 300, easing = identity, tick = noop, css } = config || null_transition;\n if (css)\n animation_name = create_rule(node, 0, 1, duration, delay, easing, css, uid++);\n tick(0, 1);\n const start_time = now() + delay;\n const end_time = start_time + duration;\n if (task)\n task.abort();\n running = true;\n add_render_callback(() => dispatch(node, true, 'start'));\n task = loop(now => {\n if (running) {\n if (now >= end_time) {\n tick(1, 0);\n dispatch(node, true, 'end');\n cleanup();\n return running = false;\n }\n if (now >= start_time) {\n const t = easing((now - start_time) / duration);\n tick(t, 1 - t);\n }\n }\n return running;\n });\n }\n let started = false;\n return {\n start() {\n if (started)\n return;\n started = true;\n delete_rule(node);\n if (is_function(config)) {\n config = config();\n wait().then(go);\n }\n else {\n go();\n }\n },\n invalidate() {\n started = false;\n },\n end() {\n if (running) {\n cleanup();\n running = false;\n }\n }\n };\n}\nfunction create_out_transition(node, fn, params) {\n let config = fn(node, params);\n let running = true;\n let animation_name;\n const group = outros;\n group.r += 1;\n function go() {\n const { delay = 0, duration = 300, easing = identity, tick = noop, css } = config || null_transition;\n if (css)\n animation_name = create_rule(node, 1, 0, duration, delay, easing, css);\n const start_time = now() + delay;\n const end_time = start_time + duration;\n add_render_callback(() => dispatch(node, false, 'start'));\n loop(now => {\n if (running) {\n if (now >= end_time) {\n tick(0, 1);\n dispatch(node, false, 'end');\n if (!--group.r) {\n // this will result in `end()` being called,\n // so we don't need to clean up here\n run_all(group.c);\n }\n return false;\n }\n if (now >= start_time) {\n const t = easing((now - start_time) / duration);\n tick(1 - t, t);\n }\n }\n return running;\n });\n }\n if (is_function(config)) {\n wait().then(() => {\n // @ts-ignore\n config = config();\n go();\n });\n }\n else {\n go();\n }\n return {\n end(reset) {\n if (reset && config.tick) {\n config.tick(1, 0);\n }\n if (running) {\n if (animation_name)\n delete_rule(node, animation_name);\n running = false;\n }\n }\n };\n}\nfunction create_bidirectional_transition(node, fn, params, intro) {\n let config = fn(node, params);\n let t = intro ? 0 : 1;\n let running_program = null;\n let pending_program = null;\n let animation_name = null;\n function clear_animation() {\n if (animation_name)\n delete_rule(node, animation_name);\n }\n function init(program, duration) {\n const d = (program.b - t);\n duration *= Math.abs(d);\n return {\n a: t,\n b: program.b,\n d,\n duration,\n start: program.start,\n end: program.start + duration,\n group: program.group\n };\n }\n function go(b) {\n const { delay = 0, duration = 300, easing = identity, tick = noop, css } = config || null_transition;\n const program = {\n start: now() + delay,\n b\n };\n if (!b) {\n // @ts-ignore todo: improve typings\n program.group = outros;\n outros.r += 1;\n }\n if (running_program || pending_program) {\n pending_program = program;\n }\n else {\n // if this is an intro, and there's a delay, we need to do\n // an initial tick and/or apply CSS animation immediately\n if (css) {\n clear_animation();\n animation_name = create_rule(node, t, b, duration, delay, easing, css);\n }\n if (b)\n tick(0, 1);\n running_program = init(program, duration);\n add_render_callback(() => dispatch(node, b, 'start'));\n loop(now => {\n if (pending_program && now > pending_program.start) {\n running_program = init(pending_program, duration);\n pending_program = null;\n dispatch(node, running_program.b, 'start');\n if (css) {\n clear_animation();\n animation_name = create_rule(node, t, running_program.b, running_program.duration, 0, easing, config.css);\n }\n }\n if (running_program) {\n if (now >= running_program.end) {\n tick(t = running_program.b, 1 - t);\n dispatch(node, running_program.b, 'end');\n if (!pending_program) {\n // we're done\n if (running_program.b) {\n // intro — we can tidy up immediately\n clear_animation();\n }\n else {\n // outro — needs to be coordinated\n if (!--running_program.group.r)\n run_all(running_program.group.c);\n }\n }\n running_program = null;\n }\n else if (now >= running_program.start) {\n const p = now - running_program.start;\n t = running_program.a + running_program.d * easing(p / running_program.duration);\n tick(t, 1 - t);\n }\n }\n return !!(running_program || pending_program);\n });\n }\n }\n return {\n run(b) {\n if (is_function(config)) {\n wait().then(() => {\n // @ts-ignore\n config = config();\n go(b);\n });\n }\n else {\n go(b);\n }\n },\n end() {\n clear_animation();\n running_program = pending_program = null;\n }\n };\n}\n\nfunction handle_promise(promise, info) {\n const token = info.token = {};\n function update(type, index, key, value) {\n if (info.token !== token)\n return;\n info.resolved = value;\n let child_ctx = info.ctx;\n if (key !== undefined) {\n child_ctx = child_ctx.slice();\n child_ctx[key] = value;\n }\n const block = type && (info.current = type)(child_ctx);\n let needs_flush = false;\n if (info.block) {\n if (info.blocks) {\n info.blocks.forEach((block, i) => {\n if (i !== index && block) {\n group_outros();\n transition_out(block, 1, 1, () => {\n if (info.blocks[i] === block) {\n info.blocks[i] = null;\n }\n });\n check_outros();\n }\n });\n }\n else {\n info.block.d(1);\n }\n block.c();\n transition_in(block, 1);\n block.m(info.mount(), info.anchor);\n needs_flush = true;\n }\n info.block = block;\n if (info.blocks)\n info.blocks[index] = block;\n if (needs_flush) {\n flush();\n }\n }\n if (is_promise(promise)) {\n const current_component = get_current_component();\n promise.then(value => {\n set_current_component(current_component);\n update(info.then, 1, info.value, value);\n set_current_component(null);\n }, error => {\n set_current_component(current_component);\n update(info.catch, 2, info.error, error);\n set_current_component(null);\n if (!info.hasCatch) {\n throw error;\n }\n });\n // if we previously had a then/catch block, destroy it\n if (info.current !== info.pending) {\n update(info.pending, 0);\n return true;\n }\n }\n else {\n if (info.current !== info.then) {\n update(info.then, 1, info.value, promise);\n return true;\n }\n info.resolved = promise;\n }\n}\nfunction update_await_block_branch(info, ctx, dirty) {\n const child_ctx = ctx.slice();\n const { resolved } = info;\n if (info.current === info.then) {\n child_ctx[info.value] = resolved;\n }\n if (info.current === info.catch) {\n child_ctx[info.error] = resolved;\n }\n info.block.p(child_ctx, dirty);\n}\n\nconst globals = (typeof window !== 'undefined'\n ? window\n : typeof globalThis !== 'undefined'\n ? globalThis\n : global);\n\nfunction destroy_block(block, lookup) {\n block.d(1);\n lookup.delete(block.key);\n}\nfunction outro_and_destroy_block(block, lookup) {\n transition_out(block, 1, 1, () => {\n lookup.delete(block.key);\n });\n}\nfunction fix_and_destroy_block(block, lookup) {\n block.f();\n destroy_block(block, lookup);\n}\nfunction fix_and_outro_and_destroy_block(block, lookup) {\n block.f();\n outro_and_destroy_block(block, lookup);\n}\nfunction update_keyed_each(old_blocks, dirty, get_key, dynamic, ctx, list, lookup, node, destroy, create_each_block, next, get_context) {\n let o = old_blocks.length;\n let n = list.length;\n let i = o;\n const old_indexes = {};\n while (i--)\n old_indexes[old_blocks[i].key] = i;\n const new_blocks = [];\n const new_lookup = new Map();\n const deltas = new Map();\n i = n;\n while (i--) {\n const child_ctx = get_context(ctx, list, i);\n const key = get_key(child_ctx);\n let block = lookup.get(key);\n if (!block) {\n block = create_each_block(key, child_ctx);\n block.c();\n }\n else if (dynamic) {\n block.p(child_ctx, dirty);\n }\n new_lookup.set(key, new_blocks[i] = block);\n if (key in old_indexes)\n deltas.set(key, Math.abs(i - old_indexes[key]));\n }\n const will_move = new Set();\n const did_move = new Set();\n function insert(block) {\n transition_in(block, 1);\n block.m(node, next);\n lookup.set(block.key, block);\n next = block.first;\n n--;\n }\n while (o && n) {\n const new_block = new_blocks[n - 1];\n const old_block = old_blocks[o - 1];\n const new_key = new_block.key;\n const old_key = old_block.key;\n if (new_block === old_block) {\n // do nothing\n next = new_block.first;\n o--;\n n--;\n }\n else if (!new_lookup.has(old_key)) {\n // remove old block\n destroy(old_block, lookup);\n o--;\n }\n else if (!lookup.has(new_key) || will_move.has(new_key)) {\n insert(new_block);\n }\n else if (did_move.has(old_key)) {\n o--;\n }\n else if (deltas.get(new_key) > deltas.get(old_key)) {\n did_move.add(new_key);\n insert(new_block);\n }\n else {\n will_move.add(old_key);\n o--;\n }\n }\n while (o--) {\n const old_block = old_blocks[o];\n if (!new_lookup.has(old_block.key))\n destroy(old_block, lookup);\n }\n while (n)\n insert(new_blocks[n - 1]);\n return new_blocks;\n}\nfunction validate_each_keys(ctx, list, get_context, get_key) {\n const keys = new Set();\n for (let i = 0; i < list.length; i++) {\n const key = get_key(get_context(ctx, list, i));\n if (keys.has(key)) {\n throw new Error('Cannot have duplicate keys in a keyed each');\n }\n keys.add(key);\n }\n}\n\nfunction get_spread_update(levels, updates) {\n const update = {};\n const to_null_out = {};\n const accounted_for = { $$scope: 1 };\n let i = levels.length;\n while (i--) {\n const o = levels[i];\n const n = updates[i];\n if (n) {\n for (const key in o) {\n if (!(key in n))\n to_null_out[key] = 1;\n }\n for (const key in n) {\n if (!accounted_for[key]) {\n update[key] = n[key];\n accounted_for[key] = 1;\n }\n }\n levels[i] = n;\n }\n else {\n for (const key in o) {\n accounted_for[key] = 1;\n }\n }\n }\n for (const key in to_null_out) {\n if (!(key in update))\n update[key] = undefined;\n }\n return update;\n}\nfunction get_spread_object(spread_props) {\n return typeof spread_props === 'object' && spread_props !== null ? spread_props : {};\n}\n\n// source: https://html.spec.whatwg.org/multipage/indices.html\nconst boolean_attributes = new Set([\n 'allowfullscreen',\n 'allowpaymentrequest',\n 'async',\n 'autofocus',\n 'autoplay',\n 'checked',\n 'controls',\n 'default',\n 'defer',\n 'disabled',\n 'formnovalidate',\n 'hidden',\n 'ismap',\n 'loop',\n 'multiple',\n 'muted',\n 'nomodule',\n 'novalidate',\n 'open',\n 'playsinline',\n 'readonly',\n 'required',\n 'reversed',\n 'selected'\n]);\n\nconst invalid_attribute_name_character = /[\\s'\">/=\\u{FDD0}-\\u{FDEF}\\u{FFFE}\\u{FFFF}\\u{1FFFE}\\u{1FFFF}\\u{2FFFE}\\u{2FFFF}\\u{3FFFE}\\u{3FFFF}\\u{4FFFE}\\u{4FFFF}\\u{5FFFE}\\u{5FFFF}\\u{6FFFE}\\u{6FFFF}\\u{7FFFE}\\u{7FFFF}\\u{8FFFE}\\u{8FFFF}\\u{9FFFE}\\u{9FFFF}\\u{AFFFE}\\u{AFFFF}\\u{BFFFE}\\u{BFFFF}\\u{CFFFE}\\u{CFFFF}\\u{DFFFE}\\u{DFFFF}\\u{EFFFE}\\u{EFFFF}\\u{FFFFE}\\u{FFFFF}\\u{10FFFE}\\u{10FFFF}]/u;\n// https://html.spec.whatwg.org/multipage/syntax.html#attributes-2\n// https://infra.spec.whatwg.org/#noncharacter\nfunction spread(args, classes_to_add) {\n const attributes = Object.assign({}, ...args);\n if (classes_to_add) {\n if (attributes.class == null) {\n attributes.class = classes_to_add;\n }\n else {\n attributes.class += ' ' + classes_to_add;\n }\n }\n let str = '';\n Object.keys(attributes).forEach(name => {\n if (invalid_attribute_name_character.test(name))\n return;\n const value = attributes[name];\n if (value === true)\n str += ' ' + name;\n else if (boolean_attributes.has(name.toLowerCase())) {\n if (value)\n str += ' ' + name;\n }\n else if (value != null) {\n str += ` ${name}=\"${value}\"`;\n }\n });\n return str;\n}\nconst escaped = {\n '\"': '"',\n \"'\": ''',\n '&': '&',\n '<': '<',\n '>': '>'\n};\nfunction escape(html) {\n return String(html).replace(/[\"'&<>]/g, match => escaped[match]);\n}\nfunction escape_attribute_value(value) {\n return typeof value === 'string' ? escape(value) : value;\n}\nfunction escape_object(obj) {\n const result = {};\n for (const key in obj) {\n result[key] = escape_attribute_value(obj[key]);\n }\n return result;\n}\nfunction each(items, fn) {\n let str = '';\n for (let i = 0; i < items.length; i += 1) {\n str += fn(items[i], i);\n }\n return str;\n}\nconst missing_component = {\n $$render: () => ''\n};\nfunction validate_component(component, name) {\n if (!component || !component.$$render) {\n if (name === 'svelte:component')\n name += ' this={...}';\n throw new Error(`<${name}> is not a valid SSR component. You may need to review your build config to ensure that dependencies are compiled, rather than imported as pre-compiled modules`);\n }\n return component;\n}\nfunction debug(file, line, column, values) {\n console.log(`{@debug} ${file ? file + ' ' : ''}(${line}:${column})`); // eslint-disable-line no-console\n console.log(values); // eslint-disable-line no-console\n return '';\n}\nlet on_destroy;\nfunction create_ssr_component(fn) {\n function $$render(result, props, bindings, slots, context) {\n const parent_component = current_component;\n const $$ = {\n on_destroy,\n context: new Map(context || (parent_component ? parent_component.$$.context : [])),\n // these will be immediately discarded\n on_mount: [],\n before_update: [],\n after_update: [],\n callbacks: blank_object()\n };\n set_current_component({ $$ });\n const html = fn(result, props, bindings, slots);\n set_current_component(parent_component);\n return html;\n }\n return {\n render: (props = {}, { $$slots = {}, context = new Map() } = {}) => {\n on_destroy = [];\n const result = { title: '', head: '', css: new Set() };\n const html = $$render(result, props, {}, $$slots, context);\n run_all(on_destroy);\n return {\n html,\n css: {\n code: Array.from(result.css).map(css => css.code).join('\\n'),\n map: null // TODO\n },\n head: result.title + result.head\n };\n },\n $$render\n };\n}\nfunction add_attribute(name, value, boolean) {\n if (value == null || (boolean && !value))\n return '';\n return ` ${name}${value === true ? '' : `=${typeof value === 'string' ? JSON.stringify(escape(value)) : `\"${value}\"`}`}`;\n}\nfunction add_classes(classes) {\n return classes ? ` class=\"${classes}\"` : '';\n}\n\nfunction bind(component, name, callback) {\n const index = component.$$.props[name];\n if (index !== undefined) {\n component.$$.bound[index] = callback;\n callback(component.$$.ctx[index]);\n }\n}\nfunction create_component(block) {\n block && block.c();\n}\nfunction claim_component(block, parent_nodes) {\n block && block.l(parent_nodes);\n}\nfunction mount_component(component, target, anchor, customElement) {\n const { fragment, on_mount, on_destroy, after_update } = component.$$;\n fragment && fragment.m(target, anchor);\n if (!customElement) {\n // onMount happens before the initial afterUpdate\n add_render_callback(() => {\n const new_on_destroy = on_mount.map(run).filter(is_function);\n if (on_destroy) {\n on_destroy.push(...new_on_destroy);\n }\n else {\n // Edge case - component was destroyed immediately,\n // most likely as a result of a binding initialising\n run_all(new_on_destroy);\n }\n component.$$.on_mount = [];\n });\n }\n after_update.forEach(add_render_callback);\n}\nfunction destroy_component(component, detaching) {\n const $$ = component.$$;\n if ($$.fragment !== null) {\n run_all($$.on_destroy);\n $$.fragment && $$.fragment.d(detaching);\n // TODO null out other refs, including component.$$ (but need to\n // preserve final state?)\n $$.on_destroy = $$.fragment = null;\n $$.ctx = [];\n }\n}\nfunction make_dirty(component, i) {\n if (component.$$.dirty[0] === -1) {\n dirty_components.push(component);\n schedule_update();\n component.$$.dirty.fill(0);\n }\n component.$$.dirty[(i / 31) | 0] |= (1 << (i % 31));\n}\nfunction init(component, options, instance, create_fragment, not_equal, props, append_styles, dirty = [-1]) {\n const parent_component = current_component;\n set_current_component(component);\n const $$ = component.$$ = {\n fragment: null,\n ctx: null,\n // state\n props,\n update: noop,\n not_equal,\n bound: blank_object(),\n // lifecycle\n on_mount: [],\n on_destroy: [],\n on_disconnect: [],\n before_update: [],\n after_update: [],\n context: new Map(options.context || (parent_component ? parent_component.$$.context : [])),\n // everything else\n callbacks: blank_object(),\n dirty,\n skip_bound: false,\n root: options.target || parent_component.$$.root\n };\n append_styles && append_styles($$.root);\n let ready = false;\n $$.ctx = instance\n ? instance(component, options.props || {}, (i, ret, ...rest) => {\n const value = rest.length ? rest[0] : ret;\n if ($$.ctx && not_equal($$.ctx[i], $$.ctx[i] = value)) {\n if (!$$.skip_bound && $$.bound[i])\n $$.bound[i](value);\n if (ready)\n make_dirty(component, i);\n }\n return ret;\n })\n : [];\n $$.update();\n ready = true;\n run_all($$.before_update);\n // `false` as a special case of no DOM component\n $$.fragment = create_fragment ? create_fragment($$.ctx) : false;\n if (options.target) {\n if (options.hydrate) {\n start_hydrating();\n const nodes = children(options.target);\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n $$.fragment && $$.fragment.l(nodes);\n nodes.forEach(detach);\n }\n else {\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n $$.fragment && $$.fragment.c();\n }\n if (options.intro)\n transition_in(component.$$.fragment);\n mount_component(component, options.target, options.anchor, options.customElement);\n end_hydrating();\n flush();\n }\n set_current_component(parent_component);\n}\nlet SvelteElement;\nif (typeof HTMLElement === 'function') {\n SvelteElement = class extends HTMLElement {\n constructor() {\n super();\n this.attachShadow({ mode: 'open' });\n }\n connectedCallback() {\n const { on_mount } = this.$$;\n this.$$.on_disconnect = on_mount.map(run).filter(is_function);\n // @ts-ignore todo: improve typings\n for (const key in this.$$.slotted) {\n // @ts-ignore todo: improve typings\n this.appendChild(this.$$.slotted[key]);\n }\n }\n attributeChangedCallback(attr, _oldValue, newValue) {\n this[attr] = newValue;\n }\n disconnectedCallback() {\n run_all(this.$$.on_disconnect);\n }\n $destroy() {\n destroy_component(this, 1);\n this.$destroy = noop;\n }\n $on(type, callback) {\n // TODO should this delegate to addEventListener?\n const callbacks = (this.$$.callbacks[type] || (this.$$.callbacks[type] = []));\n callbacks.push(callback);\n return () => {\n const index = callbacks.indexOf(callback);\n if (index !== -1)\n callbacks.splice(index, 1);\n };\n }\n $set($$props) {\n if (this.$$set && !is_empty($$props)) {\n this.$$.skip_bound = true;\n this.$$set($$props);\n this.$$.skip_bound = false;\n }\n }\n };\n}\n/**\n * Base class for Svelte components. Used when dev=false.\n */\nclass SvelteComponent {\n $destroy() {\n destroy_component(this, 1);\n this.$destroy = noop;\n }\n $on(type, callback) {\n const callbacks = (this.$$.callbacks[type] || (this.$$.callbacks[type] = []));\n callbacks.push(callback);\n return () => {\n const index = callbacks.indexOf(callback);\n if (index !== -1)\n callbacks.splice(index, 1);\n };\n }\n $set($$props) {\n if (this.$$set && !is_empty($$props)) {\n this.$$.skip_bound = true;\n this.$$set($$props);\n this.$$.skip_bound = false;\n }\n }\n}\n\nfunction dispatch_dev(type, detail) {\n document.dispatchEvent(custom_event(type, Object.assign({ version: '3.44.0' }, detail), true));\n}\nfunction append_dev(target, node) {\n dispatch_dev('SvelteDOMInsert', { target, node });\n append(target, node);\n}\nfunction append_hydration_dev(target, node) {\n dispatch_dev('SvelteDOMInsert', { target, node });\n append_hydration(target, node);\n}\nfunction insert_dev(target, node, anchor) {\n dispatch_dev('SvelteDOMInsert', { target, node, anchor });\n insert(target, node, anchor);\n}\nfunction insert_hydration_dev(target, node, anchor) {\n dispatch_dev('SvelteDOMInsert', { target, node, anchor });\n insert_hydration(target, node, anchor);\n}\nfunction detach_dev(node) {\n dispatch_dev('SvelteDOMRemove', { node });\n detach(node);\n}\nfunction detach_between_dev(before, after) {\n while (before.nextSibling && before.nextSibling !== after) {\n detach_dev(before.nextSibling);\n }\n}\nfunction detach_before_dev(after) {\n while (after.previousSibling) {\n detach_dev(after.previousSibling);\n }\n}\nfunction detach_after_dev(before) {\n while (before.nextSibling) {\n detach_dev(before.nextSibling);\n }\n}\nfunction listen_dev(node, event, handler, options, has_prevent_default, has_stop_propagation) {\n const modifiers = options === true ? ['capture'] : options ? Array.from(Object.keys(options)) : [];\n if (has_prevent_default)\n modifiers.push('preventDefault');\n if (has_stop_propagation)\n modifiers.push('stopPropagation');\n dispatch_dev('SvelteDOMAddEventListener', { node, event, handler, modifiers });\n const dispose = listen(node, event, handler, options);\n return () => {\n dispatch_dev('SvelteDOMRemoveEventListener', { node, event, handler, modifiers });\n dispose();\n };\n}\nfunction attr_dev(node, attribute, value) {\n attr(node, attribute, value);\n if (value == null)\n dispatch_dev('SvelteDOMRemoveAttribute', { node, attribute });\n else\n dispatch_dev('SvelteDOMSetAttribute', { node, attribute, value });\n}\nfunction prop_dev(node, property, value) {\n node[property] = value;\n dispatch_dev('SvelteDOMSetProperty', { node, property, value });\n}\nfunction dataset_dev(node, property, value) {\n node.dataset[property] = value;\n dispatch_dev('SvelteDOMSetDataset', { node, property, value });\n}\nfunction set_data_dev(text, data) {\n data = '' + data;\n if (text.wholeText === data)\n return;\n dispatch_dev('SvelteDOMSetData', { node: text, data });\n text.data = data;\n}\nfunction validate_each_argument(arg) {\n if (typeof arg !== 'string' && !(arg && typeof arg === 'object' && 'length' in arg)) {\n let msg = '{#each} only iterates over array-like objects.';\n if (typeof Symbol === 'function' && arg && Symbol.iterator in arg) {\n msg += ' You can use a spread to convert this iterable into an array.';\n }\n throw new Error(msg);\n }\n}\nfunction validate_slots(name, slot, keys) {\n for (const slot_key of Object.keys(slot)) {\n if (!~keys.indexOf(slot_key)) {\n console.warn(`<${name}> received an unexpected slot \"${slot_key}\".`);\n }\n }\n}\n/**\n * Base class for Svelte components with some minor dev-enhancements. Used when dev=true.\n */\nclass SvelteComponentDev extends SvelteComponent {\n constructor(options) {\n if (!options || (!options.target && !options.$$inline)) {\n throw new Error(\"'target' is a required option\");\n }\n super();\n }\n $destroy() {\n super.$destroy();\n this.$destroy = () => {\n console.warn('Component was already destroyed'); // eslint-disable-line no-console\n };\n }\n $capture_state() { }\n $inject_state() { }\n}\n/**\n * Base class to create strongly typed Svelte components.\n * This only exists for typing purposes and should be used in `.d.ts` files.\n *\n * ### Example:\n *\n * You have component library on npm called `component-library`, from which\n * you export a component called `MyComponent`. For Svelte+TypeScript users,\n * you want to provide typings. Therefore you create a `index.d.ts`:\n * ```ts\n * import { SvelteComponentTyped } from \"svelte\";\n * export class MyComponent extends SvelteComponentTyped<{foo: string}> {}\n * ```\n * Typing this makes it possible for IDEs like VS Code with the Svelte extension\n * to provide intellisense and to use the component like this in a Svelte file\n * with TypeScript:\n * ```svelte\n * <script lang=\"ts\">\n * \timport { MyComponent } from \"component-library\";\n * </script>\n * <MyComponent foo={'bar'} />\n * ```\n *\n * #### Why not make this part of `SvelteComponent(Dev)`?\n * Because\n * ```ts\n * class ASubclassOfSvelteComponent extends SvelteComponent<{foo: string}> {}\n * const component: typeof SvelteComponent = ASubclassOfSvelteComponent;\n * ```\n * will throw a type error, so we need to separate the more strictly typed class.\n */\nclass SvelteComponentTyped extends SvelteComponentDev {\n constructor(options) {\n super(options);\n }\n}\nfunction loop_guard(timeout) {\n const start = Date.now();\n return () => {\n if (Date.now() - start > timeout) {\n throw new Error('Infinite loop detected');\n }\n };\n}\n\nexport { HtmlTag, HtmlTagHydration, SvelteComponent, SvelteComponentDev, SvelteComponentTyped, SvelteElement, action_destroyer, add_attribute, add_classes, add_flush_callback, add_location, add_render_callback, add_resize_listener, add_transform, afterUpdate, append, append_dev, append_empty_stylesheet, append_hydration, append_hydration_dev, append_styles, assign, attr, attr_dev, attribute_to_object, beforeUpdate, bind, binding_callbacks, blank_object, bubble, check_outros, children, claim_component, claim_element, claim_html_tag, claim_space, claim_svg_element, claim_text, clear_loops, component_subscribe, compute_rest_props, compute_slots, createEventDispatcher, create_animation, create_bidirectional_transition, create_component, create_in_transition, create_out_transition, create_slot, create_ssr_component, current_component, custom_event, dataset_dev, debug, destroy_block, destroy_component, destroy_each, detach, detach_after_dev, detach_before_dev, detach_between_dev, detach_dev, dirty_components, dispatch_dev, each, element, element_is, empty, end_hydrating, escape, escape_attribute_value, escape_object, escaped, exclude_internal_props, fix_and_destroy_block, fix_and_outro_and_destroy_block, fix_position, flush, getAllContexts, getContext, get_all_dirty_from_scope, get_binding_group_value, get_current_component, get_custom_elements_slots, get_root_for_style, get_slot_changes, get_spread_object, get_spread_update, get_store_value, globals, group_outros, handle_promise, hasContext, has_prop, identity, init, insert, insert_dev, insert_hydration, insert_hydration_dev, intros, invalid_attribute_name_character, is_client, is_crossorigin, is_empty, is_function, is_promise, listen, listen_dev, loop, loop_guard, missing_component, mount_component, noop, not_equal, now, null_to_empty, object_without_properties, onDestroy, onMount, once, outro_and_destroy_block, prevent_default, prop_dev, query_selector_all, raf, run, run_all, safe_not_equal, schedule_update, select_multiple_value, select_option, select_options, select_value, self, setContext, set_attributes, set_current_component, set_custom_element_data, set_data, set_data_dev, set_input_type, set_input_value, set_now, set_raf, set_store_value, set_style, set_svg_attributes, space, spread, src_url_equal, start_hydrating, stop_propagation, subscribe, svg_element, text, tick, time_ranges_to_array, to_number, toggle_class, transition_in, transition_out, trusted, update_await_block_branch, update_keyed_each, update_slot, update_slot_base, validate_component, validate_each_argument, validate_each_keys, validate_slots, validate_store, xlink_attr };\n","let uid = 0;\n\nexport default function Id() {\n return '_el_' + uid++;\n}","export class LocalStore {\n\n get(name, defaultValue) {\n\n try {\n const serializedValue = window.localStorage.getItem(name);\n\n if (serializedValue) {\n return JSON.parse(serializedValue);\n }\n } catch (error) {\n console.warn('LocalStore: Failed to retrieve %s', name, error);\n }\n\n return defaultValue;\n }\n\n set(name, value) {\n\n try {\n window.localStorage.setItem(name, JSON.stringify(value));\n } catch (error) {\n console.warn('LocalStore: Failed to set %s', name, error);\n }\n }\n\n}\n\nexport class FakeLocalStore {\n\n get(name, defaultValue) {\n return defaultValue;\n }\n\n set(name, value) { }\n\n}\n\n\nexport function createLocalStore() {\n\n if (typeof window === 'undefined' || typeof window.localStorage === 'undefined') {\n return new FakeLocalStore();\n }\n\n return new LocalStore();\n}","export class History {\n\n push(url) {\n window.history.pushState(null, null, url);\n }\n\n onPop(fn) {\n window.addEventListener('popstate', fn);\n\n return function() {\n window.removeEventListener('popstate', fn);\n };\n }\n\n}\n\nexport class FakeHistory {\n\n push(url) {}\n\n onPop(fn) {\n return function() {};\n }\n\n}\n\nexport function createHistory() {\n\n if (typeof window === 'undefined' || typeof window.history === 'undefined') {\n return new FakeHistory();\n }\n\n return new History();\n}","export { default as Id } from './Id';\n\nexport { default as autoresize } from './autoresize';\n\nexport {\n createLocalStore\n} from './local-store';\n\nexport {\n createHistory\n} from './history';\n\nexport function delay(fn, timeout) {\n setTimeout(fn, timeout);\n}\n\nexport function periodic(fn, interval) {\n\n let canceled = false;\n\n let timeout = interval;\n\n let i;\n\n function stop() {\n canceled = true;\n\n clearTimeout(i);\n }\n\n function run() {\n\n Promise.resolve({}).then(() => fn()).then(\n success => true,\n err => false\n ).then(success => {\n timeout = success === false ? timeout * 1.5 : interval;\n\n if (!canceled) {\n i = setTimeout(run, timeout);\n }\n });\n }\n\n run();\n\n return stop;\n}\n\nexport {\n isClosingLink,\n isClosedByLink\n} from './links';\n\nexport function isOpen(issue) {\n return issue.state === 'open';\n}\n\nexport function isMerged(issue) {\n return issue.merged;\n}\n\nexport function isOpenOrMerged(issue) {\n return isOpen(issue) || isMerged(issue);\n}\n\nexport function isPull(issue) {\n return issue.pull_request;\n}\n\nexport {\n debounce,\n throttle\n} from 'min-dash';\n\n\nexport function noDuplicates(keyFn) {\n\n const found = {};\n\n return function filter(element) {\n const key = keyFn(element);\n\n if (key in found) {\n return false;\n }\n\n found[key] = true;\n\n return true;\n };\n}","<script>\n export let className = '';\n\n export let hints;\n export let selectedHint;\n\n export let onHover;\n export let onBlur;\n export let onSelect;\n\n export let maxElements;\n</script>\n\n<style lang=\"scss\">\n\n @import \"variables\";\n\n ul {\n list-style: none;\n margin: 0;\n padding: 0;\n }\n\n li {\n padding: 0 .8rem;\n line-height: 2em;\n\n &.selectable {\n cursor: pointer;\n\n &:hover,\n &.active {\n background: scale-color($primary, $alpha: -90%);\n }\n }\n\n &.text {\n color: $gray-600;\n }\n }\n\n .matched {\n background: scale-color($primary, $alpha: -80%);\n color: darken($primary, 10%);\n }\n</style>\n\n<ul class={ className }>\n {#each hints as hint, idx}\n {#if idx < maxElements || (selectedHint && selectedHint.name === hint.name) }\n <li\n class:active={ selectedHint && selectedHint.name === hint.name }\n class=\"selectable\"\n on:mouseover={ () => onHover(hint) }\n on:mouseout={ () => onBlur(hint) }\n on:mousedown|preventDefault={ (event) => onSelect(hint) }\n >{#each hint.parts as part}<span class:matched={ part.matched }>{ part.text }</span>{/each}</li>\n {/if}\n {/each}\n\n {#if hints.length > maxElements}\n <li class=\"text\">...</li>\n {/if}\n</ul>","function hasModifier(event) {\n const {\n ctrlKey,\n shiftKey,\n altKey,\n metaKey\n } = event;\n\n return ctrlKey || altKey || shiftKey || metaKey;\n}\n\nfunction isGlobal(event) {\n return event.target === document.body;\n}\n\nexport function isFindShortcut(event) {\n\n if (!isGlobal(event) || hasModifier(event)) {\n return false;\n }\n\n return event.key === 'f';\n}\n\nexport function isNewIssueShortcut(event) {\n\n if (!isGlobal(event) || hasModifier(event)) {\n return false;\n }\n\n return event.key === 'n';\n}\n\nexport function isApplyFilterClick(event) {\n\n const {\n shiftKey,\n altKey\n } = event;\n\n return shiftKey || altKey;\n}\n\nexport function isAddFilterClick(event) {\n\n const {\n shiftKey\n } = event;\n\n return shiftKey;\n}","<style lang=\"scss\">\n\n @import \"variables\";\n\n @import \"./HelpDropdown\";\n\n .board-filter {\n &.expanded {\n width: 500px;\n max-width: 100%;\n }\n\n > input {\n width: 100%;\n }\n\n width: 300px;\n }\n\n .icon {\n color: $gray-300;\n }\n</style>\n\n\n<script>\n import { Id } from './util';\n\n import {\n HintList\n } from './components';\n\n import {\n isFindShortcut\n } from './shortcuts';\n\n import {\n debounce\n } from './util';\n\n export let className = '';\n export let value = '';\n export let placeholder;\n\n export let completionOptions = {};\n\n export let onChange;\n\n let temporalPresets = [\n [ 'today', Date.now() ],\n [ 'last week', Date.now() - 1000 * 60 * 60 * 24 * 7 ],\n [ 'last month', Date.now() - 1000 * 60 * 60 * 24 * 30 ]\n ].map(([ name, value ]) => {\n\n const date = new Date(value);\n\n return { name, value: `>=${date.getFullYear()}-${date.getMonth() + 1}-${date.getDate()} ` };\n });\n\n let staticValues = {\n is: [\n 'assigned',\n 'unassigned',\n 'closed',\n 'open',\n 'issue',\n 'pull',\n 'milestoned'\n ].map(name => {\n return { name, value: `${name} ` };\n }),\n created: temporalPresets,\n updated: temporalPresets\n };\n\n $: dynamicValues = Object.entries(completionOptions).reduce((values, entry) => {\n\n const [ key, value ] = entry;\n\n values[key] = value.slice().sort().map(name => {\n\n const separator = /[: ]/.test(name) ? '\"' : '';\n\n return { name, value: `${separator}${name}${separator} ` };\n });\n\n return values;\n }, {});\n\n const qualifierCategories = [\n {\n name: 'Operators',\n options: [\n 'label',\n 'assignee',\n 'author',\n 'repo',\n 'reviewer',\n 'commented',\n 'milestone',\n 'created',\n 'updated',\n 'involves',\n 'is'\n ].map(name => {\n return {\n name,\n value: `${name}:`\n };\n })\n }\n ];\n\n let keyboardSelectedHint;\n let mouseSelectedHint;\n\n $: categoryValues = {\n ...staticValues,\n ...dynamicValues\n };\n\n $: selectedHint = mouseSelectedHint || keyboardSelectedHint;\n\n let input;\n\n let focussed = false;\n let match;\n let allHints;\n\n let position = 0;\n\n $: expanded = focussed || value;\n $: {\n console.time('BoardFilter#computeMatch');\n\n let opts = computeMatch(value, position, categoryValues);\n\n console.timeEnd('BoardFilter#computeMatch');\n\n match = opts.match;\n allHints = opts.allHints;\n\n keyboardSelectedHint = (\n allHints && keyboardSelectedHint && allHints.find(\n hint => hint.name === keyboardSelectedHint.name\n ) || opts.keyboardSelectedHint\n );\n }\n\n const searchId = Id();\n\n function computeMatch(value, searchEnd, categoryValues) {\n\n const beforeCursor = value.substring(0, searchEnd);\n\n const searchStart = beforeCursor.lastIndexOf(' ') + 1;\n\n value = value.substring(searchStart, searchEnd).toLowerCase();\n\n const match = /^([-!]?)(?:([\\w]+)(?:(:)(?:\"([\\w-]+)\"?|([\\w-]+))?)?)$/.exec(value);\n\n if (!match) {\n return {};\n }\n\n let [ _, negator, qualifier, sep, qualifierText, qualifierTextEscaped ] = match;\n\n const search = sep ? (qualifierText || qualifierTextEscaped || '') : qualifier;\n\n const allHints = [];\n\n const categories = sep ? [\n {\n name: 'Values',\n options: categoryValues[qualifier] || []\n }\n ] : qualifierCategories;\n\n const matchedCategories = categories.reduce((matchedCategories, category) => {\n\n const matchedValues = category.options.reduce((matchedValues, categoryOption) => {\n\n const {\n name,\n value\n } = categoryOption;\n\n if (name.toLowerCase().includes(search)) {\n\n const idx = name.indexOf(search);\n\n const hint = {\n name: name,\n parts: [\n {\n text: name.substring(0, idx)\n },\n {\n text: name.substring(idx, idx + search.length),\n matched: true\n },\n {\n text: name.substring(idx + search.length)\n }\n ],\n apply: (currentValue) => {\n\n const before = currentValue.substring(0, searchStart);\n const fix = (negator || '') + (sep ? qualifier + sep : '') + value;\n const after = currentValue.substring(searchEnd);\n\n return {\n val: `${before}${fix}${after}`,\n idx: before.length + fix.length\n };\n }\n };\n\n matchedValues.push(hint);\n allHints.push(hint);\n }\n\n return matchedValues;\n }, []);\n\n\n if (matchedValues.length) {\n matchedCategories.push({\n name: category.name,\n values: matchedValues\n });\n }\n\n return matchedCategories;\n }, []);\n\n if (matchedCategories.length) {\n\n return {\n match: { categories: matchedCategories },\n keyboardSelectedHint: matchedCategories[0].values[0],\n allHints\n };\n }\n\n return {\n match: null,\n keyboardSelectedHint: null,\n allHints: []\n };\n }\n\n function applyHint(hint) {\n\n const {\n val,\n idx\n } = hint.apply(value);\n\n input.value = value = val;\n input.selectionEnd = input.selectionStart = position = idx;\n\n triggerChanged(value);\n }\n\n function handleInput(event) {\n\n const target = event.target;\n\n value = target.value;\n position = target.selectionStart;\n\n triggerChanged(value);\n }\n\n function nextHint(currentHint, direction) {\n\n const hints = (allHints || []);\n\n const currentIndex = hints.findIndex(hint => hint.name === currentHint.name);\n\n let nextIndex = currentIndex + direction;\n\n if (nextIndex < 0) {\n nextIndex = hints.length - 1;\n }\n\n if (nextIndex === hints.length) {\n nextIndex = 0;\n }\n\n return hints[nextIndex];\n }\n\n function handleInputKey(event) {\n\n const key = event.key;\n\n if (key === 'Enter') {\n if (keyboardSelectedHint) {\n applyHint(keyboardSelectedHint);\n }\n\n event.preventDefault();\n }\n\n if (key === 'ArrowUp') {\n keyboardSelectedHint = nextHint(keyboardSelectedHint, -1);\n event.preventDefault();\n }\n\n if (key === 'ArrowDown') {\n keyboardSelectedHint = nextHint(keyboardSelectedHint, 1);\n event.preventDefault();\n }\n\n if (key === 'Escape' && !value) {\n input.blur();\n\n event.preventDefault();\n }\n }\n\n const triggerChanged = debounce((value) => {\n onChange && onChange(value);\n }, 500);\n\n function isInputTarget(event) {\n const {\n target\n } = event;\n\n return target === input;\n }\n\n function handleGlobalKey(event) {\n\n if (isFindShortcut(event)) {\n event.preventDefault();\n\n if (!isInputTarget(event)) {\n input.focus();\n }\n }\n }\n</script>\n\n<svelte:window on:keydown={ handleGlobalKey } />\n\n<div class=\"board-filter { className } dropdown-parent { expanded && 'expanded' }\">\n <input\n class=\"form-control\"\n type=\"search\"\n placeholder={ placeholder }\n id={searchId}\n autocomplete=\"off\"\n spellcheck=\"false\"\n aria-label={ placeholder }\n title={ placeholder + ' (f)'}\n bind:this={ input }\n bind:value={ value }\n on:input={ handleInput }\n on:keydown={ handleInputKey }\n on:focus={ () => focussed = true }\n on:blur={ () => focussed = false }\n />\n\n {#if value && match}\n <div class=\"help-dropdown\">\n {#each match.categories as category, idx}\n {#if idx > 0}\n <hr />\n {/if}\n\n <div class=\"category\">{ category.name }</div>\n\n <HintList\n hints={ category.values }\n selectedHint={ selectedHint }\n onHover={ hint => mouseSelectedHint = hint }\n onBlur={ () => mouseSelectedHint = null }\n onSelect={ applyHint }\n maxElements= { 7 }\n />\n\n {/each}\n </div>\n {:else if focussed && !value}\n <div class=\"help-dropdown\">\n <p class=\"note\">\n Filter cards by title and description.\n </p>\n\n <p class=\"note\">\n Refine your search with operators: <em>created</em>, <em>updated</em>, <em>milestone</em>, <em>repo</em>, <em>assignee</em>, <em>label</em> and <em>is</em>.\n </p>\n </div>\n {/if}\n</div>","<script>\n export let rounded = false;\n export let title = '';\n</script>\n\n<style lang=\"scss\">\n .avatar {\n position: relative;\n display: inline-block;\n overflow: hidden;\n color: #fff;\n white-space: nowrap;\n text-align: center;\n vertical-align: middle;\n background: #ccc;\n width: 32px;\n height: 32px;\n line-height: 32px;\n }\n\n .avatar-shadow {\n position: absolute;\n top: 0;\n left: 0;\n width: 100%;\n height: 100%;\n\n box-shadow: inset 0 0 2px 0 rgba(0,0,0,.1);\n }\n\n .avatar-rounded {\n border-radius: 50%;\n\n .avatar-shadow {\n border-radius: 50%;\n }\n }\n</style>\n\n<span class=\"avatar\" title={ title } class:avatar-rounded={ rounded }>\n <slot></slot>\n\n <div class=\"avatar-shadow\"></div>\n</span>","<style lang=\"scss\">\n .loader {\n\n position: absolute;\n left: 50%;\n top: 50%;\n transform: translate(-50%, -50%);\n text-align: center;\n z-index: 200;\n pointer-events: none;\n\n > .content {\n opacity: 0.3;\n transition: opacity 0.5s;\n }\n\n &.shown > .content {\n opacity: 1;\n\n animation: pulsate 1s infinite;\n animation-timing-function: ease-in-out;\n }\n\n &:not(.shown) > .content {\n opacity: 0;\n }\n }\n\n\n @keyframes pulsate {\n 0% {\n transform: scale(1);\n opacity: 1;\n }\n\n 50% {\n transform: scale(0.9);\n opacity: 0.8;\n }\n\n 100% {\n transform: scale(1);\n opacity: 1;\n }\n }\n</style>\n\n<script>\n export let className = '';\n export let shown = true;\n</script>\n\n<div class=\"loader { className }\" class:shown={ shown }>\n <div class=\"content\">\n <slot></slot>\n </div>\n</div>","<style lang=\"scss\">\n .powered-by {\n position: absolute;\n bottom: 10px;\n right: 10px;\n padding: 7px;\n border-radius: 4px;\n\n opacity: .5;\n transition: opacity .1s, background .1s;\n\n color: #333;\n\n z-index: 10;\n\n align-items: center;\n\n display: flex;\n\n svg {\n vertical-align: bottom;\n }\n\n &:not(:hover) .logo {\n color: #999;\n }\n\n &:hover {\n opacity: 1;\n box-shadow: 0 1px 3px rgba(0, 0, 0, 0.3);\n background: white;\n\n .help {\n display: block;\n }\n }\n\n .help {\n font-size: .9em;\n display: none;\n }\n\n .logo {\n margin-left: .5em;\n }\n\n .help-item {\n margin-left: .5em;\n }\n\n .help-item + .help-item {\n margin-left: 1em;\n }\n\n .help-item {\n display: inline-block;\n }\n }\n</style>\n\n<div class=\"powered-by\">\n <div class=\"help\">\n <a class=\"help-item\" href=\"https://wuffle.dev/docs\"\n target=\"_blank\" rel=\"noopener\">\n Documentation\n </a>\n\n <span class=\"help-item\">\n Powered by\n </span>\n </div>\n\n <a class=\"logo\" href=\"https://wuffle.dev\"\n target=\"_blank\" rel=\"noopener\">\n\n <!-- ./logo-gray.svg with dynamic fill color -->\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 80 80\" width=\"20\" height=\"20\"><path d=\"M12 0h56c7 0 12 5 12 12v56c0 7-5 12-12 12H12C5 80 0 75 0 68V12C0 5 5 0 12 0z\" fill=\"currentColor\"/><path d=\"M15 10h21c3 0 5 2 5 5v6c0 3-2 5-5 5H15c-2 0-4-2-4-5v-6c0-3 2-5 4-5zm0 20h21c3 0 5 2 5 5v6c0 2-2 4-5 4H15c-2 0-4-1-4-4v-6c0-3 2-5 4-5zm27 22h21c2 0 4 2 4 5v6c0 2-2 4-4 4H42c-2 0-4-2-4-4v-6c0-3 2-5 4-5z\" fill=\"#fff\"/></svg>\n </a>\n</div>","<style lang=\"scss\">\n .notifications {\n position: fixed;\n z-index: 1010;\n top: 24px;\n right: 24px;\n }\n</style>\n\n<div class=\"notifications\">\n <slot></slot>\n</div>","export { identity as linear } from '../internal/index.mjs';\n\n/*\nAdapted from https://github.com/mattdesl\nDistributed under MIT License https://github.com/mattdesl/eases/blob/master/LICENSE.md\n*/\nfunction backInOut(t) {\n const s = 1.70158 * 1.525;\n if ((t *= 2) < 1)\n return 0.5 * (t * t * ((s + 1) * t - s));\n return 0.5 * ((t -= 2) * t * ((s + 1) * t + s) + 2);\n}\nfunction backIn(t) {\n const s = 1.70158;\n return t * t * ((s + 1) * t - s);\n}\nfunction backOut(t) {\n const s = 1.70158;\n return --t * t * ((s + 1) * t + s) + 1;\n}\nfunction bounceOut(t) {\n const a = 4.0 / 11.0;\n const b = 8.0 / 11.0;\n const c = 9.0 / 10.0;\n const ca = 4356.0 / 361.0;\n const cb = 35442.0 / 1805.0;\n const cc = 16061.0 / 1805.0;\n const t2 = t * t;\n return t < a\n ? 7.5625 * t2\n : t < b\n ? 9.075 * t2 - 9.9 * t + 3.4\n : t < c\n ? ca * t2 - cb * t + cc\n : 10.8 * t * t - 20.52 * t + 10.72;\n}\nfunction bounceInOut(t) {\n return t < 0.5\n ? 0.5 * (1.0 - bounceOut(1.0 - t * 2.0))\n : 0.5 * bounceOut(t * 2.0 - 1.0) + 0.5;\n}\nfunction bounceIn(t) {\n return 1.0 - bounceOut(1.0 - t);\n}\nfunction circInOut(t) {\n if ((t *= 2) < 1)\n return -0.5 * (Math.sqrt(1 - t * t) - 1);\n return 0.5 * (Math.sqrt(1 - (t -= 2) * t) + 1);\n}\nfunction circIn(t) {\n return 1.0 - Math.sqrt(1.0 - t * t);\n}\nfunction circOut(t) {\n return Math.sqrt(1 - --t * t);\n}\nfunction cubicInOut(t) {\n return t < 0.5 ? 4.0 * t * t * t : 0.5 * Math.pow(2.0 * t - 2.0, 3.0) + 1.0;\n}\nfunction cubicIn(t) {\n return t * t * t;\n}\nfunction cubicOut(t) {\n const f = t - 1.0;\n return f * f * f + 1.0;\n}\nfunction elasticInOut(t) {\n return t < 0.5\n ? 0.5 *\n Math.sin(((+13.0 * Math.PI) / 2) * 2.0 * t) *\n Math.pow(2.0, 10.0 * (2.0 * t - 1.0))\n : 0.5 *\n Math.sin(((-13.0 * Math.PI) / 2) * (2.0 * t - 1.0 + 1.0)) *\n Math.pow(2.0, -10.0 * (2.0 * t - 1.0)) +\n 1.0;\n}\nfunction elasticIn(t) {\n return Math.sin((13.0 * t * Math.PI) / 2) * Math.pow(2.0, 10.0 * (t - 1.0));\n}\nfunction elasticOut(t) {\n return (Math.sin((-13.0 * (t + 1.0) * Math.PI) / 2) * Math.pow(2.0, -10.0 * t) + 1.0);\n}\nfunction expoInOut(t) {\n return t === 0.0 || t === 1.0\n ? t\n : t < 0.5\n ? +0.5 * Math.pow(2.0, 20.0 * t - 10.0)\n : -0.5 * Math.pow(2.0, 10.0 - t * 20.0) + 1.0;\n}\nfunction expoIn(t) {\n return t === 0.0 ? t : Math.pow(2.0, 10.0 * (t - 1.0));\n}\nfunction expoOut(t) {\n return t === 1.0 ? t : 1.0 - Math.pow(2.0, -10.0 * t);\n}\nfunction quadInOut(t) {\n t /= 0.5;\n if (t < 1)\n return 0.5 * t * t;\n t--;\n return -0.5 * (t * (t - 2) - 1);\n}\nfunction quadIn(t) {\n return t * t;\n}\nfunction quadOut(t) {\n return -t * (t - 2.0);\n}\nfunction quartInOut(t) {\n return t < 0.5\n ? +8.0 * Math.pow(t, 4.0)\n : -8.0 * Math.pow(t - 1.0, 4.0) + 1.0;\n}\nfunction quartIn(t) {\n return Math.pow(t, 4.0);\n}\nfunction quartOut(t) {\n return Math.pow(t - 1.0, 3.0) * (1.0 - t) + 1.0;\n}\nfunction quintInOut(t) {\n if ((t *= 2) < 1)\n return 0.5 * t * t * t * t * t;\n return 0.5 * ((t -= 2) * t * t * t * t + 2);\n}\nfunction quintIn(t) {\n return t * t * t * t * t;\n}\nfunction quintOut(t) {\n return --t * t * t * t * t + 1;\n}\nfunction sineInOut(t) {\n return -0.5 * (Math.cos(Math.PI * t) - 1);\n}\nfunction sineIn(t) {\n const v = Math.cos(t * Math.PI * 0.5);\n if (Math.abs(v) < 1e-14)\n return 1;\n else\n return 1 - v;\n}\nfunction sineOut(t) {\n return Math.sin((t * Math.PI) / 2);\n}\n\nexport { backIn, backInOut, backOut, bounceIn, bounceInOut, bounceOut, circIn, circInOut, circOut, cubicIn, cubicInOut, cubicOut, elasticIn, elasticInOut, elasticOut, expoIn, expoInOut, expoOut, quadIn, quadInOut, quadOut, quartIn, quartInOut, quartOut, quintIn, quintInOut, quintOut, sineIn, sineInOut, sineOut };\n","import { cubicInOut, linear, cubicOut } from '../easing/index.mjs';\nimport { is_function, assign } from '../internal/index.mjs';\n\n/*! *****************************************************************************\r\nCopyright (c) Microsoft Corporation.\r\n\r\nPermission to use, copy, modify, and/or distribute this software for any\r\npurpose with or without fee is hereby granted.\r\n\r\nTHE SOFTWARE IS PROVIDED \"AS IS\" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH\r\nREGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY\r\nAND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT,\r\nINDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM\r\nLOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR\r\nOTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR\r\nPERFORMANCE OF THIS SOFTWARE.\r\n***************************************************************************** */\r\n\r\nfunction __rest(s, e) {\r\n var t = {};\r\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)\r\n t[p] = s[p];\r\n if (s != null && typeof Object.getOwnPropertySymbols === \"function\")\r\n for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {\r\n if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))\r\n t[p[i]] = s[p[i]];\r\n }\r\n return t;\r\n}\n\nfunction blur(node, { delay = 0, duration = 400, easing = cubicInOut, amount = 5, opacity = 0 } = {}) {\n const style = getComputedStyle(node);\n const target_opacity = +style.opacity;\n const f = style.filter === 'none' ? '' : style.filter;\n const od = target_opacity * (1 - opacity);\n return {\n delay,\n duration,\n easing,\n css: (_t, u) => `opacity: ${target_opacity - (od * u)}; filter: ${f} blur(${u * amount}px);`\n };\n}\nfunction fade(node, { delay = 0, duration = 400, easing = linear } = {}) {\n const o = +getComputedStyle(node).opacity;\n return {\n delay,\n duration,\n easing,\n css: t => `opacity: ${t * o}`\n };\n}\nfunction fly(node, { delay = 0, duration = 400, easing = cubicOut, x = 0, y = 0, opacity = 0 } = {}) {\n const style = getComputedStyle(node);\n const target_opacity = +style.opacity;\n const transform = style.transform === 'none' ? '' : style.transform;\n const od = target_opacity * (1 - opacity);\n return {\n delay,\n duration,\n easing,\n css: (t, u) => `\n\t\t\ttransform: ${transform} translate(${(1 - t) * x}px, ${(1 - t) * y}px);\n\t\t\topacity: ${target_opacity - (od * u)}`\n };\n}\nfunction slide(node, { delay = 0, duration = 400, easing = cubicOut } = {}) {\n const style = getComputedStyle(node);\n const opacity = +style.opacity;\n const height = parseFloat(style.height);\n const padding_top = parseFloat(style.paddingTop);\n const padding_bottom = parseFloat(style.paddingBottom);\n const margin_top = parseFloat(style.marginTop);\n const margin_bottom = parseFloat(style.marginBottom);\n const border_top_width = parseFloat(style.borderTopWidth);\n const border_bottom_width = parseFloat(style.borderBottomWidth);\n return {\n delay,\n duration,\n easing,\n css: t => 'overflow: hidden;' +\n `opacity: ${Math.min(t * 20, 1) * opacity};` +\n `height: ${t * height}px;` +\n `padding-top: ${t * padding_top}px;` +\n `padding-bottom: ${t * padding_bottom}px;` +\n `margin-top: ${t * margin_top}px;` +\n `margin-bottom: ${t * margin_bottom}px;` +\n `border-top-width: ${t * border_top_width}px;` +\n `border-bottom-width: ${t * border_bottom_width}px;`\n };\n}\nfunction scale(node, { delay = 0, duration = 400, easing = cubicOut, start = 0, opacity = 0 } = {}) {\n const style = getComputedStyle(node);\n const target_opacity = +style.opacity;\n const transform = style.transform === 'none' ? '' : style.transform;\n const sd = 1 - start;\n const od = target_opacity * (1 - opacity);\n return {\n delay,\n duration,\n easing,\n css: (_t, u) => `\n\t\t\ttransform: ${transform} scale(${1 - (sd * u)});\n\t\t\topacity: ${target_opacity - (od * u)}\n\t\t`\n };\n}\nfunction draw(node, { delay = 0, speed, duration, easing = cubicInOut } = {}) {\n let len = node.getTotalLength();\n const style = getComputedStyle(node);\n if (style.strokeLinecap !== 'butt') {\n len += parseInt(style.strokeWidth);\n }\n if (duration === undefined) {\n if (speed === undefined) {\n duration = 800;\n }\n else {\n duration = len / speed;\n }\n }\n else if (typeof duration === 'function') {\n duration = duration(len);\n }\n return {\n delay,\n duration,\n easing,\n css: (t, u) => `stroke-dasharray: ${t * len} ${u * len}`\n };\n}\nfunction crossfade(_a) {\n var { fallback } = _a, defaults = __rest(_a, [\"fallback\"]);\n const to_receive = new Map();\n const to_send = new Map();\n function crossfade(from, node, params) {\n const { delay = 0, duration = d => Math.sqrt(d) * 30, easing = cubicOut } = assign(assign({}, defaults), params);\n const to = node.getBoundingClientRect();\n const dx = from.left - to.left;\n const dy = from.top - to.top;\n const dw = from.width / to.width;\n const dh = from.height / to.height;\n const d = Math.sqrt(dx * dx + dy * dy);\n const style = getComputedStyle(node);\n const transform = style.transform === 'none' ? '' : style.transform;\n const opacity = +style.opacity;\n return {\n delay,\n duration: is_function(duration) ? duration(d) : duration,\n easing,\n css: (t, u) => `\n\t\t\t\topacity: ${t * opacity};\n\t\t\t\ttransform-origin: top left;\n\t\t\t\ttransform: ${transform} translate(${u * dx}px,${u * dy}px) scale(${t + (1 - t) * dw}, ${t + (1 - t) * dh});\n\t\t\t`\n };\n }\n function transition(items, counterparts, intro) {\n return (node, params) => {\n items.set(params.key, {\n rect: node.getBoundingClientRect()\n });\n return () => {\n if (counterparts.has(params.key)) {\n const { rect } = counterparts.get(params.key);\n counterparts.delete(params.key);\n return crossfade(rect, node, params);\n }\n // if the node is disappearing altogether\n // (i.e. wasn't claimed by the other list)\n // then we need to supply an outro\n items.delete(params.key);\n return fallback && fallback(node, params, intro);\n };\n };\n }\n return [\n transition(to_send, to_receive, false),\n transition(to_receive, to_send, true)\n ];\n}\n\nexport { blur, crossfade, draw, fade, fly, scale, slide };\n","<script>\n import { fly } from 'svelte/transition';\n\n export let message;\n\n export let type = 'info';\n</script>\n\n<style lang=\"scss\">\n\n @import \"variables\";\n\n .notification {\n box-sizing: border-box;\n margin: 0;\n padding: 0;\n color: $gray-600;\n font-size: 14px;\n font-variant: tabular-nums;\n line-height: 1.5;\n list-style: none;\n width: 384px;\n max-width: calc(100vw - 32px);\n padding: 16px 24px;\n overflow: hidden;\n line-height: 1.5;\n background: #fff;\n border-radius: 3px;\n box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);\n border-left: solid 4px $info;\n\n &.error {\n border-left-color: $danger;\n }\n\n &.warning {\n border-left-color: $warning;\n }\n }\n\n .notification + .notification {\n margin-top: 16px;\n }\n\n .heading {\n color: $gray-900;\n font-weight: normal;\n font-size: 1.2em;\n margin-bottom: 5px;\n }\n</style>\n\n<div\n class=\"notification\"\n class:error={ type === 'error' }\n class:warning={ type === 'warning' }\n transition:fly\n>\n <div class=\"heading\">{ message }</div>\n <div class=\"detail\">\n <slot></slot>\n </div>\n</div>","<script>\n function isLight(color) {\n /* eslint no-bitwise: \"off\" */\n\n color = +('0x' + color.slice(1).replace(color.length < 5 && /./g, '$&$&'));\n\n const r = color >> 16,\n g = (color >> 8) & 255,\n b = color & 255;\n\n const hsp = Math.sqrt(\n 0.299 * (r * r) +\n 0.587 * (g * g) +\n 0.114 * (b * b)\n );\n\n return hsp > 127.5;\n }\n\n export let title = '';\n export let name;\n export let color = '';\n export let className = '';\n\n export let onClick;\n export let href = null;\n\n $: inverted = color && isLight(color);\n</script>\n\n{#if href}\n <a\n href={ href }\n target=\"_blank\"\n title={ title || name }\n rel=\"noopener noreferrer\"\n class:inverted={ inverted }\n class=\"tag { className }\"\n style=\"background-color: { color }\"\n on:click={ onClick }\n >{ name }</a>\n{:else}\n <span\n class:inverted={ inverted }\n class=\"tag { className }\"\n class:clickable={ onClick }\n style=\"background-color: { color }\"\n on:click={ onClick }\n title={ title || name }\n >{ name }</span>\n{/if}\n\n<style lang=\"scss\">\n .tag {\n list-style: none;\n display: inline-block;\n height: auto;\n\n margin: 0 4px 4px 0;\n padding: 1px 7px;\n\n font-size: 12px;\n font-weight: 500;\n\n line-height: 20px;\n white-space: nowrap;\n\n overflow: hidden;\n text-overflow: ellipsis;\n\n color: white;\n background: #fafafa;\n border-radius: 4px;\n\n text-decoration: none;\n\n &:not(a) {\n cursor: default;\n }\n\n &.inverted {\n color: #333;\n }\n }\n\n :not(a.tag, .tag.clickable) {\n cursor: default;\n }\n</style>","<script>\n export let item;\n\n $: merged = item.merged;\n $: open = item.state === 'open';\n $: closed = item.state === 'closed';\n $: draft = item.draft || false;\n</script>\n\n<style lang=\"scss\">\n\n .pull-request-icon {\n margin-right: 1px;\n\n &.open {\n color: #28a745;\n }\n\n &.closed {\n color: #cb2431;\n }\n\n &.merged {\n color: #6f42c1;\n }\n\n &.draft {\n color: #6e7781;\n }\n }\n</style>\n\n{#if merged}\n\n <svg class=\"pull-request-icon\" class:merged={ merged } width=\"1em\" height=\"1em\" viewBox=\"0 0 12 16\" version=\"1.1\" aria-hidden=\"true\" fill=\"currentColor\">\n <path fill-rule=\"evenodd\" d=\"M10 7c-.73 0-1.38.41-1.73 1.02V8C7.22 7.98 6 7.64 5.14 6.98c-.75-.58-1.5-1.61-1.89-2.44A1.993 1.993 0 0 0 2 .99C.89.99 0 1.89 0 3a2 2 0 0 0 1 1.72v6.56c-.59.35-1 .99-1 1.72 0 1.11.89 2 2 2a1.993 1.993 0 0 0 1-3.72V7.67c.67.7 1.44 1.27 2.3 1.69.86.42 2.03.63 2.97.64v-.02c.36.61 1 1.02 1.73 1.02 1.11 0 2-.89 2-2 0-1.11-.89-2-2-2zm-6.8 6c0 .66-.55 1.2-1.2 1.2-.65 0-1.2-.55-1.2-1.2 0-.65.55-1.2 1.2-1.2.65 0 1.2.55 1.2 1.2zM2 4.2C1.34 4.2.8 3.65.8 3c0-.65.55-1.2 1.2-1.2.65 0 1.2.55 1.2 1.2 0 .65-.55 1.2-1.2 1.2zm8 6c-.66 0-1.2-.55-1.2-1.2 0-.65.55-1.2 1.2-1.2.65 0 1.2.55 1.2 1.2 0 .65-.55 1.2-1.2 1.2z\"></path>\n </svg>\n\n{:else}\n <svg class=\"pull-request-icon\" class:closed={ closed } class:open={ open } class:draft={ draft } width=\"1em\" height=\"1em\" viewBox=\"0 0 12 16\" version=\"1.1\" aria-hidden=\"true\" fill=\"currentColor\">\n <path fill-rule=\"evenodd\" d=\"M11 11.28V5c-.03-.78-.34-1.47-.94-2.06C9.46 2.35 8.78 2.03 8 2H7V0L4 3l3 3V4h1c.27.02.48.11.69.31.21.2.3.42.31.69v6.28A1.993 1.993 0 0 0 10 15a1.993 1.993 0 0 0 1-3.72zm-1 2.92c-.66 0-1.2-.55-1.2-1.2 0-.65.55-1.2 1.2-1.2.65 0 1.2.55 1.2 1.2 0 .65-.55 1.2-1.2 1.2zM4 3c0-1.11-.89-2-2-2a1.993 1.993 0 0 0-1 3.72v6.56A1.993 1.993 0 0 0 2 15a1.993 1.993 0 0 0 1-3.72V4.72c.59-.34 1-.98 1-1.72zm-.8 10c0 .66-.55 1.2-1.2 1.2-.65 0-1.2-.55-1.2-1.2 0-.65.55-1.2 1.2-1.2.65 0 1.2.55 1.2 1.2zM2 4.2C1.34 4.2.8 3.65.8 3c0-.65.55-1.2 1.2-1.2.65 0 1.2.55 1.2 1.2 0 .65-.55 1.2-1.2 1.2z\"></path>\n </svg>\n{/if}","<style lang=\"scss\">\n\n .icon {\n margin-right: 2px;\n\n color: #1d76db;\n }\n</style>\n\n<svg class=\"icon\" width=\"1em\" height=\"1em\" viewBox=\"0 0 12 16\" version=\"1.1\" aria-hidden=\"true\">\n\n <path fill=\"currentColor\" stroke=\"#1d76db\" d=\"M1 15V4l5-3 5 3v11l-5-4-5 4z\" stroke-width=\"1.5\" />\n\n</svg>","<script>\n\n export let item;\n\n $: check_runs = item.check_runs || [];\n $: statuses = item.statuses || [];\n\n const check_run_result_map = {\n failure: 'failed',\n success: 'succeeded',\n in_progress: 'in progress',\n queued: 'queued',\n action_required: 'action required'\n };\n</script>\n\n<style lang=\"scss\">\n\n @import \"variables\";\n\n $color-success: $success;\n $color-action-required: $warning;\n $color-failure: $danger;\n\n /*\n $color-success: #77da8e;\n $color-failure: #da8077;\n $color-action-required: #dac977;\n */\n\n @mixin colored-scale($color) {\n background-color: scale-color($color, $lightness: +40%);\n box-shadow: 0 1px 2px 0px scale-color($color, $saturation: -20%, $alpha: -70%);\n }\n\n .card-status {\n display: flex;\n flex-direction: row;\n align-items: stretch;\n height: 3px;\n\n width: auto;\n margin: 3px -8px -4px;\n }\n\n .state {\n flex: 1;\n\n background-color: $gray-500;\n\n > span {\n display: none;\n }\n\n &.striped {\n background-image: linear-gradient(\n 45deg,\n rgba(255,255,255,.15) 25%,\n transparent 25%,\n transparent 50%,\n rgba(255,255,255,.15) 50%,\n rgba(255,255,255,.15) 75%,\n transparent 75%,\n transparent\n );\n\n animation: progress-bar-stripes 1s linear infinite;\n\n background-size: 1rem 1rem;\n }\n\n &.success {\n @include colored-scale($color-success);\n }\n\n &.failure {\n @include colored-scale($color-failure);\n }\n\n &.action-required {\n @include colored-scale($color-action-required);\n }\n }\n\n .state + .state {\n margin-left: 1px;\n }\n\n @keyframes progress-bar-stripes {\n from { background-position: $progress-height 0; }\n to { background-position: 0 0; }\n }\n</style>\n\n{#if check_runs.length || statuses.length}\n <div class=\"card-status\">\n\n {#each check_runs as check_run}\n <a\n class=\"state\"\n class:success={ check_run.conclusion === 'success' || check_run.status === 'in_progress' }\n class:failure={ check_run.conclusion === 'failure' }\n class:action-required={ check_run.conclusion === 'action_required' }\n class:striped={ check_run.status === 'in_progress' || check_run.status === 'queued' }\n target=\"_blank\"\n rel=\"noopener noreferrer\"\n title={ `${ check_run.name } — ${check_run_result_map[check_run.conclusion] || check_run_result_map[check_run.status] }` }\n href={ check_run.html_url }\n ><span>{check_run.name} — {check_run_result_map[check_run.conclusion] || check_run_result_map[check_run.status] }</span></a>\n {/each}\n\n {#each statuses as status}\n <a\n class=\"state\"\n class:success={ status.state === 'success' || status.state === 'pending' }\n class:failure={ status.state === 'failure' }\n class:action-required={ status.state === 'error' }\n class:striped={ status.state === 'pending' }\n target=\"_blank\"\n rel=\"noopener noreferrer\"\n title={ `${ status.context } — ${status.description}` }\n href={ status.target_url }\n ><span>{ status.context } — {status.description}</span></a>\n {/each}\n </div>\n{/if}","<script>\n\n import {\n isAddFilterClick,\n isApplyFilterClick\n } from './shortcuts';\n\n export let item;\n export let onSelect;\n\n $: number = item.number;\n $: repository = item.repository;\n $: repositoryName = `${repository.owner.login}/${repository.name}`;\n $: repoUrl = `https://github.com/${ repositoryName }`;\n\n $: assignees = item.assignees;\n\n $: comments = (\n Array.isArray(item.comments) ? item.comments : []\n ).map(comment => {\n const {\n user,\n html_url\n } = comment;\n\n return {\n state: 'commented',\n user,\n html_url\n };\n });\n\n $: requested_reviewers = item.requested_reviewers || [];\n\n $: reviews = Object.values(\n [].concat(comments, item.reviews || [])\n .filter(review => !requested_reviewers.find(reviewer => reviewer.login === review.user.login))\n .reduce((byUser, review) => {\n\n const existingReview = byUser[review.user.login];\n\n // keep last definitive review (approved, changes_requested)\n // to match GitHub display and behavior\n if (\n !existingReview ||\n existingReview.state === 'commented' ||\n review.state !== 'commented'\n ) {\n byUser[review.user.login] = review;\n }\n\n return byUser;\n }, {})\n );\n\n const stateToVerb = {\n changes_requested: 'requested changes',\n approved: 'approved',\n commented: 'commented',\n dismissed: 'dismissed his review'\n };\n\n function handleSelection(qualifier, value) {\n\n return onSelect && function(event) {\n\n if (!isApplyFilterClick(event)) {\n return;\n }\n\n event.preventDefault();\n\n onSelect(qualifier, value, isAddFilterClick(event));\n };\n }\n</script>\n\n<style lang=\"scss\">\n @import \"variables\";\n\n $separatorColor: white;\n\n @mixin review-badge($color) {\n\n &:before {\n content: '';\n display: block;\n background: $color;\n box-shadow: 0 0 0 2px $separatorColor;\n width: 6px;\n height: 6px;\n border-radius: 50%;\n position: absolute;\n top: -2px;\n left: -2px;\n z-index: 1;\n }\n }\n\n .assignee {\n box-sizing: border-box;\n margin: 0;\n font-size: 14px;\n position: relative;\n display: inline-block;\n text-align: center;\n border-radius: 2px;\n\n margin-left: 3px;\n transition: margin .1s;\n\n height: 18px;\n\n img {\n height: 100%;\n border-radius: 2px;\n vertical-align: unset;\n }\n\n .icon-shadow {\n position: absolute;\n display: none;\n top: 0;\n left: 0;\n height: 100%;\n width: 100%;\n box-shadow: inset 0 0 2px 0 rgba(20, 20, 20, 0.3);\n border-radius: 2px;\n }\n\n &.requested-reviewer {\n @include review-badge(#bf8700);\n }\n\n &.commented {\n @include review-badge($info);\n }\n\n &.approved {\n @include review-badge($success);\n }\n\n &.requested-changes {\n @include review-badge($danger);\n }\n\n }\n\n .assignee + .assignee {\n margin-left: -6px;\n box-shadow: 0 0 0 1px $separatorColor;\n }\n\n :global {\n .hovered > .header {\n .assignee + .assignee {\n margin-left: 3px !important;\n box-shadow: none;\n }\n }\n }\n</style>\n\n{#each requested_reviewers as reviewer}\n <span\n class=\"assignee requested-reviewer\"\n title=\"{ reviewer.login } requested for review\"\n on:click={ handleSelection('involves', reviewer.login) }>\n <img src=\"{ reviewer.avatar_url }&s=40\" alt=\"{ reviewer.login } avatar\" />\n <div class=\"icon-shadow\"></div>\n </span>\n{/each}\n\n{#each reviews as review}\n <a\n class=\"assignee reviewer\"\n class:approved={ review.state === 'approved' }\n class:requested-changes={ review.state === 'changes_requested' }\n class:commented={ review.state === 'commented' || review.state === 'dismissed' }\n title=\"{ review.user.login } { stateToVerb[review.state] }\"\n href={ review.html_url || `${repoUrl}/pull/${number}#pullrequestreview-${review.id}` }\n on:click={ handleSelection('involves', review.user.login) }\n target=\"_blank\"\n rel=\"noopener noreferrer\"\n >\n <img src=\"{ review.user.avatar_url }&s=40\" alt=\"{ review.user.login } avatar\" />\n <div class=\"icon-shadow\"></div>\n </a>\n{/each}\n\n{#each assignees as assignee}\n <a\n class=\"assignee\"\n title=\"{ assignee.login } assigned\"\n on:click={ handleSelection('involves', assignee.login) }\n href={ assignee.html_url }\n target=\"_blank\"\n rel=\"noopener noreferrer\"\n >\n <img src=\"{ assignee.avatar_url }&s=40\" alt=\"{ assignee.login } avatar\" />\n <div class=\"icon-shadow\"></div>\n </a>\n{/each}","<style lang=\"scss\">\n .icon {\n margin-right: 2px;\n\n &.issue.open,\n &.depends-on.closed {\n color: #28a745;\n }\n\n &.issue.closed,\n &.depends-on {\n color: #cb2431;\n }\n\n &.linked-to {\n color: #37ACC8;\n }\n }\n</style>\n\n<script>\n export let name;\n export let state = '';\n export let className = '';\n</script>\n\n{#if name === 'issue'}\n\n {#if state !== 'closed'}\n <svg class=\"icon issue { className }\" class:open={ state === 'open' } width=\"1em\" height=\"1em\" viewBox=\"0 0 14 16\" version=\"1.1\" aria-hidden=\"true\" fill=\"currentColor\">\n <path fill-rule=\"evenodd\" d=\"M7 2.3c3.14 0 5.7 2.56 5.7 5.7s-2.56 5.7-5.7 5.7A5.71 5.71 0 0 1 1.3 8c0-3.14 2.56-5.7 5.7-5.7zM7 1C3.14 1 0 4.14 0 8s3.14 7 7 7 7-3.14 7-7-3.14-7-7-7zm1 3H6v5h2V4zm0 6H6v2h2v-2z\"></path>\n </svg>\n {:else}\n <svg class=\"icon issue closed { className }\" width=\"1em\" height=\"1em\" viewBox=\"0 0 16 16\" version=\"1.1\" aria-hidden=\"true\" fill=\"currentColor\">\n <path fill-rule=\"evenodd\" d=\"M7 10h2v2H7v-2zm2-6H7v5h2V4zm1.5 1.5l-1 1L12 9l4-4.5-1-1L12 7l-1.5-1.5zM8 13.7A5.71 5.71 0 0 1 2.3 8c0-3.14 2.56-5.7 5.7-5.7 1.83 0 3.45.88 4.5 2.2l.92-.92A6.947 6.947 0 0 0 8 1C4.14 1 1 4.14 1 8s3.14 7 7 7 7-3.14 7-7l-1.52 1.52c-.66 2.41-2.86 4.19-5.48 4.19v-.01z\"></path>\n </svg>\n {/if}\n\n{/if}\n\n{#if name === 'depends-on'}\n\n {#if state === 'closed'}\n <svg class=\"icon depends-on closed { className }\" width=\"1em\" height=\"1em\" viewBox=\"0 0 12 16\" version=\"1.1\" aria-hidden=\"true\" fill=\"currentColor\">\n <path fill-rule=\"evenodd\" d=\"M12 5l-8 8-4-4 1.5-1.5L4 10l6.5-6.5L12 5z\"></path>\n </svg>\n {:else}\n <svg class=\"icon depends-on { className }\" width=\"1em\" height=\"1em\" viewBox=\"0 0 14 16\" version=\"1.1\" aria-hidden=\"true\" fill=\"currentColor\">\n <path fill-rule=\"evenodd\" d=\"M7 1C3.14 1 0 4.14 0 8s3.14 7 7 7 7-3.14 7-7-3.14-7-7-7zm0 1.3c1.3 0 2.5.44 3.47 1.17l-8 8A5.755 5.755 0 0 1 1.3 8c0-3.14 2.56-5.7 5.7-5.7zm0 11.41c-1.3 0-2.5-.44-3.47-1.17l8-8c.73.97 1.17 2.17 1.17 3.47 0 3.14-2.56 5.7-5.7 5.7z\"></path>\n </svg>\n {/if}\n\n{/if}\n\n\n{#if name === 'linked-to'}\n <svg class=\"icon linked-to { className }\" width=\"1em\" height=\"1em\" viewBox=\"0 0 14 16\" version=\"1.1\" aria-hidden=\"true\" fill=\"currentColor\">\n <path fill-rule=\"evenodd\" d=\"M6.3 5.69a.942.942 0 0 1-.28-.7c0-.28.09-.52.28-.7.19-.18.42-.28.7-.28.28 0 .52.09.7.28.18.19.28.42.28.7 0 .28-.09.52-.28.7a1 1 0 0 1-.7.3c-.28 0-.52-.11-.7-.3zM8 7.99c-.02-.25-.11-.48-.31-.69-.2-.19-.42-.3-.69-.31H6c-.27.02-.48.13-.69.31-.2.2-.3.44-.31.69h1v3c.02.27.11.5.31.69.2.2.42.31.69.31h1c.27 0 .48-.11.69-.31.2-.19.3-.42.31-.69H8V7.98v.01zM7 2.3c-3.14 0-5.7 2.54-5.7 5.68 0 3.14 2.56 5.7 5.7 5.7s5.7-2.55 5.7-5.7c0-3.15-2.56-5.69-5.7-5.69v.01zM7 .98c3.86 0 7 3.14 7 7s-3.14 7-7 7-7-3.12-7-7 3.14-7 7-7z\"></path>\n </svg>\n{/if}\n\n\n{#if name === 'epic'}\n <svg class=\"icon epic { className}\" width=\"1em\" height=\"1em\" viewBox=\"0 0 12 16\" version=\"1.1\" aria-hidden=\"true\" stroke=\"currentColor\">\n <path fill=\"none\" fill-rule=\"evenodd\" transform=\"rotate(-89.89169311523438 5.963454723358154,7.855281829833984)\"\n d=\"m-1.079501,2.743426l10.564429,0l3.521483,5.111845l-3.521483,5.111868l-10.564429,0l3.521482,-5.111868l-3.521482,-5.111845z\" stroke-width=\"1.5\" />\n </svg>\n{/if}\n\n","<script>\n import PullRequestIcon from './components/PullRequestIcon.svelte';\n import LinkIcon from './components/LinkIcon.svelte';\n\n import CollaboratorLinks from './CollaboratorLinks.svelte';\n import CardStatus from './CardStatus.svelte';\n\n import {\n isApplyFilterClick,\n isAddFilterClick\n } from './shortcuts';\n\n export let item;\n\n export let onSelect;\n\n export let hovered = false;\n\n export let type;\n\n $: number = item.number;\n $: title = item.title;\n $: repository = item.repository;\n $: pull_request = item.pull_request;\n $: state = item.state;\n\n $: repositoryName = `${repository.owner.login}/${repository.name}`;\n\n $: cardUrl = item.html_url || `https://github.com/${ repositoryName }/issues/${ number }`;\n\n $: linkTitle = ({\n CHILD_OF: 'Parent of',\n DEPENDS_ON: 'Required by',\n PARENT_OF: 'Child of',\n CLOSED_BY: 'Closes',\n REQUIRED_BY: 'Depends on',\n CLOSES: 'Closed by',\n LINKED_TO: 'Linked to',\n LINKED_BY: 'Linked to'\n })[type] || type;\n\n function handleSelection(qualifier, value) {\n\n return onSelect && function(event) {\n\n if (!isApplyFilterClick(event)) {\n return;\n }\n\n event.preventDefault();\n\n onSelect(qualifier, value, isAddFilterClick(event));\n };\n }\n</script>\n\n<style lang=\"scss\">\n @import \"./Card\";\n\n .card-link {\n border-top: solid 1px #F0F0F0;\n margin-top: 2px;\n padding-top: 2px;\n }\n\n .card-link .short-title {\n flex: 1;\n }\n\n :global {\n .card-link .epic {\n color: #1d76db;\n }\n }\n</style>\n\n<div class=\"card-link\"\n class:hovered={ hovered }\n on:mouseenter={ () => hovered = true }\n on:mouseleave={ () => hovered = false }\n>\n <div class=\"header\">\n <a href={ cardUrl }\n target=\"_blank\"\n rel=\"noopener noreferrer\"\n class=\"issue-number\"\n on:click={ handleSelection('ref', item.key) }\n title=\"{ repositoryName }#{ number } · { linkTitle } this issue\"\n >\n {#if pull_request}\n <PullRequestIcon item={ item } />\n {:else}\n {#if type === 'PARENT_OF'}\n <LinkIcon name=\"issue\" state={ state } />\n {/if}\n\n {#if type === 'CHILD_OF'}\n <LinkIcon name=\"epic\" />\n {/if}\n\n {#if type === 'DEPENDS_ON' || type === 'CLOSED_BY'}\n <LinkIcon name=\"depends-on\" state={ state } />\n {/if}\n\n {#if type === 'REQUIRED_BY' || type === 'CLOSES' }\n {#if state === 'open'}\n <LinkIcon name=\"linked-to\" />\n {:else}\n <LinkIcon name=\"issue\" state={ state } />\n {/if}\n {/if}\n\n {#if type === 'LINKED_TO'}\n <LinkIcon name=\"linked-to\" />\n {/if}\n {/if}\n\n { number }\n </a>\n\n <span class=\"short-title\" title={ title }>{ title }</span>\n\n <span class=\"collaborator-links\">\n <CollaboratorLinks item={ item } onSelect={ onSelect } />\n </span>\n </div>\n\n <CardStatus item={ item } />\n</div>","<script>\n import {\n isOpen,\n isMerged,\n isPull,\n noDuplicates\n } from './util';\n\n import {\n isApplyFilterClick,\n isAddFilterClick\n } from './shortcuts';\n\n import Tag from './components/Tag.svelte';\n import PullRequestIcon from './components/PullRequestIcon.svelte';\n import EpicIcon from './components/EpicIcon.svelte';\n\n import CardStatus from './CardStatus.svelte';\n import CollaboratorLinks from './CollaboratorLinks.svelte';\n\n import CardLink from './CardLink.svelte';\n\n const linkOrder = {\n 'DEPENDS_ON': 1,\n 'CLOSED_BY': 2,\n 'PARENT_OF': 3,\n 'REQUIRED_BY': 4,\n 'LINKED_TO': 5,\n 'CHILD_OF': 6\n };\n\n export let item;\n\n export let className = '';\n\n export let onSelect;\n\n let showChildren = false;\n\n let hovered = false;\n\n $: number = item.number;\n $: title = item.title;\n $: repository = item.repository;\n $: milestone = item.milestone;\n $: labels = item.labels.filter(l => !l.column_label);\n $: pull_request = item.pull_request;\n\n $: links = item.links || [];\n\n $: embeddedLinks = links.filter(\n (link) => !isPull(link.target) && link.type !== 'LINKED_BY'\n ).sort(\n (a, b) => {\n return linkOrder[a.type] - linkOrder[b.type];\n }\n );\n\n $: shownLinks = embeddedLinks.filter(link => showChildren || link.type !== 'PARENT_OF');\n\n $: children = embeddedLinks.filter(l => l.type === 'PARENT_OF');\n $: completedChildren = children.filter(l => l.target.state === 'closed');\n\n $: prLinks = links.filter(\n link => isPull(link.target) && (\n isOpen(link.target) || (\n isMerged(link.target) && link.type === 'CLOSED_BY'\n )\n )\n ).filter(noDuplicates(link => link.target.id));\n\n $: repositoryName = `${repository.owner.login}/${repository.name}`;\n\n $: repoUrl = `https://github.com/${ repositoryName }`;\n $: milestoneUrl = milestone && (milestone.html_url || `${repoUrl}/milestone/${milestone.number}`);\n $: cardUrl = item.html_url || `${repoUrl}/issues/${number}`;\n\n function handleSelection(qualifier, value) {\n\n return onSelect && function(event) {\n\n if (!isApplyFilterClick(event)) {\n return;\n }\n\n event.preventDefault();\n\n onSelect(qualifier, value, isAddFilterClick(event));\n };\n }\n</script>\n\n<style lang=\"scss\">\n @import \"variables\";\n\n @import \"./Card\";\n\n :global {\n .tag {\n &.label,\n &.milestone {\n margin-right: 4px;\n margin-bottom: 4px;\n }\n\n &.milestone {\n color: $gray-800 !important;\n border: solid 1px $gray-600;\n }\n }\n\n .card-link:first-child {\n border-top: none !important;\n margin-top: 1px !important;\n }\n }\n\n .board-card-links.attached {\n background: #F9F9F9;\n border-radius: 0 0 4px 4px;\n box-shadow: inset 0 3px 5px -2px rgba(0, 0, 0, 0.1), 0 1px 2px rgba(0, 0, 0, 0.1);\n margin-top: -6px;\n position: relative;\n padding: 7px 8px 4px 8px;\n }\n\n .progress {\n display: flex;\n flex-direction: row;\n align-items: center;\n margin-bottom: 7px;\n\n cursor: pointer;\n\n &:hover {\n svg {\n color: $gray-600;\n }\n }\n\n svg {\n color: #CCC;\n transition: color .3s;\n }\n\n .bar {\n border-radius: 3px;\n height: 5px;\n width: 80px;\n background: #EEE;\n margin: auto 6px;\n\n .indicator {\n border-radius: 3px;\n background: $gray-600;\n height: 100%;\n }\n }\n\n .text {\n margin-left: 6px;\n font-size: 0.9rem;\n color: $gray-600;\n }\n }\n\n</style>\n\n<div class=\"board-card-container { className }\">\n <div class=\"board-card\"\n class:hovered={ hovered }\n on:mouseenter={ () => hovered = true }\n on:mouseleave={ () => hovered = false }\n >\n <div class=\"header\">\n <a href={ cardUrl }\n target=\"_blank\"\n rel=\"noopener noreferrer\"\n class=\"issue-number\"\n title=\"{ repositoryName }#{ number }\"\n on:click={ handleSelection('ref', item.key) }\n >\n\n {#if children.length}\n <EpicIcon item={ item } linkType=\"PARENT_OF\" />\n {/if}\n\n {#if pull_request}\n <PullRequestIcon item={ item } />\n {/if}\n\n { number }\n </a>\n\n <span class=\"repository\" title={ repositoryName }>{ repositoryName }</span>\n\n <span class=\"collaborator-links\">\n <CollaboratorLinks item={ item } onSelect={ onSelect } />\n </span>\n </div>\n <div class=\"title\">\n { title }\n </div>\n {#if children.length}\n <div\n class=\"progress\"\n on:click={ () => showChildren = !showChildren }\n title=\"{ completedChildren.length } of { children.length } child tasks completed\"\n >\n <svg class=\"icon issue closed\" width=\"1em\" height=\"1em\" viewBox=\"0 0 16 16\" version=\"1.1\" aria-hidden=\"true\" fill=\"currentColor\">\n <path fill-rule=\"evenodd\" d=\"M7 10h2v2H7v-2zm2-6H7v5h2V4zm1.5 1.5l-1 1L12 9l4-4.5-1-1L12 7l-1.5-1.5zM8 13.7A5.71 5.71 0 0 1 2.3 8c0-3.14 2.56-5.7 5.7-5.7 1.83 0 3.45.88 4.5 2.2l.92-.92A6.947 6.947 0 0 0 8 1C4.14 1 1 4.14 1 8s3.14 7 7 7 7-3.14 7-7l-1.52 1.52c-.66 2.41-2.86 4.19-5.48 4.19v-.01z\"></path>\n </svg>\n <div class=\"text\">\n { completedChildren.length } of { children.length }\n </div>\n <div class=\"bar\">\n <div class=\"indicator\" style=\"width: { completedChildren.length / children.length * 100 }%\"></div>\n </div>\n </div>\n {/if}\n <div class=\"footer\">\n {#if milestone}\n <Tag\n class=\"tag milestone\"\n name={ milestone.title }\n href={ milestoneUrl }\n title={ milestone.title }\n onClick={ handleSelection('milestone', milestone.title) }\n />\n {/if}\n\n {#each labels as { name, color }}\n <Tag\n class=\"tag label\"\n color=\"#{ color }\"\n name={ name }\n title={ name }\n onClick={ handleSelection('label', name) }\n />\n {/each}\n\n <div class=\"links\">\n <a href={ cardUrl } title=\"View on GitHub\" target=\"_blank\" rel=\"noopener noreferrer\">\n <svg width=\"1em\" height=\"1em\" viewBox=\"0 0 16 16\" version=\"1.1\" aria-hidden=\"true\" fill=\"currentColor\">\n <path fill-rule=\"evenodd\" d=\"M8 0C3.58 0 0 3.58 0 8c0 3.54 2.29 6.53 5.47 7.59.4.07.55-.17.55-.38 0-.19-.01-.82-.01-1.49-2.01.37-2.53-.49-2.69-.94-.09-.23-.48-.94-.82-1.13-.28-.15-.68-.52-.01-.53.63-.01 1.08.58 1.23.82.72 1.21 1.87.87 2.33.66.07-.52.28-.87.51-1.07-1.78-.2-3.64-.89-3.64-3.95 0-.87.31-1.59.82-2.15-.08-.2-.36-1.02.08-2.12 0 0 .67-.21 2.2.82.64-.18 1.32-.27 2-.27.68 0 1.36.09 2 .27 1.53-1.04 2.2-.82 2.2-.82.44 1.1.16 1.92.08 2.12.51.56.82 1.27.82 2.15 0 3.07-1.87 3.75-3.65 3.95.29.25.54.73.54 1.48 0 1.07-.01 1.93-.01 2.2 0 .21.15.46.55.38A8.013 8.013 0 0 0 16 8c0-4.42-3.58-8-8-8z\"></path>\n </svg>\n </a>\n </div>\n </div>\n\n {#if shownLinks.length}\n <div class=\"board-card-links embedded\">\n {#each shownLinks as link}\n <CardLink item={link.target} type={ link.type } onSelect={ onSelect } />\n {/each}\n </div>\n {/if}\n\n <CardStatus item={ item } />\n </div>\n\n {#if prLinks.length}\n <div class=\"board-card-links attached\">\n {#each prLinks as link}\n <CardLink item={ link.target } type={ link.type } onSelect={ onSelect } />\n {/each}\n </div>\n {/if}\n\n</div>\n","<script>\n\n import { onMount } from 'svelte';\n\n import { HintList } from './components';\n\n import { Id } from './util';\n\n const inputId = Id();\n\n export let onClose;\n\n export let repositories;\n\n export let onSelect;\n\n let matchedHints;\n\n let keyboardSelectedHint;\n let mouseSelectedHint;\n\n let value = '';\n\n let input;\n\n $: {\n console.time('RepositorySelect#computeMatch');\n\n let opts = computeMatch(value, repositories);\n\n console.timeEnd('RepositorySelect#computeMatch');\n\n matchedHints = opts.matchedHints;\n\n keyboardSelectedHint = (\n matchedHints && keyboardSelectedHint && matchedHints.find(\n hint => hint.name === keyboardSelectedHint.name\n ) || opts.keyboardSelectedHint\n );\n }\n\n $: selectedHint = mouseSelectedHint || keyboardSelectedHint;\n\n function computeMatch(search, repositories) {\n\n const matchedHints = repositories.reduce((matchedHints, name) => {\n\n if (!name.toLowerCase().includes(search)) {\n return matchedHints;\n }\n\n const idx = name.indexOf(search);\n\n const hint = {\n name: name,\n parts: [\n {\n text: name.substring(0, idx)\n },\n {\n text: name.substring(idx, idx + search.length),\n matched: true\n },\n {\n text: name.substring(idx + search.length)\n }\n ],\n apply: (currentValue) => {\n\n return {\n val: name,\n idx: name.length\n };\n }\n };\n\n matchedHints.push(hint);\n\n return matchedHints;\n }, []);\n\n return {\n keyboardSelectedHint: matchedHints[0],\n matchedHints\n };\n }\n\n function applyHint(hint) {\n\n const {\n val,\n idx\n } = hint.apply(value);\n\n input.value = value = val;\n input.selectionEnd = input.selectionStart = idx;\n\n const [ owner, repo ] = val.split('/');\n\n return onSelect(owner, repo);\n }\n\n function handleInput(event) {\n value = event.target.value;\n }\n\n function nextHint(currentHint, direction) {\n\n const hints = (matchedHints || []);\n\n const currentIndex = hints.findIndex(hint => hint.name === currentHint.name);\n\n let nextIndex = currentIndex + direction;\n\n if (nextIndex < 0) {\n nextIndex = hints.length - 1;\n }\n\n if (nextIndex === hints.length) {\n nextIndex = 0;\n }\n\n return hints[nextIndex];\n }\n\n function handleInputKey(event) {\n\n const key = event.key;\n\n if (key === 'Enter') {\n if (keyboardSelectedHint) {\n applyHint(keyboardSelectedHint);\n event.preventDefault();\n }\n }\n\n if (key === 'ArrowUp') {\n keyboardSelectedHint = nextHint(keyboardSelectedHint, -1);\n event.preventDefault();\n }\n\n if (key === 'ArrowDown') {\n keyboardSelectedHint = nextHint(keyboardSelectedHint, 1);\n event.preventDefault();\n }\n\n if (key === 'Escape' && !value) {\n input.blur();\n\n event.preventDefault();\n }\n }\n\n onMount(() => {\n input.focus();\n });\n\n function checkClose(event) {\n\n if (event.key === 'Escape') {\n event.preventDefault();\n\n onClose();\n }\n }\n\n function checkSubmit(event) {\n event.preventDefault();\n\n if (!value) {\n return;\n }\n\n const [ owner, repo ] = value.split('/');\n\n if (!repo || !owner) {\n return;\n }\n\n return onSelect(owner, repo);\n }\n</script>\n\n<style lang=\"scss\">\n\n @import './HelpDropdown';\n\n .repository-select {\n position: fixed;\n top: 0;\n left: 0;\n right: 0;\n bottom: 0;\n\n z-index: 10;\n }\n\n .overlay {\n width: 100%;\n height: 100%;\n\n background: rgba(30, 30, 30, .30);\n }\n\n .issue-creator {\n position: absolute;\n z-index: 2;\n width: 500px;\n max-width: 100%;\n\n background: white;\n top: 30%;\n left: 50%;\n transform: translate(-50%);\n\n line-height: 1.5;\n\n border-radius: 5px;\n box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);\n }\n</style>\n\n<svelte:window on:keydown={ checkClose } />\n\n<div class=\"repository-select\">\n <div class=\"overlay\" on:click={ onClose }></div>\n\n <form class=\"issue-creator px-4 py-2\" on:submit={ checkSubmit }>\n\n <slot name=\"header\"></slot>\n\n <div class=\"form-group dropdown-parent\">\n\n <input\n id={ inputId }\n bind:this={ input }\n value={ value }\n on:input={ handleInput }\n on:keydown={ handleInputKey }\n placeholder=\"Choose repository\"\n autocomplete=\"off\"\n spellcheck=\"false\"\n aria-label=\"Repository name input\"\n class=\"form-control form-control-lg\"\n type=\"text\"\n />\n\n {#if value && matchedHints.length }\n <div class=\"help-dropdown\">\n <HintList\n hints={ matchedHints }\n selectedHint={ selectedHint }\n onHover={ hint => mouseSelectedHint = hint }\n onBlur={ () => mouseSelectedHint = null }\n onSelect={ applyHint }\n maxElements= { 7 }\n />\n </div>\n {/if}\n </div>\n </form>\n\n</div>","<script>\n import RepositorySelect from './RepositorySelect.svelte';\n\n export let repositories;\n\n export let open;\n export let onCreate;\n export let onClose;\n</script>\n\n{#if open}\n <RepositorySelect\n repositories={ repositories }\n onClose={ onClose }\n onSelect={ onCreate }\n >\n <h4 slot=\"header\" class=\"chooser-header my-3\">\n Create new Issue\n </h4>\n </RepositorySelect>\n{/if}","export default class Api {\n\n moveIssue(id, column, before, after) {\n const body = JSON.stringify({\n id,\n before,\n after,\n column\n });\n\n const url = this.appURL('/board/issues/move');\n\n return fetchJSON(url, {\n method: 'POST',\n body\n });\n }\n\n listCards(filter) {\n const url = this.appURL(`/board/cards${buildQueryString(filter)}`);\n\n return fetchJSON(url);\n }\n\n getBoard() {\n const url = this.appURL('/board');\n\n return fetchJSON(url);\n }\n\n getLoggedInUser() {\n const url = this.appURL('/login_check');\n\n return fetchJSON(url).catch(err => null);\n }\n\n listUpdates(filter, cursor) {\n const url = this.appURL(`/board/updates?cursor=${cursor}${buildQueryString(filter, '&')}`);\n\n return fetchJSON(url);\n }\n\n appURL(location) {\n const appBase = '/wuffle';\n\n return `${appBase}${location}`;\n }\n\n}\n\n\n// helpers ////////////////////\n\nfunction fetchJSON(url, options) {\n return fetch(url, {\n ...options,\n credentials: 'include'\n }).then(response => {\n const {\n ok,\n status\n } = response;\n\n if (!ok) {\n const error = new Error('HTTP ' + status);\n\n error.status = status;\n error.response = response;\n\n throw error;\n }\n\n return response;\n }).then(r => r.text()).then(t => JSON.parse(t));\n}\n\n\nfunction buildQueryString(filter, separator = '?') {\n if (filter) {\n return `${separator}s=${encodeURIComponent(filter)}`;\n } else {\n return '';\n }\n}","module.exports = function atoa (a, n) { return Array.prototype.slice.call(a, n); }\n","var si = typeof setImmediate === 'function', tick;\nif (si) {\n tick = function (fn) { setImmediate(fn); };\n} else if (typeof process !== 'undefined' && process.nextTick) {\n tick = process.nextTick;\n} else {\n tick = function (fn) { setTimeout(fn, 0); };\n}\n\nmodule.exports = tick;\n","'use strict';\n\nvar ticky = require('ticky');\n\nmodule.exports = function debounce (fn, args, ctx) {\n if (!fn) { return; }\n ticky(function run () {\n fn.apply(ctx || null, args || []);\n });\n};\n","'use strict';\n\nvar atoa = require('atoa');\nvar debounce = require('./debounce');\n\nmodule.exports = function emitter (thing, options) {\n var opts = options || {};\n var evt = {};\n if (thing === undefined) { thing = {}; }\n thing.on = function (type, fn) {\n if (!evt[type]) {\n evt[type] = [fn];\n } else {\n evt[type].push(fn);\n }\n return thing;\n };\n thing.once = function (type, fn) {\n fn._once = true; // thing.off(fn) still works!\n thing.on(type, fn);\n return thing;\n };\n thing.off = function (type, fn) {\n var c = arguments.length;\n if (c === 1) {\n delete evt[type];\n } else if (c === 0) {\n evt = {};\n } else {\n var et = evt[type];\n if (!et) { return thing; }\n et.splice(et.indexOf(fn), 1);\n }\n return thing;\n };\n thing.emit = function () {\n var args = atoa(arguments);\n return thing.emitterSnapshot(args.shift()).apply(this, args);\n };\n thing.emitterSnapshot = function (type) {\n var et = (evt[type] || []).slice(0);\n return function () {\n var args = atoa(arguments);\n var ctx = this || thing;\n if (type === 'error' && opts.throws !== false && !et.length) { throw args.length === 1 ? args[0] : args; }\n et.forEach(function emitter (listen) {\n if (opts.async) { debounce(listen, args, ctx); } else { listen.apply(ctx, args); }\n if (listen._once) { thing.off(type, listen); }\n });\n return thing;\n };\n };\n return thing;\n};\n","\nvar NativeCustomEvent = global.CustomEvent;\n\nfunction useNative () {\n try {\n var p = new NativeCustomEvent('cat', { detail: { foo: 'bar' } });\n return 'cat' === p.type && 'bar' === p.detail.foo;\n } catch (e) {\n }\n return false;\n}\n\n/**\n * Cross-browser `CustomEvent` constructor.\n *\n * https://developer.mozilla.org/en-US/docs/Web/API/CustomEvent.CustomEvent\n *\n * @public\n */\n\nmodule.exports = useNative() ? NativeCustomEvent :\n\n// IE >= 9\n'undefined' !== typeof document && 'function' === typeof document.createEvent ? function CustomEvent (type, params) {\n var e = document.createEvent('CustomEvent');\n if (params) {\n e.initCustomEvent(type, params.bubbles, params.cancelable, params.detail);\n } else {\n e.initCustomEvent(type, false, false, void 0);\n }\n return e;\n} :\n\n// IE <= 8\nfunction CustomEvent (type, params) {\n var e = document.createEventObject();\n e.type = type;\n if (params) {\n e.bubbles = Boolean(params.bubbles);\n e.cancelable = Boolean(params.cancelable);\n e.detail = params.detail;\n } else {\n e.bubbles = false;\n e.cancelable = false;\n e.detail = void 0;\n }\n return e;\n}\n","'use strict';\n\nvar eventmap = [];\nvar eventname = '';\nvar ron = /^on/;\n\nfor (eventname in global) {\n if (ron.test(eventname)) {\n eventmap.push(eventname.slice(2));\n }\n}\n\nmodule.exports = eventmap;\n","'use strict';\n\nvar customEvent = require('custom-event');\nvar eventmap = require('./eventmap');\nvar doc = global.document;\nvar addEvent = addEventEasy;\nvar removeEvent = removeEventEasy;\nvar hardCache = [];\n\nif (!global.addEventListener) {\n addEvent = addEventHard;\n removeEvent = removeEventHard;\n}\n\nmodule.exports = {\n add: addEvent,\n remove: removeEvent,\n fabricate: fabricateEvent\n};\n\nfunction addEventEasy (el, type, fn, capturing) {\n return el.addEventListener(type, fn, capturing);\n}\n\nfunction addEventHard (el, type, fn) {\n return el.attachEvent('on' + type, wrap(el, type, fn));\n}\n\nfunction removeEventEasy (el, type, fn, capturing) {\n return el.removeEventListener(type, fn, capturing);\n}\n\nfunction removeEventHard (el, type, fn) {\n var listener = unwrap(el, type, fn);\n if (listener) {\n return el.detachEvent('on' + type, listener);\n }\n}\n\nfunction fabricateEvent (el, type, model) {\n var e = eventmap.indexOf(type) === -1 ? makeCustomEvent() : makeClassicEvent();\n if (el.dispatchEvent) {\n el.dispatchEvent(e);\n } else {\n el.fireEvent('on' + type, e);\n }\n function makeClassicEvent () {\n var e;\n if (doc.createEvent) {\n e = doc.createEvent('Event');\n e.initEvent(type, true, true);\n } else if (doc.createEventObject) {\n e = doc.createEventObject();\n }\n return e;\n }\n function makeCustomEvent () {\n return new customEvent(type, { detail: model });\n }\n}\n\nfunction wrapperFactory (el, type, fn) {\n return function wrapper (originalEvent) {\n var e = originalEvent || global.event;\n e.target = e.target || e.srcElement;\n e.preventDefault = e.preventDefault || function preventDefault () { e.returnValue = false; };\n e.stopPropagation = e.stopPropagation || function stopPropagation () { e.cancelBubble = true; };\n e.which = e.which || e.keyCode;\n fn.call(el, e);\n };\n}\n\nfunction wrap (el, type, fn) {\n var wrapper = unwrap(el, type, fn) || wrapperFactory(el, type, fn);\n hardCache.push({\n wrapper: wrapper,\n element: el,\n type: type,\n fn: fn\n });\n return wrapper;\n}\n\nfunction unwrap (el, type, fn) {\n var i = find(el, type, fn);\n if (i) {\n var wrapper = hardCache[i].wrapper;\n hardCache.splice(i, 1); // free up a tad of memory\n return wrapper;\n }\n}\n\nfunction find (el, type, fn) {\n var i, item;\n for (i = 0; i < hardCache.length; i++) {\n item = hardCache[i];\n if (item.element === el && item.type === type && item.fn === fn) {\n return i;\n }\n }\n}\n","'use strict';\n\nvar cache = {};\nvar start = '(?:^|\\\\s)';\nvar end = '(?:\\\\s|$)';\n\nfunction lookupClass (className) {\n var cached = cache[className];\n if (cached) {\n cached.lastIndex = 0;\n } else {\n cache[className] = cached = new RegExp(start + className + end, 'g');\n }\n return cached;\n}\n\nfunction addClass (el, className) {\n var current = el.className;\n if (!current.length) {\n el.className = className;\n } else if (!lookupClass(className).test(current)) {\n el.className += ' ' + className;\n }\n}\n\nfunction rmClass (el, className) {\n el.className = el.className.replace(lookupClass(className), ' ').trim();\n}\n\nmodule.exports = {\n add: addClass,\n rm: rmClass\n};\n","'use strict';\n\nvar emitter = require('contra/emitter');\nvar crossvent = require('crossvent');\nvar classes = require('./classes');\nvar doc = document;\nvar documentElement = doc.documentElement;\n\nfunction dragula (initialContainers, options) {\n var len = arguments.length;\n if (len === 1 && Array.isArray(initialContainers) === false) {\n options = initialContainers;\n initialContainers = [];\n }\n var _mirror; // mirror image\n var _source; // source container\n var _item; // item being dragged\n var _offsetX; // reference x\n var _offsetY; // reference y\n var _moveX; // reference move x\n var _moveY; // reference move y\n var _initialSibling; // reference sibling when grabbed\n var _currentSibling; // reference sibling now\n var _copy; // item used for copying\n var _renderTimer; // timer for setTimeout renderMirrorImage\n var _lastDropTarget = null; // last container item was over\n var _grabbed; // holds mousedown context until first mousemove\n\n var o = options || {};\n if (o.moves === void 0) { o.moves = always; }\n if (o.accepts === void 0) { o.accepts = always; }\n if (o.invalid === void 0) { o.invalid = invalidTarget; }\n if (o.containers === void 0) { o.containers = initialContainers || []; }\n if (o.isContainer === void 0) { o.isContainer = never; }\n if (o.copy === void 0) { o.copy = false; }\n if (o.copySortSource === void 0) { o.copySortSource = false; }\n if (o.revertOnSpill === void 0) { o.revertOnSpill = false; }\n if (o.removeOnSpill === void 0) { o.removeOnSpill = false; }\n if (o.direction === void 0) { o.direction = 'vertical'; }\n if (o.ignoreInputTextSelection === void 0) { o.ignoreInputTextSelection = true; }\n if (o.mirrorContainer === void 0) { o.mirrorContainer = doc.body; }\n\n var drake = emitter({\n containers: o.containers,\n start: manualStart,\n end: end,\n cancel: cancel,\n remove: remove,\n destroy: destroy,\n canMove: canMove,\n dragging: false\n });\n\n if (o.removeOnSpill === true) {\n drake.on('over', spillOver).on('out', spillOut);\n }\n\n events();\n\n return drake;\n\n function isContainer (el) {\n return drake.containers.indexOf(el) !== -1 || o.isContainer(el);\n }\n\n function events (remove) {\n var op = remove ? 'remove' : 'add';\n touchy(documentElement, op, 'mousedown', grab);\n touchy(documentElement, op, 'mouseup', release);\n }\n\n function eventualMovements (remove) {\n var op = remove ? 'remove' : 'add';\n touchy(documentElement, op, 'mousemove', startBecauseMouseMoved);\n }\n\n function movements (remove) {\n var op = remove ? 'remove' : 'add';\n crossvent[op](documentElement, 'selectstart', preventGrabbed); // IE8\n crossvent[op](documentElement, 'click', preventGrabbed);\n }\n\n function destroy () {\n events(true);\n release({});\n }\n\n function preventGrabbed (e) {\n if (_grabbed) {\n e.preventDefault();\n }\n }\n\n function grab (e) {\n _moveX = e.clientX;\n _moveY = e.clientY;\n\n var ignore = whichMouseButton(e) !== 1 || e.metaKey || e.ctrlKey;\n if (ignore) {\n return; // we only care about honest-to-god left clicks and touch events\n }\n var item = e.target;\n var context = canStart(item);\n if (!context) {\n return;\n }\n _grabbed = context;\n eventualMovements();\n if (e.type === 'mousedown') {\n if (isInput(item)) { // see also: https://github.com/bevacqua/dragula/issues/208\n item.focus(); // fixes https://github.com/bevacqua/dragula/issues/176\n } else {\n e.preventDefault(); // fixes https://github.com/bevacqua/dragula/issues/155\n }\n }\n }\n\n function startBecauseMouseMoved (e) {\n if (!_grabbed) {\n return;\n }\n if (whichMouseButton(e) === 0) {\n release({});\n return; // when text is selected on an input and then dragged, mouseup doesn't fire. this is our only hope\n }\n\n // truthy check fixes #239, equality fixes #207, fixes #501\n if ((e.clientX !== void 0 && Math.abs(e.clientX - _moveX) <= (o.slideFactorX || 0)) &&\n (e.clientY !== void 0 && Math.abs(e.clientY - _moveY) <= (o.slideFactorY || 0))) {\n return;\n }\n\n if (o.ignoreInputTextSelection) {\n var clientX = getCoord('clientX', e) || 0;\n var clientY = getCoord('clientY', e) || 0;\n var elementBehindCursor = doc.elementFromPoint(clientX, clientY);\n if (isInput(elementBehindCursor)) {\n return;\n }\n }\n\n var grabbed = _grabbed; // call to end() unsets _grabbed\n eventualMovements(true);\n movements();\n end();\n start(grabbed);\n\n var offset = getOffset(_item);\n _offsetX = getCoord('pageX', e) - offset.left;\n _offsetY = getCoord('pageY', e) - offset.top;\n\n classes.add(_copy || _item, 'gu-transit');\n renderMirrorImage();\n drag(e);\n }\n\n function canStart (item) {\n if (drake.dragging && _mirror) {\n return;\n }\n if (isContainer(item)) {\n return; // don't drag container itself\n }\n var handle = item;\n while (getParent(item) && isContainer(getParent(item)) === false) {\n if (o.invalid(item, handle)) {\n return;\n }\n item = getParent(item); // drag target should be a top element\n if (!item) {\n return;\n }\n }\n var source = getParent(item);\n if (!source) {\n return;\n }\n if (o.invalid(item, handle)) {\n return;\n }\n\n var movable = o.moves(item, source, handle, nextEl(item));\n if (!movable) {\n return;\n }\n\n return {\n item: item,\n source: source\n };\n }\n\n function canMove (item) {\n return !!canStart(item);\n }\n\n function manualStart (item) {\n var context = canStart(item);\n if (context) {\n start(context);\n }\n }\n\n function start (context) {\n if (isCopy(context.item, context.source)) {\n _copy = context.item.cloneNode(true);\n drake.emit('cloned', _copy, context.item, 'copy');\n }\n\n _source = context.source;\n _item = context.item;\n _initialSibling = _currentSibling = nextEl(context.item);\n\n drake.dragging = true;\n drake.emit('drag', _item, _source);\n }\n\n function invalidTarget () {\n return false;\n }\n\n function end () {\n if (!drake.dragging) {\n return;\n }\n var item = _copy || _item;\n drop(item, getParent(item));\n }\n\n function ungrab () {\n _grabbed = false;\n eventualMovements(true);\n movements(true);\n }\n\n function release (e) {\n ungrab();\n\n if (!drake.dragging) {\n return;\n }\n var item = _copy || _item;\n var clientX = getCoord('clientX', e) || 0;\n var clientY = getCoord('clientY', e) || 0;\n var elementBehindCursor = getElementBehindPoint(_mirror, clientX, clientY);\n var dropTarget = findDropTarget(elementBehindCursor, clientX, clientY);\n if (dropTarget && ((_copy && o.copySortSource) || (!_copy || dropTarget !== _source))) {\n drop(item, dropTarget);\n } else if (o.removeOnSpill) {\n remove();\n } else {\n cancel();\n }\n }\n\n function drop (item, target) {\n var parent = getParent(item);\n if (_copy && o.copySortSource && target === _source) {\n parent.removeChild(_item);\n }\n if (isInitialPlacement(target)) {\n drake.emit('cancel', item, _source, _source);\n } else {\n drake.emit('drop', item, target, _source, _currentSibling);\n }\n cleanup();\n }\n\n function remove () {\n if (!drake.dragging) {\n return;\n }\n var item = _copy || _item;\n var parent = getParent(item);\n if (parent) {\n parent.removeChild(item);\n }\n drake.emit(_copy ? 'cancel' : 'remove', item, parent, _source);\n cleanup();\n }\n\n function cancel (revert) {\n if (!drake.dragging) {\n return;\n }\n var reverts = arguments.length > 0 ? revert : o.revertOnSpill;\n var item = _copy || _item;\n var parent = getParent(item);\n var initial = isInitialPlacement(parent);\n if (initial === false && reverts) {\n if (_copy) {\n if (parent) {\n parent.removeChild(_copy);\n }\n } else {\n _source.insertBefore(item, _initialSibling);\n }\n }\n if (initial || reverts) {\n drake.emit('cancel', item, _source, _source);\n } else {\n drake.emit('drop', item, parent, _source, _currentSibling);\n }\n cleanup();\n }\n\n function cleanup () {\n var item = _copy || _item;\n ungrab();\n removeMirrorImage();\n if (item) {\n classes.rm(item, 'gu-transit');\n }\n if (_renderTimer) {\n clearTimeout(_renderTimer);\n }\n drake.dragging = false;\n if (_lastDropTarget) {\n drake.emit('out', item, _lastDropTarget, _source);\n }\n drake.emit('dragend', item);\n _source = _item = _copy = _initialSibling = _currentSibling = _renderTimer = _lastDropTarget = null;\n }\n\n function isInitialPlacement (target, s) {\n var sibling;\n if (s !== void 0) {\n sibling = s;\n } else if (_mirror) {\n sibling = _currentSibling;\n } else {\n sibling = nextEl(_copy || _item);\n }\n return target === _source && sibling === _initialSibling;\n }\n\n function findDropTarget (elementBehindCursor, clientX, clientY) {\n var target = elementBehindCursor;\n while (target && !accepted()) {\n target = getParent(target);\n }\n return target;\n\n function accepted () {\n var droppable = isContainer(target);\n if (droppable === false) {\n return false;\n }\n\n var immediate = getImmediateChild(target, elementBehindCursor);\n var reference = getReference(target, immediate, clientX, clientY);\n var initial = isInitialPlacement(target, reference);\n if (initial) {\n return true; // should always be able to drop it right back where it was\n }\n return o.accepts(_item, target, _source, reference);\n }\n }\n\n function drag (e) {\n if (!_mirror) {\n return;\n }\n e.preventDefault();\n\n var clientX = getCoord('clientX', e) || 0;\n var clientY = getCoord('clientY', e) || 0;\n var x = clientX - _offsetX;\n var y = clientY - _offsetY;\n\n _mirror.style.left = x + 'px';\n _mirror.style.top = y + 'px';\n\n var item = _copy || _item;\n var elementBehindCursor = getElementBehindPoint(_mirror, clientX, clientY);\n var dropTarget = findDropTarget(elementBehindCursor, clientX, clientY);\n var changed = dropTarget !== null && dropTarget !== _lastDropTarget;\n if (changed || dropTarget === null) {\n out();\n _lastDropTarget = dropTarget;\n over();\n }\n var parent = getParent(item);\n if (dropTarget === _source && _copy && !o.copySortSource) {\n if (parent) {\n parent.removeChild(item);\n }\n return;\n }\n var reference;\n var immediate = getImmediateChild(dropTarget, elementBehindCursor);\n if (immediate !== null) {\n reference = getReference(dropTarget, immediate, clientX, clientY);\n } else if (o.revertOnSpill === true && !_copy) {\n reference = _initialSibling;\n dropTarget = _source;\n } else {\n if (_copy && parent) {\n parent.removeChild(item);\n }\n return;\n }\n if (\n (reference === null && changed) ||\n reference !== item &&\n reference !== nextEl(item)\n ) {\n _currentSibling = reference;\n dropTarget.insertBefore(item, reference);\n drake.emit('shadow', item, dropTarget, _source);\n }\n function moved (type) { drake.emit(type, item, _lastDropTarget, _source); }\n function over () { if (changed) { moved('over'); } }\n function out () { if (_lastDropTarget) { moved('out'); } }\n }\n\n function spillOver (el) {\n classes.rm(el, 'gu-hide');\n }\n\n function spillOut (el) {\n if (drake.dragging) { classes.add(el, 'gu-hide'); }\n }\n\n function renderMirrorImage () {\n if (_mirror) {\n return;\n }\n var rect = _item.getBoundingClientRect();\n _mirror = _item.cloneNode(true);\n _mirror.style.width = getRectWidth(rect) + 'px';\n _mirror.style.height = getRectHeight(rect) + 'px';\n classes.rm(_mirror, 'gu-transit');\n classes.add(_mirror, 'gu-mirror');\n o.mirrorContainer.appendChild(_mirror);\n touchy(documentElement, 'add', 'mousemove', drag);\n classes.add(o.mirrorContainer, 'gu-unselectable');\n drake.emit('cloned', _mirror, _item, 'mirror');\n }\n\n function removeMirrorImage () {\n if (_mirror) {\n classes.rm(o.mirrorContainer, 'gu-unselectable');\n touchy(documentElement, 'remove', 'mousemove', drag);\n getParent(_mirror).removeChild(_mirror);\n _mirror = null;\n }\n }\n\n function getImmediateChild (dropTarget, target) {\n var immediate = target;\n while (immediate !== dropTarget && getParent(immediate) !== dropTarget) {\n immediate = getParent(immediate);\n }\n if (immediate === documentElement) {\n return null;\n }\n return immediate;\n }\n\n function getReference (dropTarget, target, x, y) {\n var horizontal = o.direction === 'horizontal';\n var reference = target !== dropTarget ? inside() : outside();\n return reference;\n\n function outside () { // slower, but able to figure out any position\n var len = dropTarget.children.length;\n var i;\n var el;\n var rect;\n for (i = 0; i < len; i++) {\n el = dropTarget.children[i];\n rect = el.getBoundingClientRect();\n if (horizontal && (rect.left + rect.width / 2) > x) { return el; }\n if (!horizontal && (rect.top + rect.height / 2) > y) { return el; }\n }\n return null;\n }\n\n function inside () { // faster, but only available if dropped inside a child element\n var rect = target.getBoundingClientRect();\n if (horizontal) {\n return resolve(x > rect.left + getRectWidth(rect) / 2);\n }\n return resolve(y > rect.top + getRectHeight(rect) / 2);\n }\n\n function resolve (after) {\n return after ? nextEl(target) : target;\n }\n }\n\n function isCopy (item, container) {\n return typeof o.copy === 'boolean' ? o.copy : o.copy(item, container);\n }\n}\n\nfunction touchy (el, op, type, fn) {\n var touch = {\n mouseup: 'touchend',\n mousedown: 'touchstart',\n mousemove: 'touchmove'\n };\n var pointers = {\n mouseup: 'pointerup',\n mousedown: 'pointerdown',\n mousemove: 'pointermove'\n };\n var microsoft = {\n mouseup: 'MSPointerUp',\n mousedown: 'MSPointerDown',\n mousemove: 'MSPointerMove'\n };\n if (global.navigator.pointerEnabled) {\n crossvent[op](el, pointers[type], fn);\n } else if (global.navigator.msPointerEnabled) {\n crossvent[op](el, microsoft[type], fn);\n } else {\n crossvent[op](el, touch[type], fn);\n crossvent[op](el, type, fn);\n }\n}\n\nfunction whichMouseButton (e) {\n if (e.touches !== void 0) { return e.touches.length; }\n if (e.which !== void 0 && e.which !== 0) { return e.which; } // see https://github.com/bevacqua/dragula/issues/261\n if (e.buttons !== void 0) { return e.buttons; }\n var button = e.button;\n if (button !== void 0) { // see https://github.com/jquery/jquery/blob/99e8ff1baa7ae341e94bb89c3e84570c7c3ad9ea/src/event.js#L573-L575\n return button & 1 ? 1 : button & 2 ? 3 : (button & 4 ? 2 : 0);\n }\n}\n\nfunction getOffset (el) {\n var rect = el.getBoundingClientRect();\n return {\n left: rect.left + getScroll('scrollLeft', 'pageXOffset'),\n top: rect.top + getScroll('scrollTop', 'pageYOffset')\n };\n}\n\nfunction getScroll (scrollProp, offsetProp) {\n if (typeof global[offsetProp] !== 'undefined') {\n return global[offsetProp];\n }\n if (documentElement.clientHeight) {\n return documentElement[scrollProp];\n }\n return doc.body[scrollProp];\n}\n\nfunction getElementBehindPoint (point, x, y) {\n point = point || {};\n var state = point.className || '';\n var el;\n point.className += ' gu-hide';\n el = doc.elementFromPoint(x, y);\n point.className = state;\n return el;\n}\n\nfunction never () { return false; }\nfunction always () { return true; }\nfunction getRectWidth (rect) { return rect.width || (rect.right - rect.left); }\nfunction getRectHeight (rect) { return rect.height || (rect.bottom - rect.top); }\nfunction getParent (el) { return el.parentNode === doc ? null : el.parentNode; }\nfunction isInput (el) { return el.tagName === 'INPUT' || el.tagName === 'TEXTAREA' || el.tagName === 'SELECT' || isEditable(el); }\nfunction isEditable (el) {\n if (!el) { return false; } // no parents were editable\n if (el.contentEditable === 'false') { return false; } // stop the lookup\n if (el.contentEditable === 'true') { return true; } // found a contentEditable element in the chain\n return isEditable(getParent(el)); // contentEditable is set to 'inherit'\n}\n\nfunction nextEl (el) {\n return el.nextElementSibling || manually();\n function manually () {\n var sibling = el;\n do {\n sibling = sibling.nextSibling;\n } while (sibling && sibling.nodeType !== 1);\n return sibling;\n }\n}\n\nfunction getEventHost (e) {\n // on touchend event, we have to use `e.changedTouches`\n // see http://stackoverflow.com/questions/7192563/touchend-event-properties\n // see https://github.com/bevacqua/dragula/issues/34\n if (e.targetTouches && e.targetTouches.length) {\n return e.targetTouches[0];\n }\n if (e.changedTouches && e.changedTouches.length) {\n return e.changedTouches[0];\n }\n return e;\n}\n\nfunction getCoord (coord, e) {\n var host = getEventHost(e);\n var missMap = {\n pageX: 'clientX', // IE8\n pageY: 'clientY' // IE8\n };\n if (coord in missMap && !(coord in host) && missMap[coord] in host) {\n coord = missMap[coord];\n }\n return host[coord];\n}\n\nmodule.exports = dragula;\n","<script>\n import BoardFilter from './BoardFilter.svelte';\n\n import Avatar from './components/Avatar.svelte';\n import Loader from './components/Loader.svelte';\n\n import PoweredBy from './PoweredBy.svelte';\n\n import Notifications from './components/Notifications.svelte';\n import Notification from './components/Notification.svelte';\n\n import Card from './Card.svelte';\n\n import CreateIssue from './CreateIssue.svelte';\n\n import Api from './Api';\n\n import Dragula from 'dragula';\n\n import {\n isNewIssueShortcut\n } from './shortcuts';\n\n import {\n Id,\n createLocalStore,\n createHistory,\n isClosingLink,\n isOpenOrMerged,\n isPull,\n periodic,\n throttle\n } from './util';\n\n import loaderImage from './logo-gray.svg';\n import errorImage from './error.svg';\n\n import { onMount } from 'svelte';\n\n const DEFAULT_PER_COLUMN_RENDER_COUNT = 25;\n\n const COLUMNS_COLLAPSED_KEY = 'Taskboard_columns_collapsed_state';\n const POLL_KEY = 'Taskboard_polling';\n\n const api = new Api();\n const localStore = createLocalStore();\n const history = createHistory();\n\n const navId = Id();\n\n let name = '';\n let columns = [];\n let items = {};\n\n let itemsById = {};\n\n let localCollapsed = localStore.get(COLUMNS_COLLAPSED_KEY, {});\n let loading = true;\n let updating = 0;\n let error = null;\n let warnings = [];\n\n let filter = parseSearchFilter();\n let user = null;\n let cursor = null;\n\n let accessNotification = false;\n\n let showCreate = false;\n\n let renderCountByColumn = {};\n\n let filterOptions = {};\n\n $: defaultCollapsed = columns.reduce((defaultCollapsed, column) => {\n defaultCollapsed[column.name] = column.collapsed;\n\n return defaultCollapsed;\n }, {});\n\n $: collapsed = {\n ...defaultCollapsed,\n ...localCollapsed\n };\n\n $: localStore.set(COLUMNS_COLLAPSED_KEY, localCollapsed);\n\n // shown items\n $: shownItems = Object.keys(items).reduce((shownItems, column) => {\n\n const columnItems = items[column];\n\n shownItems[column] = columnItems.filter(item => !isClosingPull(item));\n\n return shownItems;\n }, {});\n\n // actually rendered items\n $: renderedItems = Object.keys(shownItems).reduce((renderedItems, column) => {\n\n const renderCount = renderCountByColumn[column] || DEFAULT_PER_COLUMN_RENDER_COUNT;\n const items = shownItems[column];\n\n renderedItems[column] = items.slice(0, renderCount);\n\n return renderedItems;\n }, {});\n\n function action(name, options = {}) {\n\n return fn => {\n\n return fn()\n .then(result => {\n discardWarning(name);\n\n return result;\n })\n .catch(err => {\n return handleWarning(name, err, options);\n });\n };\n }\n\n function handleWarning(action, error, options) {\n console.warn('%s failed', action, error);\n\n if (options.display === false) {\n throw error;\n }\n\n const index = warnings.findIndex(w => w.action === action);\n\n const warning = {\n action,\n error\n };\n\n if (index !== -1) {\n warnings = [\n ...warnings.slice(0, index),\n warning,\n ...warnings.slice(index + 1)\n ];\n } else {\n warnings = [\n ...warnings,\n warning\n ];\n }\n }\n\n function discardWarnings() {\n warnings = [];\n }\n\n function discardWarning(action) {\n warnings = warnings.filter(w => w.action !== action);\n }\n\n function handleError(_error) {\n console.error(_error);\n\n error = _error;\n }\n\n function discardError() {\n error = null;\n }\n\n function loadBoard() {\n discardError();\n discardWarnings();\n\n loading = true;\n\n return Promise.all([\n fetchBoard(),\n loginCheck(),\n fetchCards(filter)\n ]).then(_ => {\n discardError();\n }).catch(error => {\n handleError(error);\n }).finally(() => {\n loading = false;\n });\n }\n\n function setupHooks() {\n\n const poll = localStore.get(POLL_KEY, true);\n\n const teardownHooks = [\n\n // poll for issue updates every three seconds\n poll && periodic(pollUpdates, 1000 * 3),\n\n // check login every 1 minutes\n poll && periodic(loginCheck, 1000 * 60 * 1),\n\n // hook into history changes\n history.onPop(() => {\n const newFilter = parseSearchFilter();\n\n filterChanged(newFilter, false);\n })\n ];\n\n return () => teardownHooks.forEach(fn => fn && fn());\n }\n\n onMount(() => {\n loadBoard();\n setupHooks();\n });\n\n function applyFilter(qualifier, value, add) {\n\n if (/[\\s:]+/.test(value)) {\n value = '\"' + value + '\"';\n }\n\n const criteria = value && `${qualifier}:${value}`;\n\n if (!criteria) {\n return;\n }\n\n let newFilter;\n\n const criteriaIndex = filter.indexOf(criteria);\n\n if (criteriaIndex === 0) {\n newFilter = filter.substring(criteria.length + 1);\n } else if (criteriaIndex > 0) {\n newFilter = filter.substring(0, criteriaIndex - 1) + filter.substring(criteriaIndex + criteria.length);\n } else {\n if (add && filter.trim()) {\n newFilter = `${filter} ${qualifier}:${value}`;\n } else {\n newFilter = criteria;\n }\n }\n\n return filterChanged(newFilter);\n }\n\n function filterChanged(value, pushHistory = true) {\n\n if (value === filter) {\n return;\n }\n\n const currentFilter = filter;\n\n filter = value;\n\n if (pushHistory) {\n history.push(`/board${buildQueryString(filter)}`);\n }\n\n if (currentFilter.trim() !== filter.trim()) {\n\n action('Fetching cards')(\n () => fetchCards(filter)\n );\n }\n }\n\n function parseSearchFilter() {\n if (typeof window === 'undefined') {\n return '';\n }\n\n const queryString = window.location.search;\n\n const search = queryString.split(/[?&]/).find(param => /^s=/.test(param));\n\n if (!search) {\n return '';\n }\n\n return decodeURIComponent(search.split(/=/)[1]);\n }\n\n function buildQueryString(filter, separator = '?') {\n if (filter) {\n return `${separator}s=${encodeURIComponent(filter)}`;\n } else {\n return '';\n }\n }\n\n function loginCheck() {\n return action('User login check')(\n () => api.getLoggedInUser().then(newUser => {\n\n if (user && !newUser) {\n window.location.reload();\n } else {\n user = newUser;\n }\n })\n );\n }\n\n function fetchBoard() {\n return api.getBoard().then(result => {\n columns = result.columns;\n name = result.name;\n });\n }\n\n function updateCards(_items, _cursor) {\n console.time('Taskboard#updateCards');\n\n const _itemsById = {};\n const _filterOptions = {};\n\n for (const columnItems of Object.values(_items)) {\n\n for (const item of columnItems) {\n const {\n id,\n user,\n milestone,\n assignees,\n labels,\n repository,\n requested_reviewers\n } = item;\n\n const repoOptions = _filterOptions['repo'] = _filterOptions['repo'] || {};\n\n repoOptions[repository.owner.login + '/' + repository.name] = true;\n\n if (milestone) {\n const milestoneOptions = _filterOptions['milestone'] = _filterOptions['milestone'] || {};\n\n milestoneOptions[milestone.title] = true;\n }\n\n if (user) {\n const authorOptions = _filterOptions['author'] = _filterOptions['author'] || {};\n\n authorOptions[user.login] = true;\n }\n\n assignees.forEach(assignee => {\n const assigneeOptions = _filterOptions['assignee'] = _filterOptions['assignee'] || {};\n\n assigneeOptions[assignee.login] = true;\n });\n\n if (requested_reviewers) {\n requested_reviewers.forEach(reviewer => {\n const reviewerOptions = _filterOptions['reviewer'] = _filterOptions['reviewer'] || {};\n\n reviewerOptions[reviewer.login] = true;\n });\n }\n\n labels.forEach(label => {\n\n if (!label.column_label) {\n const labelOptions = _filterOptions['label'] = _filterOptions['label'] || {};\n\n labelOptions[label.name] = true;\n }\n });\n\n _itemsById[id] = item;\n }\n\n }\n\n items = _items;\n itemsById = _itemsById;\n filterOptions = Object.entries(_filterOptions).reduce((opts, entry) => {\n\n const [ key, value ] = entry;\n\n opts[key] = Object.keys(value);\n\n return opts;\n }, {});\n\n cursor = _cursor;\n console.timeEnd('Taskboard#updateCards');\n }\n\n function fetchCards(newFilter) {\n\n updating++;\n\n return api.listCards(newFilter).then(result => {\n\n // do not apply updates for outdated filters\n if (newFilter !== filter) {\n return;\n }\n\n const {\n items,\n cursor\n } = result;\n\n updateCards(items, cursor);\n }).finally(() => updating--);\n }\n\n\n function pollUpdates() {\n\n if (updating) {\n return;\n }\n\n const currentFilter = filter;\n\n return action('Checking for updates', { display: false })(\n () => api.listUpdates(currentFilter, cursor).then(updates => {\n\n if (!updates.length) {\n return;\n }\n\n if (currentFilter !== filter) {\n return;\n }\n\n const {\n items: _items,\n itemsById: _itemsById,\n cursor: _cursor\n } = applyUpdates(updates, items, itemsById);\n\n items = _items;\n itemsById = _itemsById;\n cursor = _cursor;\n })\n );\n }\n\n function applyUpdates(updates, items, itemsById) {\n\n const cursor = updates[updates.length - 1].id;\n\n updates.forEach(update => {\n const {\n type,\n issue\n } = update;\n\n const {\n id\n } = issue;\n\n const from = itemsById[id];\n\n const to = type !== 'remove' && issue;\n\n items = {\n ...items,\n ...moveItem(items, issue, from, to)\n };\n\n // remove from index\n if (type === 'remove') {\n const {\n [id]: removedItem,\n ...remainingItems\n } = itemsById;\n\n itemsById = remainingItems;\n } else {\n\n // update in index\n itemsById = {\n ...itemsById,\n [id]: issue\n };\n }\n });\n\n return {\n cursor,\n itemsById,\n items\n };\n }\n\n const drake = Dragula({\n isContainer: (el) => {\n return el.matches('[data-column-id]');\n }\n });\n\n function getCardId(el) {\n const dataset = el.dataset;\n return dataset.cardId;\n }\n\n function getCardOrder(el) {\n const dataset = el.dataset;\n return parseFloat(dataset.cardOrder);\n }\n\n function getColumnId(el) {\n const dataset = el.dataset;\n return dataset.columnId;\n }\n\n function checkCancel(event) {\n if (event.key === 'Escape') {\n drake.cancel(true);\n }\n }\n\n drake.on('drag', () => {\n document.addEventListener('keydown', checkCancel);\n });\n\n drake.on('dragend', () => {\n document.removeEventListener('keydown', checkCancel);\n });\n\n drake.on('drop', (el, target, source, nextEl) => {\n const cardId = getCardId(el);\n const cardOrder = getCardOrder(el);\n\n const previousEl = el.previousElementSibling;\n\n const nextOrder = nextEl && getCardOrder(nextEl);\n const previousOrder = previousEl && getCardOrder(previousEl);\n\n const newOrder =\n previousOrder && nextOrder\n ? (previousOrder + nextOrder) / 2\n : previousOrder\n ? previousOrder + 731241.218\n : nextOrder\n ? nextOrder - 811231.691\n : -71271.88455;\n\n handleCardDrop(\n itemsById[cardId],\n {\n order: cardOrder,\n column: getColumnId(source)\n },\n {\n order: newOrder,\n column: getColumnId(target)\n }\n );\n\n });\n\n function handleCardDrop(card, from, to) {\n\n const { before, after } = moveCard(card, from, to);\n\n return api.moveIssue(\n card.id,\n to.column,\n before && before.id,\n after && after.id\n ).catch(err => {\n console.warn('reverting card movement', err);\n\n accessNotification = user ? 'forbidden' : 'authentication-required';\n\n setTimeout(() => {\n accessNotification = false;\n }, 8000);\n\n moveCard(card, to, from);\n });\n }\n\n function removeItem(item, list = []) {\n const { id } = item;\n\n return list.filter(existing => existing.id !== id);\n }\n\n function insertItem(item, order, list = []) {\n const insertIdx = list.findIndex(existing => existing.order > order);\n\n if (insertIdx === -1) {\n return [ ...list, item ];\n }\n\n return [\n ...list.slice(0, insertIdx),\n item,\n ...list.slice(insertIdx)\n ];\n\n }\n\n function moveCard(card, from, to) {\n\n // temporarily update card with new column and ordering\n card.column = to.column;\n card.order = to.order;\n\n const updatedItems = moveItem(items, card, from, to);\n\n items = {\n ...items,\n ...updatedItems\n };\n\n const targetColumn = updatedItems[to.column];\n\n const cardIndex = targetColumn.findIndex(el => el.id === card.id);\n\n return {\n after: targetColumn[cardIndex - 1],\n before: targetColumn[cardIndex + 1]\n };\n }\n\n function moveItem(items, item, from, to) {\n\n const oldColumn = from && from.column;\n\n const newColumn = to && to.column;\n const newOrder = to && to.order;\n\n // remove from old column\n if (oldColumn) {\n const updatedColumn = removeItem(item, items[oldColumn]);\n\n items = {\n ...items,\n [oldColumn]: updatedColumn\n };\n }\n\n // add to new column\n if (newColumn) {\n const updatedColumn = insertItem(item, newOrder, items[newColumn]);\n\n items = {\n ...items,\n [newColumn]: updatedColumn\n };\n }\n\n return items;\n }\n\n function toggleCollapse(column) {\n\n localCollapsed = {\n ...localCollapsed,\n [column.name]: !collapsed[column.name]\n };\n }\n\n function isClosingPull(item) {\n return isPull(item) && isOpenOrMerged(item) && item.links.some(link => {\n return isClosingLink(link) && itemsById[link.target.id];\n });\n }\n\n function checkRender(columnName) {\n\n return throttle(function(event) {\n\n const node = event.target;\n\n const {\n scrollHeight,\n scrollTop,\n offsetHeight\n } = node;\n\n if (scrollTop + offsetHeight > scrollHeight * .95) {\n\n const columnItems = shownItems[columnName] || [];\n\n const columnRenderedCount = renderCountByColumn[columnName] || DEFAULT_PER_COLUMN_RENDER_COUNT;\n\n if (columnRenderedCount < columnItems.length) {\n\n renderCountByColumn = {\n ...renderCountByColumn,\n [columnName]: columnRenderedCount + DEFAULT_PER_COLUMN_RENDER_COUNT / 5\n };\n }\n }\n }, 5);\n }\n\n function openCreateIssue() {\n showCreate = true;\n }\n\n function closeCreateIssue() {\n showCreate = false;\n }\n\n function createIssue(owner, repo) {\n closeCreateIssue();\n\n window.open(\n `https://github.com/${owner}/${repo}/issues/new/choose`,\n '_blank'\n );\n }\n\n function handleGlobalKey(event) {\n\n if (isNewIssueShortcut(event)) {\n openCreateIssue();\n\n event.preventDefault();\n }\n }\n</script>\n\n<style lang=\"scss\">\n @import \"variables\";\n\n @import \"./Taskboard\";\n\n .vertical-divider {\n display: inline-block;\n width: 1px;\n height: 0.9em;\n margin: 0 8px;\n\n background: $gray-300;\n }\n\n .muted {\n color: $gray-600;\n }\n\n .taskboard {\n position: relative;\n }\n</style>\n\n<svelte:head>\n {#if !loading}\n <title>{ name } · Wuffle Board</title>\n {/if}\n</svelte:head>\n\n<svelte:window on:keydown={ handleGlobalKey } />\n\n<div class=\"taskboard\">\n\n <Loader shown={ loading }>\n <img src={ loaderImage } width=\"64\" alt=\"Loading\" />\n </Loader>\n\n <CreateIssue\n repositories={ filterOptions['repo'] }\n onCreate={ createIssue }\n open={ showCreate }\n onClose={ closeCreateIssue }\n />\n\n {#if error}\n <div class=\"taskboard-error\">\n\n <img src={ errorImage } width=\"128\" alt=\"An error occured\" />\n\n <p>We could not load the board.</p>\n\n <button class=\"btn btn-primary\" on:click={ () => loadBoard() }>\n Retry\n </button>\n </div>\n {/if}\n\n <Notifications>\n {#if !error}\n {#each warnings as warning}\n <Notification type=\"warning\" message=\"{ warning.action } failed\">\n Could not reach the board back-end. <a href>Reload board.</a>\n </Notification>\n {/each}\n {/if}\n\n {#if accessNotification}\n <Notification type=\"error\" message=\"Failed to move card\">\n {#if accessNotification === 'forbidden'}\n It seems like you do not have write access to the underlying GitHub repository.\n {:else}\n Please <a href=\"/wuffle/login\" aria-label=\"Login via GitHub\">login via GitHub</a> to interact with cards.\n {/if}\n </Notification>\n {/if}\n </Notifications>\n\n <PoweredBy />\n\n <nav class=\"navbar navbar-expand navbar-light taskboard-header\">\n\n <a class=\"navbar-brand m-0 mr-3 my-2\" href=\"/\" aria-label={ name } title=\"{ name } - Wuffle board\">\n <img src=\"./logo.svg\" height=\"30px\" alt=\"Wuffle board logo\" class=\"logo\" />\n </a>\n <button class=\"navbar-toggler\" type=\"button\" data-toggle=\"collapse\" data-target=\"#{navId}\" aria-controls={navId} aria-expanded=\"false\" aria-label=\"Toggle navigation\">\n <span class=\"navbar-toggler-icon\"></span>\n </button>\n\n <div class=\"collapse navbar-collapse\" id={navId}>\n\n <form class=\"form-inline board-filter-parent my-2 my-lg-0\" on:submit|preventDefault={ () => {} }>\n <BoardFilter\n value={ filter }\n completionOptions={ filterOptions }\n onChange={ filterChanged }\n placeholder={ 'Filter board...' }\n />\n </form>\n\n <form class=\"form-inline mx-3 my-2 my-sm-0\" on:submit|preventDefault={ openCreateIssue }>\n <button class=\"btn btn-outline-primary\" type=\"submit\" title=\"Create new issue (n)\">\n <svg xmlns=\"http://www.w3.org/2000/svg\" height=\"1em\" viewBox=\"0 0 16 16\"><path fill=\"currentColor\" fill-rule=\"evenodd\" d=\"M7.75 2a.75.75 0 01.75.75V7h4.25a.75.75 0 110 1.5H8.5v4.25a.75.75 0 11-1.5 0V8.5H2.75a.75.75 0 010-1.5H7V2.75A.75.75 0 017.75 2z\"></path></svg>\n </button>\n </form>\n </div>\n\n <div class=\"taskboard-header-login ml-2\">\n {#if user}\n <a href=\"/wuffle/logout\" aria-label=\"Logout\">\n <Avatar title={ `Logout ${user.login}` } rounded>\n <img src=\"{ user.avatar_url }&s=40\" style=\"max-width: 100%\" alt=\"Logged in user avatar\" />\n </Avatar>\n </a>\n {:else}\n <a href=\"/wuffle/login\" aria-label=\"Login with GitHub\">\n <Avatar title=\"Login with GitHub\" rounded>\n <svg height=\"1.3em\" fill=\"currentColor\" viewBox=\"0 0 12 16\" version=\"1.1\" aria-hidden=\"true\"><path fill-rule=\"evenodd\" d=\"M12 14.002a.998.998 0 0 1-.998.998H1.001A1 1 0 0 1 0 13.999V13c0-2.633 4-4 4-4s.229-.409 0-1c-.841-.62-.944-1.59-1-4 .173-2.413 1.867-3 3-3s2.827.586 3 3c-.056 2.41-.159 3.38-1 4-.229.59 0 1 0 1s4 1.367 4 4v1.002z\"></path></svg>\n </Avatar>\n </a>\n {/if}\n </div>\n </nav>\n\n <main class=\"taskboard-board\">\n\n {#if !error}\n {#each columns as column }\n <div class=\"taskboard-column\" class:collapsed={ collapsed[column.name] }>\n <div class=\"taskboard-column-header\">\n <button\n class=\"taskboard-column-collapse btn btn-link\"\n title=\"{ collapsed[column.name] ? 'Expand' : 'Collapse' } column\"\n on:click={ (e) => e.preventDefault() || toggleCollapse(column) }\n >\n {#if collapsed[column.name] }\n <svg viewBox=\"64 64 896 896\" height=\"1em\" aria-hidden=\"true\" fill=\"currentColor\"><path d=\"M602 548c0 4 4 8 8 8h186v74c0 6 7 9 11 6l150-120c3-3 3-8 0-11L807 386c-4-4-11-1-11 5v75H609c-4 0-7 3-7 7zM68 514l149 122c4 3 11 0 11-6v-76h186c4 0 8-2 8-6v-77c0-4-4-7-8-7H228v-75c0-6-7-9-11-5L68 503c-4 3-4 8 0 11z\"/></svg>\n {:else}\n <svg viewBox=\"64 64 896 896\" height=\"1em\" aria-hidden=\"true\" fill=\"currentColor\"><path d=\"M605 515l149 122c5 3 12 0 12-6v-76h186c4 0 7-2 7-6v-77c0-4-3-7-7-7H766v-75c0-6-7-9-12-5L605 504c-4 3-4 8 0 11zM65 547c0 4 3 8 7 8h186v74c0 6 7 9 12 6l149-120c4-3 4-8 0-11L270 385c-5-4-12-1-12 5v75H72c-4 0-7 3-7 7z\"/></svg>\n {/if}\n </button>\n <span class=\"taskboard-column-name\">\n { column.name }\n </span>\n <span class=\"taskboard-column-issue-count\">\n { (shownItems[column.name] || []).length }\n </span>\n </div>\n\n {#if !collapsed[column.name] }\n <div class=\"taskboard-column-items\"\n data-column-id={ column.name }\n on:scroll={ checkRender(column.name) }>\n\n {#each (renderedItems[column.name] || []) as item, index (item.id) }\n <div\n class=\"card-container\"\n data-card-id={ item.id }\n data-card-order={ item.order }\n >\n <Card\n item={item}\n onSelect={ applyFilter }\n />\n </div>\n {/each}\n\n </div>\n {/if}\n </div>\n {/each}\n {/if}\n </main>\n</div>","export default \"data:image/svg+xml,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20viewBox%3D%220%200%2080%2080%22%3E%3Cpath%20d%3D%22M12%200h56c7%200%2012%205%2012%2012v56c0%207-5%2012-12%2012H12C5%2080%200%2075%200%2068V12C0%205%205%200%2012%200z%22%20fill%3D%22%23999%22%2F%3E%3Cpath%20d%3D%22M15%2010h21c3%200%205%202%205%205v6c0%203-2%205-5%205H15c-2%200-4-2-4-5v-6c0-3%202-5%204-5zm0%2020h21c3%200%205%202%205%205v6c0%202-2%204-5%204H15c-2%200-4-1-4-4v-6c0-3%202-5%204-5zm27%2022h21c2%200%204%202%204%205v6c0%202-2%204-4%204H42c-2%200-4-2-4-4v-6c0-3%202-5%204-5z%22%20fill%3D%22%23fff%22%2F%3E%3C%2Fsvg%3E\"","export default \"data:image/svg+xml,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20viewBox%3D%220%200%2080%2080%22%3E%3Cpath%20d%3D%22M12%200h56c7%200%2012%205%2012%2012v56c0%207-5%2012-12%2012H12C5%2080%200%2075%200%2068V12C0%205%205%200%2012%200z%22%20fill%3D%22%23d35f5f%22%2F%3E%3Cpath%20d%3D%22M30%2038l19%207c3%201%204%204%203%206l-2%206c-1%202-4%203-6%203l-20-8c-2-1-3-3-2-6l2-6c1-2%203-3%206-2z%22%20fill%3D%22%23fff%22%2F%3E%3Cpath%20d%3D%22M12%2066l18-10c2-1%205-1%206%202l3%205c1%202%201%205-1%206L19%2080c-2%201-5%200-6-2l-3-6c-1-2%200-4%202-6z%22%20fill%3D%22%23fff%22%2F%3E%3Cpath%20d%3D%22M46%2060l20%205c2%201%204%203%203%206l-1%206c-1%202-3%204-6%203l-20-6c-3%200-4-3-3-5l1-6c1-2%203-4%206-3z%22%20fill%3D%22%23fff%22%2F%3E%3C%2Fsvg%3E\"","export function isClosingLink(link) {\n const {\n type\n } = link;\n\n return type === 'CLOSES';\n}\n\nexport function isClosedByLink(link) {\n const {\n type\n } = link;\n\n return type === 'CLOSED_BY';\n}","import {\n debounce\n} from 'min-dash';\n\nimport Taskboard from './Taskboard.svelte';\n\nconsole.timeEnd('Wuffle#load');\n\nconsole.time('Taskboard#create');\n\nconst taskboard = new Taskboard({\n target: document.body\n});\n\nconsole.timeEnd('Taskboard#create');\n\nif ('serviceWorker' in navigator) {\n\n const triggerReload = debounce(() => {\n window.location.reload();\n }, 500);\n\n window.addEventListener('load', () => {\n navigator.serviceWorker.register('/service-worker.js').catch((err) => {\n console.warn('Failed to register service worker', err);\n });\n\n navigator.serviceWorker.addEventListener('message', event => {\n if (event.data.message === 'resource.changed') {\n console.log('Resource changed', event.data.url);\n\n triggerReload();\n }\n });\n });\n}\n\nexport default taskboard;"],"names":["debounce","fn","timeout","timer","lastArgs","lastThis","lastNow","fire","force","now","Date","scheduledDiff","schedule","apply","clear","setTimeout","clearTimeout","undefined","callback","_len","arguments","length","args","Array","_key","this","flush","cancel","noop","identity","x","run","blank_object","Object","create","run_all","fns","forEach","is_function","thing","src_url_equal_anchor","src_url_equal","element_src","url","document","createElement","href","not_equal","a","b","create_slot","definition","ctx","$$scope","slot_ctx","get_slot_context","tar","src","k","assign","slice","get_slot_changes","dirty","lets","merged","len","Math","max","i","update_slot_base","slot","slot_definition","slot_changes","get_slot_context_fn","slot_context","p","get_all_dirty_from_scope","null_to_empty","value","is_client","window","performance","raf","cb","requestAnimationFrame","tasks","Set","run_tasks","task","c","delete","f","size","append","target","node","appendChild","get_root_for_style","root","getRootNode","ownerDocument","host","append_empty_stylesheet","style_element","element","style","head","append_stylesheet","insert","anchor","insertBefore","detach","parentNode","removeChild","destroy_each","iterations","detaching","d","name","svg_element","createElementNS","text","data","createTextNode","space","empty","listen","event","handler","options","addEventListener","removeEventListener","prevent_default","preventDefault","call","attr","attribute","removeAttribute","getAttribute","setAttribute","set_data","wholeText","set_input_value","input","set_style","key","important","setProperty","toggle_class","toggle","classList","active_docs","current_component","active","create_rule","duration","delay","ease","uid","step","keyframes","t","rule","str","hash","charCodeAt","doc","add","stylesheet","__svelte_stylesheet","sheet","current_rules","__svelte_rules","insertRule","cssRules","animation","delete_rule","previous","split","next","filter","anim","indexOf","deleted","join","deleteRule","set_current_component","component","onMount","Error","get_current_component","$$","on_mount","push","dirty_components","binding_callbacks","render_callbacks","flush_callbacks","resolved_promise","Promise","resolve","update_scheduled","add_render_callback","flushing","seen_callbacks","update","pop","has","fragment","before_update","after_update","promise","dispatch","direction","kind","dispatchEvent","type","detail","bubbles","e","createEvent","initCustomEvent","custom_event","outroing","outros","group_outros","r","check_outros","transition_in","block","local","transition_out","o","null_transition","create_bidirectional_transition","params","intro","config","running_program","pending_program","animation_name","clear_animation","init","program","abs","start","end","group","go","easing","tick","css","fulfill","loop","then","globals","globalThis","global","outro_and_destroy_block","lookup","create_component","mount_component","customElement","on_destroy","m","new_on_destroy","map","destroy_component","make_dirty","fill","instance","create_fragment","props","append_styles","parent_component","bound","on_disconnect","context","Map","callbacks","skip_bound","ready","ret","rest","hydrate","nodes","from","childNodes","children","l","SvelteComponent","$destroy","$on","index","splice","$set","$$props","obj","$$set","keys","Id","LocalStore","get","defaultValue","serializedValue","localStorage","getItem","JSON","parse","error","console","warn","set","setItem","stringify","FakeLocalStore","History","history","pushState","onPop","FakeHistory","periodic","interval","canceled","success","err","isOpen","issue","state","isMerged","isPull","pull_request","parts","matched","onHover","hint","onBlur","onSelect","hasModifier","ctrlKey","shiftKey","altKey","metaKey","isGlobal","body","isApplyFilterClick","isAddFilterClick","categories","values","focussed","mouseSelectedHint","rounded","title","cubicOut","fly","y","opacity","getComputedStyle","target_opacity","transform","od","u","message","item","open","closed","draft","conclusion","status","html_url","description","target_url","check_runs","statuses","failure","in_progress","queued","action_required","avatar_url","login","user","id","number","repository","repositoryName","owner","repoUrl","assignees","comments","isArray","comment","requested_reviewers","reviews","concat","review","find","reviewer","reduce","byUser","existingReview","changes_requested","approved","commented","dismissed","qualifier","hovered","cardUrl","linkTitle","CHILD_OF","DEPENDS_ON","PARENT_OF","CLOSED_BY","REQUIRED_BY","CLOSES","LINKED_TO","LINKED_BY","keyFn","found","showChildren","inputId","matchedHints","keyboardSelectedHint","onClose","repositories","applyHint","val","idx","selectionEnd","selectionStart","repo","nextHint","currentHint","hints","nextIndex","findIndex","focus","time","opts","search","toLowerCase","includes","substring","currentValue","computeMatch","timeEnd","selectedHint","blur","onCreate","Api","moveIssue","column","before","after","fetchJSON","appURL","method","listCards","buildQueryString","getBoard","getLoggedInUser","catch","listUpdates","cursor","location","fetch","credentials","response","ok","separator","encodeURIComponent","n","prototype","setImmediate","process","nextTick","ticky","evt","on","once","_once","off","et","emit","atoa","emitterSnapshot","shift","throws","async","NativeCustomEvent","CustomEvent","foo","useNative","cancelable","createEventObject","Boolean","eventmap","eventname","ron","test","addEvent","el","capturing","removeEvent","hardCache","attachEvent","wrapper","unwrap","originalEvent","srcElement","returnValue","stopPropagation","cancelBubble","which","keyCode","wrapperFactory","wrap","listener","detachEvent","remove","fabricate","model","customEvent","initEvent","makeClassicEvent","fireEvent","cache","lookupClass","className","cached","lastIndex","RegExp","current","rm","replace","trim","documentElement","touchy","op","navigator","pointerEnabled","crossvent","mouseup","mousedown","mousemove","msPointerEnabled","whichMouseButton","touches","buttons","button","getOffset","rect","getBoundingClientRect","left","getScroll","top","scrollProp","offsetProp","clientHeight","getElementBehindPoint","point","elementFromPoint","never","always","getRectWidth","width","right","getRectHeight","height","bottom","getParent","isInput","tagName","isEditable","contentEditable","nextEl","nextElementSibling","sibling","nextSibling","nodeType","manually","getCoord","coord","targetTouches","changedTouches","getEventHost","missMap","pageX","pageY","initialContainers","_mirror","_source","_item","_offsetX","_offsetY","_moveX","_moveY","_initialSibling","_currentSibling","_copy","_renderTimer","_grabbed","_lastDropTarget","moves","accepts","invalid","invalidTarget","containers","isContainer","copy","copySortSource","revertOnSpill","removeOnSpill","ignoreInputTextSelection","mirrorContainer","drake","emitter","manualStart","destroy","canMove","dragging","spillOver","spillOut","events","grab","release","eventualMovements","startBecauseMouseMoved","movements","preventGrabbed","clientX","clientY","canStart","slideFactorX","slideFactorY","grabbed","offset","classes","renderMirrorImage","drag","handle","source","isCopy","cloneNode","drop","ungrab","dropTarget","findDropTarget","parent","isInitialPlacement","cleanup","revert","reverts","initial","removeMirrorImage","s","elementBehindCursor","accepted","immediate","getImmediateChild","reference","getReference","changed","moved","horizontal","inside","outside","container","action","old_blocks","get_key","dynamic","list","create_each_block","get_context","old_indexes","new_blocks","new_lookup","deltas","child_ctx","will_move","did_move","first","new_block","old_block","new_key","old_key","order","COLUMNS_COLLAPSED_KEY","parseSearchFilter","param","decodeURIComponent","getCardOrder","dataset","parseFloat","cardOrder","getColumnId","columnId","moveItem","items","to","oldColumn","newColumn","newOrder","updatedColumn","existing","removeItem","insertIdx","insertItem","api","localStore","navId","columns","itemsById","localCollapsed","loading","updating","warnings","accessNotification","showCreate","renderCountByColumn","filterOptions","result","w","discardWarning","display","warning","handleWarning","handleError","_error","discardError","loadBoard","all","loginCheck","fetchCards","_","finally","filterChanged","pushHistory","currentFilter","newUser","reload","updateCards","_items","_cursor","_itemsById","_filterOptions","columnItems","milestone","labels","assignee","label","column_label","entries","entry","newFilter","pollUpdates","updates","removedItem","remainingItems","applyUpdates","poll","teardownHooks","setupHooks","Dragula","matches","checkCancel","moveCard","card","updatedItems","targetColumn","cardIndex","toggleCollapse","collapsed","isClosingPull","links","some","link","isClosingLink","openCreateIssue","closeCreateIssue","cardId","getCardId","previousEl","previousElementSibling","nextOrder","previousOrder","handleCardDrop","defaultCollapsed","shownItems","renderedItems","renderCount","criteria","criteriaIndex","columnName","scrollHeight","scrollTop","offsetHeight","columnRenderedCount","DEFAULT_PER_COLUMN_RENDER_COUNT","throttling","isNewIssueShortcut","taskboard","triggerReload","serviceWorker","register","log"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"bundle.js","sources":["../../board/node_modules/min-dash/dist/index.esm.js","../../board/node_modules/svelte/internal/index.mjs","../../board/src/util/Id.js","../../board/src/util/local-store.js","../../board/src/util/history.js","../../board/src/util/index.js","../../board/src/components/HintList.svelte","../../board/src/shortcuts.js","../../board/src/BoardFilter.svelte","../../board/src/components/Avatar.svelte","../../board/src/components/Loader.svelte","../../board/src/PoweredBy.svelte","../../board/src/components/Notifications.svelte","../../board/node_modules/svelte/easing/index.mjs","../../board/node_modules/svelte/transition/index.mjs","../../board/src/components/Notification.svelte","../../board/src/components/Tag.svelte","../../board/src/components/PullRequestIcon.svelte","../../board/src/components/EpicIcon.svelte","../../board/src/CardStatus.svelte","../../board/src/CollaboratorLinks.svelte","../../board/src/components/LinkIcon.svelte","../../board/src/CardLink.svelte","../../board/src/Card.svelte","../../board/src/RepositorySelect.svelte","../../board/src/CreateIssue.svelte","../../board/src/Api.js","../../board/node_modules/atoa/atoa.js","../../board/node_modules/ticky/ticky.js","../../board/node_modules/contra/debounce.js","../../board/node_modules/contra/emitter.js","../../board/node_modules/custom-event/index.js","../../board/node_modules/crossvent/src/eventmap.js","../../board/node_modules/crossvent/src/crossvent.js","../../board/node_modules/dragula/classes.js","../../board/node_modules/dragula/dragula.js","../../board/src/Taskboard.svelte","../../board/src/logo-gray.svg","../../board/src/error.svg","../../board/src/util/links.js","../../board/src/main.js"],"sourcesContent":["/**\n * Flatten array, one level deep.\n *\n * @param {Array<?>} arr\n *\n * @return {Array<?>}\n */\nfunction flatten(arr) {\n return Array.prototype.concat.apply([], arr);\n}\n\nvar nativeToString = Object.prototype.toString;\nvar nativeHasOwnProperty = Object.prototype.hasOwnProperty;\nfunction isUndefined(obj) {\n return obj === undefined;\n}\nfunction isDefined(obj) {\n return obj !== undefined;\n}\nfunction isNil(obj) {\n return obj == null;\n}\nfunction isArray(obj) {\n return nativeToString.call(obj) === '[object Array]';\n}\nfunction isObject(obj) {\n return nativeToString.call(obj) === '[object Object]';\n}\nfunction isNumber(obj) {\n return nativeToString.call(obj) === '[object Number]';\n}\nfunction isFunction(obj) {\n var tag = nativeToString.call(obj);\n return tag === '[object Function]' || tag === '[object AsyncFunction]' || tag === '[object GeneratorFunction]' || tag === '[object AsyncGeneratorFunction]' || tag === '[object Proxy]';\n}\nfunction isString(obj) {\n return nativeToString.call(obj) === '[object String]';\n}\n/**\n * Ensure collection is an array.\n *\n * @param {Object} obj\n */\n\nfunction ensureArray(obj) {\n if (isArray(obj)) {\n return;\n }\n\n throw new Error('must supply array');\n}\n/**\n * Return true, if target owns a property with the given key.\n *\n * @param {Object} target\n * @param {String} key\n *\n * @return {Boolean}\n */\n\nfunction has(target, key) {\n return nativeHasOwnProperty.call(target, key);\n}\n\n/**\n * Find element in collection.\n *\n * @param {Array|Object} collection\n * @param {Function|Object} matcher\n *\n * @return {Object}\n */\n\nfunction find(collection, matcher) {\n matcher = toMatcher(matcher);\n var match;\n forEach(collection, function (val, key) {\n if (matcher(val, key)) {\n match = val;\n return false;\n }\n });\n return match;\n}\n/**\n * Find element index in collection.\n *\n * @param {Array|Object} collection\n * @param {Function} matcher\n *\n * @return {Object}\n */\n\nfunction findIndex(collection, matcher) {\n matcher = toMatcher(matcher);\n var idx = isArray(collection) ? -1 : undefined;\n forEach(collection, function (val, key) {\n if (matcher(val, key)) {\n idx = key;\n return false;\n }\n });\n return idx;\n}\n/**\n * Find element in collection.\n *\n * @param {Array|Object} collection\n * @param {Function} matcher\n *\n * @return {Array} result\n */\n\nfunction filter(collection, matcher) {\n var result = [];\n forEach(collection, function (val, key) {\n if (matcher(val, key)) {\n result.push(val);\n }\n });\n return result;\n}\n/**\n * Iterate over collection; returning something\n * (non-undefined) will stop iteration.\n *\n * @param {Array|Object} collection\n * @param {Function} iterator\n *\n * @return {Object} return result that stopped the iteration\n */\n\nfunction forEach(collection, iterator) {\n var val, result;\n\n if (isUndefined(collection)) {\n return;\n }\n\n var convertKey = isArray(collection) ? toNum : identity;\n\n for (var key in collection) {\n if (has(collection, key)) {\n val = collection[key];\n result = iterator(val, convertKey(key));\n\n if (result === false) {\n return val;\n }\n }\n }\n}\n/**\n * Return collection without element.\n *\n * @param {Array} arr\n * @param {Function} matcher\n *\n * @return {Array}\n */\n\nfunction without(arr, matcher) {\n if (isUndefined(arr)) {\n return [];\n }\n\n ensureArray(arr);\n matcher = toMatcher(matcher);\n return arr.filter(function (el, idx) {\n return !matcher(el, idx);\n });\n}\n/**\n * Reduce collection, returning a single result.\n *\n * @param {Object|Array} collection\n * @param {Function} iterator\n * @param {Any} result\n *\n * @return {Any} result returned from last iterator\n */\n\nfunction reduce(collection, iterator, result) {\n forEach(collection, function (value, idx) {\n result = iterator(result, value, idx);\n });\n return result;\n}\n/**\n * Return true if every element in the collection\n * matches the criteria.\n *\n * @param {Object|Array} collection\n * @param {Function} matcher\n *\n * @return {Boolean}\n */\n\nfunction every(collection, matcher) {\n return !!reduce(collection, function (matches, val, key) {\n return matches && matcher(val, key);\n }, true);\n}\n/**\n * Return true if some elements in the collection\n * match the criteria.\n *\n * @param {Object|Array} collection\n * @param {Function} matcher\n *\n * @return {Boolean}\n */\n\nfunction some(collection, matcher) {\n return !!find(collection, matcher);\n}\n/**\n * Transform a collection into another collection\n * by piping each member through the given fn.\n *\n * @param {Object|Array} collection\n * @param {Function} fn\n *\n * @return {Array} transformed collection\n */\n\nfunction map(collection, fn) {\n var result = [];\n forEach(collection, function (val, key) {\n result.push(fn(val, key));\n });\n return result;\n}\n/**\n * Get the collections keys.\n *\n * @param {Object|Array} collection\n *\n * @return {Array}\n */\n\nfunction keys(collection) {\n return collection && Object.keys(collection) || [];\n}\n/**\n * Shorthand for `keys(o).length`.\n *\n * @param {Object|Array} collection\n *\n * @return {Number}\n */\n\nfunction size(collection) {\n return keys(collection).length;\n}\n/**\n * Get the values in the collection.\n *\n * @param {Object|Array} collection\n *\n * @return {Array}\n */\n\nfunction values(collection) {\n return map(collection, function (val) {\n return val;\n });\n}\n/**\n * Group collection members by attribute.\n *\n * @param {Object|Array} collection\n * @param {Function} extractor\n *\n * @return {Object} map with { attrValue => [ a, b, c ] }\n */\n\nfunction groupBy(collection, extractor) {\n var grouped = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {};\n extractor = toExtractor(extractor);\n forEach(collection, function (val) {\n var discriminator = extractor(val) || '_';\n var group = grouped[discriminator];\n\n if (!group) {\n group = grouped[discriminator] = [];\n }\n\n group.push(val);\n });\n return grouped;\n}\nfunction uniqueBy(extractor) {\n extractor = toExtractor(extractor);\n var grouped = {};\n\n for (var _len = arguments.length, collections = new Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) {\n collections[_key - 1] = arguments[_key];\n }\n\n forEach(collections, function (c) {\n return groupBy(c, extractor, grouped);\n });\n var result = map(grouped, function (val, key) {\n return val[0];\n });\n return result;\n}\nvar unionBy = uniqueBy;\n/**\n * Sort collection by criteria.\n *\n * @param {Object|Array} collection\n * @param {String|Function} extractor\n *\n * @return {Array}\n */\n\nfunction sortBy(collection, extractor) {\n extractor = toExtractor(extractor);\n var sorted = [];\n forEach(collection, function (value, key) {\n var disc = extractor(value, key);\n var entry = {\n d: disc,\n v: value\n };\n\n for (var idx = 0; idx < sorted.length; idx++) {\n var d = sorted[idx].d;\n\n if (disc < d) {\n sorted.splice(idx, 0, entry);\n return;\n }\n } // not inserted, append (!)\n\n\n sorted.push(entry);\n });\n return map(sorted, function (e) {\n return e.v;\n });\n}\n/**\n * Create an object pattern matcher.\n *\n * @example\n *\n * const matcher = matchPattern({ id: 1 });\n *\n * let element = find(elements, matcher);\n *\n * @param {Object} pattern\n *\n * @return {Function} matcherFn\n */\n\nfunction matchPattern(pattern) {\n return function (el) {\n return every(pattern, function (val, key) {\n return el[key] === val;\n });\n };\n}\n\nfunction toExtractor(extractor) {\n return isFunction(extractor) ? extractor : function (e) {\n return e[extractor];\n };\n}\n\nfunction toMatcher(matcher) {\n return isFunction(matcher) ? matcher : function (e) {\n return e === matcher;\n };\n}\n\nfunction identity(arg) {\n return arg;\n}\n\nfunction toNum(arg) {\n return Number(arg);\n}\n\n/**\n * Debounce fn, calling it only once if the given time\n * elapsed between calls.\n *\n * Lodash-style the function exposes methods to `#clear`\n * and `#flush` to control internal behavior.\n *\n * @param {Function} fn\n * @param {Number} timeout\n *\n * @return {Function} debounced function\n */\nfunction debounce(fn, timeout) {\n var timer;\n var lastArgs;\n var lastThis;\n var lastNow;\n\n function fire(force) {\n var now = Date.now();\n var scheduledDiff = force ? 0 : lastNow + timeout - now;\n\n if (scheduledDiff > 0) {\n return schedule(scheduledDiff);\n }\n\n fn.apply(lastThis, lastArgs);\n clear();\n }\n\n function schedule(timeout) {\n timer = setTimeout(fire, timeout);\n }\n\n function clear() {\n if (timer) {\n clearTimeout(timer);\n }\n\n timer = lastNow = lastArgs = lastThis = undefined;\n }\n\n function flush() {\n if (timer) {\n fire(true);\n }\n\n clear();\n }\n\n function callback() {\n lastNow = Date.now();\n\n for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {\n args[_key] = arguments[_key];\n }\n\n lastArgs = args;\n lastThis = this; // ensure an execution is scheduled\n\n if (!timer) {\n schedule(timeout);\n }\n }\n\n callback.flush = flush;\n callback.cancel = clear;\n return callback;\n}\n/**\n * Throttle fn, calling at most once\n * in the given interval.\n *\n * @param {Function} fn\n * @param {Number} interval\n *\n * @return {Function} throttled function\n */\n\nfunction throttle(fn, interval) {\n var throttling = false;\n return function () {\n if (throttling) {\n return;\n }\n\n fn.apply(void 0, arguments);\n throttling = true;\n setTimeout(function () {\n throttling = false;\n }, interval);\n };\n}\n/**\n * Bind function against target <this>.\n *\n * @param {Function} fn\n * @param {Object} target\n *\n * @return {Function} bound function\n */\n\nfunction bind(fn, target) {\n return fn.bind(target);\n}\n\nfunction _extends() {\n _extends = Object.assign || function (target) {\n for (var i = 1; i < arguments.length; i++) {\n var source = arguments[i];\n\n for (var key in source) {\n if (Object.prototype.hasOwnProperty.call(source, key)) {\n target[key] = source[key];\n }\n }\n }\n\n return target;\n };\n\n return _extends.apply(this, arguments);\n}\n\n/**\n * Convenience wrapper for `Object.assign`.\n *\n * @param {Object} target\n * @param {...Object} others\n *\n * @return {Object} the target\n */\n\nfunction assign(target) {\n for (var _len = arguments.length, others = new Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) {\n others[_key - 1] = arguments[_key];\n }\n\n return _extends.apply(void 0, [target].concat(others));\n}\n/**\n * Sets a nested property of a given object to the specified value.\n *\n * This mutates the object and returns it.\n *\n * @param {Object} target The target of the set operation.\n * @param {(string|number)[]} path The path to the nested value.\n * @param {any} value The value to set.\n */\n\nfunction set(target, path, value) {\n var currentTarget = target;\n forEach(path, function (key, idx) {\n if (key === '__proto__') {\n throw new Error('illegal key: __proto__');\n }\n\n var nextKey = path[idx + 1];\n var nextTarget = currentTarget[key];\n\n if (isDefined(nextKey) && isNil(nextTarget)) {\n nextTarget = currentTarget[key] = isNaN(+nextKey) ? {} : [];\n }\n\n if (isUndefined(nextKey)) {\n if (isUndefined(value)) {\n delete currentTarget[key];\n } else {\n currentTarget[key] = value;\n }\n } else {\n currentTarget = nextTarget;\n }\n });\n return target;\n}\n/**\n * Gets a nested property of a given object.\n *\n * @param {Object} target The target of the get operation.\n * @param {(string|number)[]} path The path to the nested value.\n * @param {any} [defaultValue] The value to return if no value exists.\n */\n\nfunction get(target, path, defaultValue) {\n var currentTarget = target;\n forEach(path, function (key) {\n // accessing nil property yields <undefined>\n if (isNil(currentTarget)) {\n currentTarget = undefined;\n return false;\n }\n\n currentTarget = currentTarget[key];\n });\n return isUndefined(currentTarget) ? defaultValue : currentTarget;\n}\n/**\n * Pick given properties from the target object.\n *\n * @param {Object} target\n * @param {Array} properties\n *\n * @return {Object} target\n */\n\nfunction pick(target, properties) {\n var result = {};\n var obj = Object(target);\n forEach(properties, function (prop) {\n if (prop in obj) {\n result[prop] = target[prop];\n }\n });\n return result;\n}\n/**\n * Pick all target properties, excluding the given ones.\n *\n * @param {Object} target\n * @param {Array} properties\n *\n * @return {Object} target\n */\n\nfunction omit(target, properties) {\n var result = {};\n var obj = Object(target);\n forEach(obj, function (prop, key) {\n if (properties.indexOf(key) === -1) {\n result[key] = prop;\n }\n });\n return result;\n}\n/**\n * Recursively merge `...sources` into given target.\n *\n * Does support merging objects; does not support merging arrays.\n *\n * @param {Object} target\n * @param {...Object} sources\n *\n * @return {Object} the target\n */\n\nfunction merge(target) {\n for (var _len2 = arguments.length, sources = new Array(_len2 > 1 ? _len2 - 1 : 0), _key2 = 1; _key2 < _len2; _key2++) {\n sources[_key2 - 1] = arguments[_key2];\n }\n\n if (!sources.length) {\n return target;\n }\n\n forEach(sources, function (source) {\n // skip non-obj sources, i.e. null\n if (!source || !isObject(source)) {\n return;\n }\n\n forEach(source, function (sourceVal, key) {\n if (key === '__proto__') {\n return;\n }\n\n var targetVal = target[key];\n\n if (isObject(sourceVal)) {\n if (!isObject(targetVal)) {\n // override target[key] with object\n targetVal = {};\n }\n\n target[key] = merge(targetVal, sourceVal);\n } else {\n target[key] = sourceVal;\n }\n });\n });\n return target;\n}\n\nexport { assign, bind, debounce, ensureArray, every, filter, find, findIndex, flatten, forEach, get, groupBy, has, isArray, isDefined, isFunction, isNil, isNumber, isObject, isString, isUndefined, keys, map, matchPattern, merge, omit, pick, reduce, set, size, some, sortBy, throttle, unionBy, uniqueBy, values, without };\n","function noop() { }\nconst identity = x => x;\nfunction assign(tar, src) {\n // @ts-ignore\n for (const k in src)\n tar[k] = src[k];\n return tar;\n}\nfunction is_promise(value) {\n return value && typeof value === 'object' && typeof value.then === 'function';\n}\nfunction add_location(element, file, line, column, char) {\n element.__svelte_meta = {\n loc: { file, line, column, char }\n };\n}\nfunction run(fn) {\n return fn();\n}\nfunction blank_object() {\n return Object.create(null);\n}\nfunction run_all(fns) {\n fns.forEach(run);\n}\nfunction is_function(thing) {\n return typeof thing === 'function';\n}\nfunction safe_not_equal(a, b) {\n return a != a ? b == b : a !== b || ((a && typeof a === 'object') || typeof a === 'function');\n}\nlet src_url_equal_anchor;\nfunction src_url_equal(element_src, url) {\n if (!src_url_equal_anchor) {\n src_url_equal_anchor = document.createElement('a');\n }\n src_url_equal_anchor.href = url;\n return element_src === src_url_equal_anchor.href;\n}\nfunction not_equal(a, b) {\n return a != a ? b == b : a !== b;\n}\nfunction is_empty(obj) {\n return Object.keys(obj).length === 0;\n}\nfunction validate_store(store, name) {\n if (store != null && typeof store.subscribe !== 'function') {\n throw new Error(`'${name}' is not a store with a 'subscribe' method`);\n }\n}\nfunction subscribe(store, ...callbacks) {\n if (store == null) {\n return noop;\n }\n const unsub = store.subscribe(...callbacks);\n return unsub.unsubscribe ? () => unsub.unsubscribe() : unsub;\n}\nfunction get_store_value(store) {\n let value;\n subscribe(store, _ => value = _)();\n return value;\n}\nfunction component_subscribe(component, store, callback) {\n component.$$.on_destroy.push(subscribe(store, callback));\n}\nfunction create_slot(definition, ctx, $$scope, fn) {\n if (definition) {\n const slot_ctx = get_slot_context(definition, ctx, $$scope, fn);\n return definition[0](slot_ctx);\n }\n}\nfunction get_slot_context(definition, ctx, $$scope, fn) {\n return definition[1] && fn\n ? assign($$scope.ctx.slice(), definition[1](fn(ctx)))\n : $$scope.ctx;\n}\nfunction get_slot_changes(definition, $$scope, dirty, fn) {\n if (definition[2] && fn) {\n const lets = definition[2](fn(dirty));\n if ($$scope.dirty === undefined) {\n return lets;\n }\n if (typeof lets === 'object') {\n const merged = [];\n const len = Math.max($$scope.dirty.length, lets.length);\n for (let i = 0; i < len; i += 1) {\n merged[i] = $$scope.dirty[i] | lets[i];\n }\n return merged;\n }\n return $$scope.dirty | lets;\n }\n return $$scope.dirty;\n}\nfunction update_slot_base(slot, slot_definition, ctx, $$scope, slot_changes, get_slot_context_fn) {\n if (slot_changes) {\n const slot_context = get_slot_context(slot_definition, ctx, $$scope, get_slot_context_fn);\n slot.p(slot_context, slot_changes);\n }\n}\nfunction update_slot(slot, slot_definition, ctx, $$scope, dirty, get_slot_changes_fn, get_slot_context_fn) {\n const slot_changes = get_slot_changes(slot_definition, $$scope, dirty, get_slot_changes_fn);\n update_slot_base(slot, slot_definition, ctx, $$scope, slot_changes, get_slot_context_fn);\n}\nfunction get_all_dirty_from_scope($$scope) {\n if ($$scope.ctx.length > 32) {\n const dirty = [];\n const length = $$scope.ctx.length / 32;\n for (let i = 0; i < length; i++) {\n dirty[i] = -1;\n }\n return dirty;\n }\n return -1;\n}\nfunction exclude_internal_props(props) {\n const result = {};\n for (const k in props)\n if (k[0] !== '$')\n result[k] = props[k];\n return result;\n}\nfunction compute_rest_props(props, keys) {\n const rest = {};\n keys = new Set(keys);\n for (const k in props)\n if (!keys.has(k) && k[0] !== '$')\n rest[k] = props[k];\n return rest;\n}\nfunction compute_slots(slots) {\n const result = {};\n for (const key in slots) {\n result[key] = true;\n }\n return result;\n}\nfunction once(fn) {\n let ran = false;\n return function (...args) {\n if (ran)\n return;\n ran = true;\n fn.call(this, ...args);\n };\n}\nfunction null_to_empty(value) {\n return value == null ? '' : value;\n}\nfunction set_store_value(store, ret, value) {\n store.set(value);\n return ret;\n}\nconst has_prop = (obj, prop) => Object.prototype.hasOwnProperty.call(obj, prop);\nfunction action_destroyer(action_result) {\n return action_result && is_function(action_result.destroy) ? action_result.destroy : noop;\n}\n\nconst is_client = typeof window !== 'undefined';\nlet now = is_client\n ? () => window.performance.now()\n : () => Date.now();\nlet raf = is_client ? cb => requestAnimationFrame(cb) : noop;\n// used internally for testing\nfunction set_now(fn) {\n now = fn;\n}\nfunction set_raf(fn) {\n raf = fn;\n}\n\nconst tasks = new Set();\nfunction run_tasks(now) {\n tasks.forEach(task => {\n if (!task.c(now)) {\n tasks.delete(task);\n task.f();\n }\n });\n if (tasks.size !== 0)\n raf(run_tasks);\n}\n/**\n * For testing purposes only!\n */\nfunction clear_loops() {\n tasks.clear();\n}\n/**\n * Creates a new task that runs on each raf frame\n * until it returns a falsy value or is aborted\n */\nfunction loop(callback) {\n let task;\n if (tasks.size === 0)\n raf(run_tasks);\n return {\n promise: new Promise(fulfill => {\n tasks.add(task = { c: callback, f: fulfill });\n }),\n abort() {\n tasks.delete(task);\n }\n };\n}\n\n// Track which nodes are claimed during hydration. Unclaimed nodes can then be removed from the DOM\n// at the end of hydration without touching the remaining nodes.\nlet is_hydrating = false;\nfunction start_hydrating() {\n is_hydrating = true;\n}\nfunction end_hydrating() {\n is_hydrating = false;\n}\nfunction upper_bound(low, high, key, value) {\n // Return first index of value larger than input value in the range [low, high)\n while (low < high) {\n const mid = low + ((high - low) >> 1);\n if (key(mid) <= value) {\n low = mid + 1;\n }\n else {\n high = mid;\n }\n }\n return low;\n}\nfunction init_hydrate(target) {\n if (target.hydrate_init)\n return;\n target.hydrate_init = true;\n // We know that all children have claim_order values since the unclaimed have been detached if target is not <head>\n let children = target.childNodes;\n // If target is <head>, there may be children without claim_order\n if (target.nodeName === 'HEAD') {\n const myChildren = [];\n for (let i = 0; i < children.length; i++) {\n const node = children[i];\n if (node.claim_order !== undefined) {\n myChildren.push(node);\n }\n }\n children = myChildren;\n }\n /*\n * Reorder claimed children optimally.\n * We can reorder claimed children optimally by finding the longest subsequence of\n * nodes that are already claimed in order and only moving the rest. The longest\n * subsequence subsequence of nodes that are claimed in order can be found by\n * computing the longest increasing subsequence of .claim_order values.\n *\n * This algorithm is optimal in generating the least amount of reorder operations\n * possible.\n *\n * Proof:\n * We know that, given a set of reordering operations, the nodes that do not move\n * always form an increasing subsequence, since they do not move among each other\n * meaning that they must be already ordered among each other. Thus, the maximal\n * set of nodes that do not move form a longest increasing subsequence.\n */\n // Compute longest increasing subsequence\n // m: subsequence length j => index k of smallest value that ends an increasing subsequence of length j\n const m = new Int32Array(children.length + 1);\n // Predecessor indices + 1\n const p = new Int32Array(children.length);\n m[0] = -1;\n let longest = 0;\n for (let i = 0; i < children.length; i++) {\n const current = children[i].claim_order;\n // Find the largest subsequence length such that it ends in a value less than our current value\n // upper_bound returns first greater value, so we subtract one\n // with fast path for when we are on the current longest subsequence\n const seqLen = ((longest > 0 && children[m[longest]].claim_order <= current) ? longest + 1 : upper_bound(1, longest, idx => children[m[idx]].claim_order, current)) - 1;\n p[i] = m[seqLen] + 1;\n const newLen = seqLen + 1;\n // We can guarantee that current is the smallest value. Otherwise, we would have generated a longer sequence.\n m[newLen] = i;\n longest = Math.max(newLen, longest);\n }\n // The longest increasing subsequence of nodes (initially reversed)\n const lis = [];\n // The rest of the nodes, nodes that will be moved\n const toMove = [];\n let last = children.length - 1;\n for (let cur = m[longest] + 1; cur != 0; cur = p[cur - 1]) {\n lis.push(children[cur - 1]);\n for (; last >= cur; last--) {\n toMove.push(children[last]);\n }\n last--;\n }\n for (; last >= 0; last--) {\n toMove.push(children[last]);\n }\n lis.reverse();\n // We sort the nodes being moved to guarantee that their insertion order matches the claim order\n toMove.sort((a, b) => a.claim_order - b.claim_order);\n // Finally, we move the nodes\n for (let i = 0, j = 0; i < toMove.length; i++) {\n while (j < lis.length && toMove[i].claim_order >= lis[j].claim_order) {\n j++;\n }\n const anchor = j < lis.length ? lis[j] : null;\n target.insertBefore(toMove[i], anchor);\n }\n}\nfunction append(target, node) {\n target.appendChild(node);\n}\nfunction append_styles(target, style_sheet_id, styles) {\n const append_styles_to = get_root_for_style(target);\n if (!append_styles_to.getElementById(style_sheet_id)) {\n const style = element('style');\n style.id = style_sheet_id;\n style.textContent = styles;\n append_stylesheet(append_styles_to, style);\n }\n}\nfunction get_root_for_style(node) {\n if (!node)\n return document;\n const root = node.getRootNode ? node.getRootNode() : node.ownerDocument;\n if (root && root.host) {\n return root;\n }\n return node.ownerDocument;\n}\nfunction append_empty_stylesheet(node) {\n const style_element = element('style');\n append_stylesheet(get_root_for_style(node), style_element);\n return style_element;\n}\nfunction append_stylesheet(node, style) {\n append(node.head || node, style);\n}\nfunction append_hydration(target, node) {\n if (is_hydrating) {\n init_hydrate(target);\n if ((target.actual_end_child === undefined) || ((target.actual_end_child !== null) && (target.actual_end_child.parentElement !== target))) {\n target.actual_end_child = target.firstChild;\n }\n // Skip nodes of undefined ordering\n while ((target.actual_end_child !== null) && (target.actual_end_child.claim_order === undefined)) {\n target.actual_end_child = target.actual_end_child.nextSibling;\n }\n if (node !== target.actual_end_child) {\n // We only insert if the ordering of this node should be modified or the parent node is not target\n if (node.claim_order !== undefined || node.parentNode !== target) {\n target.insertBefore(node, target.actual_end_child);\n }\n }\n else {\n target.actual_end_child = node.nextSibling;\n }\n }\n else if (node.parentNode !== target || node.nextSibling !== null) {\n target.appendChild(node);\n }\n}\nfunction insert(target, node, anchor) {\n target.insertBefore(node, anchor || null);\n}\nfunction insert_hydration(target, node, anchor) {\n if (is_hydrating && !anchor) {\n append_hydration(target, node);\n }\n else if (node.parentNode !== target || node.nextSibling != anchor) {\n target.insertBefore(node, anchor || null);\n }\n}\nfunction detach(node) {\n node.parentNode.removeChild(node);\n}\nfunction destroy_each(iterations, detaching) {\n for (let i = 0; i < iterations.length; i += 1) {\n if (iterations[i])\n iterations[i].d(detaching);\n }\n}\nfunction element(name) {\n return document.createElement(name);\n}\nfunction element_is(name, is) {\n return document.createElement(name, { is });\n}\nfunction object_without_properties(obj, exclude) {\n const target = {};\n for (const k in obj) {\n if (has_prop(obj, k)\n // @ts-ignore\n && exclude.indexOf(k) === -1) {\n // @ts-ignore\n target[k] = obj[k];\n }\n }\n return target;\n}\nfunction svg_element(name) {\n return document.createElementNS('http://www.w3.org/2000/svg', name);\n}\nfunction text(data) {\n return document.createTextNode(data);\n}\nfunction space() {\n return text(' ');\n}\nfunction empty() {\n return text('');\n}\nfunction listen(node, event, handler, options) {\n node.addEventListener(event, handler, options);\n return () => node.removeEventListener(event, handler, options);\n}\nfunction prevent_default(fn) {\n return function (event) {\n event.preventDefault();\n // @ts-ignore\n return fn.call(this, event);\n };\n}\nfunction stop_propagation(fn) {\n return function (event) {\n event.stopPropagation();\n // @ts-ignore\n return fn.call(this, event);\n };\n}\nfunction self(fn) {\n return function (event) {\n // @ts-ignore\n if (event.target === this)\n fn.call(this, event);\n };\n}\nfunction trusted(fn) {\n return function (event) {\n // @ts-ignore\n if (event.isTrusted)\n fn.call(this, event);\n };\n}\nfunction attr(node, attribute, value) {\n if (value == null)\n node.removeAttribute(attribute);\n else if (node.getAttribute(attribute) !== value)\n node.setAttribute(attribute, value);\n}\nfunction set_attributes(node, attributes) {\n // @ts-ignore\n const descriptors = Object.getOwnPropertyDescriptors(node.__proto__);\n for (const key in attributes) {\n if (attributes[key] == null) {\n node.removeAttribute(key);\n }\n else if (key === 'style') {\n node.style.cssText = attributes[key];\n }\n else if (key === '__value') {\n node.value = node[key] = attributes[key];\n }\n else if (descriptors[key] && descriptors[key].set) {\n node[key] = attributes[key];\n }\n else {\n attr(node, key, attributes[key]);\n }\n }\n}\nfunction set_svg_attributes(node, attributes) {\n for (const key in attributes) {\n attr(node, key, attributes[key]);\n }\n}\nfunction set_custom_element_data(node, prop, value) {\n if (prop in node) {\n node[prop] = typeof node[prop] === 'boolean' && value === '' ? true : value;\n }\n else {\n attr(node, prop, value);\n }\n}\nfunction xlink_attr(node, attribute, value) {\n node.setAttributeNS('http://www.w3.org/1999/xlink', attribute, value);\n}\nfunction get_binding_group_value(group, __value, checked) {\n const value = new Set();\n for (let i = 0; i < group.length; i += 1) {\n if (group[i].checked)\n value.add(group[i].__value);\n }\n if (!checked) {\n value.delete(__value);\n }\n return Array.from(value);\n}\nfunction to_number(value) {\n return value === '' ? null : +value;\n}\nfunction time_ranges_to_array(ranges) {\n const array = [];\n for (let i = 0; i < ranges.length; i += 1) {\n array.push({ start: ranges.start(i), end: ranges.end(i) });\n }\n return array;\n}\nfunction children(element) {\n return Array.from(element.childNodes);\n}\nfunction init_claim_info(nodes) {\n if (nodes.claim_info === undefined) {\n nodes.claim_info = { last_index: 0, total_claimed: 0 };\n }\n}\nfunction claim_node(nodes, predicate, processNode, createNode, dontUpdateLastIndex = false) {\n // Try to find nodes in an order such that we lengthen the longest increasing subsequence\n init_claim_info(nodes);\n const resultNode = (() => {\n // We first try to find an element after the previous one\n for (let i = nodes.claim_info.last_index; i < nodes.length; i++) {\n const node = nodes[i];\n if (predicate(node)) {\n const replacement = processNode(node);\n if (replacement === undefined) {\n nodes.splice(i, 1);\n }\n else {\n nodes[i] = replacement;\n }\n if (!dontUpdateLastIndex) {\n nodes.claim_info.last_index = i;\n }\n return node;\n }\n }\n // Otherwise, we try to find one before\n // We iterate in reverse so that we don't go too far back\n for (let i = nodes.claim_info.last_index - 1; i >= 0; i--) {\n const node = nodes[i];\n if (predicate(node)) {\n const replacement = processNode(node);\n if (replacement === undefined) {\n nodes.splice(i, 1);\n }\n else {\n nodes[i] = replacement;\n }\n if (!dontUpdateLastIndex) {\n nodes.claim_info.last_index = i;\n }\n else if (replacement === undefined) {\n // Since we spliced before the last_index, we decrease it\n nodes.claim_info.last_index--;\n }\n return node;\n }\n }\n // If we can't find any matching node, we create a new one\n return createNode();\n })();\n resultNode.claim_order = nodes.claim_info.total_claimed;\n nodes.claim_info.total_claimed += 1;\n return resultNode;\n}\nfunction claim_element_base(nodes, name, attributes, create_element) {\n return claim_node(nodes, (node) => node.nodeName === name, (node) => {\n const remove = [];\n for (let j = 0; j < node.attributes.length; j++) {\n const attribute = node.attributes[j];\n if (!attributes[attribute.name]) {\n remove.push(attribute.name);\n }\n }\n remove.forEach(v => node.removeAttribute(v));\n return undefined;\n }, () => create_element(name));\n}\nfunction claim_element(nodes, name, attributes) {\n return claim_element_base(nodes, name, attributes, element);\n}\nfunction claim_svg_element(nodes, name, attributes) {\n return claim_element_base(nodes, name, attributes, svg_element);\n}\nfunction claim_text(nodes, data) {\n return claim_node(nodes, (node) => node.nodeType === 3, (node) => {\n const dataStr = '' + data;\n if (node.data.startsWith(dataStr)) {\n if (node.data.length !== dataStr.length) {\n return node.splitText(dataStr.length);\n }\n }\n else {\n node.data = dataStr;\n }\n }, () => text(data), true // Text nodes should not update last index since it is likely not worth it to eliminate an increasing subsequence of actual elements\n );\n}\nfunction claim_space(nodes) {\n return claim_text(nodes, ' ');\n}\nfunction find_comment(nodes, text, start) {\n for (let i = start; i < nodes.length; i += 1) {\n const node = nodes[i];\n if (node.nodeType === 8 /* comment node */ && node.textContent.trim() === text) {\n return i;\n }\n }\n return nodes.length;\n}\nfunction claim_html_tag(nodes) {\n // find html opening tag\n const start_index = find_comment(nodes, 'HTML_TAG_START', 0);\n const end_index = find_comment(nodes, 'HTML_TAG_END', start_index);\n if (start_index === end_index) {\n return new HtmlTagHydration();\n }\n init_claim_info(nodes);\n const html_tag_nodes = nodes.splice(start_index, end_index + 1);\n detach(html_tag_nodes[0]);\n detach(html_tag_nodes[html_tag_nodes.length - 1]);\n const claimed_nodes = html_tag_nodes.slice(1, html_tag_nodes.length - 1);\n for (const n of claimed_nodes) {\n n.claim_order = nodes.claim_info.total_claimed;\n nodes.claim_info.total_claimed += 1;\n }\n return new HtmlTagHydration(claimed_nodes);\n}\nfunction set_data(text, data) {\n data = '' + data;\n if (text.wholeText !== data)\n text.data = data;\n}\nfunction set_input_value(input, value) {\n input.value = value == null ? '' : value;\n}\nfunction set_input_type(input, type) {\n try {\n input.type = type;\n }\n catch (e) {\n // do nothing\n }\n}\nfunction set_style(node, key, value, important) {\n node.style.setProperty(key, value, important ? 'important' : '');\n}\nfunction select_option(select, value) {\n for (let i = 0; i < select.options.length; i += 1) {\n const option = select.options[i];\n if (option.__value === value) {\n option.selected = true;\n return;\n }\n }\n select.selectedIndex = -1; // no option should be selected\n}\nfunction select_options(select, value) {\n for (let i = 0; i < select.options.length; i += 1) {\n const option = select.options[i];\n option.selected = ~value.indexOf(option.__value);\n }\n}\nfunction select_value(select) {\n const selected_option = select.querySelector(':checked') || select.options[0];\n return selected_option && selected_option.__value;\n}\nfunction select_multiple_value(select) {\n return [].map.call(select.querySelectorAll(':checked'), option => option.__value);\n}\n// unfortunately this can't be a constant as that wouldn't be tree-shakeable\n// so we cache the result instead\nlet crossorigin;\nfunction is_crossorigin() {\n if (crossorigin === undefined) {\n crossorigin = false;\n try {\n if (typeof window !== 'undefined' && window.parent) {\n void window.parent.document;\n }\n }\n catch (error) {\n crossorigin = true;\n }\n }\n return crossorigin;\n}\nfunction add_resize_listener(node, fn) {\n const computed_style = getComputedStyle(node);\n if (computed_style.position === 'static') {\n node.style.position = 'relative';\n }\n const iframe = element('iframe');\n iframe.setAttribute('style', 'display: block; position: absolute; top: 0; left: 0; width: 100%; height: 100%; ' +\n 'overflow: hidden; border: 0; opacity: 0; pointer-events: none; z-index: -1;');\n iframe.setAttribute('aria-hidden', 'true');\n iframe.tabIndex = -1;\n const crossorigin = is_crossorigin();\n let unsubscribe;\n if (crossorigin) {\n iframe.src = \"data:text/html,<script>onresize=function(){parent.postMessage(0,'*')}</script>\";\n unsubscribe = listen(window, 'message', (event) => {\n if (event.source === iframe.contentWindow)\n fn();\n });\n }\n else {\n iframe.src = 'about:blank';\n iframe.onload = () => {\n unsubscribe = listen(iframe.contentWindow, 'resize', fn);\n };\n }\n append(node, iframe);\n return () => {\n if (crossorigin) {\n unsubscribe();\n }\n else if (unsubscribe && iframe.contentWindow) {\n unsubscribe();\n }\n detach(iframe);\n };\n}\nfunction toggle_class(element, name, toggle) {\n element.classList[toggle ? 'add' : 'remove'](name);\n}\nfunction custom_event(type, detail, bubbles = false) {\n const e = document.createEvent('CustomEvent');\n e.initCustomEvent(type, bubbles, false, detail);\n return e;\n}\nfunction query_selector_all(selector, parent = document.body) {\n return Array.from(parent.querySelectorAll(selector));\n}\nclass HtmlTag {\n constructor() {\n this.e = this.n = null;\n }\n c(html) {\n this.h(html);\n }\n m(html, target, anchor = null) {\n if (!this.e) {\n this.e = element(target.nodeName);\n this.t = target;\n this.c(html);\n }\n this.i(anchor);\n }\n h(html) {\n this.e.innerHTML = html;\n this.n = Array.from(this.e.childNodes);\n }\n i(anchor) {\n for (let i = 0; i < this.n.length; i += 1) {\n insert(this.t, this.n[i], anchor);\n }\n }\n p(html) {\n this.d();\n this.h(html);\n this.i(this.a);\n }\n d() {\n this.n.forEach(detach);\n }\n}\nclass HtmlTagHydration extends HtmlTag {\n constructor(claimed_nodes) {\n super();\n this.e = this.n = null;\n this.l = claimed_nodes;\n }\n c(html) {\n if (this.l) {\n this.n = this.l;\n }\n else {\n super.c(html);\n }\n }\n i(anchor) {\n for (let i = 0; i < this.n.length; i += 1) {\n insert_hydration(this.t, this.n[i], anchor);\n }\n }\n}\nfunction attribute_to_object(attributes) {\n const result = {};\n for (const attribute of attributes) {\n result[attribute.name] = attribute.value;\n }\n return result;\n}\nfunction get_custom_elements_slots(element) {\n const result = {};\n element.childNodes.forEach((node) => {\n result[node.slot || 'default'] = true;\n });\n return result;\n}\n\nconst active_docs = new Set();\nlet active = 0;\n// https://github.com/darkskyapp/string-hash/blob/master/index.js\nfunction hash(str) {\n let hash = 5381;\n let i = str.length;\n while (i--)\n hash = ((hash << 5) - hash) ^ str.charCodeAt(i);\n return hash >>> 0;\n}\nfunction create_rule(node, a, b, duration, delay, ease, fn, uid = 0) {\n const step = 16.666 / duration;\n let keyframes = '{\\n';\n for (let p = 0; p <= 1; p += step) {\n const t = a + (b - a) * ease(p);\n keyframes += p * 100 + `%{${fn(t, 1 - t)}}\\n`;\n }\n const rule = keyframes + `100% {${fn(b, 1 - b)}}\\n}`;\n const name = `__svelte_${hash(rule)}_${uid}`;\n const doc = get_root_for_style(node);\n active_docs.add(doc);\n const stylesheet = doc.__svelte_stylesheet || (doc.__svelte_stylesheet = append_empty_stylesheet(node).sheet);\n const current_rules = doc.__svelte_rules || (doc.__svelte_rules = {});\n if (!current_rules[name]) {\n current_rules[name] = true;\n stylesheet.insertRule(`@keyframes ${name} ${rule}`, stylesheet.cssRules.length);\n }\n const animation = node.style.animation || '';\n node.style.animation = `${animation ? `${animation}, ` : ''}${name} ${duration}ms linear ${delay}ms 1 both`;\n active += 1;\n return name;\n}\nfunction delete_rule(node, name) {\n const previous = (node.style.animation || '').split(', ');\n const next = previous.filter(name\n ? anim => anim.indexOf(name) < 0 // remove specific animation\n : anim => anim.indexOf('__svelte') === -1 // remove all Svelte animations\n );\n const deleted = previous.length - next.length;\n if (deleted) {\n node.style.animation = next.join(', ');\n active -= deleted;\n if (!active)\n clear_rules();\n }\n}\nfunction clear_rules() {\n raf(() => {\n if (active)\n return;\n active_docs.forEach(doc => {\n const stylesheet = doc.__svelte_stylesheet;\n let i = stylesheet.cssRules.length;\n while (i--)\n stylesheet.deleteRule(i);\n doc.__svelte_rules = {};\n });\n active_docs.clear();\n });\n}\n\nfunction create_animation(node, from, fn, params) {\n if (!from)\n return noop;\n const to = node.getBoundingClientRect();\n if (from.left === to.left && from.right === to.right && from.top === to.top && from.bottom === to.bottom)\n return noop;\n const { delay = 0, duration = 300, easing = identity, \n // @ts-ignore todo: should this be separated from destructuring? Or start/end added to public api and documentation?\n start: start_time = now() + delay, \n // @ts-ignore todo:\n end = start_time + duration, tick = noop, css } = fn(node, { from, to }, params);\n let running = true;\n let started = false;\n let name;\n function start() {\n if (css) {\n name = create_rule(node, 0, 1, duration, delay, easing, css);\n }\n if (!delay) {\n started = true;\n }\n }\n function stop() {\n if (css)\n delete_rule(node, name);\n running = false;\n }\n loop(now => {\n if (!started && now >= start_time) {\n started = true;\n }\n if (started && now >= end) {\n tick(1, 0);\n stop();\n }\n if (!running) {\n return false;\n }\n if (started) {\n const p = now - start_time;\n const t = 0 + 1 * easing(p / duration);\n tick(t, 1 - t);\n }\n return true;\n });\n start();\n tick(0, 1);\n return stop;\n}\nfunction fix_position(node) {\n const style = getComputedStyle(node);\n if (style.position !== 'absolute' && style.position !== 'fixed') {\n const { width, height } = style;\n const a = node.getBoundingClientRect();\n node.style.position = 'absolute';\n node.style.width = width;\n node.style.height = height;\n add_transform(node, a);\n }\n}\nfunction add_transform(node, a) {\n const b = node.getBoundingClientRect();\n if (a.left !== b.left || a.top !== b.top) {\n const style = getComputedStyle(node);\n const transform = style.transform === 'none' ? '' : style.transform;\n node.style.transform = `${transform} translate(${a.left - b.left}px, ${a.top - b.top}px)`;\n }\n}\n\nlet current_component;\nfunction set_current_component(component) {\n current_component = component;\n}\nfunction get_current_component() {\n if (!current_component)\n throw new Error('Function called outside component initialization');\n return current_component;\n}\nfunction beforeUpdate(fn) {\n get_current_component().$$.before_update.push(fn);\n}\nfunction onMount(fn) {\n get_current_component().$$.on_mount.push(fn);\n}\nfunction afterUpdate(fn) {\n get_current_component().$$.after_update.push(fn);\n}\nfunction onDestroy(fn) {\n get_current_component().$$.on_destroy.push(fn);\n}\nfunction createEventDispatcher() {\n const component = get_current_component();\n return (type, detail) => {\n const callbacks = component.$$.callbacks[type];\n if (callbacks) {\n // TODO are there situations where events could be dispatched\n // in a server (non-DOM) environment?\n const event = custom_event(type, detail);\n callbacks.slice().forEach(fn => {\n fn.call(component, event);\n });\n }\n };\n}\nfunction setContext(key, context) {\n get_current_component().$$.context.set(key, context);\n}\nfunction getContext(key) {\n return get_current_component().$$.context.get(key);\n}\nfunction getAllContexts() {\n return get_current_component().$$.context;\n}\nfunction hasContext(key) {\n return get_current_component().$$.context.has(key);\n}\n// TODO figure out if we still want to support\n// shorthand events, or if we want to implement\n// a real bubbling mechanism\nfunction bubble(component, event) {\n const callbacks = component.$$.callbacks[event.type];\n if (callbacks) {\n // @ts-ignore\n callbacks.slice().forEach(fn => fn.call(this, event));\n }\n}\n\nconst dirty_components = [];\nconst intros = { enabled: false };\nconst binding_callbacks = [];\nconst render_callbacks = [];\nconst flush_callbacks = [];\nconst resolved_promise = Promise.resolve();\nlet update_scheduled = false;\nfunction schedule_update() {\n if (!update_scheduled) {\n update_scheduled = true;\n resolved_promise.then(flush);\n }\n}\nfunction tick() {\n schedule_update();\n return resolved_promise;\n}\nfunction add_render_callback(fn) {\n render_callbacks.push(fn);\n}\nfunction add_flush_callback(fn) {\n flush_callbacks.push(fn);\n}\nlet flushing = false;\nconst seen_callbacks = new Set();\nfunction flush() {\n if (flushing)\n return;\n flushing = true;\n do {\n // first, call beforeUpdate functions\n // and update components\n for (let i = 0; i < dirty_components.length; i += 1) {\n const component = dirty_components[i];\n set_current_component(component);\n update(component.$$);\n }\n set_current_component(null);\n dirty_components.length = 0;\n while (binding_callbacks.length)\n binding_callbacks.pop()();\n // then, once components are updated, call\n // afterUpdate functions. This may cause\n // subsequent updates...\n for (let i = 0; i < render_callbacks.length; i += 1) {\n const callback = render_callbacks[i];\n if (!seen_callbacks.has(callback)) {\n // ...so guard against infinite loops\n seen_callbacks.add(callback);\n callback();\n }\n }\n render_callbacks.length = 0;\n } while (dirty_components.length);\n while (flush_callbacks.length) {\n flush_callbacks.pop()();\n }\n update_scheduled = false;\n flushing = false;\n seen_callbacks.clear();\n}\nfunction update($$) {\n if ($$.fragment !== null) {\n $$.update();\n run_all($$.before_update);\n const dirty = $$.dirty;\n $$.dirty = [-1];\n $$.fragment && $$.fragment.p($$.ctx, dirty);\n $$.after_update.forEach(add_render_callback);\n }\n}\n\nlet promise;\nfunction wait() {\n if (!promise) {\n promise = Promise.resolve();\n promise.then(() => {\n promise = null;\n });\n }\n return promise;\n}\nfunction dispatch(node, direction, kind) {\n node.dispatchEvent(custom_event(`${direction ? 'intro' : 'outro'}${kind}`));\n}\nconst outroing = new Set();\nlet outros;\nfunction group_outros() {\n outros = {\n r: 0,\n c: [],\n p: outros // parent group\n };\n}\nfunction check_outros() {\n if (!outros.r) {\n run_all(outros.c);\n }\n outros = outros.p;\n}\nfunction transition_in(block, local) {\n if (block && block.i) {\n outroing.delete(block);\n block.i(local);\n }\n}\nfunction transition_out(block, local, detach, callback) {\n if (block && block.o) {\n if (outroing.has(block))\n return;\n outroing.add(block);\n outros.c.push(() => {\n outroing.delete(block);\n if (callback) {\n if (detach)\n block.d(1);\n callback();\n }\n });\n block.o(local);\n }\n}\nconst null_transition = { duration: 0 };\nfunction create_in_transition(node, fn, params) {\n let config = fn(node, params);\n let running = false;\n let animation_name;\n let task;\n let uid = 0;\n function cleanup() {\n if (animation_name)\n delete_rule(node, animation_name);\n }\n function go() {\n const { delay = 0, duration = 300, easing = identity, tick = noop, css } = config || null_transition;\n if (css)\n animation_name = create_rule(node, 0, 1, duration, delay, easing, css, uid++);\n tick(0, 1);\n const start_time = now() + delay;\n const end_time = start_time + duration;\n if (task)\n task.abort();\n running = true;\n add_render_callback(() => dispatch(node, true, 'start'));\n task = loop(now => {\n if (running) {\n if (now >= end_time) {\n tick(1, 0);\n dispatch(node, true, 'end');\n cleanup();\n return running = false;\n }\n if (now >= start_time) {\n const t = easing((now - start_time) / duration);\n tick(t, 1 - t);\n }\n }\n return running;\n });\n }\n let started = false;\n return {\n start() {\n if (started)\n return;\n started = true;\n delete_rule(node);\n if (is_function(config)) {\n config = config();\n wait().then(go);\n }\n else {\n go();\n }\n },\n invalidate() {\n started = false;\n },\n end() {\n if (running) {\n cleanup();\n running = false;\n }\n }\n };\n}\nfunction create_out_transition(node, fn, params) {\n let config = fn(node, params);\n let running = true;\n let animation_name;\n const group = outros;\n group.r += 1;\n function go() {\n const { delay = 0, duration = 300, easing = identity, tick = noop, css } = config || null_transition;\n if (css)\n animation_name = create_rule(node, 1, 0, duration, delay, easing, css);\n const start_time = now() + delay;\n const end_time = start_time + duration;\n add_render_callback(() => dispatch(node, false, 'start'));\n loop(now => {\n if (running) {\n if (now >= end_time) {\n tick(0, 1);\n dispatch(node, false, 'end');\n if (!--group.r) {\n // this will result in `end()` being called,\n // so we don't need to clean up here\n run_all(group.c);\n }\n return false;\n }\n if (now >= start_time) {\n const t = easing((now - start_time) / duration);\n tick(1 - t, t);\n }\n }\n return running;\n });\n }\n if (is_function(config)) {\n wait().then(() => {\n // @ts-ignore\n config = config();\n go();\n });\n }\n else {\n go();\n }\n return {\n end(reset) {\n if (reset && config.tick) {\n config.tick(1, 0);\n }\n if (running) {\n if (animation_name)\n delete_rule(node, animation_name);\n running = false;\n }\n }\n };\n}\nfunction create_bidirectional_transition(node, fn, params, intro) {\n let config = fn(node, params);\n let t = intro ? 0 : 1;\n let running_program = null;\n let pending_program = null;\n let animation_name = null;\n function clear_animation() {\n if (animation_name)\n delete_rule(node, animation_name);\n }\n function init(program, duration) {\n const d = (program.b - t);\n duration *= Math.abs(d);\n return {\n a: t,\n b: program.b,\n d,\n duration,\n start: program.start,\n end: program.start + duration,\n group: program.group\n };\n }\n function go(b) {\n const { delay = 0, duration = 300, easing = identity, tick = noop, css } = config || null_transition;\n const program = {\n start: now() + delay,\n b\n };\n if (!b) {\n // @ts-ignore todo: improve typings\n program.group = outros;\n outros.r += 1;\n }\n if (running_program || pending_program) {\n pending_program = program;\n }\n else {\n // if this is an intro, and there's a delay, we need to do\n // an initial tick and/or apply CSS animation immediately\n if (css) {\n clear_animation();\n animation_name = create_rule(node, t, b, duration, delay, easing, css);\n }\n if (b)\n tick(0, 1);\n running_program = init(program, duration);\n add_render_callback(() => dispatch(node, b, 'start'));\n loop(now => {\n if (pending_program && now > pending_program.start) {\n running_program = init(pending_program, duration);\n pending_program = null;\n dispatch(node, running_program.b, 'start');\n if (css) {\n clear_animation();\n animation_name = create_rule(node, t, running_program.b, running_program.duration, 0, easing, config.css);\n }\n }\n if (running_program) {\n if (now >= running_program.end) {\n tick(t = running_program.b, 1 - t);\n dispatch(node, running_program.b, 'end');\n if (!pending_program) {\n // we're done\n if (running_program.b) {\n // intro — we can tidy up immediately\n clear_animation();\n }\n else {\n // outro — needs to be coordinated\n if (!--running_program.group.r)\n run_all(running_program.group.c);\n }\n }\n running_program = null;\n }\n else if (now >= running_program.start) {\n const p = now - running_program.start;\n t = running_program.a + running_program.d * easing(p / running_program.duration);\n tick(t, 1 - t);\n }\n }\n return !!(running_program || pending_program);\n });\n }\n }\n return {\n run(b) {\n if (is_function(config)) {\n wait().then(() => {\n // @ts-ignore\n config = config();\n go(b);\n });\n }\n else {\n go(b);\n }\n },\n end() {\n clear_animation();\n running_program = pending_program = null;\n }\n };\n}\n\nfunction handle_promise(promise, info) {\n const token = info.token = {};\n function update(type, index, key, value) {\n if (info.token !== token)\n return;\n info.resolved = value;\n let child_ctx = info.ctx;\n if (key !== undefined) {\n child_ctx = child_ctx.slice();\n child_ctx[key] = value;\n }\n const block = type && (info.current = type)(child_ctx);\n let needs_flush = false;\n if (info.block) {\n if (info.blocks) {\n info.blocks.forEach((block, i) => {\n if (i !== index && block) {\n group_outros();\n transition_out(block, 1, 1, () => {\n if (info.blocks[i] === block) {\n info.blocks[i] = null;\n }\n });\n check_outros();\n }\n });\n }\n else {\n info.block.d(1);\n }\n block.c();\n transition_in(block, 1);\n block.m(info.mount(), info.anchor);\n needs_flush = true;\n }\n info.block = block;\n if (info.blocks)\n info.blocks[index] = block;\n if (needs_flush) {\n flush();\n }\n }\n if (is_promise(promise)) {\n const current_component = get_current_component();\n promise.then(value => {\n set_current_component(current_component);\n update(info.then, 1, info.value, value);\n set_current_component(null);\n }, error => {\n set_current_component(current_component);\n update(info.catch, 2, info.error, error);\n set_current_component(null);\n if (!info.hasCatch) {\n throw error;\n }\n });\n // if we previously had a then/catch block, destroy it\n if (info.current !== info.pending) {\n update(info.pending, 0);\n return true;\n }\n }\n else {\n if (info.current !== info.then) {\n update(info.then, 1, info.value, promise);\n return true;\n }\n info.resolved = promise;\n }\n}\nfunction update_await_block_branch(info, ctx, dirty) {\n const child_ctx = ctx.slice();\n const { resolved } = info;\n if (info.current === info.then) {\n child_ctx[info.value] = resolved;\n }\n if (info.current === info.catch) {\n child_ctx[info.error] = resolved;\n }\n info.block.p(child_ctx, dirty);\n}\n\nconst globals = (typeof window !== 'undefined'\n ? window\n : typeof globalThis !== 'undefined'\n ? globalThis\n : global);\n\nfunction destroy_block(block, lookup) {\n block.d(1);\n lookup.delete(block.key);\n}\nfunction outro_and_destroy_block(block, lookup) {\n transition_out(block, 1, 1, () => {\n lookup.delete(block.key);\n });\n}\nfunction fix_and_destroy_block(block, lookup) {\n block.f();\n destroy_block(block, lookup);\n}\nfunction fix_and_outro_and_destroy_block(block, lookup) {\n block.f();\n outro_and_destroy_block(block, lookup);\n}\nfunction update_keyed_each(old_blocks, dirty, get_key, dynamic, ctx, list, lookup, node, destroy, create_each_block, next, get_context) {\n let o = old_blocks.length;\n let n = list.length;\n let i = o;\n const old_indexes = {};\n while (i--)\n old_indexes[old_blocks[i].key] = i;\n const new_blocks = [];\n const new_lookup = new Map();\n const deltas = new Map();\n i = n;\n while (i--) {\n const child_ctx = get_context(ctx, list, i);\n const key = get_key(child_ctx);\n let block = lookup.get(key);\n if (!block) {\n block = create_each_block(key, child_ctx);\n block.c();\n }\n else if (dynamic) {\n block.p(child_ctx, dirty);\n }\n new_lookup.set(key, new_blocks[i] = block);\n if (key in old_indexes)\n deltas.set(key, Math.abs(i - old_indexes[key]));\n }\n const will_move = new Set();\n const did_move = new Set();\n function insert(block) {\n transition_in(block, 1);\n block.m(node, next);\n lookup.set(block.key, block);\n next = block.first;\n n--;\n }\n while (o && n) {\n const new_block = new_blocks[n - 1];\n const old_block = old_blocks[o - 1];\n const new_key = new_block.key;\n const old_key = old_block.key;\n if (new_block === old_block) {\n // do nothing\n next = new_block.first;\n o--;\n n--;\n }\n else if (!new_lookup.has(old_key)) {\n // remove old block\n destroy(old_block, lookup);\n o--;\n }\n else if (!lookup.has(new_key) || will_move.has(new_key)) {\n insert(new_block);\n }\n else if (did_move.has(old_key)) {\n o--;\n }\n else if (deltas.get(new_key) > deltas.get(old_key)) {\n did_move.add(new_key);\n insert(new_block);\n }\n else {\n will_move.add(old_key);\n o--;\n }\n }\n while (o--) {\n const old_block = old_blocks[o];\n if (!new_lookup.has(old_block.key))\n destroy(old_block, lookup);\n }\n while (n)\n insert(new_blocks[n - 1]);\n return new_blocks;\n}\nfunction validate_each_keys(ctx, list, get_context, get_key) {\n const keys = new Set();\n for (let i = 0; i < list.length; i++) {\n const key = get_key(get_context(ctx, list, i));\n if (keys.has(key)) {\n throw new Error('Cannot have duplicate keys in a keyed each');\n }\n keys.add(key);\n }\n}\n\nfunction get_spread_update(levels, updates) {\n const update = {};\n const to_null_out = {};\n const accounted_for = { $$scope: 1 };\n let i = levels.length;\n while (i--) {\n const o = levels[i];\n const n = updates[i];\n if (n) {\n for (const key in o) {\n if (!(key in n))\n to_null_out[key] = 1;\n }\n for (const key in n) {\n if (!accounted_for[key]) {\n update[key] = n[key];\n accounted_for[key] = 1;\n }\n }\n levels[i] = n;\n }\n else {\n for (const key in o) {\n accounted_for[key] = 1;\n }\n }\n }\n for (const key in to_null_out) {\n if (!(key in update))\n update[key] = undefined;\n }\n return update;\n}\nfunction get_spread_object(spread_props) {\n return typeof spread_props === 'object' && spread_props !== null ? spread_props : {};\n}\n\n// source: https://html.spec.whatwg.org/multipage/indices.html\nconst boolean_attributes = new Set([\n 'allowfullscreen',\n 'allowpaymentrequest',\n 'async',\n 'autofocus',\n 'autoplay',\n 'checked',\n 'controls',\n 'default',\n 'defer',\n 'disabled',\n 'formnovalidate',\n 'hidden',\n 'ismap',\n 'loop',\n 'multiple',\n 'muted',\n 'nomodule',\n 'novalidate',\n 'open',\n 'playsinline',\n 'readonly',\n 'required',\n 'reversed',\n 'selected'\n]);\n\nconst invalid_attribute_name_character = /[\\s'\">/=\\u{FDD0}-\\u{FDEF}\\u{FFFE}\\u{FFFF}\\u{1FFFE}\\u{1FFFF}\\u{2FFFE}\\u{2FFFF}\\u{3FFFE}\\u{3FFFF}\\u{4FFFE}\\u{4FFFF}\\u{5FFFE}\\u{5FFFF}\\u{6FFFE}\\u{6FFFF}\\u{7FFFE}\\u{7FFFF}\\u{8FFFE}\\u{8FFFF}\\u{9FFFE}\\u{9FFFF}\\u{AFFFE}\\u{AFFFF}\\u{BFFFE}\\u{BFFFF}\\u{CFFFE}\\u{CFFFF}\\u{DFFFE}\\u{DFFFF}\\u{EFFFE}\\u{EFFFF}\\u{FFFFE}\\u{FFFFF}\\u{10FFFE}\\u{10FFFF}]/u;\n// https://html.spec.whatwg.org/multipage/syntax.html#attributes-2\n// https://infra.spec.whatwg.org/#noncharacter\nfunction spread(args, classes_to_add) {\n const attributes = Object.assign({}, ...args);\n if (classes_to_add) {\n if (attributes.class == null) {\n attributes.class = classes_to_add;\n }\n else {\n attributes.class += ' ' + classes_to_add;\n }\n }\n let str = '';\n Object.keys(attributes).forEach(name => {\n if (invalid_attribute_name_character.test(name))\n return;\n const value = attributes[name];\n if (value === true)\n str += ' ' + name;\n else if (boolean_attributes.has(name.toLowerCase())) {\n if (value)\n str += ' ' + name;\n }\n else if (value != null) {\n str += ` ${name}=\"${value}\"`;\n }\n });\n return str;\n}\nconst escaped = {\n '\"': '"',\n \"'\": ''',\n '&': '&',\n '<': '<',\n '>': '>'\n};\nfunction escape(html) {\n return String(html).replace(/[\"'&<>]/g, match => escaped[match]);\n}\nfunction escape_attribute_value(value) {\n return typeof value === 'string' ? escape(value) : value;\n}\nfunction escape_object(obj) {\n const result = {};\n for (const key in obj) {\n result[key] = escape_attribute_value(obj[key]);\n }\n return result;\n}\nfunction each(items, fn) {\n let str = '';\n for (let i = 0; i < items.length; i += 1) {\n str += fn(items[i], i);\n }\n return str;\n}\nconst missing_component = {\n $$render: () => ''\n};\nfunction validate_component(component, name) {\n if (!component || !component.$$render) {\n if (name === 'svelte:component')\n name += ' this={...}';\n throw new Error(`<${name}> is not a valid SSR component. You may need to review your build config to ensure that dependencies are compiled, rather than imported as pre-compiled modules`);\n }\n return component;\n}\nfunction debug(file, line, column, values) {\n console.log(`{@debug} ${file ? file + ' ' : ''}(${line}:${column})`); // eslint-disable-line no-console\n console.log(values); // eslint-disable-line no-console\n return '';\n}\nlet on_destroy;\nfunction create_ssr_component(fn) {\n function $$render(result, props, bindings, slots, context) {\n const parent_component = current_component;\n const $$ = {\n on_destroy,\n context: new Map(context || (parent_component ? parent_component.$$.context : [])),\n // these will be immediately discarded\n on_mount: [],\n before_update: [],\n after_update: [],\n callbacks: blank_object()\n };\n set_current_component({ $$ });\n const html = fn(result, props, bindings, slots);\n set_current_component(parent_component);\n return html;\n }\n return {\n render: (props = {}, { $$slots = {}, context = new Map() } = {}) => {\n on_destroy = [];\n const result = { title: '', head: '', css: new Set() };\n const html = $$render(result, props, {}, $$slots, context);\n run_all(on_destroy);\n return {\n html,\n css: {\n code: Array.from(result.css).map(css => css.code).join('\\n'),\n map: null // TODO\n },\n head: result.title + result.head\n };\n },\n $$render\n };\n}\nfunction add_attribute(name, value, boolean) {\n if (value == null || (boolean && !value))\n return '';\n return ` ${name}${value === true ? '' : `=${typeof value === 'string' ? JSON.stringify(escape(value)) : `\"${value}\"`}`}`;\n}\nfunction add_classes(classes) {\n return classes ? ` class=\"${classes}\"` : '';\n}\n\nfunction bind(component, name, callback) {\n const index = component.$$.props[name];\n if (index !== undefined) {\n component.$$.bound[index] = callback;\n callback(component.$$.ctx[index]);\n }\n}\nfunction create_component(block) {\n block && block.c();\n}\nfunction claim_component(block, parent_nodes) {\n block && block.l(parent_nodes);\n}\nfunction mount_component(component, target, anchor, customElement) {\n const { fragment, on_mount, on_destroy, after_update } = component.$$;\n fragment && fragment.m(target, anchor);\n if (!customElement) {\n // onMount happens before the initial afterUpdate\n add_render_callback(() => {\n const new_on_destroy = on_mount.map(run).filter(is_function);\n if (on_destroy) {\n on_destroy.push(...new_on_destroy);\n }\n else {\n // Edge case - component was destroyed immediately,\n // most likely as a result of a binding initialising\n run_all(new_on_destroy);\n }\n component.$$.on_mount = [];\n });\n }\n after_update.forEach(add_render_callback);\n}\nfunction destroy_component(component, detaching) {\n const $$ = component.$$;\n if ($$.fragment !== null) {\n run_all($$.on_destroy);\n $$.fragment && $$.fragment.d(detaching);\n // TODO null out other refs, including component.$$ (but need to\n // preserve final state?)\n $$.on_destroy = $$.fragment = null;\n $$.ctx = [];\n }\n}\nfunction make_dirty(component, i) {\n if (component.$$.dirty[0] === -1) {\n dirty_components.push(component);\n schedule_update();\n component.$$.dirty.fill(0);\n }\n component.$$.dirty[(i / 31) | 0] |= (1 << (i % 31));\n}\nfunction init(component, options, instance, create_fragment, not_equal, props, append_styles, dirty = [-1]) {\n const parent_component = current_component;\n set_current_component(component);\n const $$ = component.$$ = {\n fragment: null,\n ctx: null,\n // state\n props,\n update: noop,\n not_equal,\n bound: blank_object(),\n // lifecycle\n on_mount: [],\n on_destroy: [],\n on_disconnect: [],\n before_update: [],\n after_update: [],\n context: new Map(options.context || (parent_component ? parent_component.$$.context : [])),\n // everything else\n callbacks: blank_object(),\n dirty,\n skip_bound: false,\n root: options.target || parent_component.$$.root\n };\n append_styles && append_styles($$.root);\n let ready = false;\n $$.ctx = instance\n ? instance(component, options.props || {}, (i, ret, ...rest) => {\n const value = rest.length ? rest[0] : ret;\n if ($$.ctx && not_equal($$.ctx[i], $$.ctx[i] = value)) {\n if (!$$.skip_bound && $$.bound[i])\n $$.bound[i](value);\n if (ready)\n make_dirty(component, i);\n }\n return ret;\n })\n : [];\n $$.update();\n ready = true;\n run_all($$.before_update);\n // `false` as a special case of no DOM component\n $$.fragment = create_fragment ? create_fragment($$.ctx) : false;\n if (options.target) {\n if (options.hydrate) {\n start_hydrating();\n const nodes = children(options.target);\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n $$.fragment && $$.fragment.l(nodes);\n nodes.forEach(detach);\n }\n else {\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n $$.fragment && $$.fragment.c();\n }\n if (options.intro)\n transition_in(component.$$.fragment);\n mount_component(component, options.target, options.anchor, options.customElement);\n end_hydrating();\n flush();\n }\n set_current_component(parent_component);\n}\nlet SvelteElement;\nif (typeof HTMLElement === 'function') {\n SvelteElement = class extends HTMLElement {\n constructor() {\n super();\n this.attachShadow({ mode: 'open' });\n }\n connectedCallback() {\n const { on_mount } = this.$$;\n this.$$.on_disconnect = on_mount.map(run).filter(is_function);\n // @ts-ignore todo: improve typings\n for (const key in this.$$.slotted) {\n // @ts-ignore todo: improve typings\n this.appendChild(this.$$.slotted[key]);\n }\n }\n attributeChangedCallback(attr, _oldValue, newValue) {\n this[attr] = newValue;\n }\n disconnectedCallback() {\n run_all(this.$$.on_disconnect);\n }\n $destroy() {\n destroy_component(this, 1);\n this.$destroy = noop;\n }\n $on(type, callback) {\n // TODO should this delegate to addEventListener?\n const callbacks = (this.$$.callbacks[type] || (this.$$.callbacks[type] = []));\n callbacks.push(callback);\n return () => {\n const index = callbacks.indexOf(callback);\n if (index !== -1)\n callbacks.splice(index, 1);\n };\n }\n $set($$props) {\n if (this.$$set && !is_empty($$props)) {\n this.$$.skip_bound = true;\n this.$$set($$props);\n this.$$.skip_bound = false;\n }\n }\n };\n}\n/**\n * Base class for Svelte components. Used when dev=false.\n */\nclass SvelteComponent {\n $destroy() {\n destroy_component(this, 1);\n this.$destroy = noop;\n }\n $on(type, callback) {\n const callbacks = (this.$$.callbacks[type] || (this.$$.callbacks[type] = []));\n callbacks.push(callback);\n return () => {\n const index = callbacks.indexOf(callback);\n if (index !== -1)\n callbacks.splice(index, 1);\n };\n }\n $set($$props) {\n if (this.$$set && !is_empty($$props)) {\n this.$$.skip_bound = true;\n this.$$set($$props);\n this.$$.skip_bound = false;\n }\n }\n}\n\nfunction dispatch_dev(type, detail) {\n document.dispatchEvent(custom_event(type, Object.assign({ version: '3.44.0' }, detail), true));\n}\nfunction append_dev(target, node) {\n dispatch_dev('SvelteDOMInsert', { target, node });\n append(target, node);\n}\nfunction append_hydration_dev(target, node) {\n dispatch_dev('SvelteDOMInsert', { target, node });\n append_hydration(target, node);\n}\nfunction insert_dev(target, node, anchor) {\n dispatch_dev('SvelteDOMInsert', { target, node, anchor });\n insert(target, node, anchor);\n}\nfunction insert_hydration_dev(target, node, anchor) {\n dispatch_dev('SvelteDOMInsert', { target, node, anchor });\n insert_hydration(target, node, anchor);\n}\nfunction detach_dev(node) {\n dispatch_dev('SvelteDOMRemove', { node });\n detach(node);\n}\nfunction detach_between_dev(before, after) {\n while (before.nextSibling && before.nextSibling !== after) {\n detach_dev(before.nextSibling);\n }\n}\nfunction detach_before_dev(after) {\n while (after.previousSibling) {\n detach_dev(after.previousSibling);\n }\n}\nfunction detach_after_dev(before) {\n while (before.nextSibling) {\n detach_dev(before.nextSibling);\n }\n}\nfunction listen_dev(node, event, handler, options, has_prevent_default, has_stop_propagation) {\n const modifiers = options === true ? ['capture'] : options ? Array.from(Object.keys(options)) : [];\n if (has_prevent_default)\n modifiers.push('preventDefault');\n if (has_stop_propagation)\n modifiers.push('stopPropagation');\n dispatch_dev('SvelteDOMAddEventListener', { node, event, handler, modifiers });\n const dispose = listen(node, event, handler, options);\n return () => {\n dispatch_dev('SvelteDOMRemoveEventListener', { node, event, handler, modifiers });\n dispose();\n };\n}\nfunction attr_dev(node, attribute, value) {\n attr(node, attribute, value);\n if (value == null)\n dispatch_dev('SvelteDOMRemoveAttribute', { node, attribute });\n else\n dispatch_dev('SvelteDOMSetAttribute', { node, attribute, value });\n}\nfunction prop_dev(node, property, value) {\n node[property] = value;\n dispatch_dev('SvelteDOMSetProperty', { node, property, value });\n}\nfunction dataset_dev(node, property, value) {\n node.dataset[property] = value;\n dispatch_dev('SvelteDOMSetDataset', { node, property, value });\n}\nfunction set_data_dev(text, data) {\n data = '' + data;\n if (text.wholeText === data)\n return;\n dispatch_dev('SvelteDOMSetData', { node: text, data });\n text.data = data;\n}\nfunction validate_each_argument(arg) {\n if (typeof arg !== 'string' && !(arg && typeof arg === 'object' && 'length' in arg)) {\n let msg = '{#each} only iterates over array-like objects.';\n if (typeof Symbol === 'function' && arg && Symbol.iterator in arg) {\n msg += ' You can use a spread to convert this iterable into an array.';\n }\n throw new Error(msg);\n }\n}\nfunction validate_slots(name, slot, keys) {\n for (const slot_key of Object.keys(slot)) {\n if (!~keys.indexOf(slot_key)) {\n console.warn(`<${name}> received an unexpected slot \"${slot_key}\".`);\n }\n }\n}\n/**\n * Base class for Svelte components with some minor dev-enhancements. Used when dev=true.\n */\nclass SvelteComponentDev extends SvelteComponent {\n constructor(options) {\n if (!options || (!options.target && !options.$$inline)) {\n throw new Error(\"'target' is a required option\");\n }\n super();\n }\n $destroy() {\n super.$destroy();\n this.$destroy = () => {\n console.warn('Component was already destroyed'); // eslint-disable-line no-console\n };\n }\n $capture_state() { }\n $inject_state() { }\n}\n/**\n * Base class to create strongly typed Svelte components.\n * This only exists for typing purposes and should be used in `.d.ts` files.\n *\n * ### Example:\n *\n * You have component library on npm called `component-library`, from which\n * you export a component called `MyComponent`. For Svelte+TypeScript users,\n * you want to provide typings. Therefore you create a `index.d.ts`:\n * ```ts\n * import { SvelteComponentTyped } from \"svelte\";\n * export class MyComponent extends SvelteComponentTyped<{foo: string}> {}\n * ```\n * Typing this makes it possible for IDEs like VS Code with the Svelte extension\n * to provide intellisense and to use the component like this in a Svelte file\n * with TypeScript:\n * ```svelte\n * <script lang=\"ts\">\n * \timport { MyComponent } from \"component-library\";\n * </script>\n * <MyComponent foo={'bar'} />\n * ```\n *\n * #### Why not make this part of `SvelteComponent(Dev)`?\n * Because\n * ```ts\n * class ASubclassOfSvelteComponent extends SvelteComponent<{foo: string}> {}\n * const component: typeof SvelteComponent = ASubclassOfSvelteComponent;\n * ```\n * will throw a type error, so we need to separate the more strictly typed class.\n */\nclass SvelteComponentTyped extends SvelteComponentDev {\n constructor(options) {\n super(options);\n }\n}\nfunction loop_guard(timeout) {\n const start = Date.now();\n return () => {\n if (Date.now() - start > timeout) {\n throw new Error('Infinite loop detected');\n }\n };\n}\n\nexport { HtmlTag, HtmlTagHydration, SvelteComponent, SvelteComponentDev, SvelteComponentTyped, SvelteElement, action_destroyer, add_attribute, add_classes, add_flush_callback, add_location, add_render_callback, add_resize_listener, add_transform, afterUpdate, append, append_dev, append_empty_stylesheet, append_hydration, append_hydration_dev, append_styles, assign, attr, attr_dev, attribute_to_object, beforeUpdate, bind, binding_callbacks, blank_object, bubble, check_outros, children, claim_component, claim_element, claim_html_tag, claim_space, claim_svg_element, claim_text, clear_loops, component_subscribe, compute_rest_props, compute_slots, createEventDispatcher, create_animation, create_bidirectional_transition, create_component, create_in_transition, create_out_transition, create_slot, create_ssr_component, current_component, custom_event, dataset_dev, debug, destroy_block, destroy_component, destroy_each, detach, detach_after_dev, detach_before_dev, detach_between_dev, detach_dev, dirty_components, dispatch_dev, each, element, element_is, empty, end_hydrating, escape, escape_attribute_value, escape_object, escaped, exclude_internal_props, fix_and_destroy_block, fix_and_outro_and_destroy_block, fix_position, flush, getAllContexts, getContext, get_all_dirty_from_scope, get_binding_group_value, get_current_component, get_custom_elements_slots, get_root_for_style, get_slot_changes, get_spread_object, get_spread_update, get_store_value, globals, group_outros, handle_promise, hasContext, has_prop, identity, init, insert, insert_dev, insert_hydration, insert_hydration_dev, intros, invalid_attribute_name_character, is_client, is_crossorigin, is_empty, is_function, is_promise, listen, listen_dev, loop, loop_guard, missing_component, mount_component, noop, not_equal, now, null_to_empty, object_without_properties, onDestroy, onMount, once, outro_and_destroy_block, prevent_default, prop_dev, query_selector_all, raf, run, run_all, safe_not_equal, schedule_update, select_multiple_value, select_option, select_options, select_value, self, setContext, set_attributes, set_current_component, set_custom_element_data, set_data, set_data_dev, set_input_type, set_input_value, set_now, set_raf, set_store_value, set_style, set_svg_attributes, space, spread, src_url_equal, start_hydrating, stop_propagation, subscribe, svg_element, text, tick, time_ranges_to_array, to_number, toggle_class, transition_in, transition_out, trusted, update_await_block_branch, update_keyed_each, update_slot, update_slot_base, validate_component, validate_each_argument, validate_each_keys, validate_slots, validate_store, xlink_attr };\n","let uid = 0;\n\nexport default function Id() {\n return '_el_' + uid++;\n}","export class LocalStore {\n\n get(name, defaultValue) {\n\n try {\n const serializedValue = window.localStorage.getItem(name);\n\n if (serializedValue) {\n return JSON.parse(serializedValue);\n }\n } catch (error) {\n console.warn('LocalStore: Failed to retrieve %s', name, error);\n }\n\n return defaultValue;\n }\n\n set(name, value) {\n\n try {\n window.localStorage.setItem(name, JSON.stringify(value));\n } catch (error) {\n console.warn('LocalStore: Failed to set %s', name, error);\n }\n }\n\n}\n\nexport class FakeLocalStore {\n\n get(name, defaultValue) {\n return defaultValue;\n }\n\n set(name, value) { }\n\n}\n\n\nexport function createLocalStore() {\n\n if (typeof window === 'undefined' || typeof window.localStorage === 'undefined') {\n return new FakeLocalStore();\n }\n\n return new LocalStore();\n}","export class History {\n\n push(url) {\n window.history.pushState(null, null, url);\n }\n\n onPop(fn) {\n window.addEventListener('popstate', fn);\n\n return function() {\n window.removeEventListener('popstate', fn);\n };\n }\n\n}\n\nexport class FakeHistory {\n\n push(url) {}\n\n onPop(fn) {\n return function() {};\n }\n\n}\n\nexport function createHistory() {\n\n if (typeof window === 'undefined' || typeof window.history === 'undefined') {\n return new FakeHistory();\n }\n\n return new History();\n}","export { default as Id } from './Id';\n\nexport { default as autoresize } from './autoresize';\n\nexport {\n createLocalStore\n} from './local-store';\n\nexport {\n createHistory\n} from './history';\n\nexport function delay(fn, timeout) {\n setTimeout(fn, timeout);\n}\n\nexport function periodic(fn, interval) {\n\n let canceled = false;\n\n let timeout = interval;\n\n let i;\n\n function stop() {\n canceled = true;\n\n clearTimeout(i);\n }\n\n function run() {\n\n Promise.resolve({}).then(() => fn()).then(\n success => true,\n err => false\n ).then(success => {\n timeout = success === false ? timeout * 1.5 : interval;\n\n if (!canceled) {\n i = setTimeout(run, timeout);\n }\n });\n }\n\n run();\n\n return stop;\n}\n\nexport {\n isClosingLink,\n isClosedByLink\n} from './links';\n\nexport function isOpen(issue) {\n return issue.state === 'open';\n}\n\nexport function isMerged(issue) {\n return issue.merged;\n}\n\nexport function isOpenOrMerged(issue) {\n return isOpen(issue) || isMerged(issue);\n}\n\nexport function isPull(issue) {\n return issue.pull_request;\n}\n\nexport {\n debounce,\n throttle\n} from 'min-dash';\n\n\nexport function noDuplicates(keyFn) {\n\n const found = {};\n\n return function filter(element) {\n const key = keyFn(element);\n\n if (key in found) {\n return false;\n }\n\n found[key] = true;\n\n return true;\n };\n}","<script>\n export let className = '';\n\n export let hints;\n export let selectedHint;\n\n export let onHover;\n export let onBlur;\n export let onSelect;\n\n export let maxElements;\n</script>\n\n<style lang=\"scss\">\n\n @import \"variables\";\n\n ul {\n list-style: none;\n margin: 0;\n padding: 0;\n }\n\n li {\n padding: 0 .8rem;\n line-height: 2em;\n\n &.selectable {\n cursor: pointer;\n\n &:hover,\n &.active {\n background: scale-color($primary, $alpha: -90%);\n }\n }\n\n &.text {\n color: $gray-600;\n }\n }\n\n .matched {\n background: scale-color($primary, $alpha: -80%);\n color: darken($primary, 10%);\n }\n</style>\n\n<ul class={ className }>\n {#each hints as hint, idx}\n {#if idx < maxElements || (selectedHint && selectedHint.name === hint.name) }\n <li\n class:active={ selectedHint && selectedHint.name === hint.name }\n class=\"selectable\"\n on:mouseover={ () => onHover(hint) }\n on:mouseout={ () => onBlur(hint) }\n on:mousedown|preventDefault={ (event) => onSelect(hint) }\n >{#each hint.parts as part}<span class:matched={ part.matched }>{ part.text }</span>{/each}</li>\n {/if}\n {/each}\n\n {#if hints.length > maxElements}\n <li class=\"text\">...</li>\n {/if}\n</ul>","function hasModifier(event) {\n const {\n ctrlKey,\n shiftKey,\n altKey,\n metaKey\n } = event;\n\n return ctrlKey || altKey || shiftKey || metaKey;\n}\n\nfunction isGlobal(event) {\n return event.target === document.body;\n}\n\nexport function isFindShortcut(event) {\n\n if (!isGlobal(event) || hasModifier(event)) {\n return false;\n }\n\n return event.key === 'f';\n}\n\nexport function isNewIssueShortcut(event) {\n\n if (!isGlobal(event) || hasModifier(event)) {\n return false;\n }\n\n return event.key === 'n';\n}\n\nexport function isApplyFilterClick(event) {\n\n const {\n shiftKey,\n altKey\n } = event;\n\n return shiftKey || altKey;\n}\n\nexport function isAddFilterClick(event) {\n\n const {\n shiftKey\n } = event;\n\n return shiftKey;\n}","<style lang=\"scss\">\n\n @import \"variables\";\n\n @import \"./HelpDropdown\";\n\n .board-filter {\n &.expanded {\n width: 500px;\n max-width: 100%;\n }\n\n > input {\n width: 100%;\n }\n\n width: 300px;\n }\n\n .icon {\n color: $gray-300;\n }\n</style>\n\n\n<script>\n import { Id } from './util';\n\n import {\n HintList\n } from './components';\n\n import {\n isFindShortcut\n } from './shortcuts';\n\n import {\n debounce\n } from './util';\n\n export let className = '';\n export let value = '';\n export let placeholder;\n\n export let completionOptions = {};\n\n export let onChange;\n\n let temporalPresets = [\n [ 'today', Date.now() ],\n [ 'last week', Date.now() - 1000 * 60 * 60 * 24 * 7 ],\n [ 'last month', Date.now() - 1000 * 60 * 60 * 24 * 30 ]\n ].map(([ name, value ]) => {\n\n const date = new Date(value);\n\n return { name, value: `>=${date.getFullYear()}-${date.getMonth() + 1}-${date.getDate()} ` };\n });\n\n let staticValues = {\n is: [\n 'assigned',\n 'unassigned',\n 'epic',\n 'milestoned',\n 'open',\n 'closed',\n 'issue',\n 'pull'\n ].map(name => {\n return { name, value: `${name} ` };\n }),\n created: temporalPresets,\n updated: temporalPresets\n };\n\n $: dynamicValues = Object.entries(completionOptions).reduce((values, entry) => {\n\n const [ key, value ] = entry;\n\n values[key] = value.slice().sort().map(name => {\n\n const separator = /[: ]/.test(name) ? '\"' : '';\n\n return { name, value: `${separator}${name}${separator} ` };\n });\n\n return values;\n }, {});\n\n const qualifierCategories = [\n {\n name: 'Operators',\n options: [\n 'label',\n 'assignee',\n 'author',\n 'repo',\n 'reviewer',\n 'commented',\n 'milestone',\n 'created',\n 'updated',\n 'involves',\n 'is'\n ].map(name => {\n return {\n name,\n value: `${name}:`\n };\n })\n }\n ];\n\n let keyboardSelectedHint;\n let mouseSelectedHint;\n\n $: categoryValues = {\n ...staticValues,\n ...dynamicValues\n };\n\n $: selectedHint = mouseSelectedHint || keyboardSelectedHint;\n\n let input;\n\n let focussed = false;\n let match;\n let allHints;\n\n let position = 0;\n\n $: expanded = focussed || value;\n $: {\n console.time('BoardFilter#computeMatch');\n\n let opts = computeMatch(value, position, categoryValues);\n\n console.timeEnd('BoardFilter#computeMatch');\n\n match = opts.match;\n allHints = opts.allHints;\n\n keyboardSelectedHint = (\n allHints && keyboardSelectedHint && allHints.find(\n hint => hint.name === keyboardSelectedHint.name\n ) || opts.keyboardSelectedHint\n );\n }\n\n const searchId = Id();\n\n function computeMatch(value, searchEnd, categoryValues) {\n\n const beforeCursor = value.substring(0, searchEnd);\n\n const searchStart = beforeCursor.lastIndexOf(' ') + 1;\n\n value = value.substring(searchStart, searchEnd).toLowerCase();\n\n const match = /^([-!]?)(?:([\\w]+)(?:(:)(?:\"([\\w-]+)\"?|([\\w-]+))?)?)$/.exec(value);\n\n if (!match) {\n return {};\n }\n\n let [ _, negator, qualifier, sep, qualifierText, qualifierTextEscaped ] = match;\n\n const search = sep ? (qualifierText || qualifierTextEscaped || '') : qualifier;\n\n const allHints = [];\n\n const categories = sep ? [\n {\n name: 'Values',\n options: categoryValues[qualifier] || []\n }\n ] : qualifierCategories;\n\n const matchedCategories = categories.reduce((matchedCategories, category) => {\n\n const matchedValues = category.options.reduce((matchedValues, categoryOption) => {\n\n const {\n name,\n value\n } = categoryOption;\n\n if (name.toLowerCase().includes(search)) {\n\n const idx = name.indexOf(search);\n\n const hint = {\n name: name,\n parts: [\n {\n text: name.substring(0, idx)\n },\n {\n text: name.substring(idx, idx + search.length),\n matched: true\n },\n {\n text: name.substring(idx + search.length)\n }\n ],\n apply: (currentValue) => {\n\n const before = currentValue.substring(0, searchStart);\n const fix = (negator || '') + (sep ? qualifier + sep : '') + value;\n const after = currentValue.substring(searchEnd);\n\n return {\n val: `${before}${fix}${after}`,\n idx: before.length + fix.length\n };\n }\n };\n\n matchedValues.push(hint);\n allHints.push(hint);\n }\n\n return matchedValues;\n }, []);\n\n\n if (matchedValues.length) {\n matchedCategories.push({\n name: category.name,\n values: matchedValues\n });\n }\n\n return matchedCategories;\n }, []);\n\n if (matchedCategories.length) {\n\n return {\n match: { categories: matchedCategories },\n keyboardSelectedHint: matchedCategories[0].values[0],\n allHints\n };\n }\n\n return {\n match: null,\n keyboardSelectedHint: null,\n allHints: []\n };\n }\n\n function applyHint(hint) {\n\n const {\n val,\n idx\n } = hint.apply(value);\n\n input.value = value = val;\n input.selectionEnd = input.selectionStart = position = idx;\n\n triggerChanged(value);\n }\n\n function handleInput(event) {\n\n const target = event.target;\n\n value = target.value;\n position = target.selectionStart;\n\n triggerChanged(value);\n }\n\n function nextHint(currentHint, direction) {\n\n const hints = (allHints || []);\n\n const currentIndex = hints.findIndex(hint => hint.name === currentHint.name);\n\n let nextIndex = currentIndex + direction;\n\n if (nextIndex < 0) {\n nextIndex = hints.length - 1;\n }\n\n if (nextIndex === hints.length) {\n nextIndex = 0;\n }\n\n return hints[nextIndex];\n }\n\n function handleInputKey(event) {\n\n const key = event.key;\n\n if (key === 'Enter') {\n if (keyboardSelectedHint) {\n applyHint(keyboardSelectedHint);\n }\n\n event.preventDefault();\n }\n\n if (key === 'ArrowUp') {\n keyboardSelectedHint = nextHint(keyboardSelectedHint, -1);\n event.preventDefault();\n }\n\n if (key === 'ArrowDown') {\n keyboardSelectedHint = nextHint(keyboardSelectedHint, 1);\n event.preventDefault();\n }\n\n if (key === 'Escape' && !value) {\n input.blur();\n\n event.preventDefault();\n }\n }\n\n const triggerChanged = debounce((value) => {\n onChange && onChange(value);\n }, 500);\n\n function isInputTarget(event) {\n const {\n target\n } = event;\n\n return target === input;\n }\n\n function handleGlobalKey(event) {\n\n if (isFindShortcut(event)) {\n event.preventDefault();\n\n if (!isInputTarget(event)) {\n input.focus();\n }\n }\n }\n</script>\n\n<svelte:window on:keydown={ handleGlobalKey } />\n\n<div class=\"board-filter { className } dropdown-parent { expanded && 'expanded' }\">\n <input\n class=\"form-control\"\n type=\"search\"\n placeholder={ placeholder }\n id={searchId}\n autocomplete=\"off\"\n spellcheck=\"false\"\n aria-label={ placeholder }\n title={ placeholder + ' (f)'}\n bind:this={ input }\n bind:value={ value }\n on:input={ handleInput }\n on:keydown={ handleInputKey }\n on:focus={ () => focussed = true }\n on:blur={ () => focussed = false }\n />\n\n {#if value && match}\n <div class=\"help-dropdown\">\n {#each match.categories as category, idx}\n {#if idx > 0}\n <hr />\n {/if}\n\n <div class=\"category\">{ category.name }</div>\n\n <HintList\n hints={ category.values }\n selectedHint={ selectedHint }\n onHover={ hint => mouseSelectedHint = hint }\n onBlur={ () => mouseSelectedHint = null }\n onSelect={ applyHint }\n maxElements= { 7 }\n />\n\n {/each}\n </div>\n {:else if focussed && !value}\n <div class=\"help-dropdown\">\n <p class=\"note\">\n Filter cards by title and description.\n </p>\n\n <p class=\"note\">\n Refine your search with operators: <em>created</em>, <em>updated</em>, <em>milestone</em>, <em>repo</em>, <em>assignee</em>, <em>label</em> and <em>is</em>.\n </p>\n </div>\n {/if}\n</div>","<script>\n export let rounded = false;\n export let title = '';\n</script>\n\n<style lang=\"scss\">\n .avatar {\n position: relative;\n display: inline-block;\n overflow: hidden;\n color: #fff;\n white-space: nowrap;\n text-align: center;\n vertical-align: middle;\n background: #ccc;\n width: 32px;\n height: 32px;\n line-height: 32px;\n }\n\n .avatar-shadow {\n position: absolute;\n top: 0;\n left: 0;\n width: 100%;\n height: 100%;\n\n box-shadow: inset 0 0 2px 0 rgba(0,0,0,.1);\n }\n\n .avatar-rounded {\n border-radius: 50%;\n\n .avatar-shadow {\n border-radius: 50%;\n }\n }\n</style>\n\n<span class=\"avatar\" title={ title } class:avatar-rounded={ rounded }>\n <slot></slot>\n\n <div class=\"avatar-shadow\"></div>\n</span>","<style lang=\"scss\">\n .loader {\n\n position: absolute;\n left: 50%;\n top: 50%;\n transform: translate(-50%, -50%);\n text-align: center;\n z-index: 200;\n pointer-events: none;\n\n > .content {\n opacity: 0.3;\n transition: opacity 0.5s;\n }\n\n &.shown > .content {\n opacity: 1;\n\n animation: pulsate 1s infinite;\n animation-timing-function: ease-in-out;\n }\n\n &:not(.shown) > .content {\n opacity: 0;\n }\n }\n\n\n @keyframes pulsate {\n 0% {\n transform: scale(1);\n opacity: 1;\n }\n\n 50% {\n transform: scale(0.9);\n opacity: 0.8;\n }\n\n 100% {\n transform: scale(1);\n opacity: 1;\n }\n }\n</style>\n\n<script>\n export let className = '';\n export let shown = true;\n</script>\n\n<div class=\"loader { className }\" class:shown={ shown }>\n <div class=\"content\">\n <slot></slot>\n </div>\n</div>","<style lang=\"scss\">\n .powered-by {\n position: absolute;\n bottom: 10px;\n right: 10px;\n padding: 7px;\n border-radius: 4px;\n\n opacity: .5;\n transition: opacity .1s, background .1s;\n\n color: #333;\n\n z-index: 10;\n\n align-items: center;\n\n display: flex;\n\n svg {\n vertical-align: bottom;\n }\n\n &:not(:hover) .logo {\n color: #999;\n }\n\n &:hover {\n opacity: 1;\n box-shadow: 0 1px 3px rgba(0, 0, 0, 0.3);\n background: white;\n\n .help {\n display: block;\n }\n }\n\n .help {\n font-size: .9em;\n display: none;\n }\n\n .logo {\n margin-left: .5em;\n }\n\n .help-item {\n margin-left: .5em;\n }\n\n .help-item + .help-item {\n margin-left: 1em;\n }\n\n .help-item {\n display: inline-block;\n }\n }\n</style>\n\n<div class=\"powered-by\">\n <div class=\"help\">\n <a class=\"help-item\" href=\"https://wuffle.dev/docs\"\n target=\"_blank\" rel=\"noopener\">\n Documentation\n </a>\n\n <span class=\"help-item\">\n Powered by\n </span>\n </div>\n\n <a class=\"logo\" href=\"https://wuffle.dev\"\n target=\"_blank\" rel=\"noopener\">\n\n <!-- ./logo-gray.svg with dynamic fill color -->\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 80 80\" width=\"20\" height=\"20\"><path d=\"M12 0h56c7 0 12 5 12 12v56c0 7-5 12-12 12H12C5 80 0 75 0 68V12C0 5 5 0 12 0z\" fill=\"currentColor\"/><path d=\"M15 10h21c3 0 5 2 5 5v6c0 3-2 5-5 5H15c-2 0-4-2-4-5v-6c0-3 2-5 4-5zm0 20h21c3 0 5 2 5 5v6c0 2-2 4-5 4H15c-2 0-4-1-4-4v-6c0-3 2-5 4-5zm27 22h21c2 0 4 2 4 5v6c0 2-2 4-4 4H42c-2 0-4-2-4-4v-6c0-3 2-5 4-5z\" fill=\"#fff\"/></svg>\n </a>\n</div>","<style lang=\"scss\">\n .notifications {\n position: fixed;\n z-index: 1010;\n top: 24px;\n right: 24px;\n }\n</style>\n\n<div class=\"notifications\">\n <slot></slot>\n</div>","export { identity as linear } from '../internal/index.mjs';\n\n/*\nAdapted from https://github.com/mattdesl\nDistributed under MIT License https://github.com/mattdesl/eases/blob/master/LICENSE.md\n*/\nfunction backInOut(t) {\n const s = 1.70158 * 1.525;\n if ((t *= 2) < 1)\n return 0.5 * (t * t * ((s + 1) * t - s));\n return 0.5 * ((t -= 2) * t * ((s + 1) * t + s) + 2);\n}\nfunction backIn(t) {\n const s = 1.70158;\n return t * t * ((s + 1) * t - s);\n}\nfunction backOut(t) {\n const s = 1.70158;\n return --t * t * ((s + 1) * t + s) + 1;\n}\nfunction bounceOut(t) {\n const a = 4.0 / 11.0;\n const b = 8.0 / 11.0;\n const c = 9.0 / 10.0;\n const ca = 4356.0 / 361.0;\n const cb = 35442.0 / 1805.0;\n const cc = 16061.0 / 1805.0;\n const t2 = t * t;\n return t < a\n ? 7.5625 * t2\n : t < b\n ? 9.075 * t2 - 9.9 * t + 3.4\n : t < c\n ? ca * t2 - cb * t + cc\n : 10.8 * t * t - 20.52 * t + 10.72;\n}\nfunction bounceInOut(t) {\n return t < 0.5\n ? 0.5 * (1.0 - bounceOut(1.0 - t * 2.0))\n : 0.5 * bounceOut(t * 2.0 - 1.0) + 0.5;\n}\nfunction bounceIn(t) {\n return 1.0 - bounceOut(1.0 - t);\n}\nfunction circInOut(t) {\n if ((t *= 2) < 1)\n return -0.5 * (Math.sqrt(1 - t * t) - 1);\n return 0.5 * (Math.sqrt(1 - (t -= 2) * t) + 1);\n}\nfunction circIn(t) {\n return 1.0 - Math.sqrt(1.0 - t * t);\n}\nfunction circOut(t) {\n return Math.sqrt(1 - --t * t);\n}\nfunction cubicInOut(t) {\n return t < 0.5 ? 4.0 * t * t * t : 0.5 * Math.pow(2.0 * t - 2.0, 3.0) + 1.0;\n}\nfunction cubicIn(t) {\n return t * t * t;\n}\nfunction cubicOut(t) {\n const f = t - 1.0;\n return f * f * f + 1.0;\n}\nfunction elasticInOut(t) {\n return t < 0.5\n ? 0.5 *\n Math.sin(((+13.0 * Math.PI) / 2) * 2.0 * t) *\n Math.pow(2.0, 10.0 * (2.0 * t - 1.0))\n : 0.5 *\n Math.sin(((-13.0 * Math.PI) / 2) * (2.0 * t - 1.0 + 1.0)) *\n Math.pow(2.0, -10.0 * (2.0 * t - 1.0)) +\n 1.0;\n}\nfunction elasticIn(t) {\n return Math.sin((13.0 * t * Math.PI) / 2) * Math.pow(2.0, 10.0 * (t - 1.0));\n}\nfunction elasticOut(t) {\n return (Math.sin((-13.0 * (t + 1.0) * Math.PI) / 2) * Math.pow(2.0, -10.0 * t) + 1.0);\n}\nfunction expoInOut(t) {\n return t === 0.0 || t === 1.0\n ? t\n : t < 0.5\n ? +0.5 * Math.pow(2.0, 20.0 * t - 10.0)\n : -0.5 * Math.pow(2.0, 10.0 - t * 20.0) + 1.0;\n}\nfunction expoIn(t) {\n return t === 0.0 ? t : Math.pow(2.0, 10.0 * (t - 1.0));\n}\nfunction expoOut(t) {\n return t === 1.0 ? t : 1.0 - Math.pow(2.0, -10.0 * t);\n}\nfunction quadInOut(t) {\n t /= 0.5;\n if (t < 1)\n return 0.5 * t * t;\n t--;\n return -0.5 * (t * (t - 2) - 1);\n}\nfunction quadIn(t) {\n return t * t;\n}\nfunction quadOut(t) {\n return -t * (t - 2.0);\n}\nfunction quartInOut(t) {\n return t < 0.5\n ? +8.0 * Math.pow(t, 4.0)\n : -8.0 * Math.pow(t - 1.0, 4.0) + 1.0;\n}\nfunction quartIn(t) {\n return Math.pow(t, 4.0);\n}\nfunction quartOut(t) {\n return Math.pow(t - 1.0, 3.0) * (1.0 - t) + 1.0;\n}\nfunction quintInOut(t) {\n if ((t *= 2) < 1)\n return 0.5 * t * t * t * t * t;\n return 0.5 * ((t -= 2) * t * t * t * t + 2);\n}\nfunction quintIn(t) {\n return t * t * t * t * t;\n}\nfunction quintOut(t) {\n return --t * t * t * t * t + 1;\n}\nfunction sineInOut(t) {\n return -0.5 * (Math.cos(Math.PI * t) - 1);\n}\nfunction sineIn(t) {\n const v = Math.cos(t * Math.PI * 0.5);\n if (Math.abs(v) < 1e-14)\n return 1;\n else\n return 1 - v;\n}\nfunction sineOut(t) {\n return Math.sin((t * Math.PI) / 2);\n}\n\nexport { backIn, backInOut, backOut, bounceIn, bounceInOut, bounceOut, circIn, circInOut, circOut, cubicIn, cubicInOut, cubicOut, elasticIn, elasticInOut, elasticOut, expoIn, expoInOut, expoOut, quadIn, quadInOut, quadOut, quartIn, quartInOut, quartOut, quintIn, quintInOut, quintOut, sineIn, sineInOut, sineOut };\n","import { cubicInOut, linear, cubicOut } from '../easing/index.mjs';\nimport { is_function, assign } from '../internal/index.mjs';\n\n/*! *****************************************************************************\r\nCopyright (c) Microsoft Corporation.\r\n\r\nPermission to use, copy, modify, and/or distribute this software for any\r\npurpose with or without fee is hereby granted.\r\n\r\nTHE SOFTWARE IS PROVIDED \"AS IS\" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH\r\nREGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY\r\nAND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT,\r\nINDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM\r\nLOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR\r\nOTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR\r\nPERFORMANCE OF THIS SOFTWARE.\r\n***************************************************************************** */\r\n\r\nfunction __rest(s, e) {\r\n var t = {};\r\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)\r\n t[p] = s[p];\r\n if (s != null && typeof Object.getOwnPropertySymbols === \"function\")\r\n for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {\r\n if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))\r\n t[p[i]] = s[p[i]];\r\n }\r\n return t;\r\n}\n\nfunction blur(node, { delay = 0, duration = 400, easing = cubicInOut, amount = 5, opacity = 0 } = {}) {\n const style = getComputedStyle(node);\n const target_opacity = +style.opacity;\n const f = style.filter === 'none' ? '' : style.filter;\n const od = target_opacity * (1 - opacity);\n return {\n delay,\n duration,\n easing,\n css: (_t, u) => `opacity: ${target_opacity - (od * u)}; filter: ${f} blur(${u * amount}px);`\n };\n}\nfunction fade(node, { delay = 0, duration = 400, easing = linear } = {}) {\n const o = +getComputedStyle(node).opacity;\n return {\n delay,\n duration,\n easing,\n css: t => `opacity: ${t * o}`\n };\n}\nfunction fly(node, { delay = 0, duration = 400, easing = cubicOut, x = 0, y = 0, opacity = 0 } = {}) {\n const style = getComputedStyle(node);\n const target_opacity = +style.opacity;\n const transform = style.transform === 'none' ? '' : style.transform;\n const od = target_opacity * (1 - opacity);\n return {\n delay,\n duration,\n easing,\n css: (t, u) => `\n\t\t\ttransform: ${transform} translate(${(1 - t) * x}px, ${(1 - t) * y}px);\n\t\t\topacity: ${target_opacity - (od * u)}`\n };\n}\nfunction slide(node, { delay = 0, duration = 400, easing = cubicOut } = {}) {\n const style = getComputedStyle(node);\n const opacity = +style.opacity;\n const height = parseFloat(style.height);\n const padding_top = parseFloat(style.paddingTop);\n const padding_bottom = parseFloat(style.paddingBottom);\n const margin_top = parseFloat(style.marginTop);\n const margin_bottom = parseFloat(style.marginBottom);\n const border_top_width = parseFloat(style.borderTopWidth);\n const border_bottom_width = parseFloat(style.borderBottomWidth);\n return {\n delay,\n duration,\n easing,\n css: t => 'overflow: hidden;' +\n `opacity: ${Math.min(t * 20, 1) * opacity};` +\n `height: ${t * height}px;` +\n `padding-top: ${t * padding_top}px;` +\n `padding-bottom: ${t * padding_bottom}px;` +\n `margin-top: ${t * margin_top}px;` +\n `margin-bottom: ${t * margin_bottom}px;` +\n `border-top-width: ${t * border_top_width}px;` +\n `border-bottom-width: ${t * border_bottom_width}px;`\n };\n}\nfunction scale(node, { delay = 0, duration = 400, easing = cubicOut, start = 0, opacity = 0 } = {}) {\n const style = getComputedStyle(node);\n const target_opacity = +style.opacity;\n const transform = style.transform === 'none' ? '' : style.transform;\n const sd = 1 - start;\n const od = target_opacity * (1 - opacity);\n return {\n delay,\n duration,\n easing,\n css: (_t, u) => `\n\t\t\ttransform: ${transform} scale(${1 - (sd * u)});\n\t\t\topacity: ${target_opacity - (od * u)}\n\t\t`\n };\n}\nfunction draw(node, { delay = 0, speed, duration, easing = cubicInOut } = {}) {\n let len = node.getTotalLength();\n const style = getComputedStyle(node);\n if (style.strokeLinecap !== 'butt') {\n len += parseInt(style.strokeWidth);\n }\n if (duration === undefined) {\n if (speed === undefined) {\n duration = 800;\n }\n else {\n duration = len / speed;\n }\n }\n else if (typeof duration === 'function') {\n duration = duration(len);\n }\n return {\n delay,\n duration,\n easing,\n css: (t, u) => `stroke-dasharray: ${t * len} ${u * len}`\n };\n}\nfunction crossfade(_a) {\n var { fallback } = _a, defaults = __rest(_a, [\"fallback\"]);\n const to_receive = new Map();\n const to_send = new Map();\n function crossfade(from, node, params) {\n const { delay = 0, duration = d => Math.sqrt(d) * 30, easing = cubicOut } = assign(assign({}, defaults), params);\n const to = node.getBoundingClientRect();\n const dx = from.left - to.left;\n const dy = from.top - to.top;\n const dw = from.width / to.width;\n const dh = from.height / to.height;\n const d = Math.sqrt(dx * dx + dy * dy);\n const style = getComputedStyle(node);\n const transform = style.transform === 'none' ? '' : style.transform;\n const opacity = +style.opacity;\n return {\n delay,\n duration: is_function(duration) ? duration(d) : duration,\n easing,\n css: (t, u) => `\n\t\t\t\topacity: ${t * opacity};\n\t\t\t\ttransform-origin: top left;\n\t\t\t\ttransform: ${transform} translate(${u * dx}px,${u * dy}px) scale(${t + (1 - t) * dw}, ${t + (1 - t) * dh});\n\t\t\t`\n };\n }\n function transition(items, counterparts, intro) {\n return (node, params) => {\n items.set(params.key, {\n rect: node.getBoundingClientRect()\n });\n return () => {\n if (counterparts.has(params.key)) {\n const { rect } = counterparts.get(params.key);\n counterparts.delete(params.key);\n return crossfade(rect, node, params);\n }\n // if the node is disappearing altogether\n // (i.e. wasn't claimed by the other list)\n // then we need to supply an outro\n items.delete(params.key);\n return fallback && fallback(node, params, intro);\n };\n };\n }\n return [\n transition(to_send, to_receive, false),\n transition(to_receive, to_send, true)\n ];\n}\n\nexport { blur, crossfade, draw, fade, fly, scale, slide };\n","<script>\n import { fly } from 'svelte/transition';\n\n export let message;\n\n export let type = 'info';\n</script>\n\n<style lang=\"scss\">\n\n @import \"variables\";\n\n .notification {\n box-sizing: border-box;\n margin: 0;\n padding: 0;\n color: $gray-600;\n font-size: 14px;\n font-variant: tabular-nums;\n line-height: 1.5;\n list-style: none;\n width: 384px;\n max-width: calc(100vw - 32px);\n padding: 16px 24px;\n overflow: hidden;\n line-height: 1.5;\n background: #fff;\n border-radius: 3px;\n box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);\n border-left: solid 4px $info;\n\n &.error {\n border-left-color: $danger;\n }\n\n &.warning {\n border-left-color: $warning;\n }\n }\n\n .notification + .notification {\n margin-top: 16px;\n }\n\n .heading {\n color: $gray-900;\n font-weight: normal;\n font-size: 1.2em;\n margin-bottom: 5px;\n }\n</style>\n\n<div\n class=\"notification\"\n class:error={ type === 'error' }\n class:warning={ type === 'warning' }\n transition:fly\n>\n <div class=\"heading\">{ message }</div>\n <div class=\"detail\">\n <slot></slot>\n </div>\n</div>","<script>\n function isLight(color) {\n /* eslint no-bitwise: \"off\" */\n\n color = +('0x' + color.slice(1).replace(color.length < 5 && /./g, '$&$&'));\n\n const r = color >> 16,\n g = (color >> 8) & 255,\n b = color & 255;\n\n const hsp = Math.sqrt(\n 0.299 * (r * r) +\n 0.587 * (g * g) +\n 0.114 * (b * b)\n );\n\n return hsp > 127.5;\n }\n\n export let title = '';\n export let name;\n export let color = '';\n export let className = '';\n\n export let onClick;\n export let href = null;\n\n $: inverted = color && isLight(color);\n</script>\n\n{#if href}\n <a\n href={ href }\n target=\"_blank\"\n title={ title || name }\n rel=\"noopener noreferrer\"\n class:inverted={ inverted }\n class=\"tag { className }\"\n style=\"background-color: { color }\"\n on:click={ onClick }\n >{ name }</a>\n{:else}\n <span\n class:inverted={ inverted }\n class=\"tag { className }\"\n class:clickable={ onClick }\n style=\"background-color: { color }\"\n on:click={ onClick }\n title={ title || name }\n >{ name }</span>\n{/if}\n\n<style lang=\"scss\">\n .tag {\n list-style: none;\n display: inline-block;\n height: auto;\n\n margin: 0 4px 4px 0;\n padding: 1px 7px;\n\n font-size: 12px;\n font-weight: 500;\n\n line-height: 20px;\n white-space: nowrap;\n\n overflow: hidden;\n text-overflow: ellipsis;\n\n color: white;\n background: #fafafa;\n border-radius: 4px;\n\n text-decoration: none;\n\n &:not(a) {\n cursor: default;\n }\n\n &.inverted {\n color: #333;\n }\n }\n\n :not(a.tag, .tag.clickable) {\n cursor: default;\n }\n</style>","<script>\n export let item;\n\n $: merged = item.merged;\n $: open = item.state === 'open';\n $: closed = item.state === 'closed';\n $: draft = item.draft || false;\n</script>\n\n<style lang=\"scss\">\n\n .pull-request-icon {\n margin-right: 1px;\n\n &.open {\n color: #28a745;\n }\n\n &.closed {\n color: #cb2431;\n }\n\n &.merged {\n color: #6f42c1;\n }\n\n &.draft {\n color: #6e7781;\n }\n }\n</style>\n\n{#if merged}\n\n <svg class=\"pull-request-icon\" class:merged={ merged } width=\"1em\" height=\"1em\" viewBox=\"0 0 12 16\" version=\"1.1\" aria-hidden=\"true\" fill=\"currentColor\">\n <path fill-rule=\"evenodd\" d=\"M10 7c-.73 0-1.38.41-1.73 1.02V8C7.22 7.98 6 7.64 5.14 6.98c-.75-.58-1.5-1.61-1.89-2.44A1.993 1.993 0 0 0 2 .99C.89.99 0 1.89 0 3a2 2 0 0 0 1 1.72v6.56c-.59.35-1 .99-1 1.72 0 1.11.89 2 2 2a1.993 1.993 0 0 0 1-3.72V7.67c.67.7 1.44 1.27 2.3 1.69.86.42 2.03.63 2.97.64v-.02c.36.61 1 1.02 1.73 1.02 1.11 0 2-.89 2-2 0-1.11-.89-2-2-2zm-6.8 6c0 .66-.55 1.2-1.2 1.2-.65 0-1.2-.55-1.2-1.2 0-.65.55-1.2 1.2-1.2.65 0 1.2.55 1.2 1.2zM2 4.2C1.34 4.2.8 3.65.8 3c0-.65.55-1.2 1.2-1.2.65 0 1.2.55 1.2 1.2 0 .65-.55 1.2-1.2 1.2zm8 6c-.66 0-1.2-.55-1.2-1.2 0-.65.55-1.2 1.2-1.2.65 0 1.2.55 1.2 1.2 0 .65-.55 1.2-1.2 1.2z\"></path>\n </svg>\n\n{:else}\n <svg class=\"pull-request-icon\" class:closed={ closed } class:open={ open } class:draft={ draft } width=\"1em\" height=\"1em\" viewBox=\"0 0 12 16\" version=\"1.1\" aria-hidden=\"true\" fill=\"currentColor\">\n <path fill-rule=\"evenodd\" d=\"M11 11.28V5c-.03-.78-.34-1.47-.94-2.06C9.46 2.35 8.78 2.03 8 2H7V0L4 3l3 3V4h1c.27.02.48.11.69.31.21.2.3.42.31.69v6.28A1.993 1.993 0 0 0 10 15a1.993 1.993 0 0 0 1-3.72zm-1 2.92c-.66 0-1.2-.55-1.2-1.2 0-.65.55-1.2 1.2-1.2.65 0 1.2.55 1.2 1.2 0 .65-.55 1.2-1.2 1.2zM4 3c0-1.11-.89-2-2-2a1.993 1.993 0 0 0-1 3.72v6.56A1.993 1.993 0 0 0 2 15a1.993 1.993 0 0 0 1-3.72V4.72c.59-.34 1-.98 1-1.72zm-.8 10c0 .66-.55 1.2-1.2 1.2-.65 0-1.2-.55-1.2-1.2 0-.65.55-1.2 1.2-1.2.65 0 1.2.55 1.2 1.2zM2 4.2C1.34 4.2.8 3.65.8 3c0-.65.55-1.2 1.2-1.2.65 0 1.2.55 1.2 1.2 0 .65-.55 1.2-1.2 1.2z\"></path>\n </svg>\n{/if}","<style lang=\"scss\">\n\n .icon {\n margin-right: 2px;\n\n color: #1d76db;\n }\n</style>\n\n<svg class=\"icon\" width=\"1em\" height=\"1em\" viewBox=\"0 0 12 16\" version=\"1.1\" aria-hidden=\"true\">\n\n <path fill=\"currentColor\" stroke=\"#1d76db\" d=\"M1 15V4l5-3 5 3v11l-5-4-5 4z\" stroke-width=\"1.5\" />\n\n</svg>","<script>\n\n export let item;\n\n $: check_runs = item.check_runs || [];\n $: statuses = item.statuses || [];\n\n const check_run_result_map = {\n failure: 'failed',\n success: 'succeeded',\n in_progress: 'in progress',\n queued: 'queued',\n action_required: 'action required'\n };\n</script>\n\n<style lang=\"scss\">\n\n @import \"variables\";\n\n $color-success: $success;\n $color-action-required: $warning;\n $color-failure: $danger;\n\n /*\n $color-success: #77da8e;\n $color-failure: #da8077;\n $color-action-required: #dac977;\n */\n\n @mixin colored-scale($color) {\n background-color: scale-color($color, $lightness: +40%);\n box-shadow: 0 1px 2px 0px scale-color($color, $saturation: -20%, $alpha: -70%);\n }\n\n .card-status {\n display: flex;\n flex-direction: row;\n align-items: stretch;\n height: 3px;\n\n width: auto;\n margin: 3px -8px -4px;\n }\n\n .state {\n flex: 1;\n\n background-color: $gray-500;\n\n > span {\n display: none;\n }\n\n &.striped {\n background-image: linear-gradient(\n 45deg,\n rgba(255,255,255,.15) 25%,\n transparent 25%,\n transparent 50%,\n rgba(255,255,255,.15) 50%,\n rgba(255,255,255,.15) 75%,\n transparent 75%,\n transparent\n );\n\n animation: progress-bar-stripes 1s linear infinite;\n\n background-size: 1rem 1rem;\n }\n\n &.success {\n @include colored-scale($color-success);\n }\n\n &.failure {\n @include colored-scale($color-failure);\n }\n\n &.action-required {\n @include colored-scale($color-action-required);\n }\n }\n\n .state + .state {\n margin-left: 1px;\n }\n\n @keyframes progress-bar-stripes {\n from { background-position: $progress-height 0; }\n to { background-position: 0 0; }\n }\n</style>\n\n{#if check_runs.length || statuses.length}\n <div class=\"card-status\">\n\n {#each check_runs as check_run}\n <a\n class=\"state\"\n class:success={ check_run.conclusion === 'success' || check_run.status === 'in_progress' }\n class:failure={ check_run.conclusion === 'failure' }\n class:action-required={ check_run.conclusion === 'action_required' }\n class:striped={ check_run.status === 'in_progress' || check_run.status === 'queued' }\n target=\"_blank\"\n rel=\"noopener noreferrer\"\n title={ `${ check_run.name } — ${check_run_result_map[check_run.conclusion] || check_run_result_map[check_run.status] }` }\n href={ check_run.html_url }\n ><span>{check_run.name} — {check_run_result_map[check_run.conclusion] || check_run_result_map[check_run.status] }</span></a>\n {/each}\n\n {#each statuses as status}\n <a\n class=\"state\"\n class:success={ status.state === 'success' || status.state === 'pending' }\n class:failure={ status.state === 'failure' }\n class:action-required={ status.state === 'error' }\n class:striped={ status.state === 'pending' }\n target=\"_blank\"\n rel=\"noopener noreferrer\"\n title={ `${ status.context } — ${status.description}` }\n href={ status.target_url }\n ><span>{ status.context } — {status.description}</span></a>\n {/each}\n </div>\n{/if}","<script>\n\n import {\n isAddFilterClick,\n isApplyFilterClick\n } from './shortcuts';\n\n export let item;\n export let onSelect;\n\n $: number = item.number;\n $: repository = item.repository;\n $: repositoryName = `${repository.owner.login}/${repository.name}`;\n $: repoUrl = `https://github.com/${ repositoryName }`;\n\n $: assignees = item.assignees;\n\n $: comments = (\n Array.isArray(item.comments) ? item.comments : []\n ).map(comment => {\n const {\n user,\n html_url\n } = comment;\n\n return {\n state: 'commented',\n user,\n html_url\n };\n });\n\n $: requested_reviewers = item.requested_reviewers || [];\n\n $: reviews = Object.values(\n [].concat(comments, item.reviews || [])\n .filter(review => !requested_reviewers.find(reviewer => reviewer.login === review.user.login))\n .reduce((byUser, review) => {\n\n const existingReview = byUser[review.user.login];\n\n // keep last definitive review (approved, changes_requested)\n // to match GitHub display and behavior\n if (\n !existingReview ||\n existingReview.state === 'commented' ||\n review.state !== 'commented'\n ) {\n byUser[review.user.login] = review;\n }\n\n return byUser;\n }, {})\n );\n\n const stateToVerb = {\n changes_requested: 'requested changes',\n approved: 'approved',\n commented: 'commented',\n dismissed: 'dismissed his review'\n };\n\n function handleSelection(qualifier, value) {\n\n return onSelect && function(event) {\n\n if (!isApplyFilterClick(event)) {\n return;\n }\n\n event.preventDefault();\n\n onSelect(qualifier, value, isAddFilterClick(event));\n };\n }\n</script>\n\n<style lang=\"scss\">\n @import \"variables\";\n\n $separatorColor: white;\n\n @mixin review-badge($color) {\n\n &:before {\n content: '';\n display: block;\n background: $color;\n box-shadow: 0 0 0 2px $separatorColor;\n width: 6px;\n height: 6px;\n border-radius: 50%;\n position: absolute;\n top: -2px;\n left: -2px;\n z-index: 1;\n }\n }\n\n .assignee {\n box-sizing: border-box;\n margin: 0;\n font-size: 14px;\n position: relative;\n display: inline-block;\n text-align: center;\n border-radius: 2px;\n\n margin-left: 3px;\n transition: margin .1s;\n\n height: 18px;\n\n img {\n height: 100%;\n border-radius: 2px;\n vertical-align: unset;\n }\n\n .icon-shadow {\n position: absolute;\n display: none;\n top: 0;\n left: 0;\n height: 100%;\n width: 100%;\n box-shadow: inset 0 0 2px 0 rgba(20, 20, 20, 0.3);\n border-radius: 2px;\n }\n\n &.requested-reviewer {\n @include review-badge(#bf8700);\n }\n\n &.commented {\n @include review-badge($info);\n }\n\n &.approved {\n @include review-badge($success);\n }\n\n &.requested-changes {\n @include review-badge($danger);\n }\n\n }\n\n .assignee + .assignee {\n margin-left: -6px;\n box-shadow: 0 0 0 1px $separatorColor;\n }\n\n :global {\n .hovered > .header {\n .assignee + .assignee {\n margin-left: 3px !important;\n box-shadow: none;\n }\n }\n }\n</style>\n\n{#each requested_reviewers as reviewer}\n <span\n class=\"assignee requested-reviewer\"\n title=\"{ reviewer.login } requested for review\"\n on:click={ handleSelection('involves', reviewer.login) }>\n <img src=\"{ reviewer.avatar_url }&s=40\" alt=\"{ reviewer.login } avatar\" />\n <div class=\"icon-shadow\"></div>\n </span>\n{/each}\n\n{#each reviews as review}\n <a\n class=\"assignee reviewer\"\n class:approved={ review.state === 'approved' }\n class:requested-changes={ review.state === 'changes_requested' }\n class:commented={ review.state === 'commented' || review.state === 'dismissed' }\n title=\"{ review.user.login } { stateToVerb[review.state] }\"\n href={ review.html_url || `${repoUrl}/pull/${number}#pullrequestreview-${review.id}` }\n on:click={ handleSelection('involves', review.user.login) }\n target=\"_blank\"\n rel=\"noopener noreferrer\"\n >\n <img src=\"{ review.user.avatar_url }&s=40\" alt=\"{ review.user.login } avatar\" />\n <div class=\"icon-shadow\"></div>\n </a>\n{/each}\n\n{#each assignees as assignee}\n <a\n class=\"assignee\"\n title=\"{ assignee.login } assigned\"\n on:click={ handleSelection('involves', assignee.login) }\n href={ assignee.html_url }\n target=\"_blank\"\n rel=\"noopener noreferrer\"\n >\n <img src=\"{ assignee.avatar_url }&s=40\" alt=\"{ assignee.login } avatar\" />\n <div class=\"icon-shadow\"></div>\n </a>\n{/each}","<style lang=\"scss\">\n .icon {\n margin-right: 2px;\n\n &.issue.open,\n &.depends-on.closed {\n color: #28a745;\n }\n\n &.issue.closed,\n &.depends-on {\n color: #cb2431;\n }\n\n &.linked-to {\n color: #37ACC8;\n }\n }\n</style>\n\n<script>\n export let name;\n export let state = '';\n export let className = '';\n</script>\n\n{#if name === 'issue'}\n\n {#if state !== 'closed'}\n <svg class=\"icon issue { className }\" class:open={ state === 'open' } width=\"1em\" height=\"1em\" viewBox=\"0 0 14 16\" version=\"1.1\" aria-hidden=\"true\" fill=\"currentColor\">\n <path fill-rule=\"evenodd\" d=\"M7 2.3c3.14 0 5.7 2.56 5.7 5.7s-2.56 5.7-5.7 5.7A5.71 5.71 0 0 1 1.3 8c0-3.14 2.56-5.7 5.7-5.7zM7 1C3.14 1 0 4.14 0 8s3.14 7 7 7 7-3.14 7-7-3.14-7-7-7zm1 3H6v5h2V4zm0 6H6v2h2v-2z\"></path>\n </svg>\n {:else}\n <svg class=\"icon issue closed { className }\" width=\"1em\" height=\"1em\" viewBox=\"0 0 16 16\" version=\"1.1\" aria-hidden=\"true\" fill=\"currentColor\">\n <path fill-rule=\"evenodd\" d=\"M7 10h2v2H7v-2zm2-6H7v5h2V4zm1.5 1.5l-1 1L12 9l4-4.5-1-1L12 7l-1.5-1.5zM8 13.7A5.71 5.71 0 0 1 2.3 8c0-3.14 2.56-5.7 5.7-5.7 1.83 0 3.45.88 4.5 2.2l.92-.92A6.947 6.947 0 0 0 8 1C4.14 1 1 4.14 1 8s3.14 7 7 7 7-3.14 7-7l-1.52 1.52c-.66 2.41-2.86 4.19-5.48 4.19v-.01z\"></path>\n </svg>\n {/if}\n\n{/if}\n\n{#if name === 'depends-on'}\n\n {#if state === 'closed'}\n <svg class=\"icon depends-on closed { className }\" width=\"1em\" height=\"1em\" viewBox=\"0 0 12 16\" version=\"1.1\" aria-hidden=\"true\" fill=\"currentColor\">\n <path fill-rule=\"evenodd\" d=\"M12 5l-8 8-4-4 1.5-1.5L4 10l6.5-6.5L12 5z\"></path>\n </svg>\n {:else}\n <svg class=\"icon depends-on { className }\" width=\"1em\" height=\"1em\" viewBox=\"0 0 14 16\" version=\"1.1\" aria-hidden=\"true\" fill=\"currentColor\">\n <path fill-rule=\"evenodd\" d=\"M7 1C3.14 1 0 4.14 0 8s3.14 7 7 7 7-3.14 7-7-3.14-7-7-7zm0 1.3c1.3 0 2.5.44 3.47 1.17l-8 8A5.755 5.755 0 0 1 1.3 8c0-3.14 2.56-5.7 5.7-5.7zm0 11.41c-1.3 0-2.5-.44-3.47-1.17l8-8c.73.97 1.17 2.17 1.17 3.47 0 3.14-2.56 5.7-5.7 5.7z\"></path>\n </svg>\n {/if}\n\n{/if}\n\n\n{#if name === 'linked-to'}\n <svg class=\"icon linked-to { className }\" width=\"1em\" height=\"1em\" viewBox=\"0 0 14 16\" version=\"1.1\" aria-hidden=\"true\" fill=\"currentColor\">\n <path fill-rule=\"evenodd\" d=\"M6.3 5.69a.942.942 0 0 1-.28-.7c0-.28.09-.52.28-.7.19-.18.42-.28.7-.28.28 0 .52.09.7.28.18.19.28.42.28.7 0 .28-.09.52-.28.7a1 1 0 0 1-.7.3c-.28 0-.52-.11-.7-.3zM8 7.99c-.02-.25-.11-.48-.31-.69-.2-.19-.42-.3-.69-.31H6c-.27.02-.48.13-.69.31-.2.2-.3.44-.31.69h1v3c.02.27.11.5.31.69.2.2.42.31.69.31h1c.27 0 .48-.11.69-.31.2-.19.3-.42.31-.69H8V7.98v.01zM7 2.3c-3.14 0-5.7 2.54-5.7 5.68 0 3.14 2.56 5.7 5.7 5.7s5.7-2.55 5.7-5.7c0-3.15-2.56-5.69-5.7-5.69v.01zM7 .98c3.86 0 7 3.14 7 7s-3.14 7-7 7-7-3.12-7-7 3.14-7 7-7z\"></path>\n </svg>\n{/if}\n\n\n{#if name === 'epic'}\n <svg class=\"icon epic { className}\" width=\"1em\" height=\"1em\" viewBox=\"0 0 12 16\" version=\"1.1\" aria-hidden=\"true\" stroke=\"currentColor\">\n <path fill=\"none\" fill-rule=\"evenodd\" transform=\"rotate(-89.89169311523438 5.963454723358154,7.855281829833984)\"\n d=\"m-1.079501,2.743426l10.564429,0l3.521483,5.111845l-3.521483,5.111868l-10.564429,0l3.521482,-5.111868l-3.521482,-5.111845z\" stroke-width=\"1.5\" />\n </svg>\n{/if}\n\n","<script>\n import PullRequestIcon from './components/PullRequestIcon.svelte';\n import LinkIcon from './components/LinkIcon.svelte';\n\n import CollaboratorLinks from './CollaboratorLinks.svelte';\n import CardStatus from './CardStatus.svelte';\n\n import {\n isApplyFilterClick,\n isAddFilterClick\n } from './shortcuts';\n\n export let item;\n\n export let onSelect;\n\n export let hovered = false;\n\n export let type;\n\n $: number = item.number;\n $: title = item.title;\n $: repository = item.repository;\n $: pull_request = item.pull_request;\n $: state = item.state;\n\n $: repositoryName = `${repository.owner.login}/${repository.name}`;\n\n $: cardUrl = item.html_url || `https://github.com/${ repositoryName }/issues/${ number }`;\n\n $: linkTitle = ({\n CHILD_OF: 'Parent of',\n DEPENDS_ON: 'Required by',\n PARENT_OF: 'Child of',\n CLOSED_BY: 'Closes',\n REQUIRED_BY: 'Depends on',\n CLOSES: 'Closed by',\n LINKED_TO: 'Linked to',\n LINKED_BY: 'Linked to'\n })[type] || type;\n\n function handleSelection(qualifier, value) {\n\n return onSelect && function(event) {\n\n if (!isApplyFilterClick(event)) {\n return;\n }\n\n event.preventDefault();\n\n onSelect(qualifier, value, isAddFilterClick(event));\n };\n }\n</script>\n\n<style lang=\"scss\">\n @import \"./Card\";\n\n .card-link {\n border-top: solid 1px #F0F0F0;\n margin-top: 2px;\n padding-top: 2px;\n }\n\n .card-link .short-title {\n flex: 1;\n }\n\n :global {\n .card-link .epic {\n color: #1d76db;\n }\n }\n</style>\n\n<div class=\"card-link\"\n class:hovered={ hovered }\n on:mouseenter={ () => hovered = true }\n on:mouseleave={ () => hovered = false }\n>\n <div class=\"header\">\n <a href={ cardUrl }\n target=\"_blank\"\n rel=\"noopener noreferrer\"\n class=\"issue-number\"\n on:click={ handleSelection('ref', item.key) }\n title=\"{ repositoryName }#{ number } · { linkTitle } this issue\"\n >\n {#if pull_request}\n <PullRequestIcon item={ item } />\n {:else}\n {#if type === 'PARENT_OF'}\n <LinkIcon name=\"issue\" state={ state } />\n {/if}\n\n {#if type === 'CHILD_OF'}\n <LinkIcon name=\"epic\" />\n {/if}\n\n {#if type === 'DEPENDS_ON' || type === 'CLOSED_BY'}\n <LinkIcon name=\"depends-on\" state={ state } />\n {/if}\n\n {#if type === 'REQUIRED_BY' || type === 'CLOSES' }\n {#if state === 'open'}\n <LinkIcon name=\"linked-to\" />\n {:else}\n <LinkIcon name=\"issue\" state={ state } />\n {/if}\n {/if}\n\n {#if type === 'LINKED_TO'}\n <LinkIcon name=\"linked-to\" />\n {/if}\n {/if}\n\n { number }\n </a>\n\n <span class=\"short-title\" title={ title }>{ title }</span>\n\n <span class=\"collaborator-links\">\n <CollaboratorLinks item={ item } onSelect={ onSelect } />\n </span>\n </div>\n\n <CardStatus item={ item } />\n</div>","<script>\n import {\n isOpen,\n isMerged,\n isPull,\n noDuplicates\n } from './util';\n\n import {\n isApplyFilterClick,\n isAddFilterClick\n } from './shortcuts';\n\n import Tag from './components/Tag.svelte';\n import PullRequestIcon from './components/PullRequestIcon.svelte';\n import EpicIcon from './components/EpicIcon.svelte';\n\n import CardStatus from './CardStatus.svelte';\n import CollaboratorLinks from './CollaboratorLinks.svelte';\n\n import CardLink from './CardLink.svelte';\n\n const linkOrder = {\n 'DEPENDS_ON': 1,\n 'CLOSED_BY': 2,\n 'PARENT_OF': 3,\n 'REQUIRED_BY': 4,\n 'LINKED_TO': 5,\n 'CHILD_OF': 6\n };\n\n export let item;\n\n export let className = '';\n\n export let onSelect;\n\n let showChildren = false;\n\n let hovered = false;\n\n $: number = item.number;\n $: title = item.title;\n $: repository = item.repository;\n $: milestone = item.milestone;\n $: labels = item.labels.filter(l => !l.column_label);\n $: pull_request = item.pull_request;\n\n $: links = item.links || [];\n\n $: embeddedLinks = links.filter(\n (link) => !isPull(link.target) && link.type !== 'LINKED_BY'\n ).sort(\n (a, b) => {\n return linkOrder[a.type] - linkOrder[b.type];\n }\n );\n\n $: shownLinks = embeddedLinks.filter(link => showChildren || link.type !== 'PARENT_OF');\n\n $: children = embeddedLinks.filter(l => l.type === 'PARENT_OF');\n $: completedChildren = children.filter(l => l.target.state === 'closed');\n\n $: prLinks = links.filter(\n link => isPull(link.target) && (\n isOpen(link.target) || (\n isMerged(link.target) && link.type === 'CLOSED_BY'\n )\n )\n ).filter(noDuplicates(link => link.target.id));\n\n $: repositoryName = `${repository.owner.login}/${repository.name}`;\n\n $: repoUrl = `https://github.com/${ repositoryName }`;\n $: milestoneUrl = milestone && (milestone.html_url || `${repoUrl}/milestone/${milestone.number}`);\n $: cardUrl = item.html_url || `${repoUrl}/issues/${number}`;\n\n function handleSelection(qualifier, value) {\n\n return onSelect && function(event) {\n\n if (!isApplyFilterClick(event)) {\n return;\n }\n\n event.preventDefault();\n\n onSelect(qualifier, value, isAddFilterClick(event));\n };\n }\n</script>\n\n<style lang=\"scss\">\n @import \"variables\";\n\n @import \"./Card\";\n\n :global {\n .tag {\n &.label,\n &.milestone {\n margin-right: 4px;\n margin-bottom: 4px;\n }\n\n &.milestone {\n color: $gray-800 !important;\n border: solid 1px $gray-600;\n }\n }\n\n .card-link:first-child {\n border-top: none !important;\n margin-top: 1px !important;\n }\n }\n\n .board-card-links.attached {\n background: #F9F9F9;\n border-radius: 0 0 4px 4px;\n box-shadow: inset 0 3px 5px -2px rgba(0, 0, 0, 0.1), 0 1px 2px rgba(0, 0, 0, 0.1);\n margin-top: -6px;\n position: relative;\n padding: 7px 8px 4px 8px;\n }\n\n .progress {\n display: flex;\n flex-direction: row;\n align-items: center;\n margin-bottom: 7px;\n\n cursor: pointer;\n\n &:hover {\n svg {\n color: $gray-600;\n }\n }\n\n svg {\n color: #CCC;\n transition: color .3s;\n }\n\n .bar {\n border-radius: 3px;\n height: 5px;\n width: 80px;\n background: #EEE;\n margin: auto 6px;\n\n .indicator {\n border-radius: 3px;\n background: $gray-600;\n height: 100%;\n }\n }\n\n .text {\n margin-left: 6px;\n font-size: 0.9rem;\n color: $gray-600;\n }\n }\n\n</style>\n\n<div class=\"board-card-container { className }\">\n <div class=\"board-card\"\n class:hovered={ hovered }\n on:mouseenter={ () => hovered = true }\n on:mouseleave={ () => hovered = false }\n >\n <div class=\"header\">\n <a href={ cardUrl }\n target=\"_blank\"\n rel=\"noopener noreferrer\"\n class=\"issue-number\"\n title=\"{ repositoryName }#{ number }\"\n on:click={ handleSelection('ref', item.key) }\n >\n\n {#if children.length}\n <EpicIcon item={ item } linkType=\"PARENT_OF\" />\n {/if}\n\n {#if pull_request}\n <PullRequestIcon item={ item } />\n {/if}\n\n { number }\n </a>\n\n <span class=\"repository\" title={ repositoryName }>{ repositoryName }</span>\n\n <span class=\"collaborator-links\">\n <CollaboratorLinks item={ item } onSelect={ onSelect } />\n </span>\n </div>\n <div class=\"title\">\n { title }\n </div>\n {#if children.length}\n <div\n class=\"progress\"\n on:click={ () => showChildren = !showChildren }\n title=\"{ completedChildren.length } of { children.length } child tasks completed\"\n >\n <svg class=\"icon issue closed\" width=\"1em\" height=\"1em\" viewBox=\"0 0 16 16\" version=\"1.1\" aria-hidden=\"true\" fill=\"currentColor\">\n <path fill-rule=\"evenodd\" d=\"M7 10h2v2H7v-2zm2-6H7v5h2V4zm1.5 1.5l-1 1L12 9l4-4.5-1-1L12 7l-1.5-1.5zM8 13.7A5.71 5.71 0 0 1 2.3 8c0-3.14 2.56-5.7 5.7-5.7 1.83 0 3.45.88 4.5 2.2l.92-.92A6.947 6.947 0 0 0 8 1C4.14 1 1 4.14 1 8s3.14 7 7 7 7-3.14 7-7l-1.52 1.52c-.66 2.41-2.86 4.19-5.48 4.19v-.01z\"></path>\n </svg>\n <div class=\"text\">\n { completedChildren.length } of { children.length }\n </div>\n <div class=\"bar\">\n <div class=\"indicator\" style=\"width: { completedChildren.length / children.length * 100 }%\"></div>\n </div>\n </div>\n {/if}\n <div class=\"footer\">\n {#if milestone}\n <Tag\n class=\"tag milestone\"\n name={ milestone.title }\n href={ milestoneUrl }\n title={ milestone.title }\n onClick={ handleSelection('milestone', milestone.title) }\n />\n {/if}\n\n {#each labels as { name, color }}\n <Tag\n class=\"tag label\"\n color=\"#{ color }\"\n name={ name }\n title={ name }\n onClick={ handleSelection('label', name) }\n />\n {/each}\n\n <div class=\"links\">\n <a href={ cardUrl } title=\"View on GitHub\" target=\"_blank\" rel=\"noopener noreferrer\">\n <svg width=\"1em\" height=\"1em\" viewBox=\"0 0 16 16\" version=\"1.1\" aria-hidden=\"true\" fill=\"currentColor\">\n <path fill-rule=\"evenodd\" d=\"M8 0C3.58 0 0 3.58 0 8c0 3.54 2.29 6.53 5.47 7.59.4.07.55-.17.55-.38 0-.19-.01-.82-.01-1.49-2.01.37-2.53-.49-2.69-.94-.09-.23-.48-.94-.82-1.13-.28-.15-.68-.52-.01-.53.63-.01 1.08.58 1.23.82.72 1.21 1.87.87 2.33.66.07-.52.28-.87.51-1.07-1.78-.2-3.64-.89-3.64-3.95 0-.87.31-1.59.82-2.15-.08-.2-.36-1.02.08-2.12 0 0 .67-.21 2.2.82.64-.18 1.32-.27 2-.27.68 0 1.36.09 2 .27 1.53-1.04 2.2-.82 2.2-.82.44 1.1.16 1.92.08 2.12.51.56.82 1.27.82 2.15 0 3.07-1.87 3.75-3.65 3.95.29.25.54.73.54 1.48 0 1.07-.01 1.93-.01 2.2 0 .21.15.46.55.38A8.013 8.013 0 0 0 16 8c0-4.42-3.58-8-8-8z\"></path>\n </svg>\n </a>\n </div>\n </div>\n\n {#if shownLinks.length}\n <div class=\"board-card-links embedded\">\n {#each shownLinks as link}\n <CardLink item={link.target} type={ link.type } onSelect={ onSelect } />\n {/each}\n </div>\n {/if}\n\n <CardStatus item={ item } />\n </div>\n\n {#if prLinks.length}\n <div class=\"board-card-links attached\">\n {#each prLinks as link}\n <CardLink item={ link.target } type={ link.type } onSelect={ onSelect } />\n {/each}\n </div>\n {/if}\n\n</div>\n","<script>\n\n import { onMount } from 'svelte';\n\n import { HintList } from './components';\n\n import { Id } from './util';\n\n const inputId = Id();\n\n export let onClose;\n\n export let repositories;\n\n export let onSelect;\n\n let matchedHints;\n\n let keyboardSelectedHint;\n let mouseSelectedHint;\n\n let value = '';\n\n let input;\n\n $: {\n console.time('RepositorySelect#computeMatch');\n\n let opts = computeMatch(value, repositories);\n\n console.timeEnd('RepositorySelect#computeMatch');\n\n matchedHints = opts.matchedHints;\n\n keyboardSelectedHint = (\n matchedHints && keyboardSelectedHint && matchedHints.find(\n hint => hint.name === keyboardSelectedHint.name\n ) || opts.keyboardSelectedHint\n );\n }\n\n $: selectedHint = mouseSelectedHint || keyboardSelectedHint;\n\n function computeMatch(search, repositories) {\n\n const matchedHints = repositories.reduce((matchedHints, name) => {\n\n if (!name.toLowerCase().includes(search)) {\n return matchedHints;\n }\n\n const idx = name.indexOf(search);\n\n const hint = {\n name: name,\n parts: [\n {\n text: name.substring(0, idx)\n },\n {\n text: name.substring(idx, idx + search.length),\n matched: true\n },\n {\n text: name.substring(idx + search.length)\n }\n ],\n apply: (currentValue) => {\n\n return {\n val: name,\n idx: name.length\n };\n }\n };\n\n matchedHints.push(hint);\n\n return matchedHints;\n }, []);\n\n return {\n keyboardSelectedHint: matchedHints[0],\n matchedHints\n };\n }\n\n function applyHint(hint) {\n\n const {\n val,\n idx\n } = hint.apply(value);\n\n input.value = value = val;\n input.selectionEnd = input.selectionStart = idx;\n\n const [ owner, repo ] = val.split('/');\n\n return onSelect(owner, repo);\n }\n\n function handleInput(event) {\n value = event.target.value;\n }\n\n function nextHint(currentHint, direction) {\n\n const hints = (matchedHints || []);\n\n const currentIndex = hints.findIndex(hint => hint.name === currentHint.name);\n\n let nextIndex = currentIndex + direction;\n\n if (nextIndex < 0) {\n nextIndex = hints.length - 1;\n }\n\n if (nextIndex === hints.length) {\n nextIndex = 0;\n }\n\n return hints[nextIndex];\n }\n\n function handleInputKey(event) {\n\n const key = event.key;\n\n if (key === 'Enter') {\n if (keyboardSelectedHint) {\n applyHint(keyboardSelectedHint);\n event.preventDefault();\n }\n }\n\n if (key === 'ArrowUp') {\n keyboardSelectedHint = nextHint(keyboardSelectedHint, -1);\n event.preventDefault();\n }\n\n if (key === 'ArrowDown') {\n keyboardSelectedHint = nextHint(keyboardSelectedHint, 1);\n event.preventDefault();\n }\n\n if (key === 'Escape' && !value) {\n input.blur();\n\n event.preventDefault();\n }\n }\n\n onMount(() => {\n input.focus();\n });\n\n function checkClose(event) {\n\n if (event.key === 'Escape') {\n event.preventDefault();\n\n onClose();\n }\n }\n\n function checkSubmit(event) {\n event.preventDefault();\n\n if (!value) {\n return;\n }\n\n const [ owner, repo ] = value.split('/');\n\n if (!repo || !owner) {\n return;\n }\n\n return onSelect(owner, repo);\n }\n</script>\n\n<style lang=\"scss\">\n\n @import './HelpDropdown';\n\n .repository-select {\n position: fixed;\n top: 0;\n left: 0;\n right: 0;\n bottom: 0;\n\n z-index: 10;\n }\n\n .overlay {\n width: 100%;\n height: 100%;\n\n background: rgba(30, 30, 30, .30);\n }\n\n .issue-creator {\n position: absolute;\n z-index: 2;\n width: 500px;\n max-width: 100%;\n\n background: white;\n top: 30%;\n left: 50%;\n transform: translate(-50%);\n\n line-height: 1.5;\n\n border-radius: 5px;\n box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);\n }\n</style>\n\n<svelte:window on:keydown={ checkClose } />\n\n<div class=\"repository-select\">\n <div class=\"overlay\" on:click={ onClose }></div>\n\n <form class=\"issue-creator px-4 py-2\" on:submit={ checkSubmit }>\n\n <slot name=\"header\"></slot>\n\n <div class=\"form-group dropdown-parent\">\n\n <input\n id={ inputId }\n bind:this={ input }\n value={ value }\n on:input={ handleInput }\n on:keydown={ handleInputKey }\n placeholder=\"Choose repository\"\n autocomplete=\"off\"\n spellcheck=\"false\"\n aria-label=\"Repository name input\"\n class=\"form-control form-control-lg\"\n type=\"text\"\n />\n\n {#if value && matchedHints.length }\n <div class=\"help-dropdown\">\n <HintList\n hints={ matchedHints }\n selectedHint={ selectedHint }\n onHover={ hint => mouseSelectedHint = hint }\n onBlur={ () => mouseSelectedHint = null }\n onSelect={ applyHint }\n maxElements= { 7 }\n />\n </div>\n {/if}\n </div>\n </form>\n\n</div>","<script>\n import RepositorySelect from './RepositorySelect.svelte';\n\n export let repositories;\n\n export let open;\n export let onCreate;\n export let onClose;\n</script>\n\n{#if open}\n <RepositorySelect\n repositories={ repositories }\n onClose={ onClose }\n onSelect={ onCreate }\n >\n <h4 slot=\"header\" class=\"chooser-header my-3\">\n Create new Issue\n </h4>\n </RepositorySelect>\n{/if}","export default class Api {\n\n moveIssue(id, column, before, after) {\n const body = JSON.stringify({\n id,\n before,\n after,\n column\n });\n\n const url = this.appURL('/board/issues/move');\n\n return fetchJSON(url, {\n method: 'POST',\n body\n });\n }\n\n listCards(filter) {\n const url = this.appURL(`/board/cards${buildQueryString(filter)}`);\n\n return fetchJSON(url);\n }\n\n getBoard() {\n const url = this.appURL('/board');\n\n return fetchJSON(url);\n }\n\n getLoggedInUser() {\n const url = this.appURL('/login_check');\n\n return fetchJSON(url).catch(err => null);\n }\n\n listUpdates(filter, cursor) {\n const url = this.appURL(`/board/updates?cursor=${cursor}${buildQueryString(filter, '&')}`);\n\n return fetchJSON(url);\n }\n\n appURL(location) {\n const appBase = '/wuffle';\n\n return `${appBase}${location}`;\n }\n\n}\n\n\n// helpers ////////////////////\n\nfunction fetchJSON(url, options) {\n return fetch(url, {\n ...options,\n credentials: 'include'\n }).then(response => {\n const {\n ok,\n status\n } = response;\n\n if (!ok) {\n const error = new Error('HTTP ' + status);\n\n error.status = status;\n error.response = response;\n\n throw error;\n }\n\n return response;\n }).then(r => r.text()).then(t => JSON.parse(t));\n}\n\n\nfunction buildQueryString(filter, separator = '?') {\n if (filter) {\n return `${separator}s=${encodeURIComponent(filter)}`;\n } else {\n return '';\n }\n}","module.exports = function atoa (a, n) { return Array.prototype.slice.call(a, n); }\n","var si = typeof setImmediate === 'function', tick;\nif (si) {\n tick = function (fn) { setImmediate(fn); };\n} else if (typeof process !== 'undefined' && process.nextTick) {\n tick = process.nextTick;\n} else {\n tick = function (fn) { setTimeout(fn, 0); };\n}\n\nmodule.exports = tick;\n","'use strict';\n\nvar ticky = require('ticky');\n\nmodule.exports = function debounce (fn, args, ctx) {\n if (!fn) { return; }\n ticky(function run () {\n fn.apply(ctx || null, args || []);\n });\n};\n","'use strict';\n\nvar atoa = require('atoa');\nvar debounce = require('./debounce');\n\nmodule.exports = function emitter (thing, options) {\n var opts = options || {};\n var evt = {};\n if (thing === undefined) { thing = {}; }\n thing.on = function (type, fn) {\n if (!evt[type]) {\n evt[type] = [fn];\n } else {\n evt[type].push(fn);\n }\n return thing;\n };\n thing.once = function (type, fn) {\n fn._once = true; // thing.off(fn) still works!\n thing.on(type, fn);\n return thing;\n };\n thing.off = function (type, fn) {\n var c = arguments.length;\n if (c === 1) {\n delete evt[type];\n } else if (c === 0) {\n evt = {};\n } else {\n var et = evt[type];\n if (!et) { return thing; }\n et.splice(et.indexOf(fn), 1);\n }\n return thing;\n };\n thing.emit = function () {\n var args = atoa(arguments);\n return thing.emitterSnapshot(args.shift()).apply(this, args);\n };\n thing.emitterSnapshot = function (type) {\n var et = (evt[type] || []).slice(0);\n return function () {\n var args = atoa(arguments);\n var ctx = this || thing;\n if (type === 'error' && opts.throws !== false && !et.length) { throw args.length === 1 ? args[0] : args; }\n et.forEach(function emitter (listen) {\n if (opts.async) { debounce(listen, args, ctx); } else { listen.apply(ctx, args); }\n if (listen._once) { thing.off(type, listen); }\n });\n return thing;\n };\n };\n return thing;\n};\n","\nvar NativeCustomEvent = global.CustomEvent;\n\nfunction useNative () {\n try {\n var p = new NativeCustomEvent('cat', { detail: { foo: 'bar' } });\n return 'cat' === p.type && 'bar' === p.detail.foo;\n } catch (e) {\n }\n return false;\n}\n\n/**\n * Cross-browser `CustomEvent` constructor.\n *\n * https://developer.mozilla.org/en-US/docs/Web/API/CustomEvent.CustomEvent\n *\n * @public\n */\n\nmodule.exports = useNative() ? NativeCustomEvent :\n\n// IE >= 9\n'undefined' !== typeof document && 'function' === typeof document.createEvent ? function CustomEvent (type, params) {\n var e = document.createEvent('CustomEvent');\n if (params) {\n e.initCustomEvent(type, params.bubbles, params.cancelable, params.detail);\n } else {\n e.initCustomEvent(type, false, false, void 0);\n }\n return e;\n} :\n\n// IE <= 8\nfunction CustomEvent (type, params) {\n var e = document.createEventObject();\n e.type = type;\n if (params) {\n e.bubbles = Boolean(params.bubbles);\n e.cancelable = Boolean(params.cancelable);\n e.detail = params.detail;\n } else {\n e.bubbles = false;\n e.cancelable = false;\n e.detail = void 0;\n }\n return e;\n}\n","'use strict';\n\nvar eventmap = [];\nvar eventname = '';\nvar ron = /^on/;\n\nfor (eventname in global) {\n if (ron.test(eventname)) {\n eventmap.push(eventname.slice(2));\n }\n}\n\nmodule.exports = eventmap;\n","'use strict';\n\nvar customEvent = require('custom-event');\nvar eventmap = require('./eventmap');\nvar doc = global.document;\nvar addEvent = addEventEasy;\nvar removeEvent = removeEventEasy;\nvar hardCache = [];\n\nif (!global.addEventListener) {\n addEvent = addEventHard;\n removeEvent = removeEventHard;\n}\n\nmodule.exports = {\n add: addEvent,\n remove: removeEvent,\n fabricate: fabricateEvent\n};\n\nfunction addEventEasy (el, type, fn, capturing) {\n return el.addEventListener(type, fn, capturing);\n}\n\nfunction addEventHard (el, type, fn) {\n return el.attachEvent('on' + type, wrap(el, type, fn));\n}\n\nfunction removeEventEasy (el, type, fn, capturing) {\n return el.removeEventListener(type, fn, capturing);\n}\n\nfunction removeEventHard (el, type, fn) {\n var listener = unwrap(el, type, fn);\n if (listener) {\n return el.detachEvent('on' + type, listener);\n }\n}\n\nfunction fabricateEvent (el, type, model) {\n var e = eventmap.indexOf(type) === -1 ? makeCustomEvent() : makeClassicEvent();\n if (el.dispatchEvent) {\n el.dispatchEvent(e);\n } else {\n el.fireEvent('on' + type, e);\n }\n function makeClassicEvent () {\n var e;\n if (doc.createEvent) {\n e = doc.createEvent('Event');\n e.initEvent(type, true, true);\n } else if (doc.createEventObject) {\n e = doc.createEventObject();\n }\n return e;\n }\n function makeCustomEvent () {\n return new customEvent(type, { detail: model });\n }\n}\n\nfunction wrapperFactory (el, type, fn) {\n return function wrapper (originalEvent) {\n var e = originalEvent || global.event;\n e.target = e.target || e.srcElement;\n e.preventDefault = e.preventDefault || function preventDefault () { e.returnValue = false; };\n e.stopPropagation = e.stopPropagation || function stopPropagation () { e.cancelBubble = true; };\n e.which = e.which || e.keyCode;\n fn.call(el, e);\n };\n}\n\nfunction wrap (el, type, fn) {\n var wrapper = unwrap(el, type, fn) || wrapperFactory(el, type, fn);\n hardCache.push({\n wrapper: wrapper,\n element: el,\n type: type,\n fn: fn\n });\n return wrapper;\n}\n\nfunction unwrap (el, type, fn) {\n var i = find(el, type, fn);\n if (i) {\n var wrapper = hardCache[i].wrapper;\n hardCache.splice(i, 1); // free up a tad of memory\n return wrapper;\n }\n}\n\nfunction find (el, type, fn) {\n var i, item;\n for (i = 0; i < hardCache.length; i++) {\n item = hardCache[i];\n if (item.element === el && item.type === type && item.fn === fn) {\n return i;\n }\n }\n}\n","'use strict';\n\nvar cache = {};\nvar start = '(?:^|\\\\s)';\nvar end = '(?:\\\\s|$)';\n\nfunction lookupClass (className) {\n var cached = cache[className];\n if (cached) {\n cached.lastIndex = 0;\n } else {\n cache[className] = cached = new RegExp(start + className + end, 'g');\n }\n return cached;\n}\n\nfunction addClass (el, className) {\n var current = el.className;\n if (!current.length) {\n el.className = className;\n } else if (!lookupClass(className).test(current)) {\n el.className += ' ' + className;\n }\n}\n\nfunction rmClass (el, className) {\n el.className = el.className.replace(lookupClass(className), ' ').trim();\n}\n\nmodule.exports = {\n add: addClass,\n rm: rmClass\n};\n","'use strict';\n\nvar emitter = require('contra/emitter');\nvar crossvent = require('crossvent');\nvar classes = require('./classes');\nvar doc = document;\nvar documentElement = doc.documentElement;\n\nfunction dragula (initialContainers, options) {\n var len = arguments.length;\n if (len === 1 && Array.isArray(initialContainers) === false) {\n options = initialContainers;\n initialContainers = [];\n }\n var _mirror; // mirror image\n var _source; // source container\n var _item; // item being dragged\n var _offsetX; // reference x\n var _offsetY; // reference y\n var _moveX; // reference move x\n var _moveY; // reference move y\n var _initialSibling; // reference sibling when grabbed\n var _currentSibling; // reference sibling now\n var _copy; // item used for copying\n var _renderTimer; // timer for setTimeout renderMirrorImage\n var _lastDropTarget = null; // last container item was over\n var _grabbed; // holds mousedown context until first mousemove\n\n var o = options || {};\n if (o.moves === void 0) { o.moves = always; }\n if (o.accepts === void 0) { o.accepts = always; }\n if (o.invalid === void 0) { o.invalid = invalidTarget; }\n if (o.containers === void 0) { o.containers = initialContainers || []; }\n if (o.isContainer === void 0) { o.isContainer = never; }\n if (o.copy === void 0) { o.copy = false; }\n if (o.copySortSource === void 0) { o.copySortSource = false; }\n if (o.revertOnSpill === void 0) { o.revertOnSpill = false; }\n if (o.removeOnSpill === void 0) { o.removeOnSpill = false; }\n if (o.direction === void 0) { o.direction = 'vertical'; }\n if (o.ignoreInputTextSelection === void 0) { o.ignoreInputTextSelection = true; }\n if (o.mirrorContainer === void 0) { o.mirrorContainer = doc.body; }\n\n var drake = emitter({\n containers: o.containers,\n start: manualStart,\n end: end,\n cancel: cancel,\n remove: remove,\n destroy: destroy,\n canMove: canMove,\n dragging: false\n });\n\n if (o.removeOnSpill === true) {\n drake.on('over', spillOver).on('out', spillOut);\n }\n\n events();\n\n return drake;\n\n function isContainer (el) {\n return drake.containers.indexOf(el) !== -1 || o.isContainer(el);\n }\n\n function events (remove) {\n var op = remove ? 'remove' : 'add';\n touchy(documentElement, op, 'mousedown', grab);\n touchy(documentElement, op, 'mouseup', release);\n }\n\n function eventualMovements (remove) {\n var op = remove ? 'remove' : 'add';\n touchy(documentElement, op, 'mousemove', startBecauseMouseMoved);\n }\n\n function movements (remove) {\n var op = remove ? 'remove' : 'add';\n crossvent[op](documentElement, 'selectstart', preventGrabbed); // IE8\n crossvent[op](documentElement, 'click', preventGrabbed);\n }\n\n function destroy () {\n events(true);\n release({});\n }\n\n function preventGrabbed (e) {\n if (_grabbed) {\n e.preventDefault();\n }\n }\n\n function grab (e) {\n _moveX = e.clientX;\n _moveY = e.clientY;\n\n var ignore = whichMouseButton(e) !== 1 || e.metaKey || e.ctrlKey;\n if (ignore) {\n return; // we only care about honest-to-god left clicks and touch events\n }\n var item = e.target;\n var context = canStart(item);\n if (!context) {\n return;\n }\n _grabbed = context;\n eventualMovements();\n if (e.type === 'mousedown') {\n if (isInput(item)) { // see also: https://github.com/bevacqua/dragula/issues/208\n item.focus(); // fixes https://github.com/bevacqua/dragula/issues/176\n } else {\n e.preventDefault(); // fixes https://github.com/bevacqua/dragula/issues/155\n }\n }\n }\n\n function startBecauseMouseMoved (e) {\n if (!_grabbed) {\n return;\n }\n if (whichMouseButton(e) === 0) {\n release({});\n return; // when text is selected on an input and then dragged, mouseup doesn't fire. this is our only hope\n }\n\n // truthy check fixes #239, equality fixes #207, fixes #501\n if ((e.clientX !== void 0 && Math.abs(e.clientX - _moveX) <= (o.slideFactorX || 0)) &&\n (e.clientY !== void 0 && Math.abs(e.clientY - _moveY) <= (o.slideFactorY || 0))) {\n return;\n }\n\n if (o.ignoreInputTextSelection) {\n var clientX = getCoord('clientX', e) || 0;\n var clientY = getCoord('clientY', e) || 0;\n var elementBehindCursor = doc.elementFromPoint(clientX, clientY);\n if (isInput(elementBehindCursor)) {\n return;\n }\n }\n\n var grabbed = _grabbed; // call to end() unsets _grabbed\n eventualMovements(true);\n movements();\n end();\n start(grabbed);\n\n var offset = getOffset(_item);\n _offsetX = getCoord('pageX', e) - offset.left;\n _offsetY = getCoord('pageY', e) - offset.top;\n\n classes.add(_copy || _item, 'gu-transit');\n renderMirrorImage();\n drag(e);\n }\n\n function canStart (item) {\n if (drake.dragging && _mirror) {\n return;\n }\n if (isContainer(item)) {\n return; // don't drag container itself\n }\n var handle = item;\n while (getParent(item) && isContainer(getParent(item)) === false) {\n if (o.invalid(item, handle)) {\n return;\n }\n item = getParent(item); // drag target should be a top element\n if (!item) {\n return;\n }\n }\n var source = getParent(item);\n if (!source) {\n return;\n }\n if (o.invalid(item, handle)) {\n return;\n }\n\n var movable = o.moves(item, source, handle, nextEl(item));\n if (!movable) {\n return;\n }\n\n return {\n item: item,\n source: source\n };\n }\n\n function canMove (item) {\n return !!canStart(item);\n }\n\n function manualStart (item) {\n var context = canStart(item);\n if (context) {\n start(context);\n }\n }\n\n function start (context) {\n if (isCopy(context.item, context.source)) {\n _copy = context.item.cloneNode(true);\n drake.emit('cloned', _copy, context.item, 'copy');\n }\n\n _source = context.source;\n _item = context.item;\n _initialSibling = _currentSibling = nextEl(context.item);\n\n drake.dragging = true;\n drake.emit('drag', _item, _source);\n }\n\n function invalidTarget () {\n return false;\n }\n\n function end () {\n if (!drake.dragging) {\n return;\n }\n var item = _copy || _item;\n drop(item, getParent(item));\n }\n\n function ungrab () {\n _grabbed = false;\n eventualMovements(true);\n movements(true);\n }\n\n function release (e) {\n ungrab();\n\n if (!drake.dragging) {\n return;\n }\n var item = _copy || _item;\n var clientX = getCoord('clientX', e) || 0;\n var clientY = getCoord('clientY', e) || 0;\n var elementBehindCursor = getElementBehindPoint(_mirror, clientX, clientY);\n var dropTarget = findDropTarget(elementBehindCursor, clientX, clientY);\n if (dropTarget && ((_copy && o.copySortSource) || (!_copy || dropTarget !== _source))) {\n drop(item, dropTarget);\n } else if (o.removeOnSpill) {\n remove();\n } else {\n cancel();\n }\n }\n\n function drop (item, target) {\n var parent = getParent(item);\n if (_copy && o.copySortSource && target === _source) {\n parent.removeChild(_item);\n }\n if (isInitialPlacement(target)) {\n drake.emit('cancel', item, _source, _source);\n } else {\n drake.emit('drop', item, target, _source, _currentSibling);\n }\n cleanup();\n }\n\n function remove () {\n if (!drake.dragging) {\n return;\n }\n var item = _copy || _item;\n var parent = getParent(item);\n if (parent) {\n parent.removeChild(item);\n }\n drake.emit(_copy ? 'cancel' : 'remove', item, parent, _source);\n cleanup();\n }\n\n function cancel (revert) {\n if (!drake.dragging) {\n return;\n }\n var reverts = arguments.length > 0 ? revert : o.revertOnSpill;\n var item = _copy || _item;\n var parent = getParent(item);\n var initial = isInitialPlacement(parent);\n if (initial === false && reverts) {\n if (_copy) {\n if (parent) {\n parent.removeChild(_copy);\n }\n } else {\n _source.insertBefore(item, _initialSibling);\n }\n }\n if (initial || reverts) {\n drake.emit('cancel', item, _source, _source);\n } else {\n drake.emit('drop', item, parent, _source, _currentSibling);\n }\n cleanup();\n }\n\n function cleanup () {\n var item = _copy || _item;\n ungrab();\n removeMirrorImage();\n if (item) {\n classes.rm(item, 'gu-transit');\n }\n if (_renderTimer) {\n clearTimeout(_renderTimer);\n }\n drake.dragging = false;\n if (_lastDropTarget) {\n drake.emit('out', item, _lastDropTarget, _source);\n }\n drake.emit('dragend', item);\n _source = _item = _copy = _initialSibling = _currentSibling = _renderTimer = _lastDropTarget = null;\n }\n\n function isInitialPlacement (target, s) {\n var sibling;\n if (s !== void 0) {\n sibling = s;\n } else if (_mirror) {\n sibling = _currentSibling;\n } else {\n sibling = nextEl(_copy || _item);\n }\n return target === _source && sibling === _initialSibling;\n }\n\n function findDropTarget (elementBehindCursor, clientX, clientY) {\n var target = elementBehindCursor;\n while (target && !accepted()) {\n target = getParent(target);\n }\n return target;\n\n function accepted () {\n var droppable = isContainer(target);\n if (droppable === false) {\n return false;\n }\n\n var immediate = getImmediateChild(target, elementBehindCursor);\n var reference = getReference(target, immediate, clientX, clientY);\n var initial = isInitialPlacement(target, reference);\n if (initial) {\n return true; // should always be able to drop it right back where it was\n }\n return o.accepts(_item, target, _source, reference);\n }\n }\n\n function drag (e) {\n if (!_mirror) {\n return;\n }\n e.preventDefault();\n\n var clientX = getCoord('clientX', e) || 0;\n var clientY = getCoord('clientY', e) || 0;\n var x = clientX - _offsetX;\n var y = clientY - _offsetY;\n\n _mirror.style.left = x + 'px';\n _mirror.style.top = y + 'px';\n\n var item = _copy || _item;\n var elementBehindCursor = getElementBehindPoint(_mirror, clientX, clientY);\n var dropTarget = findDropTarget(elementBehindCursor, clientX, clientY);\n var changed = dropTarget !== null && dropTarget !== _lastDropTarget;\n if (changed || dropTarget === null) {\n out();\n _lastDropTarget = dropTarget;\n over();\n }\n var parent = getParent(item);\n if (dropTarget === _source && _copy && !o.copySortSource) {\n if (parent) {\n parent.removeChild(item);\n }\n return;\n }\n var reference;\n var immediate = getImmediateChild(dropTarget, elementBehindCursor);\n if (immediate !== null) {\n reference = getReference(dropTarget, immediate, clientX, clientY);\n } else if (o.revertOnSpill === true && !_copy) {\n reference = _initialSibling;\n dropTarget = _source;\n } else {\n if (_copy && parent) {\n parent.removeChild(item);\n }\n return;\n }\n if (\n (reference === null && changed) ||\n reference !== item &&\n reference !== nextEl(item)\n ) {\n _currentSibling = reference;\n dropTarget.insertBefore(item, reference);\n drake.emit('shadow', item, dropTarget, _source);\n }\n function moved (type) { drake.emit(type, item, _lastDropTarget, _source); }\n function over () { if (changed) { moved('over'); } }\n function out () { if (_lastDropTarget) { moved('out'); } }\n }\n\n function spillOver (el) {\n classes.rm(el, 'gu-hide');\n }\n\n function spillOut (el) {\n if (drake.dragging) { classes.add(el, 'gu-hide'); }\n }\n\n function renderMirrorImage () {\n if (_mirror) {\n return;\n }\n var rect = _item.getBoundingClientRect();\n _mirror = _item.cloneNode(true);\n _mirror.style.width = getRectWidth(rect) + 'px';\n _mirror.style.height = getRectHeight(rect) + 'px';\n classes.rm(_mirror, 'gu-transit');\n classes.add(_mirror, 'gu-mirror');\n o.mirrorContainer.appendChild(_mirror);\n touchy(documentElement, 'add', 'mousemove', drag);\n classes.add(o.mirrorContainer, 'gu-unselectable');\n drake.emit('cloned', _mirror, _item, 'mirror');\n }\n\n function removeMirrorImage () {\n if (_mirror) {\n classes.rm(o.mirrorContainer, 'gu-unselectable');\n touchy(documentElement, 'remove', 'mousemove', drag);\n getParent(_mirror).removeChild(_mirror);\n _mirror = null;\n }\n }\n\n function getImmediateChild (dropTarget, target) {\n var immediate = target;\n while (immediate !== dropTarget && getParent(immediate) !== dropTarget) {\n immediate = getParent(immediate);\n }\n if (immediate === documentElement) {\n return null;\n }\n return immediate;\n }\n\n function getReference (dropTarget, target, x, y) {\n var horizontal = o.direction === 'horizontal';\n var reference = target !== dropTarget ? inside() : outside();\n return reference;\n\n function outside () { // slower, but able to figure out any position\n var len = dropTarget.children.length;\n var i;\n var el;\n var rect;\n for (i = 0; i < len; i++) {\n el = dropTarget.children[i];\n rect = el.getBoundingClientRect();\n if (horizontal && (rect.left + rect.width / 2) > x) { return el; }\n if (!horizontal && (rect.top + rect.height / 2) > y) { return el; }\n }\n return null;\n }\n\n function inside () { // faster, but only available if dropped inside a child element\n var rect = target.getBoundingClientRect();\n if (horizontal) {\n return resolve(x > rect.left + getRectWidth(rect) / 2);\n }\n return resolve(y > rect.top + getRectHeight(rect) / 2);\n }\n\n function resolve (after) {\n return after ? nextEl(target) : target;\n }\n }\n\n function isCopy (item, container) {\n return typeof o.copy === 'boolean' ? o.copy : o.copy(item, container);\n }\n}\n\nfunction touchy (el, op, type, fn) {\n var touch = {\n mouseup: 'touchend',\n mousedown: 'touchstart',\n mousemove: 'touchmove'\n };\n var pointers = {\n mouseup: 'pointerup',\n mousedown: 'pointerdown',\n mousemove: 'pointermove'\n };\n var microsoft = {\n mouseup: 'MSPointerUp',\n mousedown: 'MSPointerDown',\n mousemove: 'MSPointerMove'\n };\n if (global.navigator.pointerEnabled) {\n crossvent[op](el, pointers[type], fn);\n } else if (global.navigator.msPointerEnabled) {\n crossvent[op](el, microsoft[type], fn);\n } else {\n crossvent[op](el, touch[type], fn);\n crossvent[op](el, type, fn);\n }\n}\n\nfunction whichMouseButton (e) {\n if (e.touches !== void 0) { return e.touches.length; }\n if (e.which !== void 0 && e.which !== 0) { return e.which; } // see https://github.com/bevacqua/dragula/issues/261\n if (e.buttons !== void 0) { return e.buttons; }\n var button = e.button;\n if (button !== void 0) { // see https://github.com/jquery/jquery/blob/99e8ff1baa7ae341e94bb89c3e84570c7c3ad9ea/src/event.js#L573-L575\n return button & 1 ? 1 : button & 2 ? 3 : (button & 4 ? 2 : 0);\n }\n}\n\nfunction getOffset (el) {\n var rect = el.getBoundingClientRect();\n return {\n left: rect.left + getScroll('scrollLeft', 'pageXOffset'),\n top: rect.top + getScroll('scrollTop', 'pageYOffset')\n };\n}\n\nfunction getScroll (scrollProp, offsetProp) {\n if (typeof global[offsetProp] !== 'undefined') {\n return global[offsetProp];\n }\n if (documentElement.clientHeight) {\n return documentElement[scrollProp];\n }\n return doc.body[scrollProp];\n}\n\nfunction getElementBehindPoint (point, x, y) {\n point = point || {};\n var state = point.className || '';\n var el;\n point.className += ' gu-hide';\n el = doc.elementFromPoint(x, y);\n point.className = state;\n return el;\n}\n\nfunction never () { return false; }\nfunction always () { return true; }\nfunction getRectWidth (rect) { return rect.width || (rect.right - rect.left); }\nfunction getRectHeight (rect) { return rect.height || (rect.bottom - rect.top); }\nfunction getParent (el) { return el.parentNode === doc ? null : el.parentNode; }\nfunction isInput (el) { return el.tagName === 'INPUT' || el.tagName === 'TEXTAREA' || el.tagName === 'SELECT' || isEditable(el); }\nfunction isEditable (el) {\n if (!el) { return false; } // no parents were editable\n if (el.contentEditable === 'false') { return false; } // stop the lookup\n if (el.contentEditable === 'true') { return true; } // found a contentEditable element in the chain\n return isEditable(getParent(el)); // contentEditable is set to 'inherit'\n}\n\nfunction nextEl (el) {\n return el.nextElementSibling || manually();\n function manually () {\n var sibling = el;\n do {\n sibling = sibling.nextSibling;\n } while (sibling && sibling.nodeType !== 1);\n return sibling;\n }\n}\n\nfunction getEventHost (e) {\n // on touchend event, we have to use `e.changedTouches`\n // see http://stackoverflow.com/questions/7192563/touchend-event-properties\n // see https://github.com/bevacqua/dragula/issues/34\n if (e.targetTouches && e.targetTouches.length) {\n return e.targetTouches[0];\n }\n if (e.changedTouches && e.changedTouches.length) {\n return e.changedTouches[0];\n }\n return e;\n}\n\nfunction getCoord (coord, e) {\n var host = getEventHost(e);\n var missMap = {\n pageX: 'clientX', // IE8\n pageY: 'clientY' // IE8\n };\n if (coord in missMap && !(coord in host) && missMap[coord] in host) {\n coord = missMap[coord];\n }\n return host[coord];\n}\n\nmodule.exports = dragula;\n","<script>\n import BoardFilter from './BoardFilter.svelte';\n\n import Avatar from './components/Avatar.svelte';\n import Loader from './components/Loader.svelte';\n\n import PoweredBy from './PoweredBy.svelte';\n\n import Notifications from './components/Notifications.svelte';\n import Notification from './components/Notification.svelte';\n\n import Card from './Card.svelte';\n\n import CreateIssue from './CreateIssue.svelte';\n\n import Api from './Api';\n\n import Dragula from 'dragula';\n\n import {\n isNewIssueShortcut\n } from './shortcuts';\n\n import {\n Id,\n createLocalStore,\n createHistory,\n isClosingLink,\n isOpenOrMerged,\n isPull,\n periodic,\n throttle\n } from './util';\n\n import loaderImage from './logo-gray.svg';\n import errorImage from './error.svg';\n\n import { onMount } from 'svelte';\n\n const DEFAULT_PER_COLUMN_RENDER_COUNT = 25;\n\n const POLL_KEY = 'Taskboard_polling';\n\n const api = new Api();\n const localStore = createLocalStore();\n const history = createHistory();\n\n const navId = Id();\n\n let name = '';\n let columns = [];\n let items = {};\n\n let itemsById = {};\n\n let loading = true;\n let updating = 0;\n let error = null;\n let warnings = [];\n\n let user = null;\n let cursor = null;\n\n let accessNotification = false;\n\n let showCreate = false;\n\n let renderCountByColumn = {};\n\n let filterOptions = {};\n\n $: defaultCollapsed = columns.reduce((defaultCollapsed, column) => {\n defaultCollapsed[column.name] = column.collapsed;\n\n return defaultCollapsed;\n }, {});\n\n let filter = parseSearchFilter();\n\n let localCollapsed = parseCollapsedColumns();\n\n $: collapsed = {\n ...defaultCollapsed,\n ...localCollapsed\n };\n\n $: updateBoardLocation(filter, localCollapsed);\n\n // shown items\n $: shownItems = Object.keys(items).reduce((shownItems, column) => {\n\n const columnItems = items[column];\n\n shownItems[column] = columnItems.filter(item => !isClosingPull(item));\n\n return shownItems;\n }, {});\n\n // actually rendered items\n $: renderedItems = Object.keys(shownItems).reduce((renderedItems, column) => {\n\n const renderCount = renderCountByColumn[column] || DEFAULT_PER_COLUMN_RENDER_COUNT;\n const items = shownItems[column];\n\n renderedItems[column] = items.slice(0, renderCount);\n\n return renderedItems;\n }, {});\n\n function action(name, options = {}) {\n\n return fn => {\n\n return fn()\n .then(result => {\n discardWarning(name);\n\n return result;\n })\n .catch(err => {\n return handleWarning(name, err, options);\n });\n };\n }\n\n function handleWarning(action, error, options) {\n console.warn('%s failed', action, error);\n\n if (options.display === false) {\n throw error;\n }\n\n const index = warnings.findIndex(w => w.action === action);\n\n const warning = {\n action,\n error\n };\n\n if (index !== -1) {\n warnings = [\n ...warnings.slice(0, index),\n warning,\n ...warnings.slice(index + 1)\n ];\n } else {\n warnings = [\n ...warnings,\n warning\n ];\n }\n }\n\n function discardWarnings() {\n warnings = [];\n }\n\n function discardWarning(action) {\n warnings = warnings.filter(w => w.action !== action);\n }\n\n function handleError(_error) {\n console.error(_error);\n\n error = _error;\n }\n\n function discardError() {\n error = null;\n }\n\n function loadBoard() {\n discardError();\n discardWarnings();\n\n loading = true;\n\n return Promise.all([\n fetchBoard(),\n loginCheck(),\n fetchCards(filter)\n ]).then(_ => {\n discardError();\n }).catch(error => {\n handleError(error);\n }).finally(() => {\n loading = false;\n });\n }\n\n function setupHooks() {\n\n const poll = localStore.get(POLL_KEY, true);\n\n const teardownHooks = [\n\n // poll for issue updates every three seconds\n poll && periodic(pollUpdates, 1000 * 3),\n\n // check login every 1 minutes\n poll && periodic(loginCheck, 1000 * 60 * 1),\n\n // hook into history changes\n history.onPop(() => {\n const newFilter = parseSearchFilter();\n\n localCollapsed = parseCollapsedColumns();\n\n filterChanged(newFilter);\n })\n ];\n\n return () => teardownHooks.forEach(fn => fn && fn());\n }\n\n onMount(() => {\n loadBoard();\n setupHooks();\n });\n\n function applyFilter(qualifier, value, add) {\n\n if (/[\\s:]+/.test(value)) {\n value = '\"' + value + '\"';\n }\n\n const criteria = value && `${qualifier}:${value}`;\n\n if (!criteria) {\n return;\n }\n\n let newFilter;\n\n const criteriaIndex = filter.indexOf(criteria);\n\n if (criteriaIndex === 0) {\n newFilter = filter.substring(criteria.length + 1);\n } else if (criteriaIndex > 0) {\n newFilter = filter.substring(0, criteriaIndex - 1) + filter.substring(criteriaIndex + criteria.length);\n } else {\n if (add && filter.trim()) {\n newFilter = `${filter} ${qualifier}:${value}`;\n } else {\n newFilter = criteria;\n }\n }\n\n return filterChanged(newFilter);\n }\n\n function filterChanged(value) {\n\n if (value === filter) {\n return;\n }\n\n if (value.trim() !== filter.trim()) {\n\n action('Fetching cards')(\n () => fetchCards(value)\n );\n }\n\n filter = value;\n }\n\n function parseSearchFilter() {\n if (typeof window === 'undefined') {\n return '';\n }\n\n const url = new URL(window.location.href);\n\n return url.searchParams.get('s') || '';\n }\n\n function parseCollapsedColumns() {\n if (typeof window === 'undefined') {\n return '';\n }\n\n const url = new URL(window.location.href);\n\n const collapsed = url.searchParams.get('c');\n\n if (!collapsed) {\n return {};\n }\n\n return collapsed.split(',').filter(c => c).reduce((collapsed, column) => {\n\n const split = column.split('!');\n\n collapsed[split[1] || split[0]] = split.length === 1;\n\n return collapsed;\n }, {});\n }\n\n function updateBoardLocation(filter, collapsed) {\n const ref = buildBoardLink(filter, collapsed);\n\n if (ref !== window.location.href) {\n history.push(ref);\n }\n }\n\n function buildBoardLink(filter, collapsed) {\n\n const url = new URL(window.location.href);\n\n const searchParams = url.searchParams;\n\n const searchParam = filter;\n const collapsedParam = Object.entries(collapsed).filter(([ key, value ]) => {\n return defaultCollapsed[key] !== value;\n }).map(\n ([ key, value ]) => (value ? '' : '!') + key\n ).join(',');\n\n if (searchParam) {\n searchParams.set('s', searchParam);\n } else {\n searchParams.delete('s');\n }\n\n if (collapsedParam) {\n searchParams.set('c', collapsedParam);\n } else {\n searchParams.delete('c');\n }\n\n return url.toString();\n }\n\n function loginCheck() {\n return action('User login check')(\n () => api.getLoggedInUser().then(newUser => {\n\n if (user && !newUser) {\n window.location.reload();\n } else {\n user = newUser;\n }\n })\n );\n }\n\n function fetchBoard() {\n return api.getBoard().then(result => {\n columns = result.columns;\n name = result.name;\n });\n }\n\n function updateCards(_items, _cursor) {\n console.time('Taskboard#updateCards');\n\n const _itemsById = {};\n const _filterOptions = {};\n\n for (const columnItems of Object.values(_items)) {\n\n for (const item of columnItems) {\n const {\n id,\n user,\n milestone,\n assignees,\n labels,\n repository,\n requested_reviewers\n } = item;\n\n const repoOptions = _filterOptions['repo'] = _filterOptions['repo'] || {};\n\n repoOptions[repository.owner.login + '/' + repository.name] = true;\n\n if (milestone) {\n const milestoneOptions = _filterOptions['milestone'] = _filterOptions['milestone'] || {};\n\n milestoneOptions[milestone.title] = true;\n }\n\n if (user) {\n const authorOptions = _filterOptions['author'] = _filterOptions['author'] || {};\n\n authorOptions[user.login] = true;\n }\n\n assignees.forEach(assignee => {\n const assigneeOptions = _filterOptions['assignee'] = _filterOptions['assignee'] || {};\n\n assigneeOptions[assignee.login] = true;\n });\n\n if (requested_reviewers) {\n requested_reviewers.forEach(reviewer => {\n const reviewerOptions = _filterOptions['reviewer'] = _filterOptions['reviewer'] || {};\n\n reviewerOptions[reviewer.login] = true;\n });\n }\n\n labels.forEach(label => {\n\n if (!label.column_label) {\n const labelOptions = _filterOptions['label'] = _filterOptions['label'] || {};\n\n labelOptions[label.name] = true;\n }\n });\n\n _itemsById[id] = item;\n }\n\n }\n\n items = _items;\n itemsById = _itemsById;\n filterOptions = Object.entries(_filterOptions).reduce((opts, entry) => {\n\n const [ key, value ] = entry;\n\n opts[key] = Object.keys(value);\n\n return opts;\n }, {});\n\n cursor = _cursor;\n console.timeEnd('Taskboard#updateCards');\n }\n\n function fetchCards(newFilter) {\n\n updating++;\n\n return api.listCards(newFilter).then(result => {\n\n // do not apply updates for outdated filters\n if (newFilter !== filter) {\n return;\n }\n\n const {\n items,\n cursor\n } = result;\n\n updateCards(items, cursor);\n }).finally(() => updating--);\n }\n\n\n function pollUpdates() {\n\n if (updating) {\n return;\n }\n\n const currentFilter = filter;\n\n return action('Checking for updates', { display: false })(\n () => api.listUpdates(currentFilter, cursor).then(updates => {\n\n if (!updates.length) {\n return;\n }\n\n if (currentFilter !== filter) {\n return;\n }\n\n const {\n items: _items,\n itemsById: _itemsById,\n cursor: _cursor\n } = applyUpdates(updates, items, itemsById);\n\n items = _items;\n itemsById = _itemsById;\n cursor = _cursor;\n })\n );\n }\n\n function applyUpdates(updates, items, itemsById) {\n\n const cursor = updates[updates.length - 1].id;\n\n updates.forEach(update => {\n const {\n type,\n issue\n } = update;\n\n const {\n id\n } = issue;\n\n const from = itemsById[id];\n\n const to = type !== 'remove' && issue;\n\n items = {\n ...items,\n ...moveItem(items, issue, from, to)\n };\n\n // remove from index\n if (type === 'remove') {\n const {\n [id]: removedItem,\n ...remainingItems\n } = itemsById;\n\n itemsById = remainingItems;\n } else {\n\n // update in index\n itemsById = {\n ...itemsById,\n [id]: issue\n };\n }\n });\n\n return {\n cursor,\n itemsById,\n items\n };\n }\n\n const drake = Dragula({\n isContainer: (el) => {\n return el.matches('[data-column-id]');\n }\n });\n\n function getCardId(el) {\n const dataset = el.dataset;\n return dataset.cardId;\n }\n\n function getCardOrder(el) {\n const dataset = el.dataset;\n return parseFloat(dataset.cardOrder);\n }\n\n function getColumnId(el) {\n const dataset = el.dataset;\n return dataset.columnId;\n }\n\n function checkCancel(event) {\n if (event.key === 'Escape') {\n drake.cancel(true);\n }\n }\n\n drake.on('drag', () => {\n document.addEventListener('keydown', checkCancel);\n });\n\n drake.on('dragend', () => {\n document.removeEventListener('keydown', checkCancel);\n });\n\n drake.on('drop', (el, target, source, nextEl) => {\n const cardId = getCardId(el);\n const cardOrder = getCardOrder(el);\n\n const previousEl = el.previousElementSibling;\n\n const nextOrder = nextEl && getCardOrder(nextEl);\n const previousOrder = previousEl && getCardOrder(previousEl);\n\n const newOrder =\n previousOrder && nextOrder\n ? (previousOrder + nextOrder) / 2\n : previousOrder\n ? previousOrder + 731241.218\n : nextOrder\n ? nextOrder - 811231.691\n : -71271.88455;\n\n handleCardDrop(\n itemsById[cardId],\n {\n order: cardOrder,\n column: getColumnId(source)\n },\n {\n order: newOrder,\n column: getColumnId(target)\n }\n );\n\n });\n\n function handleCardDrop(card, from, to) {\n\n const { before, after } = moveCard(card, from, to);\n\n return api.moveIssue(\n card.id,\n to.column,\n before && before.id,\n after && after.id\n ).catch(err => {\n console.warn('reverting card movement', err);\n\n accessNotification = user ? 'forbidden' : 'authentication-required';\n\n setTimeout(() => {\n accessNotification = false;\n }, 8000);\n\n moveCard(card, to, from);\n });\n }\n\n function removeItem(item, list = []) {\n const { id } = item;\n\n return list.filter(existing => existing.id !== id);\n }\n\n function insertItem(item, order, list = []) {\n const insertIdx = list.findIndex(existing => existing.order > order);\n\n if (insertIdx === -1) {\n return [ ...list, item ];\n }\n\n return [\n ...list.slice(0, insertIdx),\n item,\n ...list.slice(insertIdx)\n ];\n\n }\n\n function moveCard(card, from, to) {\n\n // temporarily update card with new column and ordering\n card.column = to.column;\n card.order = to.order;\n\n const updatedItems = moveItem(items, card, from, to);\n\n items = {\n ...items,\n ...updatedItems\n };\n\n const targetColumn = updatedItems[to.column];\n\n const cardIndex = targetColumn.findIndex(el => el.id === card.id);\n\n return {\n after: targetColumn[cardIndex - 1],\n before: targetColumn[cardIndex + 1]\n };\n }\n\n function moveItem(items, item, from, to) {\n\n const oldColumn = from && from.column;\n\n const newColumn = to && to.column;\n const newOrder = to && to.order;\n\n // remove from old column\n if (oldColumn) {\n const updatedColumn = removeItem(item, items[oldColumn]);\n\n items = {\n ...items,\n [oldColumn]: updatedColumn\n };\n }\n\n // add to new column\n if (newColumn) {\n const updatedColumn = insertItem(item, newOrder, items[newColumn]);\n\n items = {\n ...items,\n [newColumn]: updatedColumn\n };\n }\n\n return items;\n }\n\n function toggleCollapse(column) {\n\n localCollapsed = {\n ...localCollapsed,\n [column.name]: !collapsed[column.name]\n };\n }\n\n function isClosingPull(item) {\n return isPull(item) && isOpenOrMerged(item) && item.links.some(link => {\n return isClosingLink(link) && itemsById[link.target.id];\n });\n }\n\n function checkRender(columnName) {\n\n return throttle(function(event) {\n\n const node = event.target;\n\n const {\n scrollHeight,\n scrollTop,\n offsetHeight\n } = node;\n\n if (scrollTop + offsetHeight > scrollHeight * .95) {\n\n const columnItems = shownItems[columnName] || [];\n\n const columnRenderedCount = renderCountByColumn[columnName] || DEFAULT_PER_COLUMN_RENDER_COUNT;\n\n if (columnRenderedCount < columnItems.length) {\n\n renderCountByColumn = {\n ...renderCountByColumn,\n [columnName]: columnRenderedCount + DEFAULT_PER_COLUMN_RENDER_COUNT / 5\n };\n }\n }\n }, 5);\n }\n\n function openCreateIssue() {\n showCreate = true;\n }\n\n function closeCreateIssue() {\n showCreate = false;\n }\n\n function createIssue(owner, repo) {\n closeCreateIssue();\n\n window.open(\n `https://github.com/${owner}/${repo}/issues/new/choose`,\n '_blank'\n );\n }\n\n function handleGlobalKey(event) {\n\n if (isNewIssueShortcut(event)) {\n openCreateIssue();\n\n event.preventDefault();\n }\n }\n</script>\n\n<style lang=\"scss\">\n @import \"variables\";\n\n @import \"./Taskboard\";\n\n .vertical-divider {\n display: inline-block;\n width: 1px;\n height: 0.9em;\n margin: 0 8px;\n\n background: $gray-300;\n }\n\n .muted {\n color: $gray-600;\n }\n\n .taskboard {\n position: relative;\n }\n</style>\n\n<svelte:head>\n {#if !loading}\n <title>{ name } · Wuffle Board</title>\n {/if}\n</svelte:head>\n\n<svelte:window on:keydown={ handleGlobalKey } />\n\n<div class=\"taskboard\">\n\n <Loader shown={ loading }>\n <img src={ loaderImage } width=\"64\" alt=\"Loading\" />\n </Loader>\n\n <CreateIssue\n repositories={ filterOptions['repo'] }\n onCreate={ createIssue }\n open={ showCreate }\n onClose={ closeCreateIssue }\n />\n\n {#if error}\n <div class=\"taskboard-error\">\n\n <img src={ errorImage } width=\"128\" alt=\"An error occured\" />\n\n <p>We could not load the board.</p>\n\n <button class=\"btn btn-primary\" on:click={ () => loadBoard() }>\n Retry\n </button>\n </div>\n {/if}\n\n <Notifications>\n {#if !error}\n {#each warnings as warning}\n <Notification type=\"warning\" message=\"{ warning.action } failed\">\n Could not reach the board back-end. <a href>Reload board.</a>\n </Notification>\n {/each}\n {/if}\n\n {#if accessNotification}\n <Notification type=\"error\" message=\"Failed to move card\">\n {#if accessNotification === 'forbidden'}\n It seems like you do not have write access to the underlying GitHub repository.\n {:else}\n Please <a href=\"/wuffle/login\" aria-label=\"Login via GitHub\">login via GitHub</a> to interact with cards.\n {/if}\n </Notification>\n {/if}\n </Notifications>\n\n <PoweredBy />\n\n <nav class=\"navbar navbar-expand navbar-light taskboard-header\">\n\n <a class=\"navbar-brand m-0 mr-3 my-2\" href=\"/\" aria-label={ name } title=\"{ name } - Wuffle board\">\n <img src=\"./logo.svg\" height=\"30px\" alt=\"Wuffle board logo\" class=\"logo\" />\n </a>\n <button class=\"navbar-toggler\" type=\"button\" data-toggle=\"collapse\" data-target=\"#{navId}\" aria-controls={navId} aria-expanded=\"false\" aria-label=\"Toggle navigation\">\n <span class=\"navbar-toggler-icon\"></span>\n </button>\n\n <div class=\"collapse navbar-collapse\" id={navId}>\n\n <form class=\"form-inline board-filter-parent my-2 my-lg-0\" on:submit|preventDefault={ () => {} }>\n <BoardFilter\n value={ filter }\n completionOptions={ filterOptions }\n onChange={ filterChanged }\n placeholder={ 'Filter board...' }\n />\n </form>\n\n <form class=\"form-inline mx-3 my-2 my-sm-0\" on:submit|preventDefault={ openCreateIssue }>\n <button class=\"btn btn-outline-primary\" type=\"submit\" title=\"Create new issue (n)\">\n <svg xmlns=\"http://www.w3.org/2000/svg\" height=\"1em\" viewBox=\"0 0 16 16\"><path fill=\"currentColor\" fill-rule=\"evenodd\" d=\"M7.75 2a.75.75 0 01.75.75V7h4.25a.75.75 0 110 1.5H8.5v4.25a.75.75 0 11-1.5 0V8.5H2.75a.75.75 0 010-1.5H7V2.75A.75.75 0 017.75 2z\"></path></svg>\n </button>\n </form>\n </div>\n\n <div class=\"taskboard-header-login ml-2\">\n {#if user}\n <a href=\"/wuffle/logout\" aria-label=\"Logout\">\n <Avatar title={ `Logout ${user.login}` } rounded>\n <img src=\"{ user.avatar_url }&s=40\" style=\"max-width: 100%\" alt=\"Logged in user avatar\" />\n </Avatar>\n </a>\n {:else}\n <a href=\"/wuffle/login\" aria-label=\"Login with GitHub\">\n <Avatar title=\"Login with GitHub\" rounded>\n <svg height=\"1.3em\" fill=\"currentColor\" viewBox=\"0 0 12 16\" version=\"1.1\" aria-hidden=\"true\"><path fill-rule=\"evenodd\" d=\"M12 14.002a.998.998 0 0 1-.998.998H1.001A1 1 0 0 1 0 13.999V13c0-2.633 4-4 4-4s.229-.409 0-1c-.841-.62-.944-1.59-1-4 .173-2.413 1.867-3 3-3s2.827.586 3 3c-.056 2.41-.159 3.38-1 4-.229.59 0 1 0 1s4 1.367 4 4v1.002z\"></path></svg>\n </Avatar>\n </a>\n {/if}\n </div>\n </nav>\n\n <main class=\"taskboard-board\">\n\n {#if !error}\n {#each columns as column }\n <div class=\"taskboard-column\" class:collapsed={ collapsed[column.name] }>\n <div class=\"taskboard-column-header\">\n <button\n class=\"taskboard-column-collapse btn btn-link\"\n title=\"{ collapsed[column.name] ? 'Expand' : 'Collapse' } column\"\n on:click={ (e) => e.preventDefault() || toggleCollapse(column) }\n >\n {#if collapsed[column.name] }\n <svg viewBox=\"64 64 896 896\" height=\"1em\" aria-hidden=\"true\" fill=\"currentColor\"><path d=\"M602 548c0 4 4 8 8 8h186v74c0 6 7 9 11 6l150-120c3-3 3-8 0-11L807 386c-4-4-11-1-11 5v75H609c-4 0-7 3-7 7zM68 514l149 122c4 3 11 0 11-6v-76h186c4 0 8-2 8-6v-77c0-4-4-7-8-7H228v-75c0-6-7-9-11-5L68 503c-4 3-4 8 0 11z\"/></svg>\n {:else}\n <svg viewBox=\"64 64 896 896\" height=\"1em\" aria-hidden=\"true\" fill=\"currentColor\"><path d=\"M605 515l149 122c5 3 12 0 12-6v-76h186c4 0 7-2 7-6v-77c0-4-3-7-7-7H766v-75c0-6-7-9-12-5L605 504c-4 3-4 8 0 11zM65 547c0 4 3 8 7 8h186v74c0 6 7 9 12 6l149-120c4-3 4-8 0-11L270 385c-5-4-12-1-12 5v75H72c-4 0-7 3-7 7z\"/></svg>\n {/if}\n </button>\n <span class=\"taskboard-column-name\">\n { column.name }\n </span>\n <span class=\"taskboard-column-issue-count\">\n { (shownItems[column.name] || []).length }\n </span>\n </div>\n\n {#if !collapsed[column.name] }\n <div class=\"taskboard-column-items\"\n data-column-id={ column.name }\n on:scroll={ checkRender(column.name) }>\n\n {#each (renderedItems[column.name] || []) as item, index (item.id) }\n <div\n class=\"card-container\"\n data-card-id={ item.id }\n data-card-order={ item.order }\n >\n <Card\n item={item}\n onSelect={ applyFilter }\n />\n </div>\n {/each}\n\n </div>\n {/if}\n </div>\n {/each}\n {/if}\n </main>\n</div>","export default \"data:image/svg+xml,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20viewBox%3D%220%200%2080%2080%22%3E%3Cpath%20d%3D%22M12%200h56c7%200%2012%205%2012%2012v56c0%207-5%2012-12%2012H12C5%2080%200%2075%200%2068V12C0%205%205%200%2012%200z%22%20fill%3D%22%23999%22%2F%3E%3Cpath%20d%3D%22M15%2010h21c3%200%205%202%205%205v6c0%203-2%205-5%205H15c-2%200-4-2-4-5v-6c0-3%202-5%204-5zm0%2020h21c3%200%205%202%205%205v6c0%202-2%204-5%204H15c-2%200-4-1-4-4v-6c0-3%202-5%204-5zm27%2022h21c2%200%204%202%204%205v6c0%202-2%204-4%204H42c-2%200-4-2-4-4v-6c0-3%202-5%204-5z%22%20fill%3D%22%23fff%22%2F%3E%3C%2Fsvg%3E\"","export default \"data:image/svg+xml,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20viewBox%3D%220%200%2080%2080%22%3E%3Cpath%20d%3D%22M12%200h56c7%200%2012%205%2012%2012v56c0%207-5%2012-12%2012H12C5%2080%200%2075%200%2068V12C0%205%205%200%2012%200z%22%20fill%3D%22%23d35f5f%22%2F%3E%3Cpath%20d%3D%22M30%2038l19%207c3%201%204%204%203%206l-2%206c-1%202-4%203-6%203l-20-8c-2-1-3-3-2-6l2-6c1-2%203-3%206-2z%22%20fill%3D%22%23fff%22%2F%3E%3Cpath%20d%3D%22M12%2066l18-10c2-1%205-1%206%202l3%205c1%202%201%205-1%206L19%2080c-2%201-5%200-6-2l-3-6c-1-2%200-4%202-6z%22%20fill%3D%22%23fff%22%2F%3E%3Cpath%20d%3D%22M46%2060l20%205c2%201%204%203%203%206l-1%206c-1%202-3%204-6%203l-20-6c-3%200-4-3-3-5l1-6c1-2%203-4%206-3z%22%20fill%3D%22%23fff%22%2F%3E%3C%2Fsvg%3E\"","export function isClosingLink(link) {\n const {\n type\n } = link;\n\n return type === 'CLOSES';\n}\n\nexport function isClosedByLink(link) {\n const {\n type\n } = link;\n\n return type === 'CLOSED_BY';\n}","import {\n debounce\n} from 'min-dash';\n\nimport Taskboard from './Taskboard.svelte';\n\nconsole.timeEnd('Wuffle#load');\n\nconsole.time('Taskboard#create');\n\nconst taskboard = new Taskboard({\n target: document.body\n});\n\nconsole.timeEnd('Taskboard#create');\n\nif ('serviceWorker' in navigator) {\n\n const triggerReload = debounce(() => {\n window.location.reload();\n }, 500);\n\n window.addEventListener('load', () => {\n navigator.serviceWorker.register('/service-worker.js').catch((err) => {\n console.warn('Failed to register service worker', err);\n });\n\n navigator.serviceWorker.addEventListener('message', event => {\n if (event.data.message === 'resource.changed') {\n console.log('Resource changed', event.data.url);\n\n triggerReload();\n }\n });\n });\n}\n\nexport default taskboard;"],"names":["debounce","fn","timeout","timer","lastArgs","lastThis","lastNow","fire","force","now","Date","scheduledDiff","schedule","apply","clear","setTimeout","clearTimeout","undefined","callback","_len","arguments","length","args","Array","_key","this","flush","cancel","noop","identity","x","run","blank_object","Object","create","run_all","fns","forEach","is_function","thing","src_url_equal_anchor","src_url_equal","element_src","url","document","createElement","href","not_equal","a","b","create_slot","definition","ctx","$$scope","slot_ctx","get_slot_context","tar","src","k","assign","slice","get_slot_changes","dirty","lets","merged","len","Math","max","i","update_slot_base","slot","slot_definition","slot_changes","get_slot_context_fn","slot_context","p","get_all_dirty_from_scope","null_to_empty","value","is_client","window","performance","raf","cb","requestAnimationFrame","tasks","Set","run_tasks","task","c","delete","f","size","append","target","node","appendChild","get_root_for_style","root","getRootNode","ownerDocument","host","append_empty_stylesheet","style_element","element","style","head","append_stylesheet","insert","anchor","insertBefore","detach","parentNode","removeChild","destroy_each","iterations","detaching","d","name","svg_element","createElementNS","text","data","createTextNode","space","empty","listen","event","handler","options","addEventListener","removeEventListener","prevent_default","preventDefault","call","attr","attribute","removeAttribute","getAttribute","setAttribute","set_data","wholeText","set_input_value","input","set_style","key","important","setProperty","toggle_class","toggle","classList","active_docs","current_component","active","create_rule","duration","delay","ease","uid","step","keyframes","t","rule","str","hash","charCodeAt","doc","add","stylesheet","__svelte_stylesheet","sheet","current_rules","__svelte_rules","insertRule","cssRules","animation","delete_rule","previous","split","next","filter","anim","indexOf","deleted","join","deleteRule","set_current_component","component","onMount","Error","get_current_component","$$","on_mount","push","dirty_components","binding_callbacks","render_callbacks","flush_callbacks","resolved_promise","Promise","resolve","update_scheduled","add_render_callback","flushing","seen_callbacks","update","pop","has","fragment","before_update","after_update","promise","dispatch","direction","kind","dispatchEvent","type","detail","bubbles","e","createEvent","initCustomEvent","custom_event","outroing","outros","group_outros","r","check_outros","transition_in","block","local","transition_out","o","null_transition","create_bidirectional_transition","params","intro","config","running_program","pending_program","animation_name","clear_animation","init","program","abs","start","end","group","go","easing","tick","css","fulfill","loop","then","globals","globalThis","global","outro_and_destroy_block","lookup","create_component","mount_component","customElement","on_destroy","m","new_on_destroy","map","destroy_component","make_dirty","fill","instance","create_fragment","props","append_styles","parent_component","bound","on_disconnect","context","Map","callbacks","skip_bound","ready","ret","rest","hydrate","nodes","from","childNodes","children","l","SvelteComponent","$destroy","$on","index","splice","$set","$$props","obj","$$set","keys","Id","LocalStore","get","defaultValue","serializedValue","localStorage","getItem","JSON","parse","error","console","warn","set","setItem","stringify","FakeLocalStore","History","history","pushState","onPop","FakeHistory","periodic","interval","canceled","success","err","isOpen","issue","state","isMerged","isPull","pull_request","parts","matched","onHover","hint","onBlur","onSelect","hasModifier","ctrlKey","shiftKey","altKey","metaKey","isGlobal","body","isApplyFilterClick","isAddFilterClick","categories","values","focussed","mouseSelectedHint","rounded","title","cubicOut","fly","y","opacity","getComputedStyle","target_opacity","transform","od","u","message","item","open","closed","draft","conclusion","status","html_url","description","target_url","check_runs","statuses","failure","in_progress","queued","action_required","avatar_url","login","user","id","number","repository","repositoryName","owner","repoUrl","assignees","comments","isArray","comment","requested_reviewers","reviews","concat","review","find","reviewer","reduce","byUser","existingReview","changes_requested","approved","commented","dismissed","qualifier","hovered","cardUrl","linkTitle","CHILD_OF","DEPENDS_ON","PARENT_OF","CLOSED_BY","REQUIRED_BY","CLOSES","LINKED_TO","LINKED_BY","keyFn","found","showChildren","inputId","matchedHints","keyboardSelectedHint","onClose","repositories","applyHint","val","idx","selectionEnd","selectionStart","repo","nextHint","currentHint","hints","nextIndex","findIndex","focus","time","opts","search","toLowerCase","includes","substring","currentValue","computeMatch","timeEnd","selectedHint","blur","onCreate","Api","moveIssue","column","before","after","fetchJSON","appURL","method","listCards","buildQueryString","getBoard","getLoggedInUser","catch","listUpdates","cursor","location","fetch","credentials","response","ok","separator","encodeURIComponent","n","prototype","setImmediate","process","nextTick","ticky","evt","on","once","_once","off","et","emit","atoa","emitterSnapshot","shift","throws","async","NativeCustomEvent","CustomEvent","foo","useNative","cancelable","createEventObject","Boolean","eventmap","eventname","ron","test","addEvent","el","capturing","removeEvent","hardCache","attachEvent","wrapper","unwrap","originalEvent","srcElement","returnValue","stopPropagation","cancelBubble","which","keyCode","wrapperFactory","wrap","listener","detachEvent","remove","fabricate","model","customEvent","initEvent","makeClassicEvent","fireEvent","cache","lookupClass","className","cached","lastIndex","RegExp","current","rm","replace","trim","documentElement","touchy","op","navigator","pointerEnabled","crossvent","mouseup","mousedown","mousemove","msPointerEnabled","whichMouseButton","touches","buttons","button","getOffset","rect","getBoundingClientRect","left","getScroll","top","scrollProp","offsetProp","clientHeight","getElementBehindPoint","point","elementFromPoint","never","always","getRectWidth","width","right","getRectHeight","height","bottom","getParent","isInput","tagName","isEditable","contentEditable","nextEl","nextElementSibling","sibling","nextSibling","nodeType","manually","getCoord","coord","targetTouches","changedTouches","getEventHost","missMap","pageX","pageY","initialContainers","_mirror","_source","_item","_offsetX","_offsetY","_moveX","_moveY","_initialSibling","_currentSibling","_copy","_renderTimer","_grabbed","_lastDropTarget","moves","accepts","invalid","invalidTarget","containers","isContainer","copy","copySortSource","revertOnSpill","removeOnSpill","ignoreInputTextSelection","mirrorContainer","drake","emitter","manualStart","destroy","canMove","dragging","spillOver","spillOut","events","grab","release","eventualMovements","startBecauseMouseMoved","movements","preventGrabbed","clientX","clientY","canStart","slideFactorX","slideFactorY","grabbed","offset","classes","renderMirrorImage","drag","handle","source","isCopy","cloneNode","drop","ungrab","dropTarget","findDropTarget","parent","isInitialPlacement","cleanup","revert","reverts","initial","removeMirrorImage","s","elementBehindCursor","accepted","immediate","getImmediateChild","reference","getReference","changed","moved","horizontal","inside","outside","container","action","old_blocks","get_key","dynamic","list","create_each_block","get_context","old_indexes","new_blocks","new_lookup","deltas","child_ctx","will_move","did_move","first","new_block","old_block","new_key","old_key","order","parseSearchFilter","URL","searchParams","getCardOrder","dataset","parseFloat","cardOrder","getColumnId","columnId","moveItem","items","to","oldColumn","newColumn","newOrder","updatedColumn","existing","removeItem","insertIdx","insertItem","api","localStore","navId","columns","itemsById","loading","updating","warnings","accessNotification","showCreate","renderCountByColumn","filterOptions","localCollapsed","parseCollapsedColumns","result","w","discardWarning","display","warning","handleWarning","handleError","_error","discardError","loadBoard","all","loginCheck","fetchCards","_","finally","filterChanged","collapsed","updateBoardLocation","ref","searchParam","collapsedParam","entries","defaultCollapsed","toString","buildBoardLink","newUser","reload","updateCards","_items","_cursor","_itemsById","_filterOptions","columnItems","milestone","labels","assignee","label","column_label","entry","newFilter","pollUpdates","currentFilter","updates","removedItem","remainingItems","applyUpdates","poll","teardownHooks","setupHooks","Dragula","matches","checkCancel","moveCard","card","updatedItems","targetColumn","cardIndex","toggleCollapse","isClosingPull","links","some","link","isClosingLink","openCreateIssue","closeCreateIssue","cardId","getCardId","previousEl","previousElementSibling","nextOrder","previousOrder","handleCardDrop","shownItems","renderedItems","renderCount","criteria","criteriaIndex","columnName","scrollHeight","scrollTop","offsetHeight","columnRenderedCount","DEFAULT_PER_COLUMN_RENDER_COUNT","throttling","isNewIssueShortcut","taskboard","triggerReload","serviceWorker","register","log"],"mappings":"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"}
|