g(x,C)?(a[d]=x,a[n]=c,d=n):(a[d]=C,a[m]=c,d=m);else if(ng(x,c))a[d]=x,a[n]=c,d=n;else break a}}return b}\nfunction g(a,b){var c=a.sortIndex-b.sortIndex;return 0!==c?c:a.id-b.id}if(\"object\"===typeof performance&&\"function\"===typeof performance.now){var l=performance;exports.unstable_now=function(){return l.now()}}else{var p=Date,q=p.now();exports.unstable_now=function(){return p.now()-q}}var r=[],t=[],u=1,v=null,y=3,z=!1,A=!1,B=!1,D=\"function\"===typeof setTimeout?setTimeout:null,E=\"function\"===typeof clearTimeout?clearTimeout:null,F=\"undefined\"!==typeof setImmediate?setImmediate:null;\n\"undefined\"!==typeof navigator&&void 0!==navigator.scheduling&&void 0!==navigator.scheduling.isInputPending&&navigator.scheduling.isInputPending.bind(navigator.scheduling);function G(a){for(var b=h(t);null!==b;){if(null===b.callback)k(t);else if(b.startTime<=a)k(t),b.sortIndex=b.expirationTime,f(r,b);else break;b=h(t)}}function H(a){B=!1;G(a);if(!A)if(null!==h(r))A=!0,I(J);else{var b=h(t);null!==b&&K(H,b.startTime-a)}}\nfunction J(a,b){A=!1;B&&(B=!1,E(L),L=-1);z=!0;var c=y;try{G(b);for(v=h(r);null!==v&&(!(v.expirationTime>b)||a&&!M());){var d=v.callback;if(\"function\"===typeof d){v.callback=null;y=v.priorityLevel;var e=d(v.expirationTime<=b);b=exports.unstable_now();\"function\"===typeof e?v.callback=e:v===h(r)&&k(r);G(b)}else k(r);v=h(r)}if(null!==v)var w=!0;else{var m=h(t);null!==m&&K(H,m.startTime-b);w=!1}return w}finally{v=null,y=c,z=!1}}var N=!1,O=null,L=-1,P=5,Q=-1;\nfunction M(){return exports.unstable_now()-Qa||125d?(a.sortIndex=c,f(t,a),null===h(r)&&a===h(t)&&(B?(E(L),L=-1):B=!0,K(H,c-d))):(a.sortIndex=e,f(r,a),A||z||(A=!0,I(J)));return a};\nexports.unstable_shouldYield=M;exports.unstable_wrapCallback=function(a){var b=y;return function(){var c=y;y=b;try{return a.apply(this,arguments)}finally{y=c}}};\n","'use strict';\n\nif (process.env.NODE_ENV === 'production') {\n module.exports = require('./cjs/scheduler.production.min.js');\n} else {\n module.exports = require('./cjs/scheduler.development.js');\n}\n","'use strict';\n\nvar isArrayish = require('is-arrayish');\n\nvar concat = Array.prototype.concat;\nvar slice = Array.prototype.slice;\n\nvar swizzle = module.exports = function swizzle(args) {\n\tvar results = [];\n\n\tfor (var i = 0, len = args.length; i < len; i++) {\n\t\tvar arg = args[i];\n\n\t\tif (isArrayish(arg)) {\n\t\t\t// http://jsperf.com/javascript-array-concat-vs-push/98\n\t\t\tresults = concat.call(results, slice.call(arg));\n\t\t} else {\n\t\t\tresults.push(arg);\n\t\t}\n\t}\n\n\treturn results;\n};\n\nswizzle.wrap = function (fn) {\n\treturn function () {\n\t\treturn fn(swizzle(arguments));\n\t};\n};\n","module.exports = function isArrayish(obj) {\n\tif (!obj || typeof obj === 'string') {\n\t\treturn false;\n\t}\n\n\treturn obj instanceof Array || Array.isArray(obj) ||\n\t\t(obj.length >= 0 && (obj.splice instanceof Function ||\n\t\t\t(Object.getOwnPropertyDescriptor(obj, (obj.length - 1)) && obj.constructor.name !== 'String')));\n};\n","let colors = require('./lib/public/colors')\nmodule.exports = (colors.__esModule ? colors : { default: colors }).default\n","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nObject.defineProperty(exports, \"default\", {\n enumerable: true,\n get: function() {\n return _default;\n }\n});\nconst _log = /*#__PURE__*/ _interop_require_default(require(\"../util/log\"));\nfunction _interop_require_default(obj) {\n return obj && obj.__esModule ? obj : {\n default: obj\n };\n}\nfunction warn({ version , from , to }) {\n _log.default.warn(`${from}-color-renamed`, [\n `As of Tailwind CSS ${version}, \\`${from}\\` has been renamed to \\`${to}\\`.`,\n \"Update your configuration file to silence this warning.\"\n ]);\n}\nconst _default = {\n inherit: \"inherit\",\n current: \"currentColor\",\n transparent: \"transparent\",\n black: \"#000\",\n white: \"#fff\",\n slate: {\n 50: \"#f8fafc\",\n 100: \"#f1f5f9\",\n 200: \"#e2e8f0\",\n 300: \"#cbd5e1\",\n 400: \"#94a3b8\",\n 500: \"#64748b\",\n 600: \"#475569\",\n 700: \"#334155\",\n 800: \"#1e293b\",\n 900: \"#0f172a\",\n 950: \"#020617\"\n },\n gray: {\n 50: \"#f9fafb\",\n 100: \"#f3f4f6\",\n 200: \"#e5e7eb\",\n 300: \"#d1d5db\",\n 400: \"#9ca3af\",\n 500: \"#6b7280\",\n 600: \"#4b5563\",\n 700: \"#374151\",\n 800: \"#1f2937\",\n 900: \"#111827\",\n 950: \"#030712\"\n },\n zinc: {\n 50: \"#fafafa\",\n 100: \"#f4f4f5\",\n 200: \"#e4e4e7\",\n 300: \"#d4d4d8\",\n 400: \"#a1a1aa\",\n 500: \"#71717a\",\n 600: \"#52525b\",\n 700: \"#3f3f46\",\n 800: \"#27272a\",\n 900: \"#18181b\",\n 950: \"#09090b\"\n },\n neutral: {\n 50: \"#fafafa\",\n 100: \"#f5f5f5\",\n 200: \"#e5e5e5\",\n 300: \"#d4d4d4\",\n 400: \"#a3a3a3\",\n 500: \"#737373\",\n 600: \"#525252\",\n 700: \"#404040\",\n 800: \"#262626\",\n 900: \"#171717\",\n 950: \"#0a0a0a\"\n },\n stone: {\n 50: \"#fafaf9\",\n 100: \"#f5f5f4\",\n 200: \"#e7e5e4\",\n 300: \"#d6d3d1\",\n 400: \"#a8a29e\",\n 500: \"#78716c\",\n 600: \"#57534e\",\n 700: \"#44403c\",\n 800: \"#292524\",\n 900: \"#1c1917\",\n 950: \"#0c0a09\"\n },\n red: {\n 50: \"#fef2f2\",\n 100: \"#fee2e2\",\n 200: \"#fecaca\",\n 300: \"#fca5a5\",\n 400: \"#f87171\",\n 500: \"#ef4444\",\n 600: \"#dc2626\",\n 700: \"#b91c1c\",\n 800: \"#991b1b\",\n 900: \"#7f1d1d\",\n 950: \"#450a0a\"\n },\n orange: {\n 50: \"#fff7ed\",\n 100: \"#ffedd5\",\n 200: \"#fed7aa\",\n 300: \"#fdba74\",\n 400: \"#fb923c\",\n 500: \"#f97316\",\n 600: \"#ea580c\",\n 700: \"#c2410c\",\n 800: \"#9a3412\",\n 900: \"#7c2d12\",\n 950: \"#431407\"\n },\n amber: {\n 50: \"#fffbeb\",\n 100: \"#fef3c7\",\n 200: \"#fde68a\",\n 300: \"#fcd34d\",\n 400: \"#fbbf24\",\n 500: \"#f59e0b\",\n 600: \"#d97706\",\n 700: \"#b45309\",\n 800: \"#92400e\",\n 900: \"#78350f\",\n 950: \"#451a03\"\n },\n yellow: {\n 50: \"#fefce8\",\n 100: \"#fef9c3\",\n 200: \"#fef08a\",\n 300: \"#fde047\",\n 400: \"#facc15\",\n 500: \"#eab308\",\n 600: \"#ca8a04\",\n 700: \"#a16207\",\n 800: \"#854d0e\",\n 900: \"#713f12\",\n 950: \"#422006\"\n },\n lime: {\n 50: \"#f7fee7\",\n 100: \"#ecfccb\",\n 200: \"#d9f99d\",\n 300: \"#bef264\",\n 400: \"#a3e635\",\n 500: \"#84cc16\",\n 600: \"#65a30d\",\n 700: \"#4d7c0f\",\n 800: \"#3f6212\",\n 900: \"#365314\",\n 950: \"#1a2e05\"\n },\n green: {\n 50: \"#f0fdf4\",\n 100: \"#dcfce7\",\n 200: \"#bbf7d0\",\n 300: \"#86efac\",\n 400: \"#4ade80\",\n 500: \"#22c55e\",\n 600: \"#16a34a\",\n 700: \"#15803d\",\n 800: \"#166534\",\n 900: \"#14532d\",\n 950: \"#052e16\"\n },\n emerald: {\n 50: \"#ecfdf5\",\n 100: \"#d1fae5\",\n 200: \"#a7f3d0\",\n 300: \"#6ee7b7\",\n 400: \"#34d399\",\n 500: \"#10b981\",\n 600: \"#059669\",\n 700: \"#047857\",\n 800: \"#065f46\",\n 900: \"#064e3b\",\n 950: \"#022c22\"\n },\n teal: {\n 50: \"#f0fdfa\",\n 100: \"#ccfbf1\",\n 200: \"#99f6e4\",\n 300: \"#5eead4\",\n 400: \"#2dd4bf\",\n 500: \"#14b8a6\",\n 600: \"#0d9488\",\n 700: \"#0f766e\",\n 800: \"#115e59\",\n 900: \"#134e4a\",\n 950: \"#042f2e\"\n },\n cyan: {\n 50: \"#ecfeff\",\n 100: \"#cffafe\",\n 200: \"#a5f3fc\",\n 300: \"#67e8f9\",\n 400: \"#22d3ee\",\n 500: \"#06b6d4\",\n 600: \"#0891b2\",\n 700: \"#0e7490\",\n 800: \"#155e75\",\n 900: \"#164e63\",\n 950: \"#083344\"\n },\n sky: {\n 50: \"#f0f9ff\",\n 100: \"#e0f2fe\",\n 200: \"#bae6fd\",\n 300: \"#7dd3fc\",\n 400: \"#38bdf8\",\n 500: \"#0ea5e9\",\n 600: \"#0284c7\",\n 700: \"#0369a1\",\n 800: \"#075985\",\n 900: \"#0c4a6e\",\n 950: \"#082f49\"\n },\n blue: {\n 50: \"#eff6ff\",\n 100: \"#dbeafe\",\n 200: \"#bfdbfe\",\n 300: \"#93c5fd\",\n 400: \"#60a5fa\",\n 500: \"#3b82f6\",\n 600: \"#2563eb\",\n 700: \"#1d4ed8\",\n 800: \"#1e40af\",\n 900: \"#1e3a8a\",\n 950: \"#172554\"\n },\n indigo: {\n 50: \"#eef2ff\",\n 100: \"#e0e7ff\",\n 200: \"#c7d2fe\",\n 300: \"#a5b4fc\",\n 400: \"#818cf8\",\n 500: \"#6366f1\",\n 600: \"#4f46e5\",\n 700: \"#4338ca\",\n 800: \"#3730a3\",\n 900: \"#312e81\",\n 950: \"#1e1b4b\"\n },\n violet: {\n 50: \"#f5f3ff\",\n 100: \"#ede9fe\",\n 200: \"#ddd6fe\",\n 300: \"#c4b5fd\",\n 400: \"#a78bfa\",\n 500: \"#8b5cf6\",\n 600: \"#7c3aed\",\n 700: \"#6d28d9\",\n 800: \"#5b21b6\",\n 900: \"#4c1d95\",\n 950: \"#2e1065\"\n },\n purple: {\n 50: \"#faf5ff\",\n 100: \"#f3e8ff\",\n 200: \"#e9d5ff\",\n 300: \"#d8b4fe\",\n 400: \"#c084fc\",\n 500: \"#a855f7\",\n 600: \"#9333ea\",\n 700: \"#7e22ce\",\n 800: \"#6b21a8\",\n 900: \"#581c87\",\n 950: \"#3b0764\"\n },\n fuchsia: {\n 50: \"#fdf4ff\",\n 100: \"#fae8ff\",\n 200: \"#f5d0fe\",\n 300: \"#f0abfc\",\n 400: \"#e879f9\",\n 500: \"#d946ef\",\n 600: \"#c026d3\",\n 700: \"#a21caf\",\n 800: \"#86198f\",\n 900: \"#701a75\",\n 950: \"#4a044e\"\n },\n pink: {\n 50: \"#fdf2f8\",\n 100: \"#fce7f3\",\n 200: \"#fbcfe8\",\n 300: \"#f9a8d4\",\n 400: \"#f472b6\",\n 500: \"#ec4899\",\n 600: \"#db2777\",\n 700: \"#be185d\",\n 800: \"#9d174d\",\n 900: \"#831843\",\n 950: \"#500724\"\n },\n rose: {\n 50: \"#fff1f2\",\n 100: \"#ffe4e6\",\n 200: \"#fecdd3\",\n 300: \"#fda4af\",\n 400: \"#fb7185\",\n 500: \"#f43f5e\",\n 600: \"#e11d48\",\n 700: \"#be123c\",\n 800: \"#9f1239\",\n 900: \"#881337\",\n 950: \"#4c0519\"\n },\n get lightBlue () {\n warn({\n version: \"v2.2\",\n from: \"lightBlue\",\n to: \"sky\"\n });\n return this.sky;\n },\n get warmGray () {\n warn({\n version: \"v3.0\",\n from: \"warmGray\",\n to: \"stone\"\n });\n return this.stone;\n },\n get trueGray () {\n warn({\n version: \"v3.0\",\n from: \"trueGray\",\n to: \"neutral\"\n });\n return this.neutral;\n },\n get coolGray () {\n warn({\n version: \"v3.0\",\n from: \"coolGray\",\n to: \"gray\"\n });\n return this.gray;\n },\n get blueGray () {\n warn({\n version: \"v3.0\",\n from: \"blueGray\",\n to: \"slate\"\n });\n return this.slate;\n }\n};\n","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nfunction _export(target, all) {\n for(var name in all)Object.defineProperty(target, name, {\n enumerable: true,\n get: all[name]\n });\n}\n_export(exports, {\n dim: function() {\n return dim;\n },\n default: function() {\n return _default;\n }\n});\nconst _picocolors = /*#__PURE__*/ _interop_require_default(require(\"picocolors\"));\nfunction _interop_require_default(obj) {\n return obj && obj.__esModule ? obj : {\n default: obj\n };\n}\nlet alreadyShown = new Set();\nfunction log(type, messages, key) {\n if (typeof process !== \"undefined\" && process.env.JEST_WORKER_ID) return;\n if (key && alreadyShown.has(key)) return;\n if (key) alreadyShown.add(key);\n console.warn(\"\");\n messages.forEach((message)=>console.warn(type, \"-\", message));\n}\nfunction dim(input) {\n return _picocolors.default.dim(input);\n}\nconst _default = {\n info (key, messages) {\n log(_picocolors.default.bold(_picocolors.default.cyan(\"info\")), ...Array.isArray(key) ? [\n key\n ] : [\n messages,\n key\n ]);\n },\n warn (key, messages) {\n log(_picocolors.default.bold(_picocolors.default.yellow(\"warn\")), ...Array.isArray(key) ? [\n key\n ] : [\n messages,\n key\n ]);\n },\n risk (key, messages) {\n log(_picocolors.default.bold(_picocolors.default.magenta(\"risk\")), ...Array.isArray(key) ? [\n key\n ] : [\n messages,\n key\n ]);\n }\n};\n","/**\n * @license React\n * use-sync-external-store-with-selector.production.min.js\n *\n * Copyright (c) Facebook, Inc. and its affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n'use strict';var g=require(\"react\");function n(a,b){return a===b&&(0!==a||1/a===1/b)||a!==a&&b!==b}var p=\"function\"===typeof Object.is?Object.is:n,q=g.useSyncExternalStore,r=g.useRef,t=g.useEffect,u=g.useMemo,v=g.useDebugValue;\nexports.useSyncExternalStoreWithSelector=function(a,b,e,l,h){var c=r(null);if(null===c.current){var f={hasValue:!1,value:null};c.current=f}else f=c.current;c=u(function(){function a(a){if(!c){c=!0;d=a;a=l(a);if(void 0!==h&&f.hasValue){var b=f.value;if(h(b,a))return k=b}return k=a}b=k;if(p(d,a))return b;var e=l(a);if(void 0!==h&&h(b,e))return b;d=a;return k=e}var c=!1,d,k,m=void 0===e?null:e;return[function(){return a(b())},null===m?void 0:function(){return a(m())}]},[b,e,l,h]);var d=q(a,c[0],c[1]);\nt(function(){f.hasValue=!0;f.value=d},[d]);v(d);return d};\n","'use strict';\n\nif (process.env.NODE_ENV === 'production') {\n module.exports = require('./cjs/use-sync-external-store-with-selector.production.min.js');\n} else {\n module.exports = require('./cjs/use-sync-external-store-with-selector.development.js');\n}\n","var v1 = require('./v1');\nvar v4 = require('./v4');\n\nvar uuid = v4;\nuuid.v1 = v1;\nuuid.v4 = v4;\n\nmodule.exports = uuid;\n","/**\n * Convert array of 16 byte values to UUID string format of the form:\n * XXXXXXXX-XXXX-XXXX-XXXX-XXXXXXXXXXXX\n */\nvar byteToHex = [];\nfor (var i = 0; i < 256; ++i) {\n byteToHex[i] = (i + 0x100).toString(16).substr(1);\n}\n\nfunction bytesToUuid(buf, offset) {\n var i = offset || 0;\n var bth = byteToHex;\n // join used to fix memory issue caused by concatenation: https://bugs.chromium.org/p/v8/issues/detail?id=3175#c4\n return ([\n bth[buf[i++]], bth[buf[i++]],\n bth[buf[i++]], bth[buf[i++]], '-',\n bth[buf[i++]], bth[buf[i++]], '-',\n bth[buf[i++]], bth[buf[i++]], '-',\n bth[buf[i++]], bth[buf[i++]], '-',\n bth[buf[i++]], bth[buf[i++]],\n bth[buf[i++]], bth[buf[i++]],\n bth[buf[i++]], bth[buf[i++]]\n ]).join('');\n}\n\nmodule.exports = bytesToUuid;\n","// Unique ID creation requires a high quality random # generator. In the\n// browser this is a little complicated due to unknown quality of Math.random()\n// and inconsistent support for the `crypto` API. We do the best we can via\n// feature-detection\n\n// getRandomValues needs to be invoked in a context where \"this\" is a Crypto\n// implementation. Also, find the complete implementation of crypto on IE11.\nvar getRandomValues = (typeof(crypto) != 'undefined' && crypto.getRandomValues && crypto.getRandomValues.bind(crypto)) ||\n (typeof(msCrypto) != 'undefined' && typeof window.msCrypto.getRandomValues == 'function' && msCrypto.getRandomValues.bind(msCrypto));\n\nif (getRandomValues) {\n // WHATWG crypto RNG - http://wiki.whatwg.org/wiki/Crypto\n var rnds8 = new Uint8Array(16); // eslint-disable-line no-undef\n\n module.exports = function whatwgRNG() {\n getRandomValues(rnds8);\n return rnds8;\n };\n} else {\n // Math.random()-based (RNG)\n //\n // If all else fails, use Math.random(). It's fast, but is of unspecified\n // quality.\n var rnds = new Array(16);\n\n module.exports = function mathRNG() {\n for (var i = 0, r; i < 16; i++) {\n if ((i & 0x03) === 0) r = Math.random() * 0x100000000;\n rnds[i] = r >>> ((i & 0x03) << 3) & 0xff;\n }\n\n return rnds;\n };\n}\n","var rng = require('./lib/rng');\nvar bytesToUuid = require('./lib/bytesToUuid');\n\n// **`v1()` - Generate time-based UUID**\n//\n// Inspired by https://github.com/LiosK/UUID.js\n// and http://docs.python.org/library/uuid.html\n\nvar _nodeId;\nvar _clockseq;\n\n// Previous uuid creation time\nvar _lastMSecs = 0;\nvar _lastNSecs = 0;\n\n// See https://github.com/uuidjs/uuid for API details\nfunction v1(options, buf, offset) {\n var i = buf && offset || 0;\n var b = buf || [];\n\n options = options || {};\n var node = options.node || _nodeId;\n var clockseq = options.clockseq !== undefined ? options.clockseq : _clockseq;\n\n // node and clockseq need to be initialized to random values if they're not\n // specified. We do this lazily to minimize issues related to insufficient\n // system entropy. See #189\n if (node == null || clockseq == null) {\n var seedBytes = rng();\n if (node == null) {\n // Per 4.5, create and 48-bit node id, (47 random bits + multicast bit = 1)\n node = _nodeId = [\n seedBytes[0] | 0x01,\n seedBytes[1], seedBytes[2], seedBytes[3], seedBytes[4], seedBytes[5]\n ];\n }\n if (clockseq == null) {\n // Per 4.2.2, randomize (14 bit) clockseq\n clockseq = _clockseq = (seedBytes[6] << 8 | seedBytes[7]) & 0x3fff;\n }\n }\n\n // UUID timestamps are 100 nano-second units since the Gregorian epoch,\n // (1582-10-15 00:00). JSNumbers aren't precise enough for this, so\n // time is handled internally as 'msecs' (integer milliseconds) and 'nsecs'\n // (100-nanoseconds offset from msecs) since unix epoch, 1970-01-01 00:00.\n var msecs = options.msecs !== undefined ? options.msecs : new Date().getTime();\n\n // Per 4.2.1.2, use count of uuid's generated during the current clock\n // cycle to simulate higher resolution clock\n var nsecs = options.nsecs !== undefined ? options.nsecs : _lastNSecs + 1;\n\n // Time since last uuid creation (in msecs)\n var dt = (msecs - _lastMSecs) + (nsecs - _lastNSecs)/10000;\n\n // Per 4.2.1.2, Bump clockseq on clock regression\n if (dt < 0 && options.clockseq === undefined) {\n clockseq = clockseq + 1 & 0x3fff;\n }\n\n // Reset nsecs if clock regresses (new clockseq) or we've moved onto a new\n // time interval\n if ((dt < 0 || msecs > _lastMSecs) && options.nsecs === undefined) {\n nsecs = 0;\n }\n\n // Per 4.2.1.2 Throw error if too many uuids are requested\n if (nsecs >= 10000) {\n throw new Error('uuid.v1(): Can\\'t create more than 10M uuids/sec');\n }\n\n _lastMSecs = msecs;\n _lastNSecs = nsecs;\n _clockseq = clockseq;\n\n // Per 4.1.4 - Convert from unix epoch to Gregorian epoch\n msecs += 12219292800000;\n\n // `time_low`\n var tl = ((msecs & 0xfffffff) * 10000 + nsecs) % 0x100000000;\n b[i++] = tl >>> 24 & 0xff;\n b[i++] = tl >>> 16 & 0xff;\n b[i++] = tl >>> 8 & 0xff;\n b[i++] = tl & 0xff;\n\n // `time_mid`\n var tmh = (msecs / 0x100000000 * 10000) & 0xfffffff;\n b[i++] = tmh >>> 8 & 0xff;\n b[i++] = tmh & 0xff;\n\n // `time_high_and_version`\n b[i++] = tmh >>> 24 & 0xf | 0x10; // include version\n b[i++] = tmh >>> 16 & 0xff;\n\n // `clock_seq_hi_and_reserved` (Per 4.2.2 - include variant)\n b[i++] = clockseq >>> 8 | 0x80;\n\n // `clock_seq_low`\n b[i++] = clockseq & 0xff;\n\n // `node`\n for (var n = 0; n < 6; ++n) {\n b[i + n] = node[n];\n }\n\n return buf ? buf : bytesToUuid(b);\n}\n\nmodule.exports = v1;\n","var rng = require('./lib/rng');\nvar bytesToUuid = require('./lib/bytesToUuid');\n\nfunction v4(options, buf, offset) {\n var i = buf && offset || 0;\n\n if (typeof(options) == 'string') {\n buf = options === 'binary' ? new Array(16) : null;\n options = null;\n }\n options = options || {};\n\n var rnds = options.random || (options.rng || rng)();\n\n // Per 4.4, set bits for version and `clock_seq_hi_and_reserved`\n rnds[6] = (rnds[6] & 0x0f) | 0x40;\n rnds[8] = (rnds[8] & 0x3f) | 0x80;\n\n // Copy bytes to buffer, if provided\n if (buf) {\n for (var ii = 0; ii < 16; ++ii) {\n buf[i + ii] = rnds[ii];\n }\n }\n\n return buf || bytesToUuid(rnds);\n}\n\nmodule.exports = v4;\n","import { v4 as UUID } from \"uuid\";\n\nexport function createAction(\n type: Type,\n payload: Payload,\n metadata?: Meta\n): Store.Action {\n const id = UUID();\n return { id, type, payload, metadata: metadata ?? {}, ts: Date.now() };\n}\n\nexport function createIOAction<\n Type = string,\n Payload = any,\n Success = any,\n Meta = any\n>(type: Type, payload: Payload, metadata?: Meta): Store.IOAction {\n let error: (reason: any) => void = (_error) => {};\n\n let success: (data: Success) => void = (_data) => {};\n\n let promise = new Promise((res, rej) => {\n error = rej;\n success = res;\n });\n\n const id = UUID();\n\n const controller = new AbortController();\n\n return {\n\n id: id,\n\n type: type,\n\n metadata: metadata ?? {},\n\n resolve: { error, success },\n\n payload: payload,\n\n signal: controller.signal,\n\n catch: (callback: (error: any) => R) => {\n return promise.catch(callback);\n },\n\n then: (\n onFullfill: (data: Success) => R,\n onReject?: (error: string) => E\n ) => {\n return promise.then(onFullfill, onReject);\n },\n\n abort: () => {\n return controller.abort();\n },\n\n finally: (callback: () => R) => {\n return promise.finally(callback);\n },\n\n ts: Date.now(),\n };\n}\n","import { createAction, createIOAction } from \"../../action\";\n\nexport interface IParams{[key: string]: any}\nexport const APP_INIT = \"APP_INIT\";\nexport type APP_INIT = typeof APP_INIT;\nexport type InitAction = Store.Action;\nexport function initStore(params: IParams = {}): InitAction {\n return createAction(APP_INIT, params);\n}\n","import { createAction, createIOAction } from \"../../action\";\n\nexport const AUTH_LOGIN = \"AUTH_LOGIN\";\nexport type AUTH_LOGIN = typeof AUTH_LOGIN;\nexport interface ILoginParams {username: string; password: string}\nexport type LoginAction = Store.IOAction;\nexport function login(params: ILoginParams): LoginAction{\n return createIOAction(AUTH_LOGIN, params);\n}\n\nexport const AUTH_LOGOUT = \"AUTH_LOGOUT\";\nexport type AUTH_LOGOUT = typeof AUTH_LOGOUT;\nexport type LogoutAction = Store.IOAction;\nexport function logout(): LogoutAction{\n return createIOAction(AUTH_LOGOUT, {});\n}\n\nexport const AUTH_REQUEST_RESET_PHONE_CODE = \"AUTH_REQUEST_RESET_PHONE_CODE\";\nexport type AUTH_REQUEST_RESET_PHONE_CODE = typeof AUTH_REQUEST_RESET_PHONE_CODE;\nexport interface IPasswordResetParams {username: string; phone: string}\nexport type IResetPasswordReqAction = Store.IOAction;\nexport function reset(params: IPasswordResetParams): IResetPasswordReqAction{\n return createIOAction(AUTH_REQUEST_RESET_PHONE_CODE, params);\n}\n","import { Record } from 'immutable';\n\nexport class CampusRecord extends Record({\n locale: \"en_US\",\n lpack: {},\n name: \"Campus Name\",\n}) {}\n\nexport class CampusAttendance extends Record({\n id: \"\",\n notes: \"\",\n type: 0,\n user_id: \"\",\n school_id: \"\",\n learner_id: \"\",\n session_id: \"\",\n created_at: \"\",\n}) {}\n\n\nexport class CampusEvent extends Record({\n id: \"\",\n name: \"\",\n description: \"\",\n start_date: \"\",\n stop_date: \"\",\n school_id: \"\",\n location_id: \"\",\n created_at: \"\",\n}) {}\n\nexport class CampusSchool extends Record({\n id: \"\",\n cc: \"\",\n name: \"\",\n title: \"\",\n image_path: null,\n owner_id: \"\",\n data: {},\n color: \"black\",\n location: \"\",\n description: \"\",\n created_at: \"\",\n}) {}\n\nexport class CampusContact extends Record({\n id: \"\",\n name: \"\",\n phone: \"\",\n priority: 0,\n school_id: \"\",\n student_id: \"\",\n created_at: \"\",\n}){}\n\nexport class CampusDiscipline extends Record({\n id: \"\",\n name: \"\",\n school_id: \"\",\n created_at: \"\",\n description: \"\",\n image_path: null,\n}) {}\n\nexport class CampusSubject extends Record({\n id: \"\",\n name: \"\",\n color: \"\",\n school_id: \"\",\n discipline_id: \"\",\n image_path: null,\n description: \"\",\n created_at: \"\",\n}) {}\n\nexport class CampusCourse extends Record({\n id: \"\",\n name: \"\",\n weight: 0.0,\n image_path: null,\n description: \"\",\n is_published: false,\n term_id: \"\",\n level_id: \"\",\n subject_id: \"\",\n school_id: \"\",\n created_at: \"\",\n}) {}\n\nexport class CampusTopic extends Record({\n id: \"\",\n name: \"\",\n number: 0,\n description: \"\",\n course_id: \"\",\n school_id: \"\",\n subject_id: \"\",\n created_at: \"\",\n}) {}\n\nexport class CampusUser extends Record({\n id: \"\",\n bio: \"\",\n title: \"\",\n last_name: \"\",\n middle_name: \"\",\n first_name: \"\",\n image_path: null,\n school_id: \"\",\n created_at: \"\",\n}) {\n\n get name() {\n return this.names;\n }\n\n get names() {\n return (`${this.title ?? \"\"} ${this.first_name ?? \"\"} ${this.last_name ?? \"\"}`).trim();\n }\n\n get fullnames() {\n return (`${this.first_name ?? \"\"} ${this.middle_name ?? \"\"} ${this.last_name ?? \"\"}`).trim();\n }\n}\n\nexport class CampusLearner extends Record({\n id: \"\",\n last_name: \"\",\n middle_name: \"\",\n first_name: \"\",\n term_id: \"\",\n classroom_id: \"\",\n school_id: \"\",\n image_path: null,\n student_id: \"\",\n created_at: \"\",\n}){\n get name() {\n return `${this.first_name} ${this.last_name}`;\n }\n\n get names() {\n return `${this.first_name} ${this.last_name}`;\n }\n\n get fullnames() {\n return `${this.first_name} ${this.middle_name} ${this.last_name}`;\n }\n}\n\nexport class CampusRequest extends Record({\n id: \"\",\n user_id: \"\",\n school_id: \"\",\n created_at: \"\",\n approved_at: \"\",\n}) {}\n\nexport class CampusCycle extends Record({\n id: \"\",\n name: \"\",\n start_date: \"\",\n end_date: \"\",\n school_id: \"\",\n created_at: \"\",\n}) {}\n\nexport class CampusTerm extends Record({\n id: \"\",\n name: \"\",\n is_active: false,\n start_date: \"\",\n stop_date: \"\",\n capacity: 0,\n school_id: \"\",\n created_at: \"\",\n}) {}\n\nexport class CampusSession extends Record({\n id: \"\",\n name: \"\",\n end_at: \"\",\n start_at: \"\",\n classroom_id: \"\",\n lesson_id: \"\",\n school_id: \"\",\n user_id: \"\",\n created_at: \"\",\n}) {}\n\nexport class CampusLecture extends Record({\n id: \"\",\n name: \"\",\n end_at: \"\",\n user_id: \"\",\n term_id: \"\",\n start_at: \"\",\n classroom_id: \"\",\n topic_id: \"\",\n course_id: \"\",\n lesson_id: \"\",\n school_id: \"\",\n subject_id: \"\",\n created_at: \"\",\n}) {}\n\nexport class CampusInstructor extends Record({\n id: \"\",\n level: 9999999,\n term_id: \"\",\n user_id: \"\",\n classroom_id: \"\",\n level_id: \"\",\n member_id: \"\",\n course_id: \"\",\n school_id: \"\",\n created_at: \"\",\n}) {}\n\nexport class CampusMembership extends Record({\n id: \"\",\n user_id: \"\",\n role_id: \"\",\n suspended: false,\n school_id: \"\",\n created_at: \"\",\n}) {}\n\nexport class CampusLesson extends Record({\n id: \"\",\n name: \"\",\n number: 0,\n user_id: \"\",\n published: -1,\n max_score: 0,\n image_path: null,\n description: \"\",\n topic_id: \"\",\n school_id: \"\",\n created_at: \"\",\n}) {\n\n get is_approved() {\n return this.published === 1;\n }\n\n get is_gradable() {\n return this.max_score > 0;\n }\n\n get is_published() {\n return this.published === 1;\n }\n \n get is_pending() {\n return this.published === 0;\n }\n\n get is_draft() {\n return this.published === -1;\n }\n\n is_author(user_id?: string) {\n return this.user_id === user_id;\n }\n}\n\nexport class CampusMember extends Record({\n id: \"\",\n user_id: \"\",\n role_id: \"\",\n metadata: {},\n notes: \"\",\n school_id: \"\",\n created_at: \"\",\n}) {\n is_user(user_id?: string) {\n return this.user_id === user_id;\n }\n}\n\nexport class CampusLevel extends Record({\n id: \"\",\n name: \"\",\n level: 0,\n school_id: \"\",\n created_at: \"\",\n}) {}\n\nexport class CampusClassroom extends Record({\n id: \"\",\n name: \"\",\n capacity: 0,\n term_id: \"\",\n level_id: \"\",\n description: \"\",\n school_id: \"\",\n created_at: \"\",\n}) {}\n\nexport class CampusRole extends Record({\n id: \"\",\n name: \"\",\n type: 0,\n color: \"\",\n school_id: \"\",\n created_at: \"\",\n}) {}\n\nexport class CampusPermission extends Record({\n id: \"\",\n caps: [],\n school_id: \"\",\n created_at: \"\",\n}) {}\n\nexport class CampusEducator extends Record({\n id: \"\",\n caps: [],\n user: {},\n course: {},\n school: {},\n user_id: \"\",\n member_id: \"\",\n classroom_id: \"\",\n course_id: \"\",\n school_id: \"\",\n created_at: \"\",\n}) {}\n\nexport class CampusStudent extends Record({\n id: \"\",\n image_path: null,\n dob: \"\",\n data: {},\n last_name: \"\",\n first_name: \"\",\n middle_name: \"\",\n classroom_id: \"\",\n school_id: \"\",\n created_at: \"\",\n is_archived: true,\n is_suspended: true,\n}) {\n\n get name() {\n return `${this.first_name} ${this.last_name}`;\n }\n\n get names() {\n return `${this.first_name} ${this.last_name}`;\n }\n\n get fullnames() {\n return `${this.first_name} ${this.middle_name} ${this.last_name}`;\n }\n}\n\nexport class CampusResult extends Record({\n id: \"\",\n score: 0,\n notes: \"\",\n user_id: \"\",\n school_id: \"\",\n session_id: \"\",\n learner_id: \"\",\n created_at: \"\",\n}) {\n \n}\n\nexport class CampusMySchedule extends Record({\n id: \"\",\n name: \"\",\n classroom_id: \"\",\n user_id: \"\",\n lesson_id: \"\",\n school_id: \"\",\n start_at: \"\",\n end_at: \"\",\n created_at: \"\",\n topic_id: \"\",\n course_id: \"\",\n member_id: \"\",\n subject_id: \"\",\n}) {}\n","import { Record } from \"immutable\";\n\nexport class Term extends Record({id:\"\",name:\"\",created_at:\"\"}) {}\n","import { Record } from 'immutable';\n\nexport class User extends Record({\n id: \"\",\n bio: \"\",\n title: \"\",\n last_name: \"\",\n first_name: \"\",\n middle_name: \"\",\n image_path: null,\n school_id: \"\",\n created_at: \"\",\n}) {\n\n get name() {\n return this.names;\n }\n\n get names() {\n return (`${this.title ?? \"\"} ${this.first_name ?? \"\"} ${this.last_name ?? \"\"}`).trim();\n }\n\n get fullnames() {\n return (`${this.first_name ?? \"\"} ${this.middle_name ?? \"\"} ${this.last_name ?? \"\"}`).trim();\n }\n}\n\n","import { Record } from 'immutable';\n\nexport class Campus extends Record({\n name: \" Name\",\n lpack: {},\n locale: \"en_US\",\n}) {}\n\nexport class Attendance extends Record({\n id: \"\",\n type: 0,\n notes: \"\",\n user_id: \"\",\n school_id: \"\",\n learner_id: \"\",\n session_id: \"\",\n created_at: \"\",\n}) {}\n\n\nexport class School extends Record({\n id: \"\",\n cc: \"\",\n name: \"\",\n title: \"\",\n image_path: null,\n owner_id: \"\",\n data: {},\n color: \"black\",\n location: \"\",\n created_at: \"\",\n description: \"\",\n}) {}\n\nexport class Contact extends Record({\n id: \"\",\n name: \"\",\n phone: \"\",\n priority: 0,\n school_id: \"\",\n student_id: \"\",\n created_at: \"\",\n}){}\n\nexport class Discipline extends Record({\n id: \"\",\n name: \"\",\n school_id: \"\",\n created_at: \"\",\n description: \"\",\n image_path: null,\n}) {}\n\nexport class Subject extends Record({\n id: \"\",\n name: \"\",\n color: \"\",\n school_id: \"\",\n discipline_id: \"\",\n image_path: null,\n description: \"\",\n created_at: \"\",\n}) {}\n\nexport class Course extends Record({\n id: \"\",\n name: \"\",\n weight: 0.0,\n image_path: null,\n description: \"\",\n is_published: false,\n term_id: \"\",\n level_id: \"\",\n subject_id: \"\",\n school_id: \"\",\n created_at: \"\",\n}) {}\n\nexport class Topic extends Record({\n id: \"\",\n name: \"\",\n number: 0,\n description: \"\",\n course_id: \"\",\n school_id: \"\",\n subject_id: \"\",\n created_at: \"\",\n}) {}\n\nexport class Learner extends Record({\n id: \"\",\n last_name: \"\",\n middle_name: \"\",\n first_name: \"\",\n term_id: \"\",\n classroom_id: \"\",\n school_id: \"\",\n image_path: null,\n student_id: \"\",\n created_at: \"\",\n}){\n get name() {\n return `${this.first_name} ${this.last_name}`;\n }\n\n get names() {\n return `${this.first_name} ${this.last_name}`;\n }\n\n get fullnames() {\n return `${this.first_name} ${this.middle_name} ${this.last_name}`;\n }\n}\n\nexport class Request extends Record({\n id: \"\",\n user_id: \"\",\n school_id: \"\",\n created_at: \"\",\n approved_at: \"\",\n}) {}\n\nexport class Cycle extends Record({\n id: \"\",\n name: \"\",\n start_date: \"\",\n end_date: \"\",\n school_id: \"\",\n created_at: \"\",\n}) {}\n\nexport class Term extends Record({\n id: \"\",\n name: \"\",\n is_active: false,\n start_date: \"\",\n stop_date: \"\",\n capacity: 0,\n school_id: \"\",\n created_at: \"\",\n}) {}\n\nexport class Session extends Record({\n id: \"\",\n name: \"\",\n end_at: \"\",\n start_at: \"\",\n classroom_id: \"\",\n lesson_id: \"\",\n school_id: \"\",\n user_id: \"\",\n created_at: \"\",\n}) {}\n\nexport class Lecture extends Record({\n id: \"\",\n name: \"\",\n end_at: \"\",\n user_id: \"\",\n term_id: \"\",\n start_at: \"\",\n classroom_id: \"\",\n topic_id: \"\",\n course_id: \"\",\n lesson_id: \"\",\n school_id: \"\",\n subject_id: \"\",\n created_at: \"\",\n}) {}\n\nexport class Instructor extends Record({\n id: \"\",\n level: 9999999,\n term_id: \"\",\n user_id: \"\",\n classroom_id: \"\",\n level_id: \"\",\n member_id: \"\",\n course_id: \"\",\n school_id: \"\",\n created_at: \"\",\n}) {}\n\nexport class Membership extends Record({\n id: \"\",\n user_id: \"\",\n role_id: \"\",\n suspended: false,\n school_id: \"\",\n created_at: \"\",\n}) {}\n\nexport class Lesson extends Record({\n id: \"\",\n name: \"\",\n number: 0,\n user_id: \"\",\n published: -1,\n max_score: 0,\n image_path: null,\n description: \"\",\n topic_id: \"\",\n school_id: \"\",\n created_at: \"\",\n}) {\n\n get is_approved() {\n return this.published === 1;\n }\n\n get is_gradable() {\n return this.max_score > 0;\n }\n\n get is_published() {\n return this.published === 1;\n }\n \n get is_pending() {\n return this.published === 0;\n }\n\n get is_draft() {\n return this.published === -1;\n }\n\n is_author(user_id?: string) {\n return this.user_id === user_id;\n }\n}\n\nexport class Member extends Record({\n id: \"\",\n user_id: \"\",\n role_id: \"\",\n metadata: {},\n notes: \"\",\n school_id: \"\",\n created_at: \"\",\n}) {\n is_user(user_id?: string) {\n return this.user_id === user_id;\n }\n}\n\nexport class Level extends Record({\n id: \"\",\n name: \"\",\n level: 0,\n school_id: \"\",\n created_at: \"\",\n}) {}\n\nexport class Classroom extends Record({\n id: \"\",\n name: \"\",\n capacity: 0,\n term_id: \"\",\n level_id: \"\",\n description: \"\",\n school_id: \"\",\n created_at: \"\",\n}) {}\n\nexport class Role extends Record({\n id: \"\",\n name: \"\",\n type: 0,\n color: \"\",\n school_id: \"\",\n created_at: \"\",\n}) {}\n\nexport class Permission extends Record({\n id: \"\",\n caps: [],\n school_id: \"\",\n created_at: \"\",\n}) {}\n\nexport class Educator extends Record({\n id: \"\",\n caps: [],\n user: {},\n course: {},\n school: {},\n user_id: \"\",\n member_id: \"\",\n classroom_id: \"\",\n course_id: \"\",\n school_id: \"\",\n created_at: \"\",\n}) {}\n\nexport class Student extends Record({\n id: \"\",\n image_path: null,\n dob: \"\",\n data: {},\n last_name: \"\",\n first_name: \"\",\n middle_name: \"\",\n classroom_id: \"\",\n school_id: \"\",\n created_at: \"\",\n is_archived: true,\n is_suspended: true,\n}) {\n\n get name() {\n return `${this.first_name} ${this.last_name}`;\n }\n\n get names() {\n return `${this.first_name} ${this.last_name}`;\n }\n\n get fullnames() {\n return `${this.first_name} ${this.middle_name} ${this.last_name}`;\n }\n}\n\nexport class Result extends Record({\n id: \"\",\n score: 0,\n notes: \"\",\n user_id: \"\",\n school_id: \"\",\n session_id: \"\",\n learner_id: \"\",\n created_at: \"\",\n}) {\n \n}\n\nexport class MySchedule extends Record({\n id: \"\",\n name: \"\",\n classroom_id: \"\",\n user_id: \"\",\n lesson_id: \"\",\n school_id: \"\",\n start_at: \"\",\n end_at: \"\",\n created_at: \"\",\n topic_id: \"\",\n course_id: \"\",\n member_id: \"\",\n subject_id: \"\",\n}) {}\n\n","import { Record } from 'immutable';\n\nexport class Session extends Record({\n access_token: \"\",\n token_type: \"\",\n expires_in: 0,\n expires_at: 0,\n user_id: \"\",\n refresh_token: \"\",\n is_anonymous: true\n}) {\n reset() {\n return new Session({});\n }\n\n get is_valid() {\n return !this.is_anonymous && Boolean(this.access_token.trim()) && Boolean(this.refresh_token.trim()) && Boolean(this.user_id.trim());\n }\n}\n\n","import { Record } from 'immutable';\nexport * as Account from \"./account\";\nexport * as Campus from \"./campus\";\nexport * as Auth from \"./auth\";\n\nexport class Country extends Record({\n id: \"\",\n name: \"\",\n isdn: \"\",\n icon: \"\",\n}) {}\n\n","import { Record } from \"immutable\";\nimport * as Actions from \"../actions/app\";\nimport { CampusRecord } from \"../records\";\n\nexport const state = new CampusRecord({});\n\nexport const reducers = {\n [Actions.APP_INIT]: (app: CampusRecord, payload: Actions.InitAction) => {\n return app;\n },\n};\n\nexport default { state, reducers, CampusRecord };\n","import { Record } from \"immutable\";\nimport { fork } from \"redux-saga/effects\";\n\nconst INIT = \"\";\n\nconst watch = ({ effect, type, handle }: Store.IHandler) =>\n function* watcher() {\n yield effect(type, handle);\n };\n\n\nexport function forkhandles(handles: Store.IHandler[]) {\n const watchers = handles.map(watch);\n return [...watchers].map(fork);\n}\n\nexport function composeReducer(\n handlers: Store.IReducerMap,\n defaultState: T\n): (state: T, action: Store.Action) => T {\n type ActionType = keyof typeof handlers;\n\n const actions: ActionType[] = Object.keys(handlers);\n\n if (actions.includes(INIT)) {\n return (state: T = defaultState, action: Store.Action): T => {\n if (actions.includes(action.type)) {\n return handlers[action.type](state, action);\n } else {\n return state;\n }\n };\n } else {\n return (state: T = defaultState, action: Store.Action): T => {\n const { type } = action;\n\n if (type === INIT) {\n return defaultState;\n } else if (actions.includes(type)) {\n return handlers[type](state, action);\n } else {\n return state;\n }\n };\n }\n}\n\n/** \n * @todo\n * abstract out the Root creation process reducer\ntype IReducer = (state: T, action: any) => T\n\ntype IReducers = {[key: string]: IReducer} & object\n\nexport function createRootReducer>(root: Root, reducers: IReducers){\n\n type Partition = keyof IReducers;\n\n const stores = Object.keys(reducers as any) as Partition[];\n\n function validatePartition(state: Record, value: Partition) {\n if (!state.has(value as any)) {\n throw Error(\"Unkown store partition \" + (value as any));\n }\n if (!(value in (reducers as any))) {\n throw Error(\"No reducers defined for store partition \" + (value as any));\n }\n }\n\n return function rootReducer(state = root, action: Store.Action) {\n return state.withMutations((state) => {\n stores.forEach((partition: Partition) => {\n validatePartition(state, partition);\n const current = state.get(partition)!;\n const reducer = reducers[partition];\n const next = reducer(current as any, action as Store.Action);\n state.set(partition, next);\n });\n });\n }\n\n}\n*/","import { Map} from 'immutable';\nimport { createAction } from '../action';\n\nconst reducers = {\n\n clear(map: Map): Map{\n return Map();\n },\n\n drop(map: Map, key: K) {\n return map.delete(key); \n },\n\n set(map: Map, payload: {[field: string|number]: V}) {\n if (typeof payload === \"object\") {\n return Object.entries(payload).reduce((map, [key, value]) => {\n if(typeof value == \"function\") {\n return map.update(key as any, value as any); \n } else {\n return map.set(key as any, value); \n }\n }, map);\n }\n return map;\n },\n\n fill(map: Map, payload: Object): Map {\n return map.merge(payload as any);\n }\n \n}\n\nconst handlers = Object.keys(reducers);\n\n\nexport default function compose(name: string){\n\n class Op {\n __parts: string[];\n constructor(parts: string[]=[]) {\n this.__parts = parts;\n return new Proxy(this, (this as any));\n }\n get(_lhs: any, type: string) {\n let val = (this as any)[type];\n if(val) {\n return val;\n }\n if(typeof type == \"string\") {\n if(this.__parts.length == 0) {\n if(type === name) {\n return new Op([...this.__parts, type])\n }\n throw new Error(`Invalid table ${type}`);\n }\n if(this.__parts.length == 1) {\n if(type.match(handlers.join(\"|\"))) {\n return (new Op([...this.__parts, type])).toString();\n }\n throw new Error(`Invalid operation ${type}`);\n }\n }\n }\n\n toArray(){\n return this.__parts;\n }\n\n toString() {\n return `@map/${this.__parts.join(\"/\")}`;\n }\n }\n\n const builder = new Op();\n\n function dispatch(state: Map, action: any, handle: string): Map {\n if(handle === \"clear\") {\n return reducers[handle](state);\n }\n if(handle === \"fill\" || handle === \"set\") {\n return reducers.set(state, action.payload);\n }\n if(handle === \"drop\") {\n return reducers[handle](state, action.payload);\n }\n return state;\n }\n\n return {\n get op(){\n return new Op();\n },\n get root(){\n return Map();\n },\n actions: {\n fill(payload: Object, meta={}) {\n const type = (builder as any)[name].set.toString();\n return createAction(type, payload, {...meta});\n },\n set(key: string, value: any, meta={}) {\n const type = (builder as any)[name].set.toString();\n return createAction(type, {[key]: value}, {...meta});\n },\n drop(key: string, meta={}) {\n const type = (builder as any)[name].drop.toString();\n return createAction(type, key, {...meta});\n },\n clear() {\n const type = (builder as any)[name].clear.toString();\n return createAction(type, {}, {});\n }\n },\n reducers: handlers.reduce((acc, handle) => {\n const handler = (map: Map, action: any) => {\n return dispatch(map, action, handle);\n }\n return {...acc, [`@map/${name}/${handle}`]: handler};\n\n }, {} as {[key: string]: (state: Map, action: any) => Map})\n\n }\n \n}\n\n\n","import { Record } from 'immutable';\nimport { createAction } from '../action';\n\ninterface BaseClass {\n [key: string]: any;\n}\n\nconst reducers = {\n\n reset(map: Record): Record{\n return map;\n },\n\n set(map: Record, payload: Object) {\n if (typeof payload === \"object\") {\n return Object.entries(payload).reduce((map, [key, value]) => {\n if(typeof value == \"function\") {\n return map.update(key as any, value); \n }\n return map.set(key as any, value); \n }, map);\n }\n return map;\n },\n\n fill(map: Record, payload: Object): Record {\n return map.merge(payload as any);\n }\n \n}\n\nconst handlers = Object.keys(reducers);\n\n\nexport default function compose Record, U=ReturnType[\"toObject\"]>>(name: string, rclass: T){\n type Root = InstanceType\n let sample = new (rclass as any)({}) as Root\n class Op {\n __parts: string[];\n constructor(parts: string[]=[]) {\n this.__parts = parts;\n return new Proxy(this, (this as any));\n }\n get(_lhs: any, type: string) {\n let val = (this as any)[type];\n if(val) {\n return val;\n }\n if(typeof type == \"string\") {\n if(this.__parts.length == 0) {\n if(type === name) {\n return new Op([...this.__parts, type])\n }\n throw new Error(`Invalid record ${type}`);\n }\n if(this.__parts.length == 1) {\n if(type.match(handlers.join(\"|\"))) {\n return (new Op([...this.__parts, type])).toString();\n }\n throw new Error(`Invalid operation ${type}`);\n }\n }\n }\n\n toArray(){\n return this.__parts;\n }\n\n toString() {\n return `@record/${this.__parts.join(\"/\")}`;\n }\n }\n\n const builder = new Op();\n\n function dispatch(state: Root, action: any, handle: string): Root {\n if(handle === \"reset\") {\n return sample;\n }\n if(handle === \"fill\" || handle === \"set\") {\n return reducers.set(state as any, action.payload) as Root;\n }\n return state;\n }\n\n return {\n get op(){\n return new Op();\n },\n get root(): Root {\n return new (rclass as any)({})\n },\n actions: {\n fill(payload: Partial, meta={}) {\n const type = (builder as any)[name].set.toString();\n return createAction(type, payload, {...meta});\n },\n set(key: keyof U, value: V, meta={}) {\n const type = (builder as any)[name].set.toString();\n return createAction(type, {[key]: value}, {...meta});\n },\n reset() {\n const type = (builder as any)[name].reset.toString();\n return createAction(type, {}, {});\n }\n },\n reducers: handlers.reduce((acc, handle) => {\n const handler = (map: Root, action: any) => {\n return dispatch(map, action, handle) as Root;\n }\n return {...acc, [`@record/${name}/${handle}`]: handler};\n\n }, {} as {[key: string]: (state: Root, action: any) => Root})\n\n }\n \n}\n\n\n\n","import { Record, OrderedMap, isImmutable } from 'immutable';\nimport { createAction, createIOAction } from '../action';\n\n\nexport type BaseTableProps = {\n row: T;\n name: string;\n rows: OrderedMap;\n}\n\nexport interface BaseTableTableMethods {\n put(key: string, value: T): Table\n clear() : Table \n\n patch(key: string, patches: T): Table\n\n drop(key: string): Table \n find(key: string, def?: T): T | undefined \n findOrDefault(key: string, def?: T): T\n}\n\nexport type BaseTable = BaseTableProps & BaseTableTableMethods\n\nexport type Table = Record> & BaseTable\n\nexport type TablesOf = Record<{[K in keyof T]: Table infer R ? R : never>}>\n\nexport function create>(row: T, name: string): ReturnType>> {\n type Row = Record;\n const schema = {\n row: row,\n name: name,\n rows: OrderedMap(),\n }\n\n const defaultRow: Row = new (row as any)({});\n\n class TableDef extends Record(schema, name) implements BaseTableTableMethods{\n\n put(key: string, value: Object) {\n // @ts-ignore\n return this.updateIn([\"rows\", key], old => old ? old.merge(value) : TableDef.make(value));\n }\n\n clear() {\n console.log(\"Clearing table\", name);\n return this.set(\"rows\", OrderedMap())\n }\n\n patch(key: string, patches: Object){\n // @ts-ignore\n if(this.rows.has(key)) {\n // @ts-ignore\n return this.updateIn([\"rows\", key], (value: any) => value.merge(patches));\n }\n return this;\n }\n\n drop(key: string){\n // @ts-ignore\n return this.updateIn([\"rows\"], (rows) => rows.delete(key));\n }\n\n find(key: string, def?: Row){\n return this.rows.get(key, def);\n }\n\n findOrDefault(key: string, def?: Row){\n return this.find(key, def) ?? defaultRow;\n }\n\n static make(data: Object): Row {\n let raw : any;\n if(isImmutable(data)) {\n raw = data.toJSON();\n } else {\n raw = data;\n }\n return new (row as any)(raw);\n }\n\n }\n return TableDef as any;\n}\n\nconst reducers = {\n\n cleared(table: Table) {\n return table.clear();\n },\n\n loaded(table: Table, id: string, payload: any) {\n if(Array.isArray(payload) && (id === undefined || id === null)) {\n return payload.reduce((table, row) => table.put(row.id, row), table);\n }\n if(id == undefined || id == null) {\n throw new Error(\"Invalid id\");\n }\n return table.put(id, payload);\n },\n\n dropped(table: Table, id: string|string[]) {\n if(Array.isArray(id)) {\n return id.reduce((table, id) => {\n return table.drop(id);\n }, table);\n }\n if(typeof id === \"function\") {\n const rows = (table as unknown as BaseTableProps).rows.filter(id);\n return table.set(\"rows\", rows);\n }\n if(typeof id === \"object\" && (id as any).id) {\n return table.drop((id as any).id);\n }\n if(typeof id === \"string\") {\n return table.drop(id);\n }\n throw new Error(\"Invalid id\");\n },\n\n updated(table: Table, id: string, payload: any) {\n if(table.rows.has(id)) {\n if(typeof payload === \"function\") {\n let row = table.find(id);\n let nextval = payload(row);\n if(nextval instanceof (table as any).row) {\n return table.setIn([\"rows\", id], nextval);\n }\n throw new Error(`Invalid return value from ${payload} Must return a new ${table.row} object`);\n } \n return table.updateIn([\"rows\", id], (row: any) => row.merge(payload));\n }\n return table;\n },\n\n set(table: Table, id: string, field: string|number, payload: any) {\n if((table as any).rows.has(id) && (table as any).rows.get(id).has(field)) {\n\n // Need to create a swap variable to avoid\n // having the value reference iself as\n // the payload if it is a function\n let value = payload;\n if(typeof payload !== \"function\") {\n value = () => payload; \n }\n return table.updateIn([\"rows\", id, field], value);\n }\n return table;\n }\n \n}\n\nconst handlers = Object.keys(reducers);\n\n\nexport default function compose(tables: Schema) {\n\n let tablenames = Object.keys(tables);\n\n const layout = Object.entries(tables).reduce((acc, [name, row]) => {\n const table = create(row, name);\n acc[name] = new table({});\n return acc;\n }, {} as {[key: string]: any});\n\n class Tables extends Record(layout, \"tables\") {}\n\n class Op {\n __parts: string[];\n constructor(parts: string[]=[]) {\n this.__parts = parts;\n return new Proxy(this, (this as any));\n }\n get(_lhs: any, type: string) {\n let val = (this as any)[type];\n if(val) {\n return val;\n }\n if(typeof type == \"string\") {\n if(this.__parts.length == 0) {\n if(tablenames.includes(type)) {\n return new Op([...this.__parts, type])\n }\n throw new Error(`Invalid table ${type}`);\n }\n if(this.__parts.length == 1) {\n return (new Op([...this.__parts, type])).toString();\n }\n }\n }\n\n toArray(){\n return this.__parts;\n }\n\n toString() {\n return `@table/${this.__parts.join(\"/\")}`;\n }\n }\n\n const builder = new Op();\n\n function dispatch(state: Table, action: any, handle: string): Table {\n const { metadata } = action;\n if(metadata) {\n if(handle === \"cleared\") {\n return reducers[handle](state);\n }\n if(handle === \"set\" && metadata.field && metadata.id) {\n let { field, id } = metadata;\n return reducers[handle](state, id, field, action.payload);\n }\n if(handle === \"updated\" && metadata.id) {\n let { id } = metadata;\n return reducers[handle](state, id, action.payload);\n }\n if(handle === \"dropped\" && metadata.id) {\n return reducers[handle](state, metadata.id ?? action.payload);\n }\n if(handle === \"loaded\" && metadata.id) {\n let { id } = metadata;\n return reducers[handle](state, id, action.payload);\n }\n }\n if(handle === \"loaded\" && (action.payload.id || Array.isArray(action.payload)) ) {\n if(Array.isArray(action.payload)) {\n return action.payload.reduce((ntable: any, row: any) => {\n if(row && row.id) {\n return reducers[handle](ntable, row.id, row);\n }\n return ntable;\n }, state);\n }\n return reducers[handle](state, action.payload.id, action.payload);\n }\n return state;\n }\n\n return {\n get op(){\n return new Op();\n },\n get root(): TablesOf {\n return new Tables({}) as any;\n },\n get tables() {\n return tablenames;\n },\n actions: {\n set(table: string, id: string, field: string, payload: any, meta={}) {\n const action = (builder as any)[table].set.toString();\n return createAction(action, payload, {...meta, field, table, action, id});\n },\n loaded(table: string, payload: any, meta={}) {\n const action = (builder as any)[table].loaded.toString();\n return createAction(action, payload, {...meta, action, table});\n },\n updated(table: string, id: string, payload: any, meta={}) {\n const action = (builder as any)[table].updated.toString();\n return createAction(action, payload, {...meta, table, action, id});\n },\n dropped(table: string, id: string, meta={}) {\n const action = (builder as any)[table].dropped.toString();\n return createAction(action, {id}, {...meta, table, action, id});\n },\n cleared(table: string) {\n const action = (builder as any)[table].cleared.toString();\n return createAction(action, {}, {table});\n },\n\n read(table: string, params: any, meta={}) {\n const action = (builder as any)[table].read.toString();\n return createIOAction(action, params, {...meta, table, action});\n },\n create(table: string, payload: any, meta={}) {\n const action = (builder as any)[table].create.toString();\n return createIOAction(action, payload, {...meta, table, action});\n },\n load(table: string, params: any, meta={}) {\n const action = (builder as any)[table].load.toString();\n return createIOAction(action, params, {...meta, table, action});\n },\n update(table: string, id: any, payload: any, meta={}) {\n const action = (builder as any)[table].update.toString();\n return createIOAction(action, {id, payload}, {...meta, table, action});\n },\n drop(table: string, id: any, meta={}) {\n const action = (builder as any)[table].drop.toString();\n return createIOAction(action, {id}, {...meta, table, action});\n },\n },\n reducers: tablenames.reduce((acc, name) => {\n\n return handlers.reduce( (acc, handle) => {\n const handler = (tables: TablesOf, action: any) => {\n const table = dispatch((tables as Tables).get(name)!, action, handle);\n return (tables as Tables).set(name, table) as TablesOf;\n }\n return {...acc, [`@table/${name}/${handle}`]: handler};\n }, acc);\n\n }, {} as {[key: string]: (state: TablesOf, action: any) => TablesOf})\n\n }\n \n}\n\n\n\n\n","import { Country, Campus, Account } from \"@campus/records\";\n\nconst tables = {\n countries: Country,\n classrooms: Campus.Classroom,\n disciplines: Campus.Discipline,\n subjects: Campus.Subject,\n levels: Campus.Level,\n students: Campus.Student,\n results: Campus.Result,\n instructors: Campus.Instructor,\n attendances: Campus.Attendance,\n roles: Campus.Role,\n permissions: Campus.Permission,\n educators: Campus.Educator,\n schools: Campus.School,\n courses: Campus.Course,\n topics: Campus.Topic,\n learners: Campus.Learner,\n lessons: Campus.Lesson,\n lectures: Campus.Lecture,\n terms: Campus.Term,\n contacts: Campus.Contact,\n sessions: Campus.Session,\n members: Campus.Member,\n memberships: Campus.Membership,\n users: Account.User,\n requests: Campus.Request,\n myschedules: Campus.MySchedule,\n}\nexport default tables\n\n","import { Record } from \"immutable\";\nimport { Auth } from \"@campus/records\";\nimport app from \"./app\";\nimport { composeReducer } from \"../utils\";\nimport mapcompose from \"./map\";\nimport listcompose from \"./list\";\nimport recordcompose from \"./record\";\nimport tablescompose from \"./tables\";\nimport tablesdef from \"../tables\";\n\n\nconst INIT = \"@@INIT\";\n\n//const lists = listcompose(\"list\");\nexport const globals = mapcompose(\"globals\");\nexport const campus = recordcompose(\"records\", app.CampusRecord);\nexport const session = recordcompose(\"session\", Auth.Session);\n\n// Compose tables\nexport const tables = tablescompose(tablesdef)\n\nconst RootStates = {\n app: app.state,\n campus: campus.root,\n tables: tables.root,\n globals: globals.root,\n session: session.root,\n};\n\nexport class RootStateRecord extends Record(RootStates, \"root\") { }\n\nexport const state = new RootStateRecord({});\n\nexport type Root = InstanceType;\n\nconst reducers = {\n app: composeReducer(app.reducers, app.state),\n campus: composeReducer(campus.reducers, campus.root),\n tables: composeReducer(tables.reducers, tables.root),\n globals: composeReducer(globals.reducers, globals.root),\n session: composeReducer(session.reducers, session.root),\n};\n\nexport type Store = keyof typeof reducers;\n\nconst stores = Object.keys(reducers) as Store[];\n\nfunction validatePartition(state: Root, value: Store) {\n if (!state.has(value)) {\n throw Error(\"Unkown store partition \" + value);\n }\n if (!(value in reducers)) {\n throw Error(\"No reducers defined for store partition \" + value);\n }\n}\n\nfunction reducer(root: Root=state, action: Store.Action){\n return root.withMutations((root) => {\n stores.forEach((partition: Store) => {\n validatePartition(root, partition);\n const current = root.get(partition)!;\n const reducer = reducers[partition];\n const next = reducer(current as any, action as Store.Action);\n root.set(partition, next);\n });\n });\n}\n\nexport default { state, reducer }\n","import { put, takeEvery, select } from \"redux-saga/effects\";\nimport * as Actions from \"../actions/app\";\n\nconst SIGNED_IN = \"SIGNED_IN\";\n\nfunction* init(payload: any, ctx: SagaContext){\n ctx.client.auth.onAuthStateChange((event: string, session: any) => {\n if(event === SIGNED_IN){\n // fill store root session\n ctx.dispatch({type: \"@@SIGNED_IN\", payload: session});\n }\n });\n}\n\nexport default [\n { effect: takeEvery, type: Actions.APP_INIT, handler: init },\n];\n","import { put, takeEvery, select } from \"redux-saga/effects\";\nimport { session} from \"../reducers\"; \nimport * as Actions from \"../actions\";\n\nconst SIGNED_IN = \"SIGNED_IN\";\n\nfunction* init(action: Actions.Auth.LoginAction, ctx: SagaContext){\n ctx.client.auth.onAuthStateChange((event: string, sess: any) => {\n if(event === SIGNED_IN){\n let { user } = sess;\n let extra = {user_id: user.id, is_anonymous: user.is_anonymous, email: user.email}\n let payload = {...sess, ...extra}\n ctx.dispatch(session.actions.fill(payload));\n }\n });\n}\n\nfunction* login(action: Actions.Auth.LoginAction, ctx: SagaContext){\n const username = action.payload.username\n const password = action.payload.password\n const email = `${username}@levelcampus.com`\n try{\n const { data, error} = yield ctx.client.auth.signInWithPassword({email, password})\n if( error){\n throw error\n }\n }catch(e: any){\n action.resolve.error(e)\n }\n\n}\n\nfunction* logout(action: Actions.Auth.LogoutAction, ctx: SagaContext){\n try{\n yield put(session.actions.reset());\n const { data, error} = yield ctx.client.auth.signOut()\n if( error){\n throw error\n }\n }catch(e: any){\n action.resolve.error(e)\n }\n\n}\n\nexport default [\n { effect: takeEvery, type: Actions.App.APP_INIT, handler: init},\n { effect: takeEvery, type: Actions.Auth.AUTH_LOGIN, handler: login},\n { effect: takeEvery, type: Actions.Auth.AUTH_LOGOUT, handler: logout},\n];\n\n","import { put, takeEvery, select } from \"redux-saga/effects\";\nimport * as Actions from \"../actions/app\";\nimport { tables } from \"../reducers\"\n\nfunction* read(action: any, ctx: SagaContext){\n try {\n let { data, error } = yield ctx.client.tables[action.metadata.table].get(action.payload);\n //tables.actions[action.metadata.action as keyof typeof tables.actions]\n if (error){\n throw error\n }\n yield action.resolve.success(data);\n yield put(tables.actions.loaded(action.metadata.table, data, {id: data.id}));\n } catch (e: any){\n console.error(e);\n yield action.resolve.error(e);\n }\n}\n\nfunction* load(action: any, ctx: SagaContext){\n try {\n let { data, error } = yield ctx.client.tables[action.metadata.table].list(action.payload);\n //tables.actions[action.metadata.action as keyof typeof tables.actions]\n if (error){\n throw error\n }\n yield action.resolve.success(data);\n yield put(tables.actions.loaded(action.metadata.table, data));\n } catch (e: any){\n console.error(e);\n yield action.resolve.error(e);\n }\n}\n\nfunction* create(action: any, ctx: SagaContext){\n try {\n let { data, error } = yield ctx.client.tables[action.metadata.table].create(action.payload);\n //tables.actions[action.metadata.action as keyof typeof tables.actions]\n if (error){\n throw error\n }\n yield action.resolve.success(data);\n yield put(tables.actions.updated(action.metadata.table, data.id, data));\n } catch (e: any){\n console.error(e);\n yield action.resolve.error(e);\n }\n}\n\nfunction* update(action: any, ctx: SagaContext){\n try {\n let { data, error } = yield ctx.client.tables[action.metadata.table].update(action.payload);\n //tables.actions[action.metadata.action as keyof typeof tables.actions]\n if (error){\n throw error\n }\n yield action.resolve.success(data);\n yield put(tables.actions.updated(action.metadata.table, data.id, data));\n } catch (e: any){\n console.error(e);\n yield action.resolve.error(e);\n }\n}\n\nfunction* trash(action: any, ctx: SagaContext){\n try {\n let { data, error } = yield ctx.client.tables[action.metadata.table].delete(action.payload);\n //tables.actions[action.metadata.action as keyof typeof tables.actions]\n if (error){\n throw error\n }\n yield action.resolve.success(data);\n yield put(tables.actions.dropped(action.metadata.table, action.payload));\n } catch (e: any){\n console.error(e);\n yield action.resolve.error(e);\n }\n}\n\nconst creates = tables.tables.map((table) => {\n return {\n effect: takeEvery,\n type: (tables.op as any)[table].create.toString(),\n handler: create\n }\n});\n\nconst reads = tables.tables.map((table) => {\n return {\n effect: takeEvery,\n type: (tables.op as any)[table].read.toString(),\n handler: read\n }\n});\n\nconst loads = tables.tables.map((table) => {\n return {\n effect: takeEvery,\n type: (tables.op as any)[table].load.toString(),\n handler: load\n }\n});\n\nconst updates = tables.tables.map((table) => {\n return {\n effect: takeEvery,\n type: (tables.op as any)[table].update.toString(),\n handler: update\n }\n});\n\nconst trashes = tables.tables.map((table) => {\n return {\n effect: takeEvery,\n type: (tables.op as any)[table].delete.toString(),\n handler: trash\n }\n});\n\nexport default [\n ...creates,\n ...reads,\n ...loads,\n ...updates,\n ...trashes,\n];\n\n","/*!\n\tCopyright (c) 2018 Jed Watson.\n\tLicensed under the MIT License (MIT), see\n\thttp://jedwatson.github.io/classnames\n*/\n/* global define */\n\n(function () {\n\t'use strict';\n\n\tvar hasOwn = {}.hasOwnProperty;\n\n\tfunction classNames () {\n\t\tvar classes = '';\n\n\t\tfor (var i = 0; i < arguments.length; i++) {\n\t\t\tvar arg = arguments[i];\n\t\t\tif (arg) {\n\t\t\t\tclasses = appendClass(classes, parseValue(arg));\n\t\t\t}\n\t\t}\n\n\t\treturn classes;\n\t}\n\n\tfunction parseValue (arg) {\n\t\tif (typeof arg === 'string' || typeof arg === 'number') {\n\t\t\treturn arg;\n\t\t}\n\n\t\tif (typeof arg !== 'object') {\n\t\t\treturn '';\n\t\t}\n\n\t\tif (Array.isArray(arg)) {\n\t\t\treturn classNames.apply(null, arg);\n\t\t}\n\n\t\tif (arg.toString !== Object.prototype.toString && !arg.toString.toString().includes('[native code]')) {\n\t\t\treturn arg.toString();\n\t\t}\n\n\t\tvar classes = '';\n\n\t\tfor (var key in arg) {\n\t\t\tif (hasOwn.call(arg, key) && arg[key]) {\n\t\t\t\tclasses = appendClass(classes, key);\n\t\t\t}\n\t\t}\n\n\t\treturn classes;\n\t}\n\n\tfunction appendClass (value, newClass) {\n\t\tif (!newClass) {\n\t\t\treturn value;\n\t\t}\n\t\n\t\tif (value) {\n\t\t\treturn value + ' ' + newClass;\n\t\t}\n\t\n\t\treturn value + newClass;\n\t}\n\n\tif (typeof module !== 'undefined' && module.exports) {\n\t\tclassNames.default = classNames;\n\t\tmodule.exports = classNames;\n\t} else if (typeof define === 'function' && typeof define.amd === 'object' && define.amd) {\n\t\t// register as 'classnames', consistent with npm package name\n\t\tdefine('classnames', [], function () {\n\t\t\treturn classNames;\n\t\t});\n\t} else {\n\t\twindow.classNames = classNames;\n\t}\n}());\n","export default function _extends() {\n _extends = Object.assign ? Object.assign.bind() : function (target) {\n for (var i = 1; i < arguments.length; i++) {\n var source = arguments[i];\n for (var key in source) {\n if (Object.prototype.hasOwnProperty.call(source, key)) {\n target[key] = source[key];\n }\n }\n }\n return target;\n };\n return _extends.apply(this, arguments);\n}","// The module cache\nvar __webpack_module_cache__ = {};\n\n// The require function\nfunction __webpack_require__(moduleId) {\n\t// Check if module is in cache\n\tvar cachedModule = __webpack_module_cache__[moduleId];\n\tif (cachedModule !== undefined) {\n\t\treturn cachedModule.exports;\n\t}\n\t// Create a new module (and put it into the cache)\n\tvar module = __webpack_module_cache__[moduleId] = {\n\t\t// no module.id needed\n\t\t// no module.loaded needed\n\t\texports: {}\n\t};\n\n\t// Execute the module function\n\t__webpack_modules__[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n\n\t// Return the exports of the module\n\treturn module.exports;\n}\n\n// expose the modules object (__webpack_modules__)\n__webpack_require__.m = __webpack_modules__;\n\n","__webpack_require__.amdO = {};","// getDefaultExport function for compatibility with non-harmony modules\n__webpack_require__.n = (module) => {\n\tvar getter = module && module.__esModule ?\n\t\t() => (module['default']) :\n\t\t() => (module);\n\t__webpack_require__.d(getter, { a: getter });\n\treturn getter;\n};","var getProto = Object.getPrototypeOf ? (obj) => (Object.getPrototypeOf(obj)) : (obj) => (obj.__proto__);\nvar leafPrototypes;\n// create a fake namespace object\n// mode & 1: value is a module id, require it\n// mode & 2: merge all properties of value into the ns\n// mode & 4: return value when already ns object\n// mode & 16: return value when it's Promise-like\n// mode & 8|1: behave like require\n__webpack_require__.t = function(value, mode) {\n\tif(mode & 1) value = this(value);\n\tif(mode & 8) return value;\n\tif(typeof value === 'object' && value) {\n\t\tif((mode & 4) && value.__esModule) return value;\n\t\tif((mode & 16) && typeof value.then === 'function') return value;\n\t}\n\tvar ns = Object.create(null);\n\t__webpack_require__.r(ns);\n\tvar def = {};\n\tleafPrototypes = leafPrototypes || [null, getProto({}), getProto([]), getProto(getProto)];\n\tfor(var current = mode & 2 && value; typeof current == 'object' && !~leafPrototypes.indexOf(current); current = getProto(current)) {\n\t\tObject.getOwnPropertyNames(current).forEach((key) => (def[key] = () => (value[key])));\n\t}\n\tdef['default'] = () => (value);\n\t__webpack_require__.d(ns, def);\n\treturn ns;\n};","// define getter functions for harmony exports\n__webpack_require__.d = (exports, definition) => {\n\tfor(var key in definition) {\n\t\tif(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) {\n\t\t\tObject.defineProperty(exports, key, { enumerable: true, get: definition[key] });\n\t\t}\n\t}\n};","__webpack_require__.f = {};\n// This file contains only the entry chunk.\n// The chunk loading function for additional chunks\n__webpack_require__.e = (chunkId) => {\n\treturn Promise.all(Object.keys(__webpack_require__.f).reduce((promises, key) => {\n\t\t__webpack_require__.f[key](chunkId, promises);\n\t\treturn promises;\n\t}, []));\n};","// This function allow to reference async chunks\n__webpack_require__.u = (chunkId) => {\n\t// return url for filenames based on template\n\treturn \"static/js/\" + chunkId + \".\" + {\"175\":\"393e8466\",\"367\":\"f57a73fd\"}[chunkId] + \".chunk.js\";\n};","// This function allow to reference async chunks\n__webpack_require__.miniCssF = (chunkId) => {\n\t// return url for filenames based on template\n\treturn undefined;\n};","__webpack_require__.g = (function() {\n\tif (typeof globalThis === 'object') return globalThis;\n\ttry {\n\t\treturn this || new Function('return this')();\n\t} catch (e) {\n\t\tif (typeof window === 'object') return window;\n\t}\n})();","__webpack_require__.o = (obj, prop) => (Object.prototype.hasOwnProperty.call(obj, prop))","var inProgress = {};\nvar dataWebpackPrefix = \"@campus/webapp:\";\n// loadScript function to load a script via script tag\n__webpack_require__.l = (url, done, key, chunkId) => {\n\tif(inProgress[url]) { inProgress[url].push(done); return; }\n\tvar script, needAttach;\n\tif(key !== undefined) {\n\t\tvar scripts = document.getElementsByTagName(\"script\");\n\t\tfor(var i = 0; i < scripts.length; i++) {\n\t\t\tvar s = scripts[i];\n\t\t\tif(s.getAttribute(\"src\") == url || s.getAttribute(\"data-webpack\") == dataWebpackPrefix + key) { script = s; break; }\n\t\t}\n\t}\n\tif(!script) {\n\t\tneedAttach = true;\n\t\tscript = document.createElement('script');\n\n\t\tscript.charset = 'utf-8';\n\t\tscript.timeout = 120;\n\t\tif (__webpack_require__.nc) {\n\t\t\tscript.setAttribute(\"nonce\", __webpack_require__.nc);\n\t\t}\n\t\tscript.setAttribute(\"data-webpack\", dataWebpackPrefix + key);\n\n\t\tscript.src = url;\n\t}\n\tinProgress[url] = [done];\n\tvar onScriptComplete = (prev, event) => {\n\t\t// avoid mem leaks in IE.\n\t\tscript.onerror = script.onload = null;\n\t\tclearTimeout(timeout);\n\t\tvar doneFns = inProgress[url];\n\t\tdelete inProgress[url];\n\t\tscript.parentNode && script.parentNode.removeChild(script);\n\t\tdoneFns && doneFns.forEach((fn) => (fn(event)));\n\t\tif(prev) return prev(event);\n\t}\n\tvar timeout = setTimeout(onScriptComplete.bind(null, undefined, { type: 'timeout', target: script }), 120000);\n\tscript.onerror = onScriptComplete.bind(null, script.onerror);\n\tscript.onload = onScriptComplete.bind(null, script.onload);\n\tneedAttach && document.head.appendChild(script);\n};","// define __esModule on exports\n__webpack_require__.r = (exports) => {\n\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\t}\n\tObject.defineProperty(exports, '__esModule', { value: true });\n};","__webpack_require__.p = \"/\";","// no baseURI\n\n// object to store loaded and loading chunks\n// undefined = chunk not loaded, null = chunk preloaded/prefetched\n// [resolve, reject, Promise] = chunk loading, 0 = chunk loaded\nvar installedChunks = {\n\t179: 0\n};\n\n__webpack_require__.f.j = (chunkId, promises) => {\n\t\t// JSONP chunk loading for javascript\n\t\tvar installedChunkData = __webpack_require__.o(installedChunks, chunkId) ? installedChunks[chunkId] : undefined;\n\t\tif(installedChunkData !== 0) { // 0 means \"already installed\".\n\n\t\t\t// a Promise means \"currently loading\".\n\t\t\tif(installedChunkData) {\n\t\t\t\tpromises.push(installedChunkData[2]);\n\t\t\t} else {\n\t\t\t\tif(true) { // all chunks have JS\n\t\t\t\t\t// setup Promise in chunk cache\n\t\t\t\t\tvar promise = new Promise((resolve, reject) => (installedChunkData = installedChunks[chunkId] = [resolve, reject]));\n\t\t\t\t\tpromises.push(installedChunkData[2] = promise);\n\n\t\t\t\t\t// start chunk loading\n\t\t\t\t\tvar url = __webpack_require__.p + __webpack_require__.u(chunkId);\n\t\t\t\t\t// create error before stack unwound to get useful stacktrace later\n\t\t\t\t\tvar error = new Error();\n\t\t\t\t\tvar loadingEnded = (event) => {\n\t\t\t\t\t\tif(__webpack_require__.o(installedChunks, chunkId)) {\n\t\t\t\t\t\t\tinstalledChunkData = installedChunks[chunkId];\n\t\t\t\t\t\t\tif(installedChunkData !== 0) installedChunks[chunkId] = undefined;\n\t\t\t\t\t\t\tif(installedChunkData) {\n\t\t\t\t\t\t\t\tvar errorType = event && (event.type === 'load' ? 'missing' : event.type);\n\t\t\t\t\t\t\t\tvar realSrc = event && event.target && event.target.src;\n\t\t\t\t\t\t\t\terror.message = 'Loading chunk ' + chunkId + ' failed.\\n(' + errorType + ': ' + realSrc + ')';\n\t\t\t\t\t\t\t\terror.name = 'ChunkLoadError';\n\t\t\t\t\t\t\t\terror.type = errorType;\n\t\t\t\t\t\t\t\terror.request = realSrc;\n\t\t\t\t\t\t\t\tinstalledChunkData[1](error);\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\t\t\t\t\t};\n\t\t\t\t\t__webpack_require__.l(url, loadingEnded, \"chunk-\" + chunkId, chunkId);\n\t\t\t\t}\n\t\t\t}\n\t\t}\n};\n\n// no prefetching\n\n// no preloaded\n\n// no HMR\n\n// no HMR manifest\n\n// no on chunks loaded\n\n// install a JSONP callback for chunk loading\nvar webpackJsonpCallback = (parentChunkLoadingFunction, data) => {\n\tvar chunkIds = data[0];\n\tvar moreModules = data[1];\n\tvar runtime = data[2];\n\t// add \"moreModules\" to the modules object,\n\t// then flag all \"chunkIds\" as loaded and fire callback\n\tvar moduleId, chunkId, i = 0;\n\tif(chunkIds.some((id) => (installedChunks[id] !== 0))) {\n\t\tfor(moduleId in moreModules) {\n\t\t\tif(__webpack_require__.o(moreModules, moduleId)) {\n\t\t\t\t__webpack_require__.m[moduleId] = moreModules[moduleId];\n\t\t\t}\n\t\t}\n\t\tif(runtime) var result = runtime(__webpack_require__);\n\t}\n\tif(parentChunkLoadingFunction) parentChunkLoadingFunction(data);\n\tfor(;i < chunkIds.length; i++) {\n\t\tchunkId = chunkIds[i];\n\t\tif(__webpack_require__.o(installedChunks, chunkId) && installedChunks[chunkId]) {\n\t\t\tinstalledChunks[chunkId][0]();\n\t\t}\n\t\tinstalledChunks[chunkId] = 0;\n\t}\n\n}\n\nvar chunkLoadingGlobal = self[\"webpackChunk_campus_webapp\"] = self[\"webpackChunk_campus_webapp\"] || [];\nchunkLoadingGlobal.forEach(webpackJsonpCallback.bind(null, 0));\nchunkLoadingGlobal.push = webpackJsonpCallback.bind(null, chunkLoadingGlobal.push.bind(chunkLoadingGlobal));","////////////////////////////////////////////////////////////////////////////////\n//#region Types and Constants\n////////////////////////////////////////////////////////////////////////////////\n\n/**\n * Actions represent the type of change to a location value.\n */\nexport enum Action {\n /**\n * A POP indicates a change to an arbitrary index in the history stack, such\n * as a back or forward navigation. It does not describe the direction of the\n * navigation, only that the current index changed.\n *\n * Note: This is the default action for newly created history objects.\n */\n Pop = \"POP\",\n\n /**\n * A PUSH indicates a new entry being added to the history stack, such as when\n * a link is clicked and a new page loads. When this happens, all subsequent\n * entries in the stack are lost.\n */\n Push = \"PUSH\",\n\n /**\n * A REPLACE indicates the entry at the current index in the history stack\n * being replaced by a new one.\n */\n Replace = \"REPLACE\",\n}\n\n/**\n * The pathname, search, and hash values of a URL.\n */\nexport interface Path {\n /**\n * A URL pathname, beginning with a /.\n */\n pathname: string;\n\n /**\n * A URL search string, beginning with a ?.\n */\n search: string;\n\n /**\n * A URL fragment identifier, beginning with a #.\n */\n hash: string;\n}\n\n// TODO: (v7) Change the Location generic default from `any` to `unknown` and\n// remove Remix `useLocation` wrapper.\n\n/**\n * An entry in a history stack. A location contains information about the\n * URL path, as well as possibly some arbitrary state and a key.\n */\nexport interface Location extends Path {\n /**\n * A value of arbitrary data associated with this location.\n */\n state: State;\n\n /**\n * A unique string associated with this location. May be used to safely store\n * and retrieve data in some other storage API, like `localStorage`.\n *\n * Note: This value is always \"default\" on the initial location.\n */\n key: string;\n}\n\n/**\n * A change to the current location.\n */\nexport interface Update {\n /**\n * The action that triggered the change.\n */\n action: Action;\n\n /**\n * The new location.\n */\n location: Location;\n\n /**\n * The delta between this location and the former location in the history stack\n */\n delta: number | null;\n}\n\n/**\n * A function that receives notifications about location changes.\n */\nexport interface Listener {\n (update: Update): void;\n}\n\n/**\n * Describes a location that is the destination of some navigation, either via\n * `history.push` or `history.replace`. This may be either a URL or the pieces\n * of a URL path.\n */\nexport type To = string | Partial;\n\n/**\n * A history is an interface to the navigation stack. The history serves as the\n * source of truth for the current location, as well as provides a set of\n * methods that may be used to change it.\n *\n * It is similar to the DOM's `window.history` object, but with a smaller, more\n * focused API.\n */\nexport interface History {\n /**\n * The last action that modified the current location. This will always be\n * Action.Pop when a history instance is first created. This value is mutable.\n */\n readonly action: Action;\n\n /**\n * The current location. This value is mutable.\n */\n readonly location: Location;\n\n /**\n * Returns a valid href for the given `to` value that may be used as\n * the value of an attribute.\n *\n * @param to - The destination URL\n */\n createHref(to: To): string;\n\n /**\n * Returns a URL for the given `to` value\n *\n * @param to - The destination URL\n */\n createURL(to: To): URL;\n\n /**\n * Encode a location the same way window.history would do (no-op for memory\n * history) so we ensure our PUSH/REPLACE navigations for data routers\n * behave the same as POP\n *\n * @param to Unencoded path\n */\n encodeLocation(to: To): Path;\n\n /**\n * Pushes a new location onto the history stack, increasing its length by one.\n * If there were any entries in the stack after the current one, they are\n * lost.\n *\n * @param to - The new URL\n * @param state - Data to associate with the new location\n */\n push(to: To, state?: any): void;\n\n /**\n * Replaces the current location in the history stack with a new one. The\n * location that was replaced will no longer be available.\n *\n * @param to - The new URL\n * @param state - Data to associate with the new location\n */\n replace(to: To, state?: any): void;\n\n /**\n * Navigates `n` entries backward/forward in the history stack relative to the\n * current index. For example, a \"back\" navigation would use go(-1).\n *\n * @param delta - The delta in the stack index\n */\n go(delta: number): void;\n\n /**\n * Sets up a listener that will be called whenever the current location\n * changes.\n *\n * @param listener - A function that will be called when the location changes\n * @returns unlisten - A function that may be used to stop listening\n */\n listen(listener: Listener): () => void;\n}\n\ntype HistoryState = {\n usr: any;\n key?: string;\n idx: number;\n};\n\nconst PopStateEventType = \"popstate\";\n//#endregion\n\n////////////////////////////////////////////////////////////////////////////////\n//#region Memory History\n////////////////////////////////////////////////////////////////////////////////\n\n/**\n * A user-supplied object that describes a location. Used when providing\n * entries to `createMemoryHistory` via its `initialEntries` option.\n */\nexport type InitialEntry = string | Partial;\n\nexport type MemoryHistoryOptions = {\n initialEntries?: InitialEntry[];\n initialIndex?: number;\n v5Compat?: boolean;\n};\n\n/**\n * A memory history stores locations in memory. This is useful in stateful\n * environments where there is no web browser, such as node tests or React\n * Native.\n */\nexport interface MemoryHistory extends History {\n /**\n * The current index in the history stack.\n */\n readonly index: number;\n}\n\n/**\n * Memory history stores the current location in memory. It is designed for use\n * in stateful non-browser environments like tests and React Native.\n */\nexport function createMemoryHistory(\n options: MemoryHistoryOptions = {}\n): MemoryHistory {\n let { initialEntries = [\"/\"], initialIndex, v5Compat = false } = options;\n let entries: Location[]; // Declare so we can access from createMemoryLocation\n entries = initialEntries.map((entry, index) =>\n createMemoryLocation(\n entry,\n typeof entry === \"string\" ? null : entry.state,\n index === 0 ? \"default\" : undefined\n )\n );\n let index = clampIndex(\n initialIndex == null ? entries.length - 1 : initialIndex\n );\n let action = Action.Pop;\n let listener: Listener | null = null;\n\n function clampIndex(n: number): number {\n return Math.min(Math.max(n, 0), entries.length - 1);\n }\n function getCurrentLocation(): Location {\n return entries[index];\n }\n function createMemoryLocation(\n to: To,\n state: any = null,\n key?: string\n ): Location {\n let location = createLocation(\n entries ? getCurrentLocation().pathname : \"/\",\n to,\n state,\n key\n );\n warning(\n location.pathname.charAt(0) === \"/\",\n `relative pathnames are not supported in memory history: ${JSON.stringify(\n to\n )}`\n );\n return location;\n }\n\n function createHref(to: To) {\n return typeof to === \"string\" ? to : createPath(to);\n }\n\n let history: MemoryHistory = {\n get index() {\n return index;\n },\n get action() {\n return action;\n },\n get location() {\n return getCurrentLocation();\n },\n createHref,\n createURL(to) {\n return new URL(createHref(to), \"http://localhost\");\n },\n encodeLocation(to: To) {\n let path = typeof to === \"string\" ? parsePath(to) : to;\n return {\n pathname: path.pathname || \"\",\n search: path.search || \"\",\n hash: path.hash || \"\",\n };\n },\n push(to, state) {\n action = Action.Push;\n let nextLocation = createMemoryLocation(to, state);\n index += 1;\n entries.splice(index, entries.length, nextLocation);\n if (v5Compat && listener) {\n listener({ action, location: nextLocation, delta: 1 });\n }\n },\n replace(to, state) {\n action = Action.Replace;\n let nextLocation = createMemoryLocation(to, state);\n entries[index] = nextLocation;\n if (v5Compat && listener) {\n listener({ action, location: nextLocation, delta: 0 });\n }\n },\n go(delta) {\n action = Action.Pop;\n let nextIndex = clampIndex(index + delta);\n let nextLocation = entries[nextIndex];\n index = nextIndex;\n if (listener) {\n listener({ action, location: nextLocation, delta });\n }\n },\n listen(fn: Listener) {\n listener = fn;\n return () => {\n listener = null;\n };\n },\n };\n\n return history;\n}\n//#endregion\n\n////////////////////////////////////////////////////////////////////////////////\n//#region Browser History\n////////////////////////////////////////////////////////////////////////////////\n\n/**\n * A browser history stores the current location in regular URLs in a web\n * browser environment. This is the standard for most web apps and provides the\n * cleanest URLs the browser's address bar.\n *\n * @see https://github.com/remix-run/history/tree/main/docs/api-reference.md#browserhistory\n */\nexport interface BrowserHistory extends UrlHistory {}\n\nexport type BrowserHistoryOptions = UrlHistoryOptions;\n\n/**\n * Browser history stores the location in regular URLs. This is the standard for\n * most web apps, but it requires some configuration on the server to ensure you\n * serve the same app at multiple URLs.\n *\n * @see https://github.com/remix-run/history/tree/main/docs/api-reference.md#createbrowserhistory\n */\nexport function createBrowserHistory(\n options: BrowserHistoryOptions = {}\n): BrowserHistory {\n function createBrowserLocation(\n window: Window,\n globalHistory: Window[\"history\"]\n ) {\n let { pathname, search, hash } = window.location;\n return createLocation(\n \"\",\n { pathname, search, hash },\n // state defaults to `null` because `window.history.state` does\n (globalHistory.state && globalHistory.state.usr) || null,\n (globalHistory.state && globalHistory.state.key) || \"default\"\n );\n }\n\n function createBrowserHref(window: Window, to: To) {\n return typeof to === \"string\" ? to : createPath(to);\n }\n\n return getUrlBasedHistory(\n createBrowserLocation,\n createBrowserHref,\n null,\n options\n );\n}\n//#endregion\n\n////////////////////////////////////////////////////////////////////////////////\n//#region Hash History\n////////////////////////////////////////////////////////////////////////////////\n\n/**\n * A hash history stores the current location in the fragment identifier portion\n * of the URL in a web browser environment.\n *\n * This is ideal for apps that do not control the server for some reason\n * (because the fragment identifier is never sent to the server), including some\n * shared hosting environments that do not provide fine-grained controls over\n * which pages are served at which URLs.\n *\n * @see https://github.com/remix-run/history/tree/main/docs/api-reference.md#hashhistory\n */\nexport interface HashHistory extends UrlHistory {}\n\nexport type HashHistoryOptions = UrlHistoryOptions;\n\n/**\n * Hash history stores the location in window.location.hash. This makes it ideal\n * for situations where you don't want to send the location to the server for\n * some reason, either because you do cannot configure it or the URL space is\n * reserved for something else.\n *\n * @see https://github.com/remix-run/history/tree/main/docs/api-reference.md#createhashhistory\n */\nexport function createHashHistory(\n options: HashHistoryOptions = {}\n): HashHistory {\n function createHashLocation(\n window: Window,\n globalHistory: Window[\"history\"]\n ) {\n let {\n pathname = \"/\",\n search = \"\",\n hash = \"\",\n } = parsePath(window.location.hash.substr(1));\n\n // Hash URL should always have a leading / just like window.location.pathname\n // does, so if an app ends up at a route like /#something then we add a\n // leading slash so all of our path-matching behaves the same as if it would\n // in a browser router. This is particularly important when there exists a\n // root splat route () since that matches internally against\n // \"/*\" and we'd expect /#something to 404 in a hash router app.\n if (!pathname.startsWith(\"/\") && !pathname.startsWith(\".\")) {\n pathname = \"/\" + pathname;\n }\n\n return createLocation(\n \"\",\n { pathname, search, hash },\n // state defaults to `null` because `window.history.state` does\n (globalHistory.state && globalHistory.state.usr) || null,\n (globalHistory.state && globalHistory.state.key) || \"default\"\n );\n }\n\n function createHashHref(window: Window, to: To) {\n let base = window.document.querySelector(\"base\");\n let href = \"\";\n\n if (base && base.getAttribute(\"href\")) {\n let url = window.location.href;\n let hashIndex = url.indexOf(\"#\");\n href = hashIndex === -1 ? url : url.slice(0, hashIndex);\n }\n\n return href + \"#\" + (typeof to === \"string\" ? to : createPath(to));\n }\n\n function validateHashLocation(location: Location, to: To) {\n warning(\n location.pathname.charAt(0) === \"/\",\n `relative pathnames are not supported in hash history.push(${JSON.stringify(\n to\n )})`\n );\n }\n\n return getUrlBasedHistory(\n createHashLocation,\n createHashHref,\n validateHashLocation,\n options\n );\n}\n//#endregion\n\n////////////////////////////////////////////////////////////////////////////////\n//#region UTILS\n////////////////////////////////////////////////////////////////////////////////\n\n/**\n * @private\n */\nexport function invariant(value: boolean, message?: string): asserts value;\nexport function invariant(\n value: T | null | undefined,\n message?: string\n): asserts value is T;\nexport function invariant(value: any, message?: string) {\n if (value === false || value === null || typeof value === \"undefined\") {\n throw new Error(message);\n }\n}\n\nexport function warning(cond: any, message: string) {\n if (!cond) {\n // eslint-disable-next-line no-console\n if (typeof console !== \"undefined\") console.warn(message);\n\n try {\n // Welcome to debugging history!\n //\n // This error is thrown as a convenience, so you can more easily\n // find the source for a warning that appears in the console by\n // enabling \"pause on exceptions\" in your JavaScript debugger.\n throw new Error(message);\n // eslint-disable-next-line no-empty\n } catch (e) {}\n }\n}\n\nfunction createKey() {\n return Math.random().toString(36).substr(2, 8);\n}\n\n/**\n * For browser-based histories, we combine the state and key into an object\n */\nfunction getHistoryState(location: Location, index: number): HistoryState {\n return {\n usr: location.state,\n key: location.key,\n idx: index,\n };\n}\n\n/**\n * Creates a Location object with a unique key from the given Path\n */\nexport function createLocation(\n current: string | Location,\n to: To,\n state: any = null,\n key?: string\n): Readonly {\n let location: Readonly = {\n pathname: typeof current === \"string\" ? current : current.pathname,\n search: \"\",\n hash: \"\",\n ...(typeof to === \"string\" ? parsePath(to) : to),\n state,\n // TODO: This could be cleaned up. push/replace should probably just take\n // full Locations now and avoid the need to run through this flow at all\n // But that's a pretty big refactor to the current test suite so going to\n // keep as is for the time being and just let any incoming keys take precedence\n key: (to && (to as Location).key) || key || createKey(),\n };\n return location;\n}\n\n/**\n * Creates a string URL path from the given pathname, search, and hash components.\n */\nexport function createPath({\n pathname = \"/\",\n search = \"\",\n hash = \"\",\n}: Partial) {\n if (search && search !== \"?\")\n pathname += search.charAt(0) === \"?\" ? search : \"?\" + search;\n if (hash && hash !== \"#\")\n pathname += hash.charAt(0) === \"#\" ? hash : \"#\" + hash;\n return pathname;\n}\n\n/**\n * Parses a string URL path into its separate pathname, search, and hash components.\n */\nexport function parsePath(path: string): Partial {\n let parsedPath: Partial = {};\n\n if (path) {\n let hashIndex = path.indexOf(\"#\");\n if (hashIndex >= 0) {\n parsedPath.hash = path.substr(hashIndex);\n path = path.substr(0, hashIndex);\n }\n\n let searchIndex = path.indexOf(\"?\");\n if (searchIndex >= 0) {\n parsedPath.search = path.substr(searchIndex);\n path = path.substr(0, searchIndex);\n }\n\n if (path) {\n parsedPath.pathname = path;\n }\n }\n\n return parsedPath;\n}\n\nexport interface UrlHistory extends History {}\n\nexport type UrlHistoryOptions = {\n window?: Window;\n v5Compat?: boolean;\n};\n\nfunction getUrlBasedHistory(\n getLocation: (window: Window, globalHistory: Window[\"history\"]) => Location,\n createHref: (window: Window, to: To) => string,\n validateLocation: ((location: Location, to: To) => void) | null,\n options: UrlHistoryOptions = {}\n): UrlHistory {\n let { window = document.defaultView!, v5Compat = false } = options;\n let globalHistory = window.history;\n let action = Action.Pop;\n let listener: Listener | null = null;\n\n let index = getIndex()!;\n // Index should only be null when we initialize. If not, it's because the\n // user called history.pushState or history.replaceState directly, in which\n // case we should log a warning as it will result in bugs.\n if (index == null) {\n index = 0;\n globalHistory.replaceState({ ...globalHistory.state, idx: index }, \"\");\n }\n\n function getIndex(): number {\n let state = globalHistory.state || { idx: null };\n return state.idx;\n }\n\n function handlePop() {\n action = Action.Pop;\n let nextIndex = getIndex();\n let delta = nextIndex == null ? null : nextIndex - index;\n index = nextIndex;\n if (listener) {\n listener({ action, location: history.location, delta });\n }\n }\n\n function push(to: To, state?: any) {\n action = Action.Push;\n let location = createLocation(history.location, to, state);\n if (validateLocation) validateLocation(location, to);\n\n index = getIndex() + 1;\n let historyState = getHistoryState(location, index);\n let url = history.createHref(location);\n\n // try...catch because iOS limits us to 100 pushState calls :/\n try {\n globalHistory.pushState(historyState, \"\", url);\n } catch (error) {\n // If the exception is because `state` can't be serialized, let that throw\n // outwards just like a replace call would so the dev knows the cause\n // https://html.spec.whatwg.org/multipage/nav-history-apis.html#shared-history-push/replace-state-steps\n // https://html.spec.whatwg.org/multipage/structured-data.html#structuredserializeinternal\n if (error instanceof DOMException && error.name === \"DataCloneError\") {\n throw error;\n }\n // They are going to lose state here, but there is no real\n // way to warn them about it since the page will refresh...\n window.location.assign(url);\n }\n\n if (v5Compat && listener) {\n listener({ action, location: history.location, delta: 1 });\n }\n }\n\n function replace(to: To, state?: any) {\n action = Action.Replace;\n let location = createLocation(history.location, to, state);\n if (validateLocation) validateLocation(location, to);\n\n index = getIndex();\n let historyState = getHistoryState(location, index);\n let url = history.createHref(location);\n globalHistory.replaceState(historyState, \"\", url);\n\n if (v5Compat && listener) {\n listener({ action, location: history.location, delta: 0 });\n }\n }\n\n function createURL(to: To): URL {\n // window.location.origin is \"null\" (the literal string value) in Firefox\n // under certain conditions, notably when serving from a local HTML file\n // See https://bugzilla.mozilla.org/show_bug.cgi?id=878297\n let base =\n window.location.origin !== \"null\"\n ? window.location.origin\n : window.location.href;\n\n let href = typeof to === \"string\" ? to : createPath(to);\n invariant(\n base,\n `No window.location.(origin|href) available to create URL for href: ${href}`\n );\n return new URL(href, base);\n }\n\n let history: History = {\n get action() {\n return action;\n },\n get location() {\n return getLocation(window, globalHistory);\n },\n listen(fn: Listener) {\n if (listener) {\n throw new Error(\"A history only accepts one active listener\");\n }\n window.addEventListener(PopStateEventType, handlePop);\n listener = fn;\n\n return () => {\n window.removeEventListener(PopStateEventType, handlePop);\n listener = null;\n };\n },\n createHref(to) {\n return createHref(window, to);\n },\n createURL,\n encodeLocation(to) {\n // Encode a Location the same way window.location would\n let url = createURL(to);\n return {\n pathname: url.pathname,\n search: url.search,\n hash: url.hash,\n };\n },\n push,\n replace,\n go(n) {\n return globalHistory.go(n);\n },\n };\n\n return history;\n}\n\n//#endregion\n","import type { Location, Path, To } from \"./history\";\nimport { invariant, parsePath, warning } from \"./history\";\n\n/**\n * Map of routeId -> data returned from a loader/action/error\n */\nexport interface RouteData {\n [routeId: string]: any;\n}\n\nexport enum ResultType {\n data = \"data\",\n deferred = \"deferred\",\n redirect = \"redirect\",\n error = \"error\",\n}\n\n/**\n * Successful result from a loader or action\n */\nexport interface SuccessResult {\n type: ResultType.data;\n data: any;\n statusCode?: number;\n headers?: Headers;\n}\n\n/**\n * Successful defer() result from a loader or action\n */\nexport interface DeferredResult {\n type: ResultType.deferred;\n deferredData: DeferredData;\n statusCode?: number;\n headers?: Headers;\n}\n\n/**\n * Redirect result from a loader or action\n */\nexport interface RedirectResult {\n type: ResultType.redirect;\n status: number;\n location: string;\n revalidate: boolean;\n reloadDocument?: boolean;\n}\n\n/**\n * Unsuccessful result from a loader or action\n */\nexport interface ErrorResult {\n type: ResultType.error;\n error: any;\n headers?: Headers;\n}\n\n/**\n * Result from a loader or action - potentially successful or unsuccessful\n */\nexport type DataResult =\n | SuccessResult\n | DeferredResult\n | RedirectResult\n | ErrorResult;\n\ntype LowerCaseFormMethod = \"get\" | \"post\" | \"put\" | \"patch\" | \"delete\";\ntype UpperCaseFormMethod = Uppercase;\n\n/**\n * Users can specify either lowercase or uppercase form methods on `