Skip to content

Instantly share code, notes, and snippets.

@douglasduteil
Last active September 29, 2017 11:41
Show Gist options
  • Save douglasduteil/8d0af7a0ecd5ab81fea9d82a653cedb1 to your computer and use it in GitHub Desktop.
Save douglasduteil/8d0af7a0ecd5ab81fea9d82a653cedb1 to your computer and use it in GitHub Desktop.
RePeople "yarn run webpack --json > stats.json"
{
"errors": [],
"warnings": [],
"version": "3.6.0",
"hash": "71c562100488c2ac824e",
"time": 2494,
"publicPath": "",
"assetsByChunkName": {
"main": "bundle.js"
},
"assets": [
{
"name": "6dc3d87ca4e7a3c134aab663f0a17a10.svg",
"size": 2479,
"chunks": [],
"chunkNames": [],
"emitted": true
},
{
"name": "bundle.js",
"size": 3734640,
"chunks": [
0
],
"chunkNames": [
"main"
],
"emitted": true,
"isOverSizeLimit": true
},
{
"name": "index.html",
"size": 200,
"chunks": [],
"chunkNames": [],
"emitted": true
},
{
"name": "people.json",
"size": 9260,
"chunks": [],
"chunkNames": [],
"emitted": true
}
],
"filteredAssets": 0,
"entrypoints": {
"main": {
"chunks": [
0
],
"assets": [
"bundle.js"
],
"isOverSizeLimit": true
}
},
"chunks": [
{
"id": 0,
"rendered": true,
"initial": true,
"entry": true,
"extraAsync": false,
"size": 3592056,
"names": [
"main"
],
"files": [
"bundle.js"
],
"hash": "a30729125722bb0744cf",
"parents": [],
"modules": [
{
"id": 0,
"identifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/bs-platform/lib/js/caml_builtin_exceptions.js",
"name": "./node_modules/bs-platform/lib/js/caml_builtin_exceptions.js",
"index": 5,
"index2": 1,
"size": 1734,
"cacheable": true,
"built": true,
"optional": false,
"prefetched": false,
"chunks": [
0
],
"assets": [],
"issuer": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/bs-platform/lib/js/list.js",
"issuerId": 14,
"issuerName": "./node_modules/bs-platform/lib/js/list.js",
"failed": false,
"errors": 0,
"warnings": 0,
"reasons": [
{
"moduleId": 5,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/reason-react/lib/js/src/reasonReact.js",
"module": "./node_modules/reason-react/lib/js/src/reasonReact.js",
"moduleName": "./node_modules/reason-react/lib/js/src/reasonReact.js",
"type": "cjs require",
"userRequest": "bs-platform/lib/js/caml_builtin_exceptions.js",
"loc": "7:38-94"
},
{
"moduleId": 8,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/bs-platform/lib/js/caml_obj.js",
"module": "./node_modules/bs-platform/lib/js/caml_obj.js",
"moduleName": "./node_modules/bs-platform/lib/js/caml_obj.js",
"type": "cjs require",
"userRequest": "./caml_builtin_exceptions.js",
"loc": "4:30-69"
},
{
"moduleId": 9,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/bs-platform/lib/js/caml_string.js",
"module": "./node_modules/bs-platform/lib/js/caml_string.js",
"moduleName": "./node_modules/bs-platform/lib/js/caml_string.js",
"type": "cjs require",
"userRequest": "./caml_builtin_exceptions.js",
"loc": "3:30-69"
},
{
"moduleId": 12,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/bs-platform/lib/js/caml_array.js",
"module": "./node_modules/bs-platform/lib/js/caml_array.js",
"moduleName": "./node_modules/bs-platform/lib/js/caml_array.js",
"type": "cjs require",
"userRequest": "./caml_builtin_exceptions.js",
"loc": "3:30-69"
},
{
"moduleId": 14,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/bs-platform/lib/js/list.js",
"module": "./node_modules/bs-platform/lib/js/list.js",
"moduleName": "./node_modules/bs-platform/lib/js/list.js",
"type": "cjs require",
"userRequest": "./caml_builtin_exceptions.js",
"loc": "6:30-69"
},
{
"moduleId": 15,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/bs-platform/lib/js/pervasives.js",
"module": "./node_modules/bs-platform/lib/js/pervasives.js",
"moduleName": "./node_modules/bs-platform/lib/js/pervasives.js",
"type": "cjs require",
"userRequest": "./caml_builtin_exceptions.js",
"loc": "11:31-70"
},
{
"moduleId": 19,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/bs-platform/lib/js/caml_format.js",
"module": "./node_modules/bs-platform/lib/js/caml_format.js",
"moduleName": "./node_modules/bs-platform/lib/js/caml_format.js",
"type": "cjs require",
"userRequest": "./caml_builtin_exceptions.js",
"loc": "7:30-69"
},
{
"moduleId": 20,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/bs-platform/lib/js/caml_int32.js",
"module": "./node_modules/bs-platform/lib/js/caml_int32.js",
"moduleName": "./node_modules/bs-platform/lib/js/caml_int32.js",
"type": "cjs require",
"userRequest": "./caml_builtin_exceptions.js",
"loc": "3:30-69"
},
{
"moduleId": 21,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/bs-platform/lib/js/array.js",
"module": "./node_modules/bs-platform/lib/js/array.js",
"moduleName": "./node_modules/bs-platform/lib/js/array.js",
"type": "cjs require",
"userRequest": "./caml_builtin_exceptions.js",
"loc": "7:30-69"
},
{
"moduleId": 24,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/bs-platform/lib/js/caml_sys.js",
"module": "./node_modules/bs-platform/lib/js/caml_sys.js",
"moduleName": "./node_modules/bs-platform/lib/js/caml_sys.js",
"type": "cjs require",
"userRequest": "./caml_builtin_exceptions.js",
"loc": "3:30-69"
},
{
"moduleId": 25,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/bs-platform/lib/js/caml_int64.js",
"module": "./node_modules/bs-platform/lib/js/caml_int64.js",
"moduleName": "./node_modules/bs-platform/lib/js/caml_int64.js",
"type": "cjs require",
"userRequest": "./caml_builtin_exceptions.js",
"loc": "6:30-69"
},
{
"moduleId": 32,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/bs-platform/lib/js/char.js",
"module": "./node_modules/bs-platform/lib/js/char.js",
"moduleName": "./node_modules/bs-platform/lib/js/char.js",
"type": "cjs require",
"userRequest": "./caml_builtin_exceptions.js",
"loc": "4:30-69"
},
{
"moduleId": 43,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/bs-platform/lib/js/caml_io.js",
"module": "./node_modules/bs-platform/lib/js/caml_io.js",
"moduleName": "./node_modules/bs-platform/lib/js/caml_io.js",
"type": "cjs require",
"userRequest": "./caml_builtin_exceptions.js",
"loc": "4:30-69"
},
{
"moduleId": 52,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/bs-json/lib/js/src/Json_decode.js",
"module": "./node_modules/bs-json/lib/js/src/Json_decode.js",
"moduleName": "./node_modules/bs-json/lib/js/src/Json_decode.js",
"type": "cjs require",
"userRequest": "bs-platform/lib/js/caml_builtin_exceptions.js",
"loc": "9:30-86"
},
{
"moduleId": 62,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/bs-platform/lib/js/random.js",
"module": "./node_modules/bs-platform/lib/js/random.js",
"moduleName": "./node_modules/bs-platform/lib/js/random.js",
"type": "cjs require",
"userRequest": "./caml_builtin_exceptions.js",
"loc": "14:30-69"
},
{
"moduleId": 65,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/bs-platform/lib/js/digest.js",
"module": "./node_modules/bs-platform/lib/js/digest.js",
"moduleName": "./node_modules/bs-platform/lib/js/digest.js",
"type": "cjs require",
"userRequest": "./caml_builtin_exceptions.js",
"loc": "9:30-69"
},
{
"moduleId": 67,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/bs-platform/lib/js/bytes.js",
"module": "./node_modules/bs-platform/lib/js/bytes.js",
"moduleName": "./node_modules/bs-platform/lib/js/bytes.js",
"type": "cjs require",
"userRequest": "./caml_builtin_exceptions.js",
"loc": "10:30-69"
},
{
"moduleId": 75,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/reason-react/lib/js/src/reactDOMRe.js",
"module": "./node_modules/reason-react/lib/js/src/reactDOMRe.js",
"moduleName": "./node_modules/reason-react/lib/js/src/reactDOMRe.js",
"type": "cjs require",
"userRequest": "bs-platform/lib/js/caml_builtin_exceptions.js",
"loc": "6:30-86"
}
],
"usedExports": true,
"providedExports": null,
"optimizationBailout": [],
"depth": 2,
"source": "'use strict';\n\n\nvar out_of_memory = /* tuple */[\n \"Out_of_memory\",\n 0\n];\n\nvar sys_error = /* tuple */[\n \"Sys_error\",\n -1\n];\n\nvar failure = /* tuple */[\n \"Failure\",\n -2\n];\n\nvar invalid_argument = /* tuple */[\n \"Invalid_argument\",\n -3\n];\n\nvar end_of_file = /* tuple */[\n \"End_of_file\",\n -4\n];\n\nvar division_by_zero = /* tuple */[\n \"Division_by_zero\",\n -5\n];\n\nvar not_found = /* tuple */[\n \"Not_found\",\n -6\n];\n\nvar match_failure = /* tuple */[\n \"Match_failure\",\n -7\n];\n\nvar stack_overflow = /* tuple */[\n \"Stack_overflow\",\n -8\n];\n\nvar sys_blocked_io = /* tuple */[\n \"Sys_blocked_io\",\n -9\n];\n\nvar assert_failure = /* tuple */[\n \"Assert_failure\",\n -10\n];\n\nvar undefined_recursive_module = /* tuple */[\n \"Undefined_recursive_module\",\n -11\n];\n\nout_of_memory.tag = 248;\n\nsys_error.tag = 248;\n\nfailure.tag = 248;\n\ninvalid_argument.tag = 248;\n\nend_of_file.tag = 248;\n\ndivision_by_zero.tag = 248;\n\nnot_found.tag = 248;\n\nmatch_failure.tag = 248;\n\nstack_overflow.tag = 248;\n\nsys_blocked_io.tag = 248;\n\nassert_failure.tag = 248;\n\nundefined_recursive_module.tag = 248;\n\nexports.out_of_memory = out_of_memory;\nexports.sys_error = sys_error;\nexports.failure = failure;\nexports.invalid_argument = invalid_argument;\nexports.end_of_file = end_of_file;\nexports.division_by_zero = division_by_zero;\nexports.not_found = not_found;\nexports.match_failure = match_failure;\nexports.stack_overflow = stack_overflow;\nexports.sys_blocked_io = sys_blocked_io;\nexports.assert_failure = assert_failure;\nexports.undefined_recursive_module = undefined_recursive_module;\n/* Not a pure module */\n"
},
{
"id": 1,
"identifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/bs-platform/lib/js/curry.js",
"name": "./node_modules/bs-platform/lib/js/curry.js",
"index": 3,
"index2": 3,
"size": 14385,
"cacheable": true,
"built": true,
"optional": false,
"prefetched": false,
"chunks": [
0
],
"assets": [],
"issuer": "/home/x/zzz/github/douglasduteil/RePeople/lib/js/src/app.js",
"issuerId": 39,
"issuerName": "./lib/js/src/app.js",
"failed": false,
"errors": 0,
"warnings": 0,
"reasons": [
{
"moduleId": 5,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/reason-react/lib/js/src/reasonReact.js",
"module": "./node_modules/reason-react/lib/js/src/reasonReact.js",
"moduleName": "./node_modules/reason-react/lib/js/src/reasonReact.js",
"type": "cjs require",
"userRequest": "bs-platform/lib/js/curry.js",
"loc": "5:38-76"
},
{
"moduleId": 14,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/bs-platform/lib/js/list.js",
"module": "./node_modules/bs-platform/lib/js/list.js",
"moduleName": "./node_modules/bs-platform/lib/js/list.js",
"type": "cjs require",
"userRequest": "./curry.js",
"loc": "3:30-51"
},
{
"moduleId": 15,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/bs-platform/lib/js/pervasives.js",
"module": "./node_modules/bs-platform/lib/js/pervasives.js",
"moduleName": "./node_modules/bs-platform/lib/js/pervasives.js",
"type": "cjs require",
"userRequest": "./curry.js",
"loc": "3:31-52"
},
{
"moduleId": 19,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/bs-platform/lib/js/caml_format.js",
"module": "./node_modules/bs-platform/lib/js/caml_format.js",
"moduleName": "./node_modules/bs-platform/lib/js/caml_format.js",
"type": "cjs require",
"userRequest": "./curry.js",
"loc": "3:30-51"
},
{
"moduleId": 21,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/bs-platform/lib/js/array.js",
"module": "./node_modules/bs-platform/lib/js/array.js",
"moduleName": "./node_modules/bs-platform/lib/js/array.js",
"type": "cjs require",
"userRequest": "./curry.js",
"loc": "3:30-51"
},
{
"moduleId": 39,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/lib/js/src/app.js",
"module": "./lib/js/src/app.js",
"moduleName": "./lib/js/src/app.js",
"type": "cjs require",
"userRequest": "bs-platform/lib/js/curry.js",
"loc": "5:18-56"
},
{
"moduleId": 43,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/bs-platform/lib/js/caml_io.js",
"module": "./node_modules/bs-platform/lib/js/caml_io.js",
"moduleName": "./node_modules/bs-platform/lib/js/caml_io.js",
"type": "cjs require",
"userRequest": "./curry.js",
"loc": "3:30-51"
},
{
"moduleId": 51,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/lib/js/src/backend.js",
"module": "./lib/js/src/backend.js",
"moduleName": "./lib/js/src/backend.js",
"type": "cjs require",
"userRequest": "bs-platform/lib/js/curry.js",
"loc": "4:18-56"
},
{
"moduleId": 52,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/bs-json/lib/js/src/Json_decode.js",
"module": "./node_modules/bs-json/lib/js/src/Json_decode.js",
"moduleName": "./node_modules/bs-json/lib/js/src/Json_decode.js",
"type": "cjs require",
"userRequest": "bs-platform/lib/js/curry.js",
"loc": "5:30-68"
},
{
"moduleId": 54,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/lib/js/src/components/listAll.js",
"module": "./lib/js/src/components/listAll.js",
"moduleName": "./lib/js/src/components/listAll.js",
"type": "cjs require",
"userRequest": "bs-platform/lib/js/curry.js",
"loc": "7:18-56"
},
{
"moduleId": 61,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/lib/js/src/components/discover.js",
"module": "./lib/js/src/components/discover.js",
"moduleName": "./lib/js/src/components/discover.js",
"type": "cjs require",
"userRequest": "bs-platform/lib/js/curry.js",
"loc": "6:18-56"
},
{
"moduleId": 62,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/bs-platform/lib/js/random.js",
"module": "./node_modules/bs-platform/lib/js/random.js",
"moduleName": "./node_modules/bs-platform/lib/js/random.js",
"type": "cjs require",
"userRequest": "./curry.js",
"loc": "4:30-51"
},
{
"moduleId": 67,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/bs-platform/lib/js/bytes.js",
"module": "./node_modules/bs-platform/lib/js/bytes.js",
"moduleName": "./node_modules/bs-platform/lib/js/bytes.js",
"type": "cjs require",
"userRequest": "./curry.js",
"loc": "5:30-51"
}
],
"usedExports": true,
"providedExports": null,
"optimizationBailout": [],
"depth": 2,
"source": "'use strict';\n\nvar Caml_array = require(\"./caml_array.js\");\n\nfunction app(_f, _args) {\n while(true) {\n var args = _args;\n var f = _f;\n var arity = f.length;\n var arity$1 = arity ? arity : 1;\n var len = args.length;\n var d = arity$1 - len | 0;\n if (d) {\n if (d < 0) {\n _args = Caml_array.caml_array_sub(args, arity$1, -d | 0);\n _f = f.apply(null, Caml_array.caml_array_sub(args, 0, arity$1));\n continue ;\n \n } else {\n return (function(f,args){\n return function (x) {\n return app(f, args.concat(/* array */[x]));\n }\n }(f,args));\n }\n } else {\n return f.apply(null, args);\n }\n };\n}\n\nfunction curry_1(o, a0, arity) {\n if (arity > 7 || arity < 0) {\n return app(o, /* array */[a0]);\n } else {\n switch (arity) {\n case 0 : \n case 1 : \n return o(a0);\n case 2 : \n return (function (param) {\n return o(a0, param);\n });\n case 3 : \n return (function (param, param$1) {\n return o(a0, param, param$1);\n });\n case 4 : \n return (function (param, param$1, param$2) {\n return o(a0, param, param$1, param$2);\n });\n case 5 : \n return (function (param, param$1, param$2, param$3) {\n return o(a0, param, param$1, param$2, param$3);\n });\n case 6 : \n return (function (param, param$1, param$2, param$3, param$4) {\n return o(a0, param, param$1, param$2, param$3, param$4);\n });\n case 7 : \n return (function (param, param$1, param$2, param$3, param$4, param$5) {\n return o(a0, param, param$1, param$2, param$3, param$4, param$5);\n });\n \n }\n }\n}\n\nfunction _1(o, a0) {\n var arity = o.length;\n if (arity === 1) {\n return o(a0);\n } else {\n return curry_1(o, a0, arity);\n }\n}\n\nfunction __1(o) {\n var arity = o.length;\n if (arity === 1) {\n return o;\n } else {\n return (function (a0) {\n return _1(o, a0);\n });\n }\n}\n\nfunction curry_2(o, a0, a1, arity) {\n if (arity > 7 || arity < 0) {\n return app(o, /* array */[\n a0,\n a1\n ]);\n } else {\n switch (arity) {\n case 0 : \n case 1 : \n return app(o(a0), /* array */[a1]);\n case 2 : \n return o(a0, a1);\n case 3 : \n return (function (param) {\n return o(a0, a1, param);\n });\n case 4 : \n return (function (param, param$1) {\n return o(a0, a1, param, param$1);\n });\n case 5 : \n return (function (param, param$1, param$2) {\n return o(a0, a1, param, param$1, param$2);\n });\n case 6 : \n return (function (param, param$1, param$2, param$3) {\n return o(a0, a1, param, param$1, param$2, param$3);\n });\n case 7 : \n return (function (param, param$1, param$2, param$3, param$4) {\n return o(a0, a1, param, param$1, param$2, param$3, param$4);\n });\n \n }\n }\n}\n\nfunction _2(o, a0, a1) {\n var arity = o.length;\n if (arity === 2) {\n return o(a0, a1);\n } else {\n return curry_2(o, a0, a1, arity);\n }\n}\n\nfunction __2(o) {\n var arity = o.length;\n if (arity === 2) {\n return o;\n } else {\n return (function (a0, a1) {\n return _2(o, a0, a1);\n });\n }\n}\n\nfunction curry_3(o, a0, a1, a2, arity) {\n var exit = 0;\n if (arity > 7 || arity < 0) {\n return app(o, /* array */[\n a0,\n a1,\n a2\n ]);\n } else {\n switch (arity) {\n case 0 : \n case 1 : \n exit = 1;\n break;\n case 2 : \n return app(o(a0, a1), /* array */[a2]);\n case 3 : \n return o(a0, a1, a2);\n case 4 : \n return (function (param) {\n return o(a0, a1, a2, param);\n });\n case 5 : \n return (function (param, param$1) {\n return o(a0, a1, a2, param, param$1);\n });\n case 6 : \n return (function (param, param$1, param$2) {\n return o(a0, a1, a2, param, param$1, param$2);\n });\n case 7 : \n return (function (param, param$1, param$2, param$3) {\n return o(a0, a1, a2, param, param$1, param$2, param$3);\n });\n \n }\n }\n if (exit === 1) {\n return app(o(a0), /* array */[\n a1,\n a2\n ]);\n }\n \n}\n\nfunction _3(o, a0, a1, a2) {\n var arity = o.length;\n if (arity === 3) {\n return o(a0, a1, a2);\n } else {\n return curry_3(o, a0, a1, a2, arity);\n }\n}\n\nfunction __3(o) {\n var arity = o.length;\n if (arity === 3) {\n return o;\n } else {\n return (function (a0, a1, a2) {\n return _3(o, a0, a1, a2);\n });\n }\n}\n\nfunction curry_4(o, a0, a1, a2, a3, arity) {\n var exit = 0;\n if (arity > 7 || arity < 0) {\n return app(o, /* array */[\n a0,\n a1,\n a2,\n a3\n ]);\n } else {\n switch (arity) {\n case 0 : \n case 1 : \n exit = 1;\n break;\n case 2 : \n return app(o(a0, a1), /* array */[\n a2,\n a3\n ]);\n case 3 : \n return app(o(a0, a1, a2), /* array */[a3]);\n case 4 : \n return o(a0, a1, a2, a3);\n case 5 : \n return (function (param) {\n return o(a0, a1, a2, a3, param);\n });\n case 6 : \n return (function (param, param$1) {\n return o(a0, a1, a2, a3, param, param$1);\n });\n case 7 : \n return (function (param, param$1, param$2) {\n return o(a0, a1, a2, a3, param, param$1, param$2);\n });\n \n }\n }\n if (exit === 1) {\n return app(o(a0), /* array */[\n a1,\n a2,\n a3\n ]);\n }\n \n}\n\nfunction _4(o, a0, a1, a2, a3) {\n var arity = o.length;\n if (arity === 4) {\n return o(a0, a1, a2, a3);\n } else {\n return curry_4(o, a0, a1, a2, a3, arity);\n }\n}\n\nfunction __4(o) {\n var arity = o.length;\n if (arity === 4) {\n return o;\n } else {\n return (function (a0, a1, a2, a3) {\n return _4(o, a0, a1, a2, a3);\n });\n }\n}\n\nfunction curry_5(o, a0, a1, a2, a3, a4, arity) {\n var exit = 0;\n if (arity > 7 || arity < 0) {\n return app(o, /* array */[\n a0,\n a1,\n a2,\n a3,\n a4\n ]);\n } else {\n switch (arity) {\n case 0 : \n case 1 : \n exit = 1;\n break;\n case 2 : \n return app(o(a0, a1), /* array */[\n a2,\n a3,\n a4\n ]);\n case 3 : \n return app(o(a0, a1, a2), /* array */[\n a3,\n a4\n ]);\n case 4 : \n return app(o(a0, a1, a2, a3), /* array */[a4]);\n case 5 : \n return o(a0, a1, a2, a3, a4);\n case 6 : \n return (function (param) {\n return o(a0, a1, a2, a3, a4, param);\n });\n case 7 : \n return (function (param, param$1) {\n return o(a0, a1, a2, a3, a4, param, param$1);\n });\n \n }\n }\n if (exit === 1) {\n return app(o(a0), /* array */[\n a1,\n a2,\n a3,\n a4\n ]);\n }\n \n}\n\nfunction _5(o, a0, a1, a2, a3, a4) {\n var arity = o.length;\n if (arity === 5) {\n return o(a0, a1, a2, a3, a4);\n } else {\n return curry_5(o, a0, a1, a2, a3, a4, arity);\n }\n}\n\nfunction __5(o) {\n var arity = o.length;\n if (arity === 5) {\n return o;\n } else {\n return (function (a0, a1, a2, a3, a4) {\n return _5(o, a0, a1, a2, a3, a4);\n });\n }\n}\n\nfunction curry_6(o, a0, a1, a2, a3, a4, a5, arity) {\n var exit = 0;\n if (arity > 7 || arity < 0) {\n return app(o, /* array */[\n a0,\n a1,\n a2,\n a3,\n a4,\n a5\n ]);\n } else {\n switch (arity) {\n case 0 : \n case 1 : \n exit = 1;\n break;\n case 2 : \n return app(o(a0, a1), /* array */[\n a2,\n a3,\n a4,\n a5\n ]);\n case 3 : \n return app(o(a0, a1, a2), /* array */[\n a3,\n a4,\n a5\n ]);\n case 4 : \n return app(o(a0, a1, a2, a3), /* array */[\n a4,\n a5\n ]);\n case 5 : \n return app(o(a0, a1, a2, a3, a4), /* array */[a5]);\n case 6 : \n return o(a0, a1, a2, a3, a4, a5);\n case 7 : \n return (function (param) {\n return o(a0, a1, a2, a3, a4, a5, param);\n });\n \n }\n }\n if (exit === 1) {\n return app(o(a0), /* array */[\n a1,\n a2,\n a3,\n a4,\n a5\n ]);\n }\n \n}\n\nfunction _6(o, a0, a1, a2, a3, a4, a5) {\n var arity = o.length;\n if (arity === 6) {\n return o(a0, a1, a2, a3, a4, a5);\n } else {\n return curry_6(o, a0, a1, a2, a3, a4, a5, arity);\n }\n}\n\nfunction __6(o) {\n var arity = o.length;\n if (arity === 6) {\n return o;\n } else {\n return (function (a0, a1, a2, a3, a4, a5) {\n return _6(o, a0, a1, a2, a3, a4, a5);\n });\n }\n}\n\nfunction curry_7(o, a0, a1, a2, a3, a4, a5, a6, arity) {\n var exit = 0;\n if (arity > 7 || arity < 0) {\n return app(o, /* array */[\n a0,\n a1,\n a2,\n a3,\n a4,\n a5,\n a6\n ]);\n } else {\n switch (arity) {\n case 0 : \n case 1 : \n exit = 1;\n break;\n case 2 : \n return app(o(a0, a1), /* array */[\n a2,\n a3,\n a4,\n a5,\n a6\n ]);\n case 3 : \n return app(o(a0, a1, a2), /* array */[\n a3,\n a4,\n a5,\n a6\n ]);\n case 4 : \n return app(o(a0, a1, a2, a3), /* array */[\n a4,\n a5,\n a6\n ]);\n case 5 : \n return app(o(a0, a1, a2, a3, a4), /* array */[\n a5,\n a6\n ]);\n case 6 : \n return app(o(a0, a1, a2, a3, a4, a5), /* array */[a6]);\n case 7 : \n return o(a0, a1, a2, a3, a4, a5, a6);\n \n }\n }\n if (exit === 1) {\n return app(o(a0), /* array */[\n a1,\n a2,\n a3,\n a4,\n a5,\n a6\n ]);\n }\n \n}\n\nfunction _7(o, a0, a1, a2, a3, a4, a5, a6) {\n var arity = o.length;\n if (arity === 7) {\n return o(a0, a1, a2, a3, a4, a5, a6);\n } else {\n return curry_7(o, a0, a1, a2, a3, a4, a5, a6, arity);\n }\n}\n\nfunction __7(o) {\n var arity = o.length;\n if (arity === 7) {\n return o;\n } else {\n return (function (a0, a1, a2, a3, a4, a5, a6) {\n return _7(o, a0, a1, a2, a3, a4, a5, a6);\n });\n }\n}\n\nfunction curry_8(o, a0, a1, a2, a3, a4, a5, a6, a7, arity) {\n var exit = 0;\n if (arity > 7 || arity < 0) {\n return app(o, /* array */[\n a0,\n a1,\n a2,\n a3,\n a4,\n a5,\n a6,\n a7\n ]);\n } else {\n switch (arity) {\n case 0 : \n case 1 : \n exit = 1;\n break;\n case 2 : \n return app(o(a0, a1), /* array */[\n a2,\n a3,\n a4,\n a5,\n a6,\n a7\n ]);\n case 3 : \n return app(o(a0, a1, a2), /* array */[\n a3,\n a4,\n a5,\n a6,\n a7\n ]);\n case 4 : \n return app(o(a0, a1, a2, a3), /* array */[\n a4,\n a5,\n a6,\n a7\n ]);\n case 5 : \n return app(o(a0, a1, a2, a3, a4), /* array */[\n a5,\n a6,\n a7\n ]);\n case 6 : \n return app(o(a0, a1, a2, a3, a4, a5), /* array */[\n a6,\n a7\n ]);\n case 7 : \n return app(o(a0, a1, a2, a3, a4, a5, a6), /* array */[a7]);\n \n }\n }\n if (exit === 1) {\n return app(o(a0), /* array */[\n a1,\n a2,\n a3,\n a4,\n a5,\n a6,\n a7\n ]);\n }\n \n}\n\nfunction _8(o, a0, a1, a2, a3, a4, a5, a6, a7) {\n var arity = o.length;\n if (arity === 8) {\n return o(a0, a1, a2, a3, a4, a5, a6, a7);\n } else {\n return curry_8(o, a0, a1, a2, a3, a4, a5, a6, a7, arity);\n }\n}\n\nfunction __8(o) {\n var arity = o.length;\n if (arity === 8) {\n return o;\n } else {\n return (function (a0, a1, a2, a3, a4, a5, a6, a7) {\n return _8(o, a0, a1, a2, a3, a4, a5, a6, a7);\n });\n }\n}\n\nexports.app = app;\nexports.curry_1 = curry_1;\nexports._1 = _1;\nexports.__1 = __1;\nexports.curry_2 = curry_2;\nexports._2 = _2;\nexports.__2 = __2;\nexports.curry_3 = curry_3;\nexports._3 = _3;\nexports.__3 = __3;\nexports.curry_4 = curry_4;\nexports._4 = _4;\nexports.__4 = __4;\nexports.curry_5 = curry_5;\nexports._5 = _5;\nexports.__5 = __5;\nexports.curry_6 = curry_6;\nexports._6 = _6;\nexports.__6 = __6;\nexports.curry_7 = curry_7;\nexports._7 = _7;\nexports.__7 = __7;\nexports.curry_8 = curry_8;\nexports._8 = _8;\nexports.__8 = __8;\n/* No side effect */\n"
},
{
"id": 2,
"identifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/process/browser.js",
"name": "./node_modules/process/browser.js",
"index": 7,
"index2": 4,
"size": 5418,
"cacheable": true,
"built": true,
"optional": false,
"prefetched": false,
"chunks": [
0
],
"assets": [],
"issuer": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/react/index.js",
"issuerId": 3,
"issuerName": "./node_modules/react/index.js",
"failed": false,
"errors": 0,
"warnings": 0,
"reasons": [
{
"moduleId": 3,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/react/index.js",
"module": "./node_modules/react/index.js",
"moduleName": "./node_modules/react/index.js",
"type": "cjs require",
"userRequest": "process",
"loc": "1:0-34"
},
{
"moduleId": 7,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/fbjs/lib/invariant.js",
"module": "./node_modules/fbjs/lib/invariant.js",
"moduleName": "./node_modules/fbjs/lib/invariant.js",
"type": "cjs require",
"userRequest": "process",
"loc": "1:0-37"
},
{
"moduleId": 17,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/fbjs/lib/emptyObject.js",
"module": "./node_modules/fbjs/lib/emptyObject.js",
"moduleName": "./node_modules/fbjs/lib/emptyObject.js",
"type": "cjs require",
"userRequest": "process",
"loc": "1:0-37"
},
{
"moduleId": 18,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/fbjs/lib/warning.js",
"module": "./node_modules/fbjs/lib/warning.js",
"moduleName": "./node_modules/fbjs/lib/warning.js",
"type": "cjs require",
"userRequest": "process",
"loc": "1:0-37"
},
{
"moduleId": 22,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/prop-types/checkPropTypes.js",
"module": "./node_modules/prop-types/checkPropTypes.js",
"moduleName": "./node_modules/prop-types/checkPropTypes.js",
"type": "cjs require",
"userRequest": "process",
"loc": "1:0-34"
},
{
"moduleId": 24,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/bs-platform/lib/js/caml_sys.js",
"module": "./node_modules/bs-platform/lib/js/caml_sys.js",
"moduleName": "./node_modules/bs-platform/lib/js/caml_sys.js",
"type": "cjs require",
"userRequest": "process",
"loc": "1:0-40"
},
{
"moduleId": 33,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/fbjs/lib/EventListener.js",
"module": "./node_modules/fbjs/lib/EventListener.js",
"moduleName": "./node_modules/fbjs/lib/EventListener.js",
"type": "cjs require",
"userRequest": "process",
"loc": "1:0-37"
},
{
"moduleId": 41,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/react/cjs/react.development.js",
"module": "./node_modules/react/cjs/react.development.js",
"moduleName": "./node_modules/react/cjs/react.development.js",
"type": "cjs require",
"userRequest": "process",
"loc": "1:0-37"
},
{
"moduleId": 43,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/bs-platform/lib/js/caml_io.js",
"module": "./node_modules/bs-platform/lib/js/caml_io.js",
"moduleName": "./node_modules/bs-platform/lib/js/caml_io.js",
"type": "cjs require",
"userRequest": "process",
"loc": "1:0-40"
},
{
"moduleId": 76,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/react-dom/index.js",
"module": "./node_modules/react-dom/index.js",
"moduleName": "./node_modules/react-dom/index.js",
"type": "cjs require",
"userRequest": "process",
"loc": "1:0-34"
},
{
"moduleId": 80,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/react-dom/cjs/react-dom.development.js",
"module": "./node_modules/react-dom/cjs/react-dom.development.js",
"moduleName": "./node_modules/react-dom/cjs/react-dom.development.js",
"type": "cjs require",
"userRequest": "process",
"loc": "1:0-37"
},
{
"moduleId": 87,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/prop-types/index.js",
"module": "./node_modules/prop-types/index.js",
"moduleName": "./node_modules/prop-types/index.js",
"type": "cjs require",
"userRequest": "process",
"loc": "1:0-34"
},
{
"moduleId": 88,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/prop-types/factoryWithTypeCheckers.js",
"module": "./node_modules/prop-types/factoryWithTypeCheckers.js",
"moduleName": "./node_modules/prop-types/factoryWithTypeCheckers.js",
"type": "cjs require",
"userRequest": "process",
"loc": "1:0-34"
}
],
"usedExports": true,
"providedExports": null,
"optimizationBailout": [],
"depth": 3,
"source": "// shim for using process in browser\nvar process = module.exports = {};\n\n// cached from whatever global is present so that test runners that stub it\n// don't break things. But we need to wrap it in a try catch in case it is\n// wrapped in strict mode code which doesn't define any globals. It's inside a\n// function because try/catches deoptimize in certain engines.\n\nvar cachedSetTimeout;\nvar cachedClearTimeout;\n\nfunction defaultSetTimout() {\n throw new Error('setTimeout has not been defined');\n}\nfunction defaultClearTimeout () {\n throw new Error('clearTimeout has not been defined');\n}\n(function () {\n try {\n if (typeof setTimeout === 'function') {\n cachedSetTimeout = setTimeout;\n } else {\n cachedSetTimeout = defaultSetTimout;\n }\n } catch (e) {\n cachedSetTimeout = defaultSetTimout;\n }\n try {\n if (typeof clearTimeout === 'function') {\n cachedClearTimeout = clearTimeout;\n } else {\n cachedClearTimeout = defaultClearTimeout;\n }\n } catch (e) {\n cachedClearTimeout = defaultClearTimeout;\n }\n} ())\nfunction runTimeout(fun) {\n if (cachedSetTimeout === setTimeout) {\n //normal enviroments in sane situations\n return setTimeout(fun, 0);\n }\n // if setTimeout wasn't available but was latter defined\n if ((cachedSetTimeout === defaultSetTimout || !cachedSetTimeout) && setTimeout) {\n cachedSetTimeout = setTimeout;\n return setTimeout(fun, 0);\n }\n try {\n // when when somebody has screwed with setTimeout but no I.E. maddness\n return cachedSetTimeout(fun, 0);\n } catch(e){\n try {\n // When we are in I.E. but the script has been evaled so I.E. doesn't trust the global object when called normally\n return cachedSetTimeout.call(null, fun, 0);\n } catch(e){\n // same as above but when it's a version of I.E. that must have the global object for 'this', hopfully our context correct otherwise it will throw a global error\n return cachedSetTimeout.call(this, fun, 0);\n }\n }\n\n\n}\nfunction runClearTimeout(marker) {\n if (cachedClearTimeout === clearTimeout) {\n //normal enviroments in sane situations\n return clearTimeout(marker);\n }\n // if clearTimeout wasn't available but was latter defined\n if ((cachedClearTimeout === defaultClearTimeout || !cachedClearTimeout) && clearTimeout) {\n cachedClearTimeout = clearTimeout;\n return clearTimeout(marker);\n }\n try {\n // when when somebody has screwed with setTimeout but no I.E. maddness\n return cachedClearTimeout(marker);\n } catch (e){\n try {\n // When we are in I.E. but the script has been evaled so I.E. doesn't trust the global object when called normally\n return cachedClearTimeout.call(null, marker);\n } catch (e){\n // same as above but when it's a version of I.E. that must have the global object for 'this', hopfully our context correct otherwise it will throw a global error.\n // Some versions of I.E. have different rules for clearTimeout vs setTimeout\n return cachedClearTimeout.call(this, marker);\n }\n }\n\n\n\n}\nvar queue = [];\nvar draining = false;\nvar currentQueue;\nvar queueIndex = -1;\n\nfunction cleanUpNextTick() {\n if (!draining || !currentQueue) {\n return;\n }\n draining = false;\n if (currentQueue.length) {\n queue = currentQueue.concat(queue);\n } else {\n queueIndex = -1;\n }\n if (queue.length) {\n drainQueue();\n }\n}\n\nfunction drainQueue() {\n if (draining) {\n return;\n }\n var timeout = runTimeout(cleanUpNextTick);\n draining = true;\n\n var len = queue.length;\n while(len) {\n currentQueue = queue;\n queue = [];\n while (++queueIndex < len) {\n if (currentQueue) {\n currentQueue[queueIndex].run();\n }\n }\n queueIndex = -1;\n len = queue.length;\n }\n currentQueue = null;\n draining = false;\n runClearTimeout(timeout);\n}\n\nprocess.nextTick = function (fun) {\n var args = new Array(arguments.length - 1);\n if (arguments.length > 1) {\n for (var i = 1; i < arguments.length; i++) {\n args[i - 1] = arguments[i];\n }\n }\n queue.push(new Item(fun, args));\n if (queue.length === 1 && !draining) {\n runTimeout(drainQueue);\n }\n};\n\n// v8 likes predictible objects\nfunction Item(fun, array) {\n this.fun = fun;\n this.array = array;\n}\nItem.prototype.run = function () {\n this.fun.apply(null, this.array);\n};\nprocess.title = 'browser';\nprocess.browser = true;\nprocess.env = {};\nprocess.argv = [];\nprocess.version = ''; // empty string to avoid regexp issues\nprocess.versions = {};\n\nfunction noop() {}\n\nprocess.on = noop;\nprocess.addListener = noop;\nprocess.once = noop;\nprocess.off = noop;\nprocess.removeListener = noop;\nprocess.removeAllListeners = noop;\nprocess.emit = noop;\nprocess.prependListener = noop;\nprocess.prependOnceListener = noop;\n\nprocess.listeners = function (name) { return [] }\n\nprocess.binding = function (name) {\n throw new Error('process.binding is not supported');\n};\n\nprocess.cwd = function () { return '/' };\nprocess.chdir = function (dir) {\n throw new Error('process.chdir is not supported');\n};\nprocess.umask = function() { return 0; };\n"
},
{
"id": 3,
"identifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/react/index.js",
"name": "./node_modules/react/index.js",
"index": 6,
"index2": 14,
"size": 190,
"cacheable": true,
"built": true,
"optional": false,
"prefetched": false,
"chunks": [
0
],
"assets": [],
"issuer": "/home/x/zzz/github/douglasduteil/RePeople/lib/js/src/app.js",
"issuerId": 39,
"issuerName": "./lib/js/src/app.js",
"failed": false,
"errors": 0,
"warnings": 0,
"reasons": [
{
"moduleId": 5,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/reason-react/lib/js/src/reasonReact.js",
"module": "./node_modules/reason-react/lib/js/src/reasonReact.js",
"moduleName": "./node_modules/reason-react/lib/js/src/reasonReact.js",
"type": "cjs require",
"userRequest": "react",
"loc": "6:38-54"
},
{
"moduleId": 31,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/lib/js/src/components/personCard.js",
"module": "./lib/js/src/components/personCard.js",
"moduleName": "./lib/js/src/components/personCard.js",
"type": "cjs require",
"userRequest": "react",
"loc": "5:18-34"
},
{
"moduleId": 39,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/lib/js/src/app.js",
"module": "./lib/js/src/app.js",
"moduleName": "./lib/js/src/app.js",
"type": "cjs require",
"userRequest": "react",
"loc": "6:18-34"
},
{
"moduleId": 42,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/lib/js/src/components/appBar.js",
"module": "./lib/js/src/components/appBar.js",
"moduleName": "./lib/js/src/components/appBar.js",
"type": "cjs require",
"userRequest": "react",
"loc": "4:18-34"
},
{
"moduleId": 45,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/reason-react/lib/js/src/reasonReactOptimizedCreateClass.js",
"module": "./node_modules/reason-react/lib/js/src/reasonReactOptimizedCreateClass.js",
"moduleName": "./node_modules/reason-react/lib/js/src/reasonReactOptimizedCreateClass.js",
"type": "cjs require",
"userRequest": "react",
"loc": "4:12-28"
},
{
"moduleId": 54,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/lib/js/src/components/listAll.js",
"module": "./lib/js/src/components/listAll.js",
"moduleName": "./lib/js/src/components/listAll.js",
"type": "cjs require",
"userRequest": "react",
"loc": "8:18-34"
},
{
"moduleId": 55,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/lib/js/src/components/card.js",
"module": "./lib/js/src/components/card.js",
"moduleName": "./lib/js/src/components/card.js",
"type": "cjs require",
"userRequest": "react",
"loc": "4:18-34"
},
{
"moduleId": 58,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/lib/js/src/components/searchInput.js",
"module": "./lib/js/src/components/searchInput.js",
"moduleName": "./lib/js/src/components/searchInput.js",
"type": "cjs require",
"userRequest": "react",
"loc": "4:18-34"
},
{
"moduleId": 61,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/lib/js/src/components/discover.js",
"module": "./lib/js/src/components/discover.js",
"moduleName": "./lib/js/src/components/discover.js",
"type": "cjs require",
"userRequest": "react",
"loc": "7:18-34"
},
{
"moduleId": 77,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/react-dom/cjs/react-dom.production.min.js",
"module": "./node_modules/react-dom/cjs/react-dom.production.min.js",
"moduleName": "./node_modules/react-dom/cjs/react-dom.production.min.js",
"type": "cjs require",
"userRequest": "react",
"loc": "11:20-36"
},
{
"moduleId": 80,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/react-dom/cjs/react-dom.development.js",
"module": "./node_modules/react-dom/cjs/react-dom.development.js",
"moduleName": "./node_modules/react-dom/cjs/react-dom.development.js",
"type": "cjs require",
"userRequest": "react",
"loc": "17:12-28"
}
],
"usedExports": true,
"providedExports": null,
"optimizationBailout": [],
"depth": 2,
"source": "'use strict';\n\nif (process.env.NODE_ENV === 'production') {\n module.exports = require('./cjs/react.production.min.js');\n} else {\n module.exports = require('./cjs/react.development.js');\n}\n"
},
{
"id": 4,
"identifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/fbjs/lib/emptyFunction.js",
"name": "./node_modules/fbjs/lib/emptyFunction.js",
"index": 12,
"index2": 8,
"size": 959,
"cacheable": true,
"built": true,
"optional": false,
"prefetched": false,
"chunks": [
0
],
"assets": [],
"issuer": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/react/cjs/react.production.min.js",
"issuerId": 40,
"issuerName": "./node_modules/react/cjs/react.production.min.js",
"failed": false,
"errors": 0,
"warnings": 0,
"reasons": [
{
"moduleId": 18,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/fbjs/lib/warning.js",
"module": "./node_modules/fbjs/lib/warning.js",
"moduleName": "./node_modules/fbjs/lib/warning.js",
"type": "cjs require",
"userRequest": "./emptyFunction",
"loc": "11:20-46"
},
{
"moduleId": 33,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/fbjs/lib/EventListener.js",
"module": "./node_modules/fbjs/lib/EventListener.js",
"moduleName": "./node_modules/fbjs/lib/EventListener.js",
"type": "cjs require",
"userRequest": "./emptyFunction",
"loc": "12:20-46"
},
{
"moduleId": 40,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/react/cjs/react.production.min.js",
"module": "./node_modules/react/cjs/react.production.min.js",
"moduleName": "./node_modules/react/cjs/react.production.min.js",
"type": "cjs require",
"userRequest": "fbjs/lib/emptyFunction",
"loc": "10:114-147"
},
{
"moduleId": 41,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/react/cjs/react.development.js",
"module": "./node_modules/react/cjs/react.development.js",
"moduleName": "./node_modules/react/cjs/react.development.js",
"type": "cjs require",
"userRequest": "fbjs/lib/emptyFunction",
"loc": "21:20-53"
},
{
"moduleId": 77,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/react-dom/cjs/react-dom.production.min.js",
"module": "./node_modules/react-dom/cjs/react-dom.production.min.js",
"moduleName": "./node_modules/react-dom/cjs/react-dom.production.min.js",
"type": "cjs require",
"userRequest": "fbjs/lib/emptyFunction",
"loc": "11:181-214"
},
{
"moduleId": 80,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/react-dom/cjs/react-dom.development.js",
"module": "./node_modules/react-dom/cjs/react-dom.development.js",
"moduleName": "./node_modules/react-dom/cjs/react-dom.development.js",
"type": "cjs require",
"userRequest": "fbjs/lib/emptyFunction",
"loc": "24:20-53"
},
{
"moduleId": 88,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/prop-types/factoryWithTypeCheckers.js",
"module": "./node_modules/prop-types/factoryWithTypeCheckers.js",
"moduleName": "./node_modules/prop-types/factoryWithTypeCheckers.js",
"type": "cjs require",
"userRequest": "fbjs/lib/emptyFunction",
"loc": "10:20-53"
},
{
"moduleId": 89,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/prop-types/factoryWithThrowingShims.js",
"module": "./node_modules/prop-types/factoryWithThrowingShims.js",
"moduleName": "./node_modules/prop-types/factoryWithThrowingShims.js",
"type": "cjs require",
"userRequest": "fbjs/lib/emptyFunction",
"loc": "10:20-53"
}
],
"usedExports": true,
"providedExports": null,
"optimizationBailout": [],
"depth": 4,
"source": "\"use strict\";\n\n/**\n * Copyright (c) 2013-present, Facebook, Inc.\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 * \n */\n\nfunction makeEmptyFunction(arg) {\n return function () {\n return arg;\n };\n}\n\n/**\n * This function accepts and discards inputs; it has no side effects. This is\n * primarily useful idiomatically for overridable function endpoints which\n * always need to be callable, since JS lacks a null-call idiom ala Cocoa.\n */\nvar emptyFunction = function emptyFunction() {};\n\nemptyFunction.thatReturns = makeEmptyFunction;\nemptyFunction.thatReturnsFalse = makeEmptyFunction(false);\nemptyFunction.thatReturnsTrue = makeEmptyFunction(true);\nemptyFunction.thatReturnsNull = makeEmptyFunction(null);\nemptyFunction.thatReturnsThis = function () {\n return this;\n};\nemptyFunction.thatReturnsArgument = function (arg) {\n return arg;\n};\n\nmodule.exports = emptyFunction;"
},
{
"id": 5,
"identifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/reason-react/lib/js/src/reasonReact.js",
"name": "./node_modules/reason-react/lib/js/src/reasonReact.js",
"index": 18,
"index2": 29,
"size": 26547,
"cacheable": true,
"built": true,
"optional": false,
"prefetched": false,
"chunks": [
0
],
"assets": [],
"issuer": "/home/x/zzz/github/douglasduteil/RePeople/lib/js/src/main.js",
"issuerId": 38,
"issuerName": "./lib/js/src/main.js",
"failed": false,
"errors": 0,
"warnings": 0,
"reasons": [
{
"moduleId": 31,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/lib/js/src/components/personCard.js",
"module": "./lib/js/src/components/personCard.js",
"moduleName": "./lib/js/src/components/personCard.js",
"type": "cjs require",
"userRequest": "reason-react/lib/js/src/reasonReact.js",
"loc": "6:18-67"
},
{
"moduleId": 38,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/lib/js/src/main.js",
"module": "./lib/js/src/main.js",
"moduleName": "./lib/js/src/main.js",
"type": "cjs require",
"userRequest": "reason-react/lib/js/src/reasonReact.js",
"loc": "6:18-67"
},
{
"moduleId": 39,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/lib/js/src/app.js",
"module": "./lib/js/src/app.js",
"moduleName": "./lib/js/src/app.js",
"type": "cjs require",
"userRequest": "reason-react/lib/js/src/reasonReact.js",
"loc": "11:18-67"
},
{
"moduleId": 42,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/lib/js/src/components/appBar.js",
"module": "./lib/js/src/components/appBar.js",
"moduleName": "./lib/js/src/components/appBar.js",
"type": "cjs require",
"userRequest": "reason-react/lib/js/src/reasonReact.js",
"loc": "5:18-67"
},
{
"moduleId": 54,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/lib/js/src/components/listAll.js",
"module": "./lib/js/src/components/listAll.js",
"moduleName": "./lib/js/src/components/listAll.js",
"type": "cjs require",
"userRequest": "reason-react/lib/js/src/reasonReact.js",
"loc": "10:18-67"
},
{
"moduleId": 55,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/lib/js/src/components/card.js",
"module": "./lib/js/src/components/card.js",
"moduleName": "./lib/js/src/components/card.js",
"type": "cjs require",
"userRequest": "reason-react/lib/js/src/reasonReact.js",
"loc": "5:18-67"
},
{
"moduleId": 58,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/lib/js/src/components/searchInput.js",
"module": "./lib/js/src/components/searchInput.js",
"moduleName": "./lib/js/src/components/searchInput.js",
"type": "cjs require",
"userRequest": "reason-react/lib/js/src/reasonReact.js",
"loc": "5:18-67"
},
{
"moduleId": 61,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/lib/js/src/components/discover.js",
"module": "./lib/js/src/components/discover.js",
"moduleName": "./lib/js/src/components/discover.js",
"type": "cjs require",
"userRequest": "reason-react/lib/js/src/reasonReact.js",
"loc": "11:18-67"
}
],
"usedExports": true,
"providedExports": null,
"optimizationBailout": [],
"depth": 1,
"source": "// Generated by BUCKLESCRIPT VERSION 1.8.2, PLEASE EDIT WITH CARE\n'use strict';\n\nvar List = require(\"bs-platform/lib/js/list.js\");\nvar Curry = require(\"bs-platform/lib/js/curry.js\");\nvar React = require(\"react\");\nvar Caml_builtin_exceptions = require(\"bs-platform/lib/js/caml_builtin_exceptions.js\");\nvar ReasonReactOptimizedCreateClass = require(\"./reasonReactOptimizedCreateClass.js\");\n\nfunction createDomElement(s, props, children) {\n var vararg = /* array */[\n s,\n props\n ].concat(children);\n return React.createElement.apply(null, vararg);\n}\n\nvar magicNull = null;\n\nfunction $$default() {\n return /* () */0;\n}\n\nfunction chain(handlerOne, handlerTwo, payload) {\n Curry._1(handlerOne, payload);\n return Curry._1(handlerTwo, payload);\n}\n\nvar Callback = /* module */[\n /* default */$$default,\n /* chain */chain\n];\n\nfunction lifecycleNoUpdate() {\n return /* NoUpdate */0;\n}\n\nfunction lifecyclePreviousNextUnit() {\n return /* () */0;\n}\n\nfunction lifecyclePreviousCurrentReturnUnit() {\n return /* () */0;\n}\n\nfunction lifecycleReturnUnit() {\n return /* () */0;\n}\n\nfunction lifecycleReturnTrue() {\n return /* true */1;\n}\n\nfunction willReceivePropsDefault(param) {\n return param[/* state */4];\n}\n\nfunction renderDefault() {\n return \"RenderNotImplemented\";\n}\n\nfunction initialStateDefault() {\n return /* () */0;\n}\n\nfunction reducerDefault(_, _$1) {\n return /* NoUpdate */0;\n}\n\nfunction convertPropsIfTheyreFromJs(props, jsPropsToReason, debugName) {\n var match = props.reasonProps;\n if (match !== undefined) {\n return match;\n } else if (jsPropsToReason) {\n return /* Element */[Curry._1(jsPropsToReason[0], props)];\n } else {\n throw [\n Caml_builtin_exceptions.invalid_argument,\n \"A JS component called the Reason component \" + (debugName + \" which didn't implement the JS->Reason React props conversion.\")\n ];\n }\n}\n\nfunction createClass(debugName) {\n return ReasonReactOptimizedCreateClass.createClass({\n displayName: debugName,\n self: (function (state, retainedProps) {\n var $$this = this ;\n return /* record */[\n /* handle */$$this.handleMethod,\n /* update */$$this.updateMethod,\n /* enqueue */$$this.enqueueMethod,\n /* reduce */$$this.reduceMethod,\n /* state */state,\n /* retainedProps */retainedProps\n ];\n }),\n transitionNextTotalState: (function (curTotalState, reasonStateUpdate) {\n if (typeof reasonStateUpdate === \"number\") {\n return curTotalState;\n } else {\n switch (reasonStateUpdate.tag | 0) {\n case 0 : \n return {\n reasonState: reasonStateUpdate[0],\n reasonStateVersion: curTotalState.reasonStateVersion + 1 | 0,\n reasonStateVersionUsedToComputeSubelements: curTotalState.reasonStateVersionUsedToComputeSubelements,\n sideEffects: curTotalState.sideEffects\n };\n case 1 : \n return {\n reasonState: reasonStateUpdate[0],\n reasonStateVersion: curTotalState.reasonStateVersion + 1 | 0,\n reasonStateVersionUsedToComputeSubelements: curTotalState.reasonStateVersionUsedToComputeSubelements + 1 | 0,\n sideEffects: curTotalState.sideEffects\n };\n case 2 : \n return {\n reasonState: curTotalState.reasonState,\n reasonStateVersion: curTotalState.reasonStateVersion + 1 | 0,\n reasonStateVersionUsedToComputeSubelements: curTotalState.reasonStateVersionUsedToComputeSubelements + 1 | 0,\n sideEffects: /* :: */[\n reasonStateUpdate[0],\n curTotalState.sideEffects\n ]\n };\n case 3 : \n return {\n reasonState: reasonStateUpdate[0],\n reasonStateVersion: curTotalState.reasonStateVersion + 1 | 0,\n reasonStateVersionUsedToComputeSubelements: curTotalState.reasonStateVersionUsedToComputeSubelements,\n sideEffects: /* :: */[\n reasonStateUpdate[1],\n curTotalState.sideEffects\n ]\n };\n case 4 : \n return {\n reasonState: reasonStateUpdate[0],\n reasonStateVersion: curTotalState.reasonStateVersion + 1 | 0,\n reasonStateVersionUsedToComputeSubelements: curTotalState.reasonStateVersionUsedToComputeSubelements + 1 | 0,\n sideEffects: /* :: */[\n reasonStateUpdate[1],\n curTotalState.sideEffects\n ]\n };\n \n }\n }\n }),\n getInitialState: (function () {\n var thisJs = (this);\n var convertedReasonProps = convertPropsIfTheyreFromJs(thisJs.props, thisJs.jsPropsToReason, debugName);\n var initialReasonState = Curry._1(convertedReasonProps[0][/* initialState */10], /* () */0);\n return {\n reasonState: initialReasonState,\n reasonStateVersion: 1,\n reasonStateVersionUsedToComputeSubelements: 1,\n sideEffects: /* [] */0\n };\n }),\n componentDidMount: (function () {\n var $$this = this ;\n var thisJs = (this);\n var convertedReasonProps = convertPropsIfTheyreFromJs(thisJs.props, thisJs.jsPropsToReason, debugName);\n var component = convertedReasonProps[0];\n if (component[/* didMount */4] !== lifecycleNoUpdate) {\n var curTotalState = thisJs.state;\n var curReasonState = curTotalState.reasonState;\n var self = $$this.self(curReasonState, component[/* retainedProps */11]);\n var reasonStateUpdate = Curry._1(component[/* didMount */4], self);\n var nextTotalState = $$this.transitionNextTotalState(curTotalState, reasonStateUpdate);\n if (nextTotalState.reasonStateVersion !== curTotalState.reasonStateVersion) {\n return thisJs.setState(nextTotalState);\n } else {\n return 0;\n }\n } else {\n return 0;\n }\n }),\n componentDidUpdate: (function (prevProps, prevState) {\n var $$this = this ;\n var thisJs = (this);\n var curState = thisJs.state;\n var curReasonState = curState.reasonState;\n var newJsProps = thisJs.props;\n var newConvertedReasonProps = convertPropsIfTheyreFromJs(newJsProps, thisJs.jsPropsToReason, debugName);\n var newComponent = newConvertedReasonProps[0];\n if (newComponent[/* didUpdate */5] !== lifecyclePreviousCurrentReturnUnit) {\n var match = +(prevProps === newJsProps);\n var oldConvertedReasonProps = match !== 0 ? newConvertedReasonProps : convertPropsIfTheyreFromJs(prevProps, thisJs.jsPropsToReason, debugName);\n var prevReasonState = prevState.reasonState;\n var newSelf = $$this.self(curReasonState, newComponent[/* retainedProps */11]);\n var oldSelf_000 = /* handle */newSelf[/* handle */0];\n var oldSelf_001 = /* update */newSelf[/* update */1];\n var oldSelf_002 = /* enqueue */newSelf[/* enqueue */2];\n var oldSelf_003 = /* reduce */newSelf[/* reduce */3];\n var oldSelf_005 = /* retainedProps */oldConvertedReasonProps[0][/* retainedProps */11];\n var oldSelf = /* record */[\n oldSelf_000,\n oldSelf_001,\n oldSelf_002,\n oldSelf_003,\n /* state */prevReasonState,\n oldSelf_005\n ];\n return Curry._1(newComponent[/* didUpdate */5], /* record */[\n /* oldSelf */oldSelf,\n /* newSelf */newSelf\n ]);\n } else {\n return 0;\n }\n }),\n componentWillUnmount: (function () {\n var $$this = this ;\n var thisJs = (this);\n var convertedReasonProps = convertPropsIfTheyreFromJs(thisJs.props, thisJs.jsPropsToReason, debugName);\n var component = convertedReasonProps[0];\n if (component[/* willUnmount */6] !== lifecycleReturnUnit) {\n var curState = thisJs.state;\n var curReasonState = curState.reasonState;\n return Curry._1(component[/* willUnmount */6], $$this.self(curReasonState, component[/* retainedProps */11]));\n } else {\n return 0;\n }\n }),\n componentWillUpdate: (function (nextProps, nextState) {\n var $$this = this ;\n var thisJs = (this);\n var newConvertedReasonProps = convertPropsIfTheyreFromJs(nextProps, thisJs.jsPropsToReason, debugName);\n var newComponent = newConvertedReasonProps[0];\n if (newComponent[/* willUpdate */7] !== lifecyclePreviousNextUnit) {\n var oldJsProps = thisJs.props;\n var match = +(nextProps === oldJsProps);\n var oldConvertedReasonProps = match !== 0 ? newConvertedReasonProps : convertPropsIfTheyreFromJs(oldJsProps, thisJs.jsPropsToReason, debugName);\n var curState = thisJs.state;\n var curReasonState = curState.reasonState;\n var nextReasonState = nextState.reasonState;\n var newSelf = $$this.self(nextReasonState, newComponent[/* retainedProps */11]);\n var oldSelf_000 = /* handle */newSelf[/* handle */0];\n var oldSelf_001 = /* update */newSelf[/* update */1];\n var oldSelf_002 = /* enqueue */newSelf[/* enqueue */2];\n var oldSelf_003 = /* reduce */newSelf[/* reduce */3];\n var oldSelf_005 = /* retainedProps */oldConvertedReasonProps[0][/* retainedProps */11];\n var oldSelf = /* record */[\n oldSelf_000,\n oldSelf_001,\n oldSelf_002,\n oldSelf_003,\n /* state */curReasonState,\n oldSelf_005\n ];\n return Curry._1(newComponent[/* willUpdate */7], /* record */[\n /* oldSelf */oldSelf,\n /* newSelf */newSelf\n ]);\n } else {\n return 0;\n }\n }),\n componentWillReceiveProps: (function (nextProps) {\n var $$this = this ;\n var thisJs = (this);\n var newConvertedReasonProps = convertPropsIfTheyreFromJs(nextProps, thisJs.jsPropsToReason, debugName);\n var newComponent = newConvertedReasonProps[0];\n if (newComponent[/* willReceiveProps */3] !== willReceivePropsDefault) {\n var oldJsProps = thisJs.props;\n var match = +(nextProps === oldJsProps);\n var oldConvertedReasonProps = match !== 0 ? newConvertedReasonProps : convertPropsIfTheyreFromJs(oldJsProps, thisJs.jsPropsToReason, debugName);\n var oldComponent = oldConvertedReasonProps[0];\n return thisJs.setState((function (curTotalState, _) {\n var curReasonState = curTotalState.reasonState;\n var curReasonStateVersion = curTotalState.reasonStateVersion;\n var oldSelf = $$this.self(curReasonState, oldComponent[/* retainedProps */11]);\n var nextReasonState = Curry._1(newComponent[/* willReceiveProps */3], oldSelf);\n var match = +(nextReasonState !== curReasonState);\n var nextReasonStateVersion = match !== 0 ? curReasonStateVersion + 1 | 0 : curReasonStateVersion;\n if (nextReasonStateVersion !== curReasonStateVersion) {\n return {\n reasonState: nextReasonState,\n reasonStateVersion: nextReasonStateVersion,\n reasonStateVersionUsedToComputeSubelements: curTotalState.reasonStateVersionUsedToComputeSubelements,\n sideEffects: nextReasonState.sideEffects\n };\n } else {\n return curTotalState;\n }\n }));\n } else {\n return 0;\n }\n }),\n shouldComponentUpdate: (function (nextJsProps, nextState, _) {\n var $$this = this ;\n var thisJs = (this);\n var curJsProps = thisJs.props;\n var propsWarrantRerender = +(nextJsProps !== curJsProps);\n var oldConvertedReasonProps = convertPropsIfTheyreFromJs(thisJs.props, thisJs.jsPropsToReason, debugName);\n var match = +(nextJsProps === curJsProps);\n var newConvertedReasonProps = match !== 0 ? oldConvertedReasonProps : convertPropsIfTheyreFromJs(nextJsProps, thisJs.jsPropsToReason, debugName);\n var newComponent = newConvertedReasonProps[0];\n var nextReasonStateVersion = nextState.reasonStateVersion;\n var nextReasonStateVersionUsedToComputeSubelements = nextState.reasonStateVersionUsedToComputeSubelements;\n var stateChangeWarrantsComputingSubelements = +(nextReasonStateVersionUsedToComputeSubelements !== nextReasonStateVersion);\n var warrantsUpdate = propsWarrantRerender || stateChangeWarrantsComputingSubelements;\n var nextReasonState = nextState.reasonState;\n var newSelf = $$this.self(nextReasonState, newComponent[/* retainedProps */11]);\n var ret;\n if (warrantsUpdate && newComponent[/* shouldUpdate */8] !== lifecycleReturnTrue) {\n var curState = thisJs.state;\n var curReasonState = curState.reasonState;\n var oldSelf_000 = /* handle */newSelf[/* handle */0];\n var oldSelf_001 = /* update */newSelf[/* update */1];\n var oldSelf_002 = /* enqueue */newSelf[/* enqueue */2];\n var oldSelf_003 = /* reduce */newSelf[/* reduce */3];\n var oldSelf_005 = /* retainedProps */oldConvertedReasonProps[0][/* retainedProps */11];\n var oldSelf = /* record */[\n oldSelf_000,\n oldSelf_001,\n oldSelf_002,\n oldSelf_003,\n /* state */curReasonState,\n oldSelf_005\n ];\n ret = Curry._1(newComponent[/* shouldUpdate */8], /* record */[\n /* oldSelf */oldSelf,\n /* newSelf */newSelf\n ]);\n } else {\n ret = warrantsUpdate;\n }\n nextState.reasonStateVersionUsedToComputeSubelements = nextReasonStateVersion;\n var nextSideEffects = List.rev(nextState.sideEffects);\n if (nextSideEffects !== /* [] */0) {\n List.iter((function (performSideEffects) {\n return Curry._1(performSideEffects, newSelf);\n }), nextSideEffects);\n var nextStateNoSideEffects = {\n reasonState: nextState.reasonState,\n reasonStateVersion: nextState.reasonStateVersion,\n reasonStateVersionUsedToComputeSubelements: nextReasonStateVersion,\n sideEffects: /* [] */0\n };\n thisJs.setState(nextStateNoSideEffects);\n }\n return ret;\n }),\n enqueueMethod: (function (callback) {\n var $$this = this ;\n var thisJs = (this);\n return (function ($$event) {\n var remainingCallback = Curry._1(callback, $$event);\n return thisJs.setState((function (curTotalState, _) {\n var curReasonState = curTotalState.reasonState;\n var reasonStateUpdate = Curry._1(remainingCallback, curReasonState);\n if (reasonStateUpdate) {\n var nextTotalState = $$this.transitionNextTotalState(curTotalState, reasonStateUpdate);\n if (nextTotalState.reasonStateVersion !== curTotalState.reasonStateVersion) {\n return nextTotalState;\n } else {\n return magicNull;\n }\n } else {\n return magicNull;\n }\n }));\n });\n }),\n handleMethod: (function (callback) {\n var $$this = this ;\n var thisJs = (this);\n return (function (callbackPayload) {\n var curState = thisJs.state;\n var curReasonState = curState.reasonState;\n var convertedReasonProps = convertPropsIfTheyreFromJs(thisJs.props, thisJs.jsPropsToReason, debugName);\n return Curry._2(callback, callbackPayload, $$this.self(curReasonState, convertedReasonProps[0][/* retainedProps */11]));\n });\n }),\n updateMethod: (function (callback) {\n var $$this = this ;\n var thisJs = (this);\n return (function ($$event) {\n var curTotalState = thisJs.state;\n var curReasonState = curTotalState.reasonState;\n var convertedReasonProps = convertPropsIfTheyreFromJs(thisJs.props, thisJs.jsPropsToReason, debugName);\n var reasonStateUpdate = Curry._2(callback, $$event, $$this.self(curReasonState, convertedReasonProps[0][/* retainedProps */11]));\n if (reasonStateUpdate) {\n var nextTotalState = $$this.transitionNextTotalState(curTotalState, reasonStateUpdate);\n if (nextTotalState.reasonStateVersion !== curTotalState.reasonStateVersion) {\n return thisJs.setState(nextTotalState);\n } else {\n return 0;\n }\n } else {\n return magicNull;\n }\n });\n }),\n reduceMethod: (function (callback) {\n var $$this = this ;\n var thisJs = (this);\n return (function ($$event) {\n var convertedReasonProps = convertPropsIfTheyreFromJs(thisJs.props, thisJs.jsPropsToReason, debugName);\n var component = convertedReasonProps[0];\n if (component[/* reducer */12] !== reducerDefault) {\n var action = Curry._1(callback, $$event);\n return thisJs.setState((function (curTotalState, _) {\n var curReasonState = curTotalState.reasonState;\n var reasonStateUpdate = Curry._2(component[/* reducer */12], action, curReasonState);\n if (reasonStateUpdate) {\n var nextTotalState = $$this.transitionNextTotalState(curTotalState, reasonStateUpdate);\n if (nextTotalState.reasonStateVersion !== curTotalState.reasonStateVersion) {\n return nextTotalState;\n } else {\n return magicNull;\n }\n } else {\n return magicNull;\n }\n }));\n } else {\n return 0;\n }\n });\n }),\n render: (function () {\n var $$this = this ;\n var thisJs = (this);\n var convertedReasonProps = convertPropsIfTheyreFromJs(thisJs.props, thisJs.jsPropsToReason, debugName);\n var created = convertedReasonProps[0];\n var curState = thisJs.state;\n var curReasonState = curState.reasonState;\n return Curry._1(created[/* render */9], $$this.self(curReasonState, created[/* retainedProps */11]));\n })\n });\n}\n\nfunction basicComponent(debugName) {\n return /* record */[\n /* debugName */debugName,\n /* reactClassInternal */createClass(debugName),\n /* handedOffState : record */[/* contents : None */0],\n /* willReceiveProps */willReceivePropsDefault,\n /* didMount */lifecycleNoUpdate,\n /* didUpdate */lifecyclePreviousCurrentReturnUnit,\n /* willUnmount */lifecycleReturnUnit,\n /* willUpdate */lifecyclePreviousNextUnit,\n /* shouldUpdate */lifecycleReturnTrue,\n /* render */renderDefault,\n /* initialState */initialStateDefault,\n /* retainedProps : () */0,\n /* reducer */reducerDefault,\n /* jsElementWrapped : None */0\n ];\n}\n\nvar statelessComponent = basicComponent;\n\nvar statefulComponent = basicComponent;\n\nvar statefulComponentWithRetainedProps = basicComponent;\n\nvar statelessComponentWithRetainedProps = basicComponent;\n\nvar reducerComponent = basicComponent;\n\nvar reducerComponentWithRetainedProps = basicComponent;\n\nfunction element($staropt$star, $staropt$star$1, component) {\n var key = $staropt$star ? $staropt$star[0] : undefined;\n var ref = $staropt$star$1 ? $staropt$star$1[0] : undefined;\n var element$1 = /* Element */[component];\n var match = component[/* jsElementWrapped */13];\n if (match) {\n return Curry._2(match[0], key, ref);\n } else {\n return React.createElement(component[/* reactClassInternal */1], {\n key: key,\n ref: ref,\n reasonProps: element$1\n });\n }\n}\n\nfunction wrapReasonForJs(component, jsPropsToReason) {\n var tmp = component[/* reactClassInternal */1].prototype;\n tmp.jsPropsToReason = /* Some */[jsPropsToReason];\n return component[/* reactClassInternal */1];\n}\n\nvar dummyInteropComponent = statefulComponent(\"interop\");\n\nfunction wrapJsForReason(reactClass, props, children) {\n var jsElementWrapped = /* Some */[(function (param, param$1) {\n var reactClass$1 = reactClass;\n var props$1 = props;\n var children$1 = children;\n var key = param;\n var ref = param$1;\n var props$2 = Object.assign(Object.assign({ }, props$1), {\n ref: ref,\n key: key\n });\n var varargs = /* array */[\n reactClass$1,\n props$2\n ].concat(children$1);\n return React.createElement.apply(null, varargs);\n })];\n var newrecord = dummyInteropComponent.slice();\n newrecord[/* jsElementWrapped */13] = jsElementWrapped;\n return newrecord;\n}\n\nexports.Callback = Callback;\nexports.statelessComponent = statelessComponent;\nexports.statelessComponentWithRetainedProps = statelessComponentWithRetainedProps;\nexports.reducerComponent = reducerComponent;\nexports.reducerComponentWithRetainedProps = reducerComponentWithRetainedProps;\nexports.statefulComponent = statefulComponent;\nexports.statefulComponentWithRetainedProps = statefulComponentWithRetainedProps;\nexports.element = element;\nexports.wrapReasonForJs = wrapReasonForJs;\nexports.createDomElement = createDomElement;\nexports.wrapJsForReason = wrapJsForReason;\n/* magicNull Not a pure module */\n"
},
{
"id": 6,
"identifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/css-loader/lib/css-base.js",
"name": "./node_modules/css-loader/lib/css-base.js",
"index": 35,
"index2": 30,
"size": 2260,
"cacheable": true,
"built": true,
"optional": false,
"prefetched": false,
"chunks": [
0
],
"assets": [],
"issuer": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/css-loader/index.js!/home/x/zzz/github/douglasduteil/RePeople/src/style/main.css",
"issuerId": 95,
"issuerName": "./node_modules/css-loader!./src/style/main.css",
"failed": false,
"errors": 0,
"warnings": 0,
"reasons": [
{
"moduleId": 47,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/css-loader/index.js!/home/x/zzz/github/douglasduteil/RePeople/src/style/appBar.css",
"module": "./node_modules/css-loader!./src/style/appBar.css",
"moduleName": "./node_modules/css-loader!./src/style/appBar.css",
"type": "cjs require",
"userRequest": "../../node_modules/css-loader/lib/css-base.js",
"loc": "1:27-83"
},
{
"moduleId": 57,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/css-loader/index.js!/home/x/zzz/github/douglasduteil/RePeople/src/style/card.css",
"module": "./node_modules/css-loader!./src/style/card.css",
"moduleName": "./node_modules/css-loader!./src/style/card.css",
"type": "cjs require",
"userRequest": "../../node_modules/css-loader/lib/css-base.js",
"loc": "1:27-83"
},
{
"moduleId": 60,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/css-loader/index.js!/home/x/zzz/github/douglasduteil/RePeople/src/style/searchInput.css",
"module": "./node_modules/css-loader!./src/style/searchInput.css",
"moduleName": "./node_modules/css-loader!./src/style/searchInput.css",
"type": "cjs require",
"userRequest": "../../node_modules/css-loader/lib/css-base.js",
"loc": "1:27-83"
},
{
"moduleId": 72,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/css-loader/index.js!/home/x/zzz/github/douglasduteil/RePeople/src/style/discover.css",
"module": "./node_modules/css-loader!./src/style/discover.css",
"moduleName": "./node_modules/css-loader!./src/style/discover.css",
"type": "cjs require",
"userRequest": "../../node_modules/css-loader/lib/css-base.js",
"loc": "1:27-83"
},
{
"moduleId": 74,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/css-loader/index.js!/home/x/zzz/github/douglasduteil/RePeople/src/style/app.css",
"module": "./node_modules/css-loader!./src/style/app.css",
"moduleName": "./node_modules/css-loader!./src/style/app.css",
"type": "cjs require",
"userRequest": "../../node_modules/css-loader/lib/css-base.js",
"loc": "1:27-83"
},
{
"moduleId": 95,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/css-loader/index.js!/home/x/zzz/github/douglasduteil/RePeople/src/style/main.css",
"module": "./node_modules/css-loader!./src/style/main.css",
"moduleName": "./node_modules/css-loader!./src/style/main.css",
"type": "cjs require",
"userRequest": "../../node_modules/css-loader/lib/css-base.js",
"loc": "1:27-83"
},
{
"moduleId": 96,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/css-loader/index.js!/home/x/zzz/github/douglasduteil/RePeople/node_modules/materialize-css/dist/css/materialize.css",
"module": "./node_modules/css-loader!./node_modules/materialize-css/dist/css/materialize.css",
"moduleName": "./node_modules/css-loader!./node_modules/materialize-css/dist/css/materialize.css",
"type": "cjs require",
"userRequest": "../../../css-loader/lib/css-base.js",
"loc": "1:27-73"
},
{
"moduleId": 107,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/css-loader/index.js!/home/x/zzz/github/douglasduteil/RePeople/node_modules/material-design-icons/iconfont/material-icons.css",
"module": "./node_modules/css-loader!./node_modules/material-design-icons/iconfont/material-icons.css",
"moduleName": "./node_modules/css-loader!./node_modules/material-design-icons/iconfont/material-icons.css",
"type": "cjs require",
"userRequest": "../../css-loader/lib/css-base.js",
"loc": "1:27-70"
}
],
"usedExports": true,
"providedExports": null,
"optimizationBailout": [],
"depth": 3,
"source": "/*\n\tMIT License http://www.opensource.org/licenses/mit-license.php\n\tAuthor Tobias Koppers @sokra\n*/\n// css base code, injected by the css-loader\nmodule.exports = function(useSourceMap) {\n\tvar list = [];\n\n\t// return the list of modules as css string\n\tlist.toString = function toString() {\n\t\treturn this.map(function (item) {\n\t\t\tvar content = cssWithMappingToString(item, useSourceMap);\n\t\t\tif(item[2]) {\n\t\t\t\treturn \"@media \" + item[2] + \"{\" + content + \"}\";\n\t\t\t} else {\n\t\t\t\treturn content;\n\t\t\t}\n\t\t}).join(\"\");\n\t};\n\n\t// import a list of modules into the list\n\tlist.i = function(modules, mediaQuery) {\n\t\tif(typeof modules === \"string\")\n\t\t\tmodules = [[null, modules, \"\"]];\n\t\tvar alreadyImportedModules = {};\n\t\tfor(var i = 0; i < this.length; i++) {\n\t\t\tvar id = this[i][0];\n\t\t\tif(typeof id === \"number\")\n\t\t\t\talreadyImportedModules[id] = true;\n\t\t}\n\t\tfor(i = 0; i < modules.length; i++) {\n\t\t\tvar item = modules[i];\n\t\t\t// skip already imported module\n\t\t\t// this implementation is not 100% perfect for weird media query combinations\n\t\t\t// when a module is imported multiple times with different media queries.\n\t\t\t// I hope this will never occur (Hey this way we have smaller bundles)\n\t\t\tif(typeof item[0] !== \"number\" || !alreadyImportedModules[item[0]]) {\n\t\t\t\tif(mediaQuery && !item[2]) {\n\t\t\t\t\titem[2] = mediaQuery;\n\t\t\t\t} else if(mediaQuery) {\n\t\t\t\t\titem[2] = \"(\" + item[2] + \") and (\" + mediaQuery + \")\";\n\t\t\t\t}\n\t\t\t\tlist.push(item);\n\t\t\t}\n\t\t}\n\t};\n\treturn list;\n};\n\nfunction cssWithMappingToString(item, useSourceMap) {\n\tvar content = item[1] || '';\n\tvar cssMapping = item[3];\n\tif (!cssMapping) {\n\t\treturn content;\n\t}\n\n\tif (useSourceMap && typeof btoa === 'function') {\n\t\tvar sourceMapping = toComment(cssMapping);\n\t\tvar sourceURLs = cssMapping.sources.map(function (source) {\n\t\t\treturn '/*# sourceURL=' + cssMapping.sourceRoot + source + ' */'\n\t\t});\n\n\t\treturn [content].concat(sourceURLs).concat([sourceMapping]).join('\\n');\n\t}\n\n\treturn [content].join('\\n');\n}\n\n// Adapted from convert-source-map (MIT)\nfunction toComment(sourceMap) {\n\t// eslint-disable-next-line no-undef\n\tvar base64 = btoa(unescape(encodeURIComponent(JSON.stringify(sourceMap))));\n\tvar data = 'sourceMappingURL=data:application/json;charset=utf-8;base64,' + base64;\n\n\treturn '/*# ' + data + ' */';\n}\n"
},
{
"id": 7,
"identifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/fbjs/lib/invariant.js",
"name": "./node_modules/fbjs/lib/invariant.js",
"index": 11,
"index2": 7,
"size": 1506,
"cacheable": true,
"built": true,
"optional": false,
"prefetched": false,
"chunks": [
0
],
"assets": [],
"issuer": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/react/cjs/react.production.min.js",
"issuerId": 40,
"issuerName": "./node_modules/react/cjs/react.production.min.js",
"failed": false,
"errors": 0,
"warnings": 0,
"reasons": [
{
"moduleId": 22,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/prop-types/checkPropTypes.js",
"module": "./node_modules/prop-types/checkPropTypes.js",
"moduleName": "./node_modules/prop-types/checkPropTypes.js",
"type": "cjs require",
"userRequest": "fbjs/lib/invariant",
"loc": "11:18-47"
},
{
"moduleId": 40,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/react/cjs/react.production.min.js",
"module": "./node_modules/react/cjs/react.production.min.js",
"moduleName": "./node_modules/react/cjs/react.production.min.js",
"type": "cjs require",
"userRequest": "fbjs/lib/invariant",
"loc": "10:78-107"
},
{
"moduleId": 41,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/react/cjs/react.development.js",
"module": "./node_modules/react/cjs/react.development.js",
"moduleName": "./node_modules/react/cjs/react.development.js",
"type": "cjs require",
"userRequest": "fbjs/lib/invariant",
"loc": "20:16-45"
},
{
"moduleId": 77,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/react-dom/cjs/react-dom.production.min.js",
"module": "./node_modules/react-dom/cjs/react-dom.production.min.js",
"moduleName": "./node_modules/react-dom/cjs/react-dom.production.min.js",
"type": "cjs require",
"userRequest": "fbjs/lib/invariant",
"loc": "11:37-66"
},
{
"moduleId": 80,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/react-dom/cjs/react-dom.development.js",
"module": "./node_modules/react-dom/cjs/react-dom.development.js",
"moduleName": "./node_modules/react-dom/cjs/react-dom.development.js",
"type": "cjs require",
"userRequest": "fbjs/lib/invariant",
"loc": "18:16-45"
},
{
"moduleId": 88,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/prop-types/factoryWithTypeCheckers.js",
"module": "./node_modules/prop-types/factoryWithTypeCheckers.js",
"moduleName": "./node_modules/prop-types/factoryWithTypeCheckers.js",
"type": "cjs require",
"userRequest": "fbjs/lib/invariant",
"loc": "11:16-45"
},
{
"moduleId": 89,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/prop-types/factoryWithThrowingShims.js",
"module": "./node_modules/prop-types/factoryWithThrowingShims.js",
"moduleName": "./node_modules/prop-types/factoryWithThrowingShims.js",
"type": "cjs require",
"userRequest": "fbjs/lib/invariant",
"loc": "11:16-45"
}
],
"usedExports": true,
"providedExports": null,
"optimizationBailout": [],
"depth": 4,
"source": "/**\n * Copyright (c) 2013-present, Facebook, Inc.\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 */\n\n'use strict';\n\n/**\n * Use invariant() to assert state which your program assumes to be true.\n *\n * Provide sprintf-style format (only %s is supported) and arguments\n * to provide information about what broke and what you were\n * expecting.\n *\n * The invariant message will be stripped in production, but the invariant\n * will remain to ensure logic does not differ in production.\n */\n\nvar validateFormat = function validateFormat(format) {};\n\nif (process.env.NODE_ENV !== 'production') {\n validateFormat = function validateFormat(format) {\n if (format === undefined) {\n throw new Error('invariant requires an error message argument');\n }\n };\n}\n\nfunction invariant(condition, format, a, b, c, d, e, f) {\n validateFormat(format);\n\n if (!condition) {\n var error;\n if (format === undefined) {\n error = new Error('Minified exception occurred; use the non-minified dev environment ' + 'for the full error message and additional helpful warnings.');\n } else {\n var args = [a, b, c, d, e, f];\n var argIndex = 0;\n error = new Error(format.replace(/%s/g, function () {\n return args[argIndex++];\n }));\n error.name = 'Invariant Violation';\n }\n\n error.framesToPop = 1; // we don't care about invariant's own frame\n throw error;\n }\n}\n\nmodule.exports = invariant;"
},
{
"id": 8,
"identifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/bs-platform/lib/js/caml_obj.js",
"name": "./node_modules/bs-platform/lib/js/caml_obj.js",
"index": 20,
"index2": 15,
"size": 8005,
"cacheable": true,
"built": true,
"optional": false,
"prefetched": false,
"chunks": [
0
],
"assets": [],
"issuer": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/bs-platform/lib/js/list.js",
"issuerId": 14,
"issuerName": "./node_modules/bs-platform/lib/js/list.js",
"failed": false,
"errors": 0,
"warnings": 0,
"reasons": [
{
"moduleId": 14,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/bs-platform/lib/js/list.js",
"module": "./node_modules/bs-platform/lib/js/list.js",
"moduleName": "./node_modules/bs-platform/lib/js/list.js",
"type": "cjs require",
"userRequest": "./caml_obj.js",
"loc": "4:30-54"
},
{
"moduleId": 15,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/bs-platform/lib/js/pervasives.js",
"module": "./node_modules/bs-platform/lib/js/pervasives.js",
"moduleName": "./node_modules/bs-platform/lib/js/pervasives.js",
"type": "cjs require",
"userRequest": "./caml_obj.js",
"loc": "5:31-55"
},
{
"moduleId": 25,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/bs-platform/lib/js/caml_int64.js",
"module": "./node_modules/bs-platform/lib/js/caml_int64.js",
"moduleName": "./node_modules/bs-platform/lib/js/caml_int64.js",
"type": "cjs require",
"userRequest": "./caml_obj.js",
"loc": "3:30-54"
},
{
"moduleId": 63,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/bs-platform/lib/js/int32.js",
"module": "./node_modules/bs-platform/lib/js/int32.js",
"moduleName": "./node_modules/bs-platform/lib/js/int32.js",
"type": "cjs require",
"userRequest": "./caml_obj.js",
"loc": "3:18-42"
},
{
"moduleId": 67,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/bs-platform/lib/js/bytes.js",
"module": "./node_modules/bs-platform/lib/js/bytes.js",
"moduleName": "./node_modules/bs-platform/lib/js/bytes.js",
"type": "cjs require",
"userRequest": "./caml_obj.js",
"loc": "6:30-54"
},
{
"moduleId": 69,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/bs-platform/lib/js/nativeint.js",
"module": "./node_modules/bs-platform/lib/js/nativeint.js",
"moduleName": "./node_modules/bs-platform/lib/js/nativeint.js",
"type": "cjs require",
"userRequest": "./caml_obj.js",
"loc": "4:18-42"
}
],
"usedExports": true,
"providedExports": null,
"optimizationBailout": [],
"depth": 3,
"source": "'use strict';\n\nvar Block = require(\"./block.js\");\nvar Caml_builtin_exceptions = require(\"./caml_builtin_exceptions.js\");\n\nfunction caml_obj_dup(x) {\n var len = x.length | 0;\n var v = new Array(len);\n for(var i = 0 ,i_finish = len - 1 | 0; i <= i_finish; ++i){\n v[i] = x[i];\n }\n v.tag = x.tag | 0;\n return v;\n}\n\nfunction caml_obj_truncate(x, new_size) {\n var len = x.length | 0;\n if (new_size <= 0 || new_size > len) {\n throw [\n Caml_builtin_exceptions.invalid_argument,\n \"Obj.truncate\"\n ];\n } else if (len !== new_size) {\n for(var i = new_size ,i_finish = len - 1 | 0; i <= i_finish; ++i){\n x[i] = 0;\n }\n x.length = new_size;\n return /* () */0;\n } else {\n return 0;\n }\n}\n\nfunction caml_lazy_make_forward(x) {\n return Block.__(250, [x]);\n}\n\nfunction caml_update_dummy(x, y) {\n var len = y.length | 0;\n for(var i = 0 ,i_finish = len - 1 | 0; i <= i_finish; ++i){\n x[i] = y[i];\n }\n var y_tag = y.tag | 0;\n if (y_tag !== 0) {\n x.tag = y_tag;\n return /* () */0;\n } else {\n return 0;\n }\n}\n\nfunction caml_int_compare(x, y) {\n if (x < y) {\n return -1;\n } else if (x === y) {\n return 0;\n } else {\n return 1;\n }\n}\n\nfunction caml_compare(_a, _b) {\n while(true) {\n var b = _b;\n var a = _a;\n var a_type = typeof a;\n var b_type = typeof b;\n if (a_type === \"string\") {\n var x = a;\n var y = b;\n if (x < y) {\n return -1;\n } else if (x === y) {\n return 0;\n } else {\n return 1;\n }\n } else {\n var is_a_number = +(a_type === \"number\");\n var is_b_number = +(b_type === \"number\");\n if (is_a_number !== 0) {\n if (is_b_number !== 0) {\n return caml_int_compare(a, b);\n } else {\n return -1;\n }\n } else if (is_b_number !== 0) {\n return 1;\n } else if (a_type === \"boolean\" || a_type === \"undefined\" || a === null) {\n var x$1 = a;\n var y$1 = b;\n if (x$1 === y$1) {\n return 0;\n } else if (x$1 < y$1) {\n return -1;\n } else {\n return 1;\n }\n } else if (a_type === \"function\" || b_type === \"function\") {\n throw [\n Caml_builtin_exceptions.invalid_argument,\n \"compare: functional value\"\n ];\n } else {\n var tag_a = a.tag | 0;\n var tag_b = b.tag | 0;\n if (tag_a === 250) {\n _a = a[0];\n continue ;\n \n } else if (tag_b === 250) {\n _b = b[0];\n continue ;\n \n } else if (tag_a === 248) {\n return caml_int_compare(a[1], b[1]);\n } else if (tag_a === 251) {\n throw [\n Caml_builtin_exceptions.invalid_argument,\n \"equal: abstract value\"\n ];\n } else if (tag_a !== tag_b) {\n if (tag_a < tag_b) {\n return -1;\n } else {\n return 1;\n }\n } else {\n var len_a = a.length | 0;\n var len_b = b.length | 0;\n if (len_a === len_b) {\n var a$1 = a;\n var b$1 = b;\n var _i = 0;\n var same_length = len_a;\n while(true) {\n var i = _i;\n if (i === same_length) {\n return 0;\n } else {\n var res = caml_compare(a$1[i], b$1[i]);\n if (res !== 0) {\n return res;\n } else {\n _i = i + 1 | 0;\n continue ;\n \n }\n }\n };\n } else if (len_a < len_b) {\n var a$2 = a;\n var b$2 = b;\n var _i$1 = 0;\n var short_length = len_a;\n while(true) {\n var i$1 = _i$1;\n if (i$1 === short_length) {\n return -1;\n } else {\n var res$1 = caml_compare(a$2[i$1], b$2[i$1]);\n if (res$1 !== 0) {\n return res$1;\n } else {\n _i$1 = i$1 + 1 | 0;\n continue ;\n \n }\n }\n };\n } else {\n var a$3 = a;\n var b$3 = b;\n var _i$2 = 0;\n var short_length$1 = len_b;\n while(true) {\n var i$2 = _i$2;\n if (i$2 === short_length$1) {\n return 1;\n } else {\n var res$2 = caml_compare(a$3[i$2], b$3[i$2]);\n if (res$2 !== 0) {\n return res$2;\n } else {\n _i$2 = i$2 + 1 | 0;\n continue ;\n \n }\n }\n };\n }\n }\n }\n }\n };\n}\n\nfunction caml_equal(_a, _b) {\n while(true) {\n var b = _b;\n var a = _a;\n if (a === b) {\n return /* true */1;\n } else {\n var a_type = typeof a;\n if (a_type === \"string\" || a_type === \"number\" || a_type === \"boolean\" || a_type === \"undefined\" || a === null) {\n return /* false */0;\n } else {\n var b_type = typeof b;\n if (a_type === \"function\" || b_type === \"function\") {\n throw [\n Caml_builtin_exceptions.invalid_argument,\n \"equal: functional value\"\n ];\n } else if (b_type === \"number\" || b_type === \"undefined\" || b === null) {\n return /* false */0;\n } else {\n var tag_a = a.tag | 0;\n var tag_b = b.tag | 0;\n if (tag_a === 250) {\n _a = a[0];\n continue ;\n \n } else if (tag_b === 250) {\n _b = b[0];\n continue ;\n \n } else if (tag_a === 248) {\n return +(a[1] === b[1]);\n } else if (tag_a === 251) {\n throw [\n Caml_builtin_exceptions.invalid_argument,\n \"equal: abstract value\"\n ];\n } else if (tag_a !== tag_b) {\n return /* false */0;\n } else {\n var len_a = a.length | 0;\n var len_b = b.length | 0;\n if (len_a === len_b) {\n var a$1 = a;\n var b$1 = b;\n var _i = 0;\n var same_length = len_a;\n while(true) {\n var i = _i;\n if (i === same_length) {\n return /* true */1;\n } else if (caml_equal(a$1[i], b$1[i])) {\n _i = i + 1 | 0;\n continue ;\n \n } else {\n return /* false */0;\n }\n };\n } else {\n return /* false */0;\n }\n }\n }\n }\n }\n };\n}\n\nfunction caml_notequal(a, b) {\n return 1 - caml_equal(a, b);\n}\n\nfunction caml_greaterequal(a, b) {\n return +(caml_compare(a, b) >= 0);\n}\n\nfunction caml_greaterthan(a, b) {\n return +(caml_compare(a, b) > 0);\n}\n\nfunction caml_lessequal(a, b) {\n return +(caml_compare(a, b) <= 0);\n}\n\nfunction caml_lessthan(a, b) {\n return +(caml_compare(a, b) < 0);\n}\n\nvar caml_int32_compare = caml_int_compare;\n\nvar caml_nativeint_compare = caml_int_compare;\n\nexports.caml_obj_dup = caml_obj_dup;\nexports.caml_obj_truncate = caml_obj_truncate;\nexports.caml_lazy_make_forward = caml_lazy_make_forward;\nexports.caml_update_dummy = caml_update_dummy;\nexports.caml_int_compare = caml_int_compare;\nexports.caml_int32_compare = caml_int32_compare;\nexports.caml_nativeint_compare = caml_nativeint_compare;\nexports.caml_compare = caml_compare;\nexports.caml_equal = caml_equal;\nexports.caml_notequal = caml_notequal;\nexports.caml_greaterequal = caml_greaterequal;\nexports.caml_greaterthan = caml_greaterthan;\nexports.caml_lessthan = caml_lessthan;\nexports.caml_lessequal = caml_lessequal;\n/* No side effect */\n"
},
{
"id": 9,
"identifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/bs-platform/lib/js/caml_string.js",
"name": "./node_modules/bs-platform/lib/js/caml_string.js",
"index": 28,
"index2": 22,
"size": 5331,
"cacheable": true,
"built": true,
"optional": false,
"prefetched": false,
"chunks": [
0
],
"assets": [],
"issuer": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/bs-platform/lib/js/random.js",
"issuerId": 62,
"issuerName": "./node_modules/bs-platform/lib/js/random.js",
"failed": false,
"errors": 0,
"warnings": 0,
"reasons": [
{
"moduleId": 15,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/bs-platform/lib/js/pervasives.js",
"module": "./node_modules/bs-platform/lib/js/pervasives.js",
"moduleName": "./node_modules/bs-platform/lib/js/pervasives.js",
"type": "cjs require",
"userRequest": "./caml_string.js",
"loc": "8:31-58"
},
{
"moduleId": 32,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/bs-platform/lib/js/char.js",
"module": "./node_modules/bs-platform/lib/js/char.js",
"moduleName": "./node_modules/bs-platform/lib/js/char.js",
"type": "cjs require",
"userRequest": "./caml_string.js",
"loc": "3:30-57"
},
{
"moduleId": 62,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/bs-platform/lib/js/random.js",
"module": "./node_modules/bs-platform/lib/js/random.js",
"moduleName": "./node_modules/bs-platform/lib/js/random.js",
"type": "cjs require",
"userRequest": "./caml_string.js",
"loc": "13:30-57"
},
{
"moduleId": 65,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/bs-platform/lib/js/digest.js",
"module": "./node_modules/bs-platform/lib/js/digest.js",
"moduleName": "./node_modules/bs-platform/lib/js/digest.js",
"type": "cjs require",
"userRequest": "./caml_string.js",
"loc": "7:30-57"
},
{
"moduleId": 66,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/bs-platform/lib/js/string.js",
"module": "./node_modules/bs-platform/lib/js/string.js",
"moduleName": "./node_modules/bs-platform/lib/js/string.js",
"type": "cjs require",
"userRequest": "./caml_string.js",
"loc": "6:18-45"
},
{
"moduleId": 67,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/bs-platform/lib/js/bytes.js",
"module": "./node_modules/bs-platform/lib/js/bytes.js",
"moduleName": "./node_modules/bs-platform/lib/js/bytes.js",
"type": "cjs require",
"userRequest": "./caml_string.js",
"loc": "9:30-57"
}
],
"usedExports": true,
"providedExports": null,
"optimizationBailout": [],
"depth": 4,
"source": "'use strict';\n\nvar Caml_builtin_exceptions = require(\"./caml_builtin_exceptions.js\");\n\nfunction string_of_char(prim) {\n return String.fromCharCode(prim);\n}\n\nfunction caml_string_get(s, i) {\n if (i >= s.length || i < 0) {\n throw [\n Caml_builtin_exceptions.invalid_argument,\n \"index out of bounds\"\n ];\n } else {\n return s.charCodeAt(i);\n }\n}\n\nfunction caml_create_string(len) {\n if (len < 0) {\n throw [\n Caml_builtin_exceptions.invalid_argument,\n \"String.create\"\n ];\n } else {\n return new Array(len);\n }\n}\n\nfunction caml_string_compare(s1, s2) {\n if (s1 === s2) {\n return 0;\n } else if (s1 < s2) {\n return -1;\n } else {\n return 1;\n }\n}\n\nfunction caml_fill_string(s, i, l, c) {\n if (l > 0) {\n for(var k = i ,k_finish = (l + i | 0) - 1 | 0; k <= k_finish; ++k){\n s[k] = c;\n }\n return /* () */0;\n } else {\n return 0;\n }\n}\n\nfunction caml_blit_string(s1, i1, s2, i2, len) {\n if (len > 0) {\n var off1 = s1.length - i1 | 0;\n if (len <= off1) {\n for(var i = 0 ,i_finish = len - 1 | 0; i <= i_finish; ++i){\n s2[i2 + i | 0] = s1.charCodeAt(i1 + i | 0);\n }\n return /* () */0;\n } else {\n for(var i$1 = 0 ,i_finish$1 = off1 - 1 | 0; i$1 <= i_finish$1; ++i$1){\n s2[i2 + i$1 | 0] = s1.charCodeAt(i1 + i$1 | 0);\n }\n for(var i$2 = off1 ,i_finish$2 = len - 1 | 0; i$2 <= i_finish$2; ++i$2){\n s2[i2 + i$2 | 0] = /* \"\\000\" */0;\n }\n return /* () */0;\n }\n } else {\n return 0;\n }\n}\n\nfunction caml_blit_bytes(s1, i1, s2, i2, len) {\n if (len > 0) {\n if (s1 === s2) {\n var s1$1 = s1;\n var i1$1 = i1;\n var i2$1 = i2;\n var len$1 = len;\n if (i1$1 < i2$1) {\n var range_a = (s1$1.length - i2$1 | 0) - 1 | 0;\n var range_b = len$1 - 1 | 0;\n var range = range_a > range_b ? range_b : range_a;\n for(var j = range; j >= 0; --j){\n s1$1[i2$1 + j | 0] = s1$1[i1$1 + j | 0];\n }\n return /* () */0;\n } else if (i1$1 > i2$1) {\n var range_a$1 = (s1$1.length - i1$1 | 0) - 1 | 0;\n var range_b$1 = len$1 - 1 | 0;\n var range$1 = range_a$1 > range_b$1 ? range_b$1 : range_a$1;\n for(var k = 0; k <= range$1; ++k){\n s1$1[i2$1 + k | 0] = s1$1[i1$1 + k | 0];\n }\n return /* () */0;\n } else {\n return 0;\n }\n } else {\n var off1 = s1.length - i1 | 0;\n if (len <= off1) {\n for(var i = 0 ,i_finish = len - 1 | 0; i <= i_finish; ++i){\n s2[i2 + i | 0] = s1[i1 + i | 0];\n }\n return /* () */0;\n } else {\n for(var i$1 = 0 ,i_finish$1 = off1 - 1 | 0; i$1 <= i_finish$1; ++i$1){\n s2[i2 + i$1 | 0] = s1[i1 + i$1 | 0];\n }\n for(var i$2 = off1 ,i_finish$2 = len - 1 | 0; i$2 <= i_finish$2; ++i$2){\n s2[i2 + i$2 | 0] = /* \"\\000\" */0;\n }\n return /* () */0;\n }\n }\n } else {\n return 0;\n }\n}\n\nfunction bytes_of_string(s) {\n var len = s.length;\n var res = new Array(len);\n for(var i = 0 ,i_finish = len - 1 | 0; i <= i_finish; ++i){\n res[i] = s.charCodeAt(i);\n }\n return res;\n}\n\nfunction bytes_to_string(a) {\n var bytes = a;\n var i = 0;\n var len = a.length;\n var s = \"\";\n var s_len = len;\n if (i === 0 && len <= 4096 && len === bytes.length) {\n return String.fromCharCode.apply(null,bytes);\n } else {\n var offset = 0;\n while(s_len > 0) {\n var next = s_len < 1024 ? s_len : 1024;\n var tmp_bytes = new Array(next);\n caml_blit_bytes(bytes, offset, tmp_bytes, 0, next);\n s = s + String.fromCharCode.apply(null,tmp_bytes);\n s_len = s_len - next | 0;\n offset = offset + next | 0;\n };\n return s;\n }\n}\n\nfunction caml_string_of_char_array(chars) {\n var len = chars.length;\n var bytes = new Array(len);\n for(var i = 0 ,i_finish = len - 1 | 0; i <= i_finish; ++i){\n bytes[i] = chars[i];\n }\n return bytes_to_string(bytes);\n}\n\nfunction caml_is_printable(c) {\n if (c > 31) {\n return +(c < 127);\n } else {\n return /* false */0;\n }\n}\n\nfunction caml_string_get16(s, i) {\n return s.charCodeAt(i) + (s.charCodeAt(i + 1 | 0) << 8) | 0;\n}\n\nfunction caml_string_get32(s, i) {\n return ((s.charCodeAt(i) + (s.charCodeAt(i + 1 | 0) << 8) | 0) + (s.charCodeAt(i + 2 | 0) << 16) | 0) + (s.charCodeAt(i + 3 | 0) << 24) | 0;\n}\n\nfunction get(s, i) {\n if (i < 0 || i >= s.length) {\n throw [\n Caml_builtin_exceptions.invalid_argument,\n \"index out of bounds\"\n ];\n } else {\n return s.charCodeAt(i);\n }\n}\n\nexports.bytes_of_string = bytes_of_string;\nexports.bytes_to_string = bytes_to_string;\nexports.caml_is_printable = caml_is_printable;\nexports.caml_string_of_char_array = caml_string_of_char_array;\nexports.caml_string_get = caml_string_get;\nexports.caml_string_compare = caml_string_compare;\nexports.caml_create_string = caml_create_string;\nexports.caml_fill_string = caml_fill_string;\nexports.caml_blit_string = caml_blit_string;\nexports.caml_blit_bytes = caml_blit_bytes;\nexports.caml_string_get16 = caml_string_get16;\nexports.caml_string_get32 = caml_string_get32;\nexports.string_of_char = string_of_char;\nexports.get = get;\n/* No side effect */\n"
},
{
"id": 10,
"identifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/style-loader/lib/addStyles.js",
"name": "./node_modules/style-loader/lib/addStyles.js",
"index": 37,
"index2": 34,
"size": 8704,
"cacheable": true,
"built": true,
"optional": false,
"prefetched": false,
"chunks": [
0
],
"assets": [],
"issuer": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/style-loader/index.js!/home/x/zzz/github/douglasduteil/RePeople/node_modules/css-loader/index.js!/home/x/zzz/github/douglasduteil/RePeople/src/style/main.css",
"issuerId": 94,
"issuerName": "./src/style/main.css",
"failed": false,
"errors": 0,
"warnings": 0,
"reasons": [
{
"moduleId": 46,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/style-loader/index.js!/home/x/zzz/github/douglasduteil/RePeople/node_modules/css-loader/index.js!/home/x/zzz/github/douglasduteil/RePeople/src/style/appBar.css",
"module": "./src/style/appBar.css",
"moduleName": "./src/style/appBar.css",
"type": "cjs require",
"userRequest": "!../../node_modules/style-loader/lib/addStyles.js",
"loc": "12:13-73"
},
{
"moduleId": 56,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/style-loader/index.js!/home/x/zzz/github/douglasduteil/RePeople/node_modules/css-loader/index.js!/home/x/zzz/github/douglasduteil/RePeople/src/style/card.css",
"module": "./src/style/card.css",
"moduleName": "./src/style/card.css",
"type": "cjs require",
"userRequest": "!../../node_modules/style-loader/lib/addStyles.js",
"loc": "12:13-73"
},
{
"moduleId": 59,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/style-loader/index.js!/home/x/zzz/github/douglasduteil/RePeople/node_modules/css-loader/index.js!/home/x/zzz/github/douglasduteil/RePeople/src/style/searchInput.css",
"module": "./src/style/searchInput.css",
"moduleName": "./src/style/searchInput.css",
"type": "cjs require",
"userRequest": "!../../node_modules/style-loader/lib/addStyles.js",
"loc": "12:13-73"
},
{
"moduleId": 71,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/style-loader/index.js!/home/x/zzz/github/douglasduteil/RePeople/node_modules/css-loader/index.js!/home/x/zzz/github/douglasduteil/RePeople/src/style/discover.css",
"module": "./src/style/discover.css",
"moduleName": "./src/style/discover.css",
"type": "cjs require",
"userRequest": "!../../node_modules/style-loader/lib/addStyles.js",
"loc": "12:13-73"
},
{
"moduleId": 73,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/style-loader/index.js!/home/x/zzz/github/douglasduteil/RePeople/node_modules/css-loader/index.js!/home/x/zzz/github/douglasduteil/RePeople/src/style/app.css",
"module": "./src/style/app.css",
"moduleName": "./src/style/app.css",
"type": "cjs require",
"userRequest": "!../../node_modules/style-loader/lib/addStyles.js",
"loc": "12:13-73"
},
{
"moduleId": 94,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/style-loader/index.js!/home/x/zzz/github/douglasduteil/RePeople/node_modules/css-loader/index.js!/home/x/zzz/github/douglasduteil/RePeople/src/style/main.css",
"module": "./src/style/main.css",
"moduleName": "./src/style/main.css",
"type": "cjs require",
"userRequest": "!../../node_modules/style-loader/lib/addStyles.js",
"loc": "12:13-73"
}
],
"usedExports": true,
"providedExports": null,
"optimizationBailout": [],
"depth": 2,
"source": "/*\n\tMIT License http://www.opensource.org/licenses/mit-license.php\n\tAuthor Tobias Koppers @sokra\n*/\n\nvar stylesInDom = {};\n\nvar\tmemoize = function (fn) {\n\tvar memo;\n\n\treturn function () {\n\t\tif (typeof memo === \"undefined\") memo = fn.apply(this, arguments);\n\t\treturn memo;\n\t};\n};\n\nvar isOldIE = memoize(function () {\n\t// Test for IE <= 9 as proposed by Browserhacks\n\t// @see http://browserhacks.com/#hack-e71d8692f65334173fee715c222cb805\n\t// Tests for existence of standard globals is to allow style-loader\n\t// to operate correctly into non-standard environments\n\t// @see https://github.com/webpack-contrib/style-loader/issues/177\n\treturn window && document && document.all && !window.atob;\n});\n\nvar getElement = (function (fn) {\n\tvar memo = {};\n\n\treturn function(selector) {\n\t\tif (typeof memo[selector] === \"undefined\") {\n\t\t\tmemo[selector] = fn.call(this, selector);\n\t\t}\n\n\t\treturn memo[selector]\n\t};\n})(function (target) {\n\treturn document.querySelector(target)\n});\n\nvar singleton = null;\nvar\tsingletonCounter = 0;\nvar\tstylesInsertedAtTop = [];\n\nvar\tfixUrls = require(\"./urls\");\n\nmodule.exports = function(list, options) {\n\tif (typeof DEBUG !== \"undefined\" && DEBUG) {\n\t\tif (typeof document !== \"object\") throw new Error(\"The style-loader cannot be used in a non-browser environment\");\n\t}\n\n\toptions = options || {};\n\n\toptions.attrs = typeof options.attrs === \"object\" ? options.attrs : {};\n\n\t// Force single-tag solution on IE6-9, which has a hard limit on the # of <style>\n\t// tags it will allow on a page\n\tif (!options.singleton) options.singleton = isOldIE();\n\n\t// By default, add <style> tags to the <head> element\n\tif (!options.insertInto) options.insertInto = \"head\";\n\n\t// By default, add <style> tags to the bottom of the target\n\tif (!options.insertAt) options.insertAt = \"bottom\";\n\n\tvar styles = listToStyles(list, options);\n\n\taddStylesToDom(styles, options);\n\n\treturn function update (newList) {\n\t\tvar mayRemove = [];\n\n\t\tfor (var i = 0; i < styles.length; i++) {\n\t\t\tvar item = styles[i];\n\t\t\tvar domStyle = stylesInDom[item.id];\n\n\t\t\tdomStyle.refs--;\n\t\t\tmayRemove.push(domStyle);\n\t\t}\n\n\t\tif(newList) {\n\t\t\tvar newStyles = listToStyles(newList, options);\n\t\t\taddStylesToDom(newStyles, options);\n\t\t}\n\n\t\tfor (var i = 0; i < mayRemove.length; i++) {\n\t\t\tvar domStyle = mayRemove[i];\n\n\t\t\tif(domStyle.refs === 0) {\n\t\t\t\tfor (var j = 0; j < domStyle.parts.length; j++) domStyle.parts[j]();\n\n\t\t\t\tdelete stylesInDom[domStyle.id];\n\t\t\t}\n\t\t}\n\t};\n};\n\nfunction addStylesToDom (styles, options) {\n\tfor (var i = 0; i < styles.length; i++) {\n\t\tvar item = styles[i];\n\t\tvar domStyle = stylesInDom[item.id];\n\n\t\tif(domStyle) {\n\t\t\tdomStyle.refs++;\n\n\t\t\tfor(var j = 0; j < domStyle.parts.length; j++) {\n\t\t\t\tdomStyle.parts[j](item.parts[j]);\n\t\t\t}\n\n\t\t\tfor(; j < item.parts.length; j++) {\n\t\t\t\tdomStyle.parts.push(addStyle(item.parts[j], options));\n\t\t\t}\n\t\t} else {\n\t\t\tvar parts = [];\n\n\t\t\tfor(var j = 0; j < item.parts.length; j++) {\n\t\t\t\tparts.push(addStyle(item.parts[j], options));\n\t\t\t}\n\n\t\t\tstylesInDom[item.id] = {id: item.id, refs: 1, parts: parts};\n\t\t}\n\t}\n}\n\nfunction listToStyles (list, options) {\n\tvar styles = [];\n\tvar newStyles = {};\n\n\tfor (var i = 0; i < list.length; i++) {\n\t\tvar item = list[i];\n\t\tvar id = options.base ? item[0] + options.base : item[0];\n\t\tvar css = item[1];\n\t\tvar media = item[2];\n\t\tvar sourceMap = item[3];\n\t\tvar part = {css: css, media: media, sourceMap: sourceMap};\n\n\t\tif(!newStyles[id]) styles.push(newStyles[id] = {id: id, parts: [part]});\n\t\telse newStyles[id].parts.push(part);\n\t}\n\n\treturn styles;\n}\n\nfunction insertStyleElement (options, style) {\n\tvar target = getElement(options.insertInto)\n\n\tif (!target) {\n\t\tthrow new Error(\"Couldn't find a style target. This probably means that the value for the 'insertInto' parameter is invalid.\");\n\t}\n\n\tvar lastStyleElementInsertedAtTop = stylesInsertedAtTop[stylesInsertedAtTop.length - 1];\n\n\tif (options.insertAt === \"top\") {\n\t\tif (!lastStyleElementInsertedAtTop) {\n\t\t\ttarget.insertBefore(style, target.firstChild);\n\t\t} else if (lastStyleElementInsertedAtTop.nextSibling) {\n\t\t\ttarget.insertBefore(style, lastStyleElementInsertedAtTop.nextSibling);\n\t\t} else {\n\t\t\ttarget.appendChild(style);\n\t\t}\n\t\tstylesInsertedAtTop.push(style);\n\t} else if (options.insertAt === \"bottom\") {\n\t\ttarget.appendChild(style);\n\t} else {\n\t\tthrow new Error(\"Invalid value for parameter 'insertAt'. Must be 'top' or 'bottom'.\");\n\t}\n}\n\nfunction removeStyleElement (style) {\n\tif (style.parentNode === null) return false;\n\tstyle.parentNode.removeChild(style);\n\n\tvar idx = stylesInsertedAtTop.indexOf(style);\n\tif(idx >= 0) {\n\t\tstylesInsertedAtTop.splice(idx, 1);\n\t}\n}\n\nfunction createStyleElement (options) {\n\tvar style = document.createElement(\"style\");\n\n\toptions.attrs.type = \"text/css\";\n\n\taddAttrs(style, options.attrs);\n\tinsertStyleElement(options, style);\n\n\treturn style;\n}\n\nfunction createLinkElement (options) {\n\tvar link = document.createElement(\"link\");\n\n\toptions.attrs.type = \"text/css\";\n\toptions.attrs.rel = \"stylesheet\";\n\n\taddAttrs(link, options.attrs);\n\tinsertStyleElement(options, link);\n\n\treturn link;\n}\n\nfunction addAttrs (el, attrs) {\n\tObject.keys(attrs).forEach(function (key) {\n\t\tel.setAttribute(key, attrs[key]);\n\t});\n}\n\nfunction addStyle (obj, options) {\n\tvar style, update, remove, result;\n\n\t// If a transform function was defined, run it on the css\n\tif (options.transform && obj.css) {\n\t result = options.transform(obj.css);\n\n\t if (result) {\n\t \t// If transform returns a value, use that instead of the original css.\n\t \t// This allows running runtime transformations on the css.\n\t \tobj.css = result;\n\t } else {\n\t \t// If the transform function returns a falsy value, don't add this css.\n\t \t// This allows conditional loading of css\n\t \treturn function() {\n\t \t\t// noop\n\t \t};\n\t }\n\t}\n\n\tif (options.singleton) {\n\t\tvar styleIndex = singletonCounter++;\n\n\t\tstyle = singleton || (singleton = createStyleElement(options));\n\n\t\tupdate = applyToSingletonTag.bind(null, style, styleIndex, false);\n\t\tremove = applyToSingletonTag.bind(null, style, styleIndex, true);\n\n\t} else if (\n\t\tobj.sourceMap &&\n\t\ttypeof URL === \"function\" &&\n\t\ttypeof URL.createObjectURL === \"function\" &&\n\t\ttypeof URL.revokeObjectURL === \"function\" &&\n\t\ttypeof Blob === \"function\" &&\n\t\ttypeof btoa === \"function\"\n\t) {\n\t\tstyle = createLinkElement(options);\n\t\tupdate = updateLink.bind(null, style, options);\n\t\tremove = function () {\n\t\t\tremoveStyleElement(style);\n\n\t\t\tif(style.href) URL.revokeObjectURL(style.href);\n\t\t};\n\t} else {\n\t\tstyle = createStyleElement(options);\n\t\tupdate = applyToTag.bind(null, style);\n\t\tremove = function () {\n\t\t\tremoveStyleElement(style);\n\t\t};\n\t}\n\n\tupdate(obj);\n\n\treturn function updateStyle (newObj) {\n\t\tif (newObj) {\n\t\t\tif (\n\t\t\t\tnewObj.css === obj.css &&\n\t\t\t\tnewObj.media === obj.media &&\n\t\t\t\tnewObj.sourceMap === obj.sourceMap\n\t\t\t) {\n\t\t\t\treturn;\n\t\t\t}\n\n\t\t\tupdate(obj = newObj);\n\t\t} else {\n\t\t\tremove();\n\t\t}\n\t};\n}\n\nvar replaceText = (function () {\n\tvar textStore = [];\n\n\treturn function (index, replacement) {\n\t\ttextStore[index] = replacement;\n\n\t\treturn textStore.filter(Boolean).join('\\n');\n\t};\n})();\n\nfunction applyToSingletonTag (style, index, remove, obj) {\n\tvar css = remove ? \"\" : obj.css;\n\n\tif (style.styleSheet) {\n\t\tstyle.styleSheet.cssText = replaceText(index, css);\n\t} else {\n\t\tvar cssNode = document.createTextNode(css);\n\t\tvar childNodes = style.childNodes;\n\n\t\tif (childNodes[index]) style.removeChild(childNodes[index]);\n\n\t\tif (childNodes.length) {\n\t\t\tstyle.insertBefore(cssNode, childNodes[index]);\n\t\t} else {\n\t\t\tstyle.appendChild(cssNode);\n\t\t}\n\t}\n}\n\nfunction applyToTag (style, obj) {\n\tvar css = obj.css;\n\tvar media = obj.media;\n\n\tif(media) {\n\t\tstyle.setAttribute(\"media\", media)\n\t}\n\n\tif(style.styleSheet) {\n\t\tstyle.styleSheet.cssText = css;\n\t} else {\n\t\twhile(style.firstChild) {\n\t\t\tstyle.removeChild(style.firstChild);\n\t\t}\n\n\t\tstyle.appendChild(document.createTextNode(css));\n\t}\n}\n\nfunction updateLink (link, options, obj) {\n\tvar css = obj.css;\n\tvar sourceMap = obj.sourceMap;\n\n\t/*\n\t\tIf convertToAbsoluteUrls isn't defined, but sourcemaps are enabled\n\t\tand there is no publicPath defined then lets turn convertToAbsoluteUrls\n\t\ton by default. Otherwise default to the convertToAbsoluteUrls option\n\t\tdirectly\n\t*/\n\tvar autoFixUrls = options.convertToAbsoluteUrls === undefined && sourceMap;\n\n\tif (options.convertToAbsoluteUrls || autoFixUrls) {\n\t\tcss = fixUrls(css);\n\t}\n\n\tif (sourceMap) {\n\t\t// http://stackoverflow.com/a/26603875\n\t\tcss += \"\\n/*# sourceMappingURL=data:application/json;base64,\" + btoa(unescape(encodeURIComponent(JSON.stringify(sourceMap)))) + \" */\";\n\t}\n\n\tvar blob = new Blob([css], { type: \"text/css\" });\n\n\tvar oldSrc = link.href;\n\n\tlink.href = URL.createObjectURL(blob);\n\n\tif(oldSrc) URL.revokeObjectURL(oldSrc);\n}\n"
},
{
"id": 11,
"identifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/bs-platform/lib/js/block.js",
"name": "./node_modules/bs-platform/lib/js/block.js",
"index": 2,
"index2": 0,
"size": 118,
"cacheable": true,
"built": true,
"optional": false,
"prefetched": false,
"chunks": [
0
],
"assets": [],
"issuer": "/home/x/zzz/github/douglasduteil/RePeople/lib/js/src/app.js",
"issuerId": 39,
"issuerName": "./lib/js/src/app.js",
"failed": false,
"errors": 0,
"warnings": 0,
"reasons": [
{
"moduleId": 8,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/bs-platform/lib/js/caml_obj.js",
"module": "./node_modules/bs-platform/lib/js/caml_obj.js",
"moduleName": "./node_modules/bs-platform/lib/js/caml_obj.js",
"type": "cjs require",
"userRequest": "./block.js",
"loc": "3:30-51"
},
{
"moduleId": 39,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/lib/js/src/app.js",
"module": "./lib/js/src/app.js",
"moduleName": "./lib/js/src/app.js",
"type": "cjs require",
"userRequest": "bs-platform/lib/js/block.js",
"loc": "4:18-56"
},
{
"moduleId": 44,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/bs-platform/lib/js/camlinternalFormatBasics.js",
"module": "./node_modules/bs-platform/lib/js/camlinternalFormatBasics.js",
"moduleName": "./node_modules/bs-platform/lib/js/camlinternalFormatBasics.js",
"type": "cjs require",
"userRequest": "./block.js",
"loc": "3:12-33"
},
{
"moduleId": 54,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/lib/js/src/components/listAll.js",
"module": "./lib/js/src/components/listAll.js",
"moduleName": "./lib/js/src/components/listAll.js",
"type": "cjs require",
"userRequest": "bs-platform/lib/js/block.js",
"loc": "6:18-56"
},
{
"moduleId": 61,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/lib/js/src/components/discover.js",
"module": "./lib/js/src/components/discover.js",
"moduleName": "./lib/js/src/components/discover.js",
"type": "cjs require",
"userRequest": "bs-platform/lib/js/block.js",
"loc": "5:18-56"
}
],
"usedExports": true,
"providedExports": null,
"optimizationBailout": [],
"depth": 2,
"source": "'use strict';\n\n\nfunction __(tag, block) {\n block.tag = tag;\n return block;\n}\n\nexports.__ = __;\n/* No side effect */\n"
},
{
"id": 12,
"identifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/bs-platform/lib/js/caml_array.js",
"name": "./node_modules/bs-platform/lib/js/caml_array.js",
"index": 4,
"index2": 2,
"size": 2275,
"cacheable": true,
"built": true,
"optional": false,
"prefetched": false,
"chunks": [
0
],
"assets": [],
"issuer": "/home/x/zzz/github/douglasduteil/RePeople/lib/js/src/components/discover.js",
"issuerId": 61,
"issuerName": "./lib/js/src/components/discover.js",
"failed": false,
"errors": 0,
"warnings": 0,
"reasons": [
{
"moduleId": 1,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/bs-platform/lib/js/curry.js",
"module": "./node_modules/bs-platform/lib/js/curry.js",
"moduleName": "./node_modules/bs-platform/lib/js/curry.js",
"type": "cjs require",
"userRequest": "./caml_array.js",
"loc": "3:17-43"
},
{
"moduleId": 21,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/bs-platform/lib/js/array.js",
"module": "./node_modules/bs-platform/lib/js/array.js",
"moduleName": "./node_modules/bs-platform/lib/js/array.js",
"type": "cjs require",
"userRequest": "./caml_array.js",
"loc": "5:30-56"
},
{
"moduleId": 61,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/lib/js/src/components/discover.js",
"module": "./lib/js/src/components/discover.js",
"moduleName": "./lib/js/src/components/discover.js",
"type": "cjs require",
"userRequest": "bs-platform/lib/js/caml_array.js",
"loc": "9:18-61"
},
{
"moduleId": 62,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/bs-platform/lib/js/random.js",
"module": "./node_modules/bs-platform/lib/js/random.js",
"moduleName": "./node_modules/bs-platform/lib/js/random.js",
"type": "cjs require",
"userRequest": "./caml_array.js",
"loc": "10:30-56"
},
{
"moduleId": 75,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/reason-react/lib/js/src/reactDOMRe.js",
"module": "./node_modules/reason-react/lib/js/src/reactDOMRe.js",
"moduleName": "./node_modules/reason-react/lib/js/src/reactDOMRe.js",
"type": "cjs require",
"userRequest": "bs-platform/lib/js/caml_array.js",
"loc": "5:30-73"
}
],
"usedExports": true,
"providedExports": null,
"optimizationBailout": [],
"depth": 2,
"source": "'use strict';\n\nvar Caml_builtin_exceptions = require(\"./caml_builtin_exceptions.js\");\n\nfunction caml_array_sub(x, offset, len) {\n var result = new Array(len);\n var j = 0;\n var i = offset;\n while(j < len) {\n result[j] = x[i];\n j = j + 1 | 0;\n i = i + 1 | 0;\n };\n return result;\n}\n\nfunction len(_acc, _l) {\n while(true) {\n var l = _l;\n var acc = _acc;\n if (l) {\n _l = l[1];\n _acc = l[0].length + acc | 0;\n continue ;\n \n } else {\n return acc;\n }\n };\n}\n\nfunction fill(arr, _i, _l) {\n while(true) {\n var l = _l;\n var i = _i;\n if (l) {\n var x = l[0];\n var l$1 = x.length;\n var k = i;\n var j = 0;\n while(j < l$1) {\n arr[k] = x[j];\n k = k + 1 | 0;\n j = j + 1 | 0;\n };\n _l = l[1];\n _i = k;\n continue ;\n \n } else {\n return /* () */0;\n }\n };\n}\n\nfunction caml_array_concat(l) {\n var v = len(0, l);\n var result = new Array(v);\n fill(result, 0, l);\n return result;\n}\n\nfunction caml_array_set(xs, index, newval) {\n if (index < 0 || index >= xs.length) {\n throw [\n Caml_builtin_exceptions.invalid_argument,\n \"index out of bounds\"\n ];\n } else {\n xs[index] = newval;\n return /* () */0;\n }\n}\n\nfunction caml_array_get(xs, index) {\n if (index < 0 || index >= xs.length) {\n throw [\n Caml_builtin_exceptions.invalid_argument,\n \"index out of bounds\"\n ];\n } else {\n return xs[index];\n }\n}\n\nfunction caml_make_vect(len, init) {\n var b = new Array(len);\n for(var i = 0 ,i_finish = len - 1 | 0; i <= i_finish; ++i){\n b[i] = init;\n }\n return b;\n}\n\nfunction caml_array_blit(a1, i1, a2, i2, len) {\n if (i2 <= i1) {\n for(var j = 0 ,j_finish = len - 1 | 0; j <= j_finish; ++j){\n a2[j + i2 | 0] = a1[j + i1 | 0];\n }\n return /* () */0;\n } else {\n for(var j$1 = len - 1 | 0; j$1 >= 0; --j$1){\n a2[j$1 + i2 | 0] = a1[j$1 + i1 | 0];\n }\n return /* () */0;\n }\n}\n\nexports.caml_array_sub = caml_array_sub;\nexports.caml_array_concat = caml_array_concat;\nexports.caml_make_vect = caml_make_vect;\nexports.caml_array_blit = caml_array_blit;\nexports.caml_array_get = caml_array_get;\nexports.caml_array_set = caml_array_set;\n/* No side effect */\n"
},
{
"id": 13,
"identifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/object-assign/index.js",
"name": "./node_modules/object-assign/index.js",
"index": 9,
"index2": 5,
"size": 2108,
"cacheable": true,
"built": true,
"optional": false,
"prefetched": false,
"chunks": [
0
],
"assets": [],
"issuer": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/react/cjs/react.production.min.js",
"issuerId": 40,
"issuerName": "./node_modules/react/cjs/react.production.min.js",
"failed": false,
"errors": 0,
"warnings": 0,
"reasons": [
{
"moduleId": 40,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/react/cjs/react.production.min.js",
"module": "./node_modules/react/cjs/react.production.min.js",
"moduleName": "./node_modules/react/cjs/react.production.min.js",
"type": "cjs require",
"userRequest": "object-assign",
"loc": "10:19-43"
},
{
"moduleId": 41,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/react/cjs/react.development.js",
"module": "./node_modules/react/cjs/react.development.js",
"moduleName": "./node_modules/react/cjs/react.development.js",
"type": "cjs require",
"userRequest": "object-assign",
"loc": "17:21-45"
},
{
"moduleId": 77,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/react-dom/cjs/react-dom.production.min.js",
"module": "./node_modules/react-dom/cjs/react-dom.production.min.js",
"moduleName": "./node_modules/react-dom/cjs/react-dom.production.min.js",
"type": "cjs require",
"userRequest": "object-assign",
"loc": "11:116-140"
},
{
"moduleId": 80,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/react-dom/cjs/react-dom.development.js",
"module": "./node_modules/react-dom/cjs/react-dom.development.js",
"moduleName": "./node_modules/react-dom/cjs/react-dom.development.js",
"type": "cjs require",
"userRequest": "object-assign",
"loc": "20:14-38"
},
{
"moduleId": 88,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/prop-types/factoryWithTypeCheckers.js",
"module": "./node_modules/prop-types/factoryWithTypeCheckers.js",
"moduleName": "./node_modules/prop-types/factoryWithTypeCheckers.js",
"type": "cjs require",
"userRequest": "object-assign",
"loc": "13:13-37"
}
],
"usedExports": true,
"providedExports": null,
"optimizationBailout": [],
"depth": 4,
"source": "/*\nobject-assign\n(c) Sindre Sorhus\n@license MIT\n*/\n\n'use strict';\n/* eslint-disable no-unused-vars */\nvar getOwnPropertySymbols = Object.getOwnPropertySymbols;\nvar hasOwnProperty = Object.prototype.hasOwnProperty;\nvar propIsEnumerable = Object.prototype.propertyIsEnumerable;\n\nfunction toObject(val) {\n\tif (val === null || val === undefined) {\n\t\tthrow new TypeError('Object.assign cannot be called with null or undefined');\n\t}\n\n\treturn Object(val);\n}\n\nfunction shouldUseNative() {\n\ttry {\n\t\tif (!Object.assign) {\n\t\t\treturn false;\n\t\t}\n\n\t\t// Detect buggy property enumeration order in older V8 versions.\n\n\t\t// https://bugs.chromium.org/p/v8/issues/detail?id=4118\n\t\tvar test1 = new String('abc'); // eslint-disable-line no-new-wrappers\n\t\ttest1[5] = 'de';\n\t\tif (Object.getOwnPropertyNames(test1)[0] === '5') {\n\t\t\treturn false;\n\t\t}\n\n\t\t// https://bugs.chromium.org/p/v8/issues/detail?id=3056\n\t\tvar test2 = {};\n\t\tfor (var i = 0; i < 10; i++) {\n\t\t\ttest2['_' + String.fromCharCode(i)] = i;\n\t\t}\n\t\tvar order2 = Object.getOwnPropertyNames(test2).map(function (n) {\n\t\t\treturn test2[n];\n\t\t});\n\t\tif (order2.join('') !== '0123456789') {\n\t\t\treturn false;\n\t\t}\n\n\t\t// https://bugs.chromium.org/p/v8/issues/detail?id=3056\n\t\tvar test3 = {};\n\t\t'abcdefghijklmnopqrst'.split('').forEach(function (letter) {\n\t\t\ttest3[letter] = letter;\n\t\t});\n\t\tif (Object.keys(Object.assign({}, test3)).join('') !==\n\t\t\t\t'abcdefghijklmnopqrst') {\n\t\t\treturn false;\n\t\t}\n\n\t\treturn true;\n\t} catch (err) {\n\t\t// We don't expect any of the above to throw, but better to be safe.\n\t\treturn false;\n\t}\n}\n\nmodule.exports = shouldUseNative() ? Object.assign : function (target, source) {\n\tvar from;\n\tvar to = toObject(target);\n\tvar symbols;\n\n\tfor (var s = 1; s < arguments.length; s++) {\n\t\tfrom = Object(arguments[s]);\n\n\t\tfor (var key in from) {\n\t\t\tif (hasOwnProperty.call(from, key)) {\n\t\t\t\tto[key] = from[key];\n\t\t\t}\n\t\t}\n\n\t\tif (getOwnPropertySymbols) {\n\t\t\tsymbols = getOwnPropertySymbols(from);\n\t\t\tfor (var i = 0; i < symbols.length; i++) {\n\t\t\t\tif (propIsEnumerable.call(from, symbols[i])) {\n\t\t\t\t\tto[symbols[i]] = from[symbols[i]];\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n\n\treturn to;\n};\n"
},
{
"id": 14,
"identifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/bs-platform/lib/js/list.js",
"name": "./node_modules/bs-platform/lib/js/list.js",
"index": 19,
"index2": 27,
"size": 39093,
"cacheable": true,
"built": true,
"optional": false,
"prefetched": false,
"chunks": [
0
],
"assets": [],
"issuer": "/home/x/zzz/github/douglasduteil/RePeople/lib/js/src/components/listAll.js",
"issuerId": 54,
"issuerName": "./lib/js/src/components/listAll.js",
"failed": false,
"errors": 0,
"warnings": 0,
"reasons": [
{
"moduleId": 5,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/reason-react/lib/js/src/reasonReact.js",
"module": "./node_modules/reason-react/lib/js/src/reasonReact.js",
"moduleName": "./node_modules/reason-react/lib/js/src/reasonReact.js",
"type": "cjs require",
"userRequest": "bs-platform/lib/js/list.js",
"loc": "4:38-75"
},
{
"moduleId": 52,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/bs-json/lib/js/src/Json_decode.js",
"module": "./node_modules/bs-json/lib/js/src/Json_decode.js",
"moduleName": "./node_modules/bs-json/lib/js/src/Json_decode.js",
"type": "cjs require",
"userRequest": "bs-platform/lib/js/list.js",
"loc": "3:30-67"
},
{
"moduleId": 54,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/lib/js/src/components/listAll.js",
"module": "./lib/js/src/components/listAll.js",
"moduleName": "./lib/js/src/components/listAll.js",
"type": "cjs require",
"userRequest": "bs-platform/lib/js/list.js",
"loc": "4:18-55"
},
{
"moduleId": 66,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/bs-platform/lib/js/string.js",
"module": "./node_modules/bs-platform/lib/js/string.js",
"moduleName": "./node_modules/bs-platform/lib/js/string.js",
"type": "cjs require",
"userRequest": "./list.js",
"loc": "3:18-38"
},
{
"moduleId": 67,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/bs-platform/lib/js/bytes.js",
"module": "./node_modules/bs-platform/lib/js/bytes.js",
"moduleName": "./node_modules/bs-platform/lib/js/bytes.js",
"type": "cjs require",
"userRequest": "./list.js",
"loc": "4:30-50"
}
],
"usedExports": true,
"providedExports": null,
"optimizationBailout": [],
"depth": 2,
"source": "'use strict';\n\nvar Curry = require(\"./curry.js\");\nvar Caml_obj = require(\"./caml_obj.js\");\nvar Pervasives = require(\"./pervasives.js\");\nvar Caml_builtin_exceptions = require(\"./caml_builtin_exceptions.js\");\n\nfunction length(l) {\n var _len = 0;\n var _param = l;\n while(true) {\n var param = _param;\n var len = _len;\n if (param) {\n _param = param[1];\n _len = len + 1 | 0;\n continue ;\n \n } else {\n return len;\n }\n };\n}\n\nfunction hd(param) {\n if (param) {\n return param[0];\n } else {\n throw [\n Caml_builtin_exceptions.failure,\n \"hd\"\n ];\n }\n}\n\nfunction tl(param) {\n if (param) {\n return param[1];\n } else {\n throw [\n Caml_builtin_exceptions.failure,\n \"tl\"\n ];\n }\n}\n\nfunction nth(l, n) {\n if (n < 0) {\n throw [\n Caml_builtin_exceptions.invalid_argument,\n \"List.nth\"\n ];\n } else {\n var _l = l;\n var _n = n;\n while(true) {\n var n$1 = _n;\n var l$1 = _l;\n if (l$1) {\n if (n$1) {\n _n = n$1 - 1 | 0;\n _l = l$1[1];\n continue ;\n \n } else {\n return l$1[0];\n }\n } else {\n throw [\n Caml_builtin_exceptions.failure,\n \"nth\"\n ];\n }\n };\n }\n}\n\nfunction rev_append(_l1, _l2) {\n while(true) {\n var l2 = _l2;\n var l1 = _l1;\n if (l1) {\n _l2 = /* :: */[\n l1[0],\n l2\n ];\n _l1 = l1[1];\n continue ;\n \n } else {\n return l2;\n }\n };\n}\n\nfunction rev(l) {\n return rev_append(l, /* [] */0);\n}\n\nfunction flatten(param) {\n if (param) {\n return Pervasives.$at(param[0], flatten(param[1]));\n } else {\n return /* [] */0;\n }\n}\n\nfunction map(f, param) {\n if (param) {\n var r = Curry._1(f, param[0]);\n return /* :: */[\n r,\n map(f, param[1])\n ];\n } else {\n return /* [] */0;\n }\n}\n\nfunction mapi(i, f, param) {\n if (param) {\n var r = Curry._2(f, i, param[0]);\n return /* :: */[\n r,\n mapi(i + 1 | 0, f, param[1])\n ];\n } else {\n return /* [] */0;\n }\n}\n\nfunction mapi$1(f, l) {\n return mapi(0, f, l);\n}\n\nfunction rev_map(f, l) {\n var _accu = /* [] */0;\n var _param = l;\n while(true) {\n var param = _param;\n var accu = _accu;\n if (param) {\n _param = param[1];\n _accu = /* :: */[\n Curry._1(f, param[0]),\n accu\n ];\n continue ;\n \n } else {\n return accu;\n }\n };\n}\n\nfunction iter(f, _param) {\n while(true) {\n var param = _param;\n if (param) {\n Curry._1(f, param[0]);\n _param = param[1];\n continue ;\n \n } else {\n return /* () */0;\n }\n };\n}\n\nfunction iteri(f, l) {\n var _i = 0;\n var f$1 = f;\n var _param = l;\n while(true) {\n var param = _param;\n var i = _i;\n if (param) {\n Curry._2(f$1, i, param[0]);\n _param = param[1];\n _i = i + 1 | 0;\n continue ;\n \n } else {\n return /* () */0;\n }\n };\n}\n\nfunction fold_left(f, _accu, _l) {\n while(true) {\n var l = _l;\n var accu = _accu;\n if (l) {\n _l = l[1];\n _accu = Curry._2(f, accu, l[0]);\n continue ;\n \n } else {\n return accu;\n }\n };\n}\n\nfunction fold_right(f, l, accu) {\n if (l) {\n return Curry._2(f, l[0], fold_right(f, l[1], accu));\n } else {\n return accu;\n }\n}\n\nfunction map2(f, l1, l2) {\n if (l1) {\n if (l2) {\n var r = Curry._2(f, l1[0], l2[0]);\n return /* :: */[\n r,\n map2(f, l1[1], l2[1])\n ];\n } else {\n throw [\n Caml_builtin_exceptions.invalid_argument,\n \"List.map2\"\n ];\n }\n } else if (l2) {\n throw [\n Caml_builtin_exceptions.invalid_argument,\n \"List.map2\"\n ];\n } else {\n return /* [] */0;\n }\n}\n\nfunction rev_map2(f, l1, l2) {\n var _accu = /* [] */0;\n var _l1 = l1;\n var _l2 = l2;\n while(true) {\n var l2$1 = _l2;\n var l1$1 = _l1;\n var accu = _accu;\n if (l1$1) {\n if (l2$1) {\n _l2 = l2$1[1];\n _l1 = l1$1[1];\n _accu = /* :: */[\n Curry._2(f, l1$1[0], l2$1[0]),\n accu\n ];\n continue ;\n \n } else {\n throw [\n Caml_builtin_exceptions.invalid_argument,\n \"List.rev_map2\"\n ];\n }\n } else if (l2$1) {\n throw [\n Caml_builtin_exceptions.invalid_argument,\n \"List.rev_map2\"\n ];\n } else {\n return accu;\n }\n };\n}\n\nfunction iter2(f, _l1, _l2) {\n while(true) {\n var l2 = _l2;\n var l1 = _l1;\n if (l1) {\n if (l2) {\n Curry._2(f, l1[0], l2[0]);\n _l2 = l2[1];\n _l1 = l1[1];\n continue ;\n \n } else {\n throw [\n Caml_builtin_exceptions.invalid_argument,\n \"List.iter2\"\n ];\n }\n } else if (l2) {\n throw [\n Caml_builtin_exceptions.invalid_argument,\n \"List.iter2\"\n ];\n } else {\n return /* () */0;\n }\n };\n}\n\nfunction fold_left2(f, _accu, _l1, _l2) {\n while(true) {\n var l2 = _l2;\n var l1 = _l1;\n var accu = _accu;\n if (l1) {\n if (l2) {\n _l2 = l2[1];\n _l1 = l1[1];\n _accu = Curry._3(f, accu, l1[0], l2[0]);\n continue ;\n \n } else {\n throw [\n Caml_builtin_exceptions.invalid_argument,\n \"List.fold_left2\"\n ];\n }\n } else if (l2) {\n throw [\n Caml_builtin_exceptions.invalid_argument,\n \"List.fold_left2\"\n ];\n } else {\n return accu;\n }\n };\n}\n\nfunction fold_right2(f, l1, l2, accu) {\n if (l1) {\n if (l2) {\n return Curry._3(f, l1[0], l2[0], fold_right2(f, l1[1], l2[1], accu));\n } else {\n throw [\n Caml_builtin_exceptions.invalid_argument,\n \"List.fold_right2\"\n ];\n }\n } else if (l2) {\n throw [\n Caml_builtin_exceptions.invalid_argument,\n \"List.fold_right2\"\n ];\n } else {\n return accu;\n }\n}\n\nfunction for_all(p, _param) {\n while(true) {\n var param = _param;\n if (param) {\n if (Curry._1(p, param[0])) {\n _param = param[1];\n continue ;\n \n } else {\n return /* false */0;\n }\n } else {\n return /* true */1;\n }\n };\n}\n\nfunction exists(p, _param) {\n while(true) {\n var param = _param;\n if (param) {\n if (Curry._1(p, param[0])) {\n return /* true */1;\n } else {\n _param = param[1];\n continue ;\n \n }\n } else {\n return /* false */0;\n }\n };\n}\n\nfunction for_all2(p, _l1, _l2) {\n while(true) {\n var l2 = _l2;\n var l1 = _l1;\n if (l1) {\n if (l2) {\n if (Curry._2(p, l1[0], l2[0])) {\n _l2 = l2[1];\n _l1 = l1[1];\n continue ;\n \n } else {\n return /* false */0;\n }\n } else {\n throw [\n Caml_builtin_exceptions.invalid_argument,\n \"List.for_all2\"\n ];\n }\n } else if (l2) {\n throw [\n Caml_builtin_exceptions.invalid_argument,\n \"List.for_all2\"\n ];\n } else {\n return /* true */1;\n }\n };\n}\n\nfunction exists2(p, _l1, _l2) {\n while(true) {\n var l2 = _l2;\n var l1 = _l1;\n if (l1) {\n if (l2) {\n if (Curry._2(p, l1[0], l2[0])) {\n return /* true */1;\n } else {\n _l2 = l2[1];\n _l1 = l1[1];\n continue ;\n \n }\n } else {\n throw [\n Caml_builtin_exceptions.invalid_argument,\n \"List.exists2\"\n ];\n }\n } else if (l2) {\n throw [\n Caml_builtin_exceptions.invalid_argument,\n \"List.exists2\"\n ];\n } else {\n return /* false */0;\n }\n };\n}\n\nfunction mem(x, _param) {\n while(true) {\n var param = _param;\n if (param) {\n if (Caml_obj.caml_compare(param[0], x)) {\n _param = param[1];\n continue ;\n \n } else {\n return /* true */1;\n }\n } else {\n return /* false */0;\n }\n };\n}\n\nfunction memq(x, _param) {\n while(true) {\n var param = _param;\n if (param) {\n if (param[0] === x) {\n return /* true */1;\n } else {\n _param = param[1];\n continue ;\n \n }\n } else {\n return /* false */0;\n }\n };\n}\n\nfunction assoc(x, _param) {\n while(true) {\n var param = _param;\n if (param) {\n var match = param[0];\n if (Caml_obj.caml_compare(match[0], x)) {\n _param = param[1];\n continue ;\n \n } else {\n return match[1];\n }\n } else {\n throw Caml_builtin_exceptions.not_found;\n }\n };\n}\n\nfunction assq(x, _param) {\n while(true) {\n var param = _param;\n if (param) {\n var match = param[0];\n if (match[0] === x) {\n return match[1];\n } else {\n _param = param[1];\n continue ;\n \n }\n } else {\n throw Caml_builtin_exceptions.not_found;\n }\n };\n}\n\nfunction mem_assoc(x, _param) {\n while(true) {\n var param = _param;\n if (param) {\n if (Caml_obj.caml_compare(param[0][0], x)) {\n _param = param[1];\n continue ;\n \n } else {\n return /* true */1;\n }\n } else {\n return /* false */0;\n }\n };\n}\n\nfunction mem_assq(x, _param) {\n while(true) {\n var param = _param;\n if (param) {\n if (param[0][0] === x) {\n return /* true */1;\n } else {\n _param = param[1];\n continue ;\n \n }\n } else {\n return /* false */0;\n }\n };\n}\n\nfunction remove_assoc(x, param) {\n if (param) {\n var l = param[1];\n var pair = param[0];\n if (Caml_obj.caml_compare(pair[0], x)) {\n return /* :: */[\n pair,\n remove_assoc(x, l)\n ];\n } else {\n return l;\n }\n } else {\n return /* [] */0;\n }\n}\n\nfunction remove_assq(x, param) {\n if (param) {\n var l = param[1];\n var pair = param[0];\n if (pair[0] === x) {\n return l;\n } else {\n return /* :: */[\n pair,\n remove_assq(x, l)\n ];\n }\n } else {\n return /* [] */0;\n }\n}\n\nfunction find(p, _param) {\n while(true) {\n var param = _param;\n if (param) {\n var x = param[0];\n if (Curry._1(p, x)) {\n return x;\n } else {\n _param = param[1];\n continue ;\n \n }\n } else {\n throw Caml_builtin_exceptions.not_found;\n }\n };\n}\n\nfunction find_all(p) {\n return (function (param) {\n var _accu = /* [] */0;\n var _param = param;\n while(true) {\n var param$1 = _param;\n var accu = _accu;\n if (param$1) {\n var l = param$1[1];\n var x = param$1[0];\n if (Curry._1(p, x)) {\n _param = l;\n _accu = /* :: */[\n x,\n accu\n ];\n continue ;\n \n } else {\n _param = l;\n continue ;\n \n }\n } else {\n return rev_append(accu, /* [] */0);\n }\n };\n });\n}\n\nfunction partition(p, l) {\n var _yes = /* [] */0;\n var _no = /* [] */0;\n var _param = l;\n while(true) {\n var param = _param;\n var no = _no;\n var yes = _yes;\n if (param) {\n var l$1 = param[1];\n var x = param[0];\n if (Curry._1(p, x)) {\n _param = l$1;\n _yes = /* :: */[\n x,\n yes\n ];\n continue ;\n \n } else {\n _param = l$1;\n _no = /* :: */[\n x,\n no\n ];\n continue ;\n \n }\n } else {\n return /* tuple */[\n rev_append(yes, /* [] */0),\n rev_append(no, /* [] */0)\n ];\n }\n };\n}\n\nfunction split(param) {\n if (param) {\n var match = param[0];\n var match$1 = split(param[1]);\n return /* tuple */[\n /* :: */[\n match[0],\n match$1[0]\n ],\n /* :: */[\n match[1],\n match$1[1]\n ]\n ];\n } else {\n return /* tuple */[\n /* [] */0,\n /* [] */0\n ];\n }\n}\n\nfunction combine(l1, l2) {\n if (l1) {\n if (l2) {\n return /* :: */[\n /* tuple */[\n l1[0],\n l2[0]\n ],\n combine(l1[1], l2[1])\n ];\n } else {\n throw [\n Caml_builtin_exceptions.invalid_argument,\n \"List.combine\"\n ];\n }\n } else if (l2) {\n throw [\n Caml_builtin_exceptions.invalid_argument,\n \"List.combine\"\n ];\n } else {\n return /* [] */0;\n }\n}\n\nfunction merge(cmp, l1, l2) {\n if (l1) {\n if (l2) {\n var h2 = l2[0];\n var h1 = l1[0];\n if (Curry._2(cmp, h1, h2) <= 0) {\n return /* :: */[\n h1,\n merge(cmp, l1[1], l2)\n ];\n } else {\n return /* :: */[\n h2,\n merge(cmp, l1, l2[1])\n ];\n }\n } else {\n return l1;\n }\n } else {\n return l2;\n }\n}\n\nfunction chop(_k, _l) {\n while(true) {\n var l = _l;\n var k = _k;\n if (k) {\n if (l) {\n _l = l[1];\n _k = k - 1 | 0;\n continue ;\n \n } else {\n throw [\n Caml_builtin_exceptions.assert_failure,\n [\n \"list.ml\",\n 223,\n 11\n ]\n ];\n }\n } else {\n return l;\n }\n };\n}\n\nfunction stable_sort(cmp, l) {\n var sort = function (n, l) {\n var exit = 0;\n if (n !== 2) {\n if (n !== 3) {\n exit = 1;\n } else if (l) {\n var match = l[1];\n if (match) {\n var match$1 = match[1];\n if (match$1) {\n var x3 = match$1[0];\n var x2 = match[0];\n var x1 = l[0];\n if (Curry._2(cmp, x1, x2) <= 0) {\n if (Curry._2(cmp, x2, x3) <= 0) {\n return /* :: */[\n x1,\n /* :: */[\n x2,\n /* :: */[\n x3,\n /* [] */0\n ]\n ]\n ];\n } else if (Curry._2(cmp, x1, x3) <= 0) {\n return /* :: */[\n x1,\n /* :: */[\n x3,\n /* :: */[\n x2,\n /* [] */0\n ]\n ]\n ];\n } else {\n return /* :: */[\n x3,\n /* :: */[\n x1,\n /* :: */[\n x2,\n /* [] */0\n ]\n ]\n ];\n }\n } else if (Curry._2(cmp, x1, x3) <= 0) {\n return /* :: */[\n x2,\n /* :: */[\n x1,\n /* :: */[\n x3,\n /* [] */0\n ]\n ]\n ];\n } else if (Curry._2(cmp, x2, x3) <= 0) {\n return /* :: */[\n x2,\n /* :: */[\n x3,\n /* :: */[\n x1,\n /* [] */0\n ]\n ]\n ];\n } else {\n return /* :: */[\n x3,\n /* :: */[\n x2,\n /* :: */[\n x1,\n /* [] */0\n ]\n ]\n ];\n }\n } else {\n exit = 1;\n }\n } else {\n exit = 1;\n }\n } else {\n exit = 1;\n }\n } else if (l) {\n var match$2 = l[1];\n if (match$2) {\n var x2$1 = match$2[0];\n var x1$1 = l[0];\n if (Curry._2(cmp, x1$1, x2$1) <= 0) {\n return /* :: */[\n x1$1,\n /* :: */[\n x2$1,\n /* [] */0\n ]\n ];\n } else {\n return /* :: */[\n x2$1,\n /* :: */[\n x1$1,\n /* [] */0\n ]\n ];\n }\n } else {\n exit = 1;\n }\n } else {\n exit = 1;\n }\n if (exit === 1) {\n var n1 = (n >> 1);\n var n2 = n - n1 | 0;\n var l2 = chop(n1, l);\n var s1 = rev_sort(n1, l);\n var s2 = rev_sort(n2, l2);\n var _l1 = s1;\n var _l2 = s2;\n var _accu = /* [] */0;\n while(true) {\n var accu = _accu;\n var l2$1 = _l2;\n var l1 = _l1;\n if (l1) {\n if (l2$1) {\n var h2 = l2$1[0];\n var h1 = l1[0];\n if (Curry._2(cmp, h1, h2) > 0) {\n _accu = /* :: */[\n h1,\n accu\n ];\n _l1 = l1[1];\n continue ;\n \n } else {\n _accu = /* :: */[\n h2,\n accu\n ];\n _l2 = l2$1[1];\n continue ;\n \n }\n } else {\n return rev_append(l1, accu);\n }\n } else {\n return rev_append(l2$1, accu);\n }\n };\n }\n \n };\n var rev_sort = function (n, l) {\n var exit = 0;\n if (n !== 2) {\n if (n !== 3) {\n exit = 1;\n } else if (l) {\n var match = l[1];\n if (match) {\n var match$1 = match[1];\n if (match$1) {\n var x3 = match$1[0];\n var x2 = match[0];\n var x1 = l[0];\n if (Curry._2(cmp, x1, x2) > 0) {\n if (Curry._2(cmp, x2, x3) > 0) {\n return /* :: */[\n x1,\n /* :: */[\n x2,\n /* :: */[\n x3,\n /* [] */0\n ]\n ]\n ];\n } else if (Curry._2(cmp, x1, x3) > 0) {\n return /* :: */[\n x1,\n /* :: */[\n x3,\n /* :: */[\n x2,\n /* [] */0\n ]\n ]\n ];\n } else {\n return /* :: */[\n x3,\n /* :: */[\n x1,\n /* :: */[\n x2,\n /* [] */0\n ]\n ]\n ];\n }\n } else if (Curry._2(cmp, x1, x3) > 0) {\n return /* :: */[\n x2,\n /* :: */[\n x1,\n /* :: */[\n x3,\n /* [] */0\n ]\n ]\n ];\n } else if (Curry._2(cmp, x2, x3) > 0) {\n return /* :: */[\n x2,\n /* :: */[\n x3,\n /* :: */[\n x1,\n /* [] */0\n ]\n ]\n ];\n } else {\n return /* :: */[\n x3,\n /* :: */[\n x2,\n /* :: */[\n x1,\n /* [] */0\n ]\n ]\n ];\n }\n } else {\n exit = 1;\n }\n } else {\n exit = 1;\n }\n } else {\n exit = 1;\n }\n } else if (l) {\n var match$2 = l[1];\n if (match$2) {\n var x2$1 = match$2[0];\n var x1$1 = l[0];\n if (Curry._2(cmp, x1$1, x2$1) > 0) {\n return /* :: */[\n x1$1,\n /* :: */[\n x2$1,\n /* [] */0\n ]\n ];\n } else {\n return /* :: */[\n x2$1,\n /* :: */[\n x1$1,\n /* [] */0\n ]\n ];\n }\n } else {\n exit = 1;\n }\n } else {\n exit = 1;\n }\n if (exit === 1) {\n var n1 = (n >> 1);\n var n2 = n - n1 | 0;\n var l2 = chop(n1, l);\n var s1 = sort(n1, l);\n var s2 = sort(n2, l2);\n var _l1 = s1;\n var _l2 = s2;\n var _accu = /* [] */0;\n while(true) {\n var accu = _accu;\n var l2$1 = _l2;\n var l1 = _l1;\n if (l1) {\n if (l2$1) {\n var h2 = l2$1[0];\n var h1 = l1[0];\n if (Curry._2(cmp, h1, h2) <= 0) {\n _accu = /* :: */[\n h1,\n accu\n ];\n _l1 = l1[1];\n continue ;\n \n } else {\n _accu = /* :: */[\n h2,\n accu\n ];\n _l2 = l2$1[1];\n continue ;\n \n }\n } else {\n return rev_append(l1, accu);\n }\n } else {\n return rev_append(l2$1, accu);\n }\n };\n }\n \n };\n var len = length(l);\n if (len < 2) {\n return l;\n } else {\n return sort(len, l);\n }\n}\n\nfunction sort_uniq(cmp, l) {\n var sort = function (n, l) {\n var exit = 0;\n if (n !== 2) {\n if (n !== 3) {\n exit = 1;\n } else if (l) {\n var match = l[1];\n if (match) {\n var match$1 = match[1];\n if (match$1) {\n var x3 = match$1[0];\n var x2 = match[0];\n var x1 = l[0];\n var c = Curry._2(cmp, x1, x2);\n if (c) {\n if (c < 0) {\n var c$1 = Curry._2(cmp, x2, x3);\n if (c$1) {\n if (c$1 < 0) {\n return /* :: */[\n x1,\n /* :: */[\n x2,\n /* :: */[\n x3,\n /* [] */0\n ]\n ]\n ];\n } else {\n var c$2 = Curry._2(cmp, x1, x3);\n if (c$2) {\n if (c$2 < 0) {\n return /* :: */[\n x1,\n /* :: */[\n x3,\n /* :: */[\n x2,\n /* [] */0\n ]\n ]\n ];\n } else {\n return /* :: */[\n x3,\n /* :: */[\n x1,\n /* :: */[\n x2,\n /* [] */0\n ]\n ]\n ];\n }\n } else {\n return /* :: */[\n x1,\n /* :: */[\n x2,\n /* [] */0\n ]\n ];\n }\n }\n } else {\n return /* :: */[\n x1,\n /* :: */[\n x2,\n /* [] */0\n ]\n ];\n }\n } else {\n var c$3 = Curry._2(cmp, x1, x3);\n if (c$3) {\n if (c$3 < 0) {\n return /* :: */[\n x2,\n /* :: */[\n x1,\n /* :: */[\n x3,\n /* [] */0\n ]\n ]\n ];\n } else {\n var c$4 = Curry._2(cmp, x2, x3);\n if (c$4) {\n if (c$4 < 0) {\n return /* :: */[\n x2,\n /* :: */[\n x3,\n /* :: */[\n x1,\n /* [] */0\n ]\n ]\n ];\n } else {\n return /* :: */[\n x3,\n /* :: */[\n x2,\n /* :: */[\n x1,\n /* [] */0\n ]\n ]\n ];\n }\n } else {\n return /* :: */[\n x2,\n /* :: */[\n x1,\n /* [] */0\n ]\n ];\n }\n }\n } else {\n return /* :: */[\n x2,\n /* :: */[\n x1,\n /* [] */0\n ]\n ];\n }\n }\n } else {\n var c$5 = Curry._2(cmp, x2, x3);\n if (c$5) {\n if (c$5 < 0) {\n return /* :: */[\n x2,\n /* :: */[\n x3,\n /* [] */0\n ]\n ];\n } else {\n return /* :: */[\n x3,\n /* :: */[\n x2,\n /* [] */0\n ]\n ];\n }\n } else {\n return /* :: */[\n x2,\n /* [] */0\n ];\n }\n }\n } else {\n exit = 1;\n }\n } else {\n exit = 1;\n }\n } else {\n exit = 1;\n }\n } else if (l) {\n var match$2 = l[1];\n if (match$2) {\n var x2$1 = match$2[0];\n var x1$1 = l[0];\n var c$6 = Curry._2(cmp, x1$1, x2$1);\n if (c$6) {\n if (c$6 < 0) {\n return /* :: */[\n x1$1,\n /* :: */[\n x2$1,\n /* [] */0\n ]\n ];\n } else {\n return /* :: */[\n x2$1,\n /* :: */[\n x1$1,\n /* [] */0\n ]\n ];\n }\n } else {\n return /* :: */[\n x1$1,\n /* [] */0\n ];\n }\n } else {\n exit = 1;\n }\n } else {\n exit = 1;\n }\n if (exit === 1) {\n var n1 = (n >> 1);\n var n2 = n - n1 | 0;\n var l2 = chop(n1, l);\n var s1 = rev_sort(n1, l);\n var s2 = rev_sort(n2, l2);\n var _l1 = s1;\n var _l2 = s2;\n var _accu = /* [] */0;\n while(true) {\n var accu = _accu;\n var l2$1 = _l2;\n var l1 = _l1;\n if (l1) {\n if (l2$1) {\n var t2 = l2$1[1];\n var h2 = l2$1[0];\n var t1 = l1[1];\n var h1 = l1[0];\n var c$7 = Curry._2(cmp, h1, h2);\n if (c$7) {\n if (c$7 > 0) {\n _accu = /* :: */[\n h1,\n accu\n ];\n _l1 = t1;\n continue ;\n \n } else {\n _accu = /* :: */[\n h2,\n accu\n ];\n _l2 = t2;\n continue ;\n \n }\n } else {\n _accu = /* :: */[\n h1,\n accu\n ];\n _l2 = t2;\n _l1 = t1;\n continue ;\n \n }\n } else {\n return rev_append(l1, accu);\n }\n } else {\n return rev_append(l2$1, accu);\n }\n };\n }\n \n };\n var rev_sort = function (n, l) {\n var exit = 0;\n if (n !== 2) {\n if (n !== 3) {\n exit = 1;\n } else if (l) {\n var match = l[1];\n if (match) {\n var match$1 = match[1];\n if (match$1) {\n var x3 = match$1[0];\n var x2 = match[0];\n var x1 = l[0];\n var c = Curry._2(cmp, x1, x2);\n if (c) {\n if (c > 0) {\n var c$1 = Curry._2(cmp, x2, x3);\n if (c$1) {\n if (c$1 > 0) {\n return /* :: */[\n x1,\n /* :: */[\n x2,\n /* :: */[\n x3,\n /* [] */0\n ]\n ]\n ];\n } else {\n var c$2 = Curry._2(cmp, x1, x3);\n if (c$2) {\n if (c$2 > 0) {\n return /* :: */[\n x1,\n /* :: */[\n x3,\n /* :: */[\n x2,\n /* [] */0\n ]\n ]\n ];\n } else {\n return /* :: */[\n x3,\n /* :: */[\n x1,\n /* :: */[\n x2,\n /* [] */0\n ]\n ]\n ];\n }\n } else {\n return /* :: */[\n x1,\n /* :: */[\n x2,\n /* [] */0\n ]\n ];\n }\n }\n } else {\n return /* :: */[\n x1,\n /* :: */[\n x2,\n /* [] */0\n ]\n ];\n }\n } else {\n var c$3 = Curry._2(cmp, x1, x3);\n if (c$3) {\n if (c$3 > 0) {\n return /* :: */[\n x2,\n /* :: */[\n x1,\n /* :: */[\n x3,\n /* [] */0\n ]\n ]\n ];\n } else {\n var c$4 = Curry._2(cmp, x2, x3);\n if (c$4) {\n if (c$4 > 0) {\n return /* :: */[\n x2,\n /* :: */[\n x3,\n /* :: */[\n x1,\n /* [] */0\n ]\n ]\n ];\n } else {\n return /* :: */[\n x3,\n /* :: */[\n x2,\n /* :: */[\n x1,\n /* [] */0\n ]\n ]\n ];\n }\n } else {\n return /* :: */[\n x2,\n /* :: */[\n x1,\n /* [] */0\n ]\n ];\n }\n }\n } else {\n return /* :: */[\n x2,\n /* :: */[\n x1,\n /* [] */0\n ]\n ];\n }\n }\n } else {\n var c$5 = Curry._2(cmp, x2, x3);\n if (c$5) {\n if (c$5 > 0) {\n return /* :: */[\n x2,\n /* :: */[\n x3,\n /* [] */0\n ]\n ];\n } else {\n return /* :: */[\n x3,\n /* :: */[\n x2,\n /* [] */0\n ]\n ];\n }\n } else {\n return /* :: */[\n x2,\n /* [] */0\n ];\n }\n }\n } else {\n exit = 1;\n }\n } else {\n exit = 1;\n }\n } else {\n exit = 1;\n }\n } else if (l) {\n var match$2 = l[1];\n if (match$2) {\n var x2$1 = match$2[0];\n var x1$1 = l[0];\n var c$6 = Curry._2(cmp, x1$1, x2$1);\n if (c$6) {\n if (c$6 > 0) {\n return /* :: */[\n x1$1,\n /* :: */[\n x2$1,\n /* [] */0\n ]\n ];\n } else {\n return /* :: */[\n x2$1,\n /* :: */[\n x1$1,\n /* [] */0\n ]\n ];\n }\n } else {\n return /* :: */[\n x1$1,\n /* [] */0\n ];\n }\n } else {\n exit = 1;\n }\n } else {\n exit = 1;\n }\n if (exit === 1) {\n var n1 = (n >> 1);\n var n2 = n - n1 | 0;\n var l2 = chop(n1, l);\n var s1 = sort(n1, l);\n var s2 = sort(n2, l2);\n var _l1 = s1;\n var _l2 = s2;\n var _accu = /* [] */0;\n while(true) {\n var accu = _accu;\n var l2$1 = _l2;\n var l1 = _l1;\n if (l1) {\n if (l2$1) {\n var t2 = l2$1[1];\n var h2 = l2$1[0];\n var t1 = l1[1];\n var h1 = l1[0];\n var c$7 = Curry._2(cmp, h1, h2);\n if (c$7) {\n if (c$7 < 0) {\n _accu = /* :: */[\n h1,\n accu\n ];\n _l1 = t1;\n continue ;\n \n } else {\n _accu = /* :: */[\n h2,\n accu\n ];\n _l2 = t2;\n continue ;\n \n }\n } else {\n _accu = /* :: */[\n h1,\n accu\n ];\n _l2 = t2;\n _l1 = t1;\n continue ;\n \n }\n } else {\n return rev_append(l1, accu);\n }\n } else {\n return rev_append(l2$1, accu);\n }\n };\n }\n \n };\n var len = length(l);\n if (len < 2) {\n return l;\n } else {\n return sort(len, l);\n }\n}\n\nvar append = Pervasives.$at;\n\nvar concat = flatten;\n\nvar filter = find_all;\n\nvar sort = stable_sort;\n\nvar fast_sort = stable_sort;\n\nexports.length = length;\nexports.hd = hd;\nexports.tl = tl;\nexports.nth = nth;\nexports.rev = rev;\nexports.append = append;\nexports.rev_append = rev_append;\nexports.concat = concat;\nexports.flatten = flatten;\nexports.iter = iter;\nexports.iteri = iteri;\nexports.map = map;\nexports.mapi = mapi$1;\nexports.rev_map = rev_map;\nexports.fold_left = fold_left;\nexports.fold_right = fold_right;\nexports.iter2 = iter2;\nexports.map2 = map2;\nexports.rev_map2 = rev_map2;\nexports.fold_left2 = fold_left2;\nexports.fold_right2 = fold_right2;\nexports.for_all = for_all;\nexports.exists = exists;\nexports.for_all2 = for_all2;\nexports.exists2 = exists2;\nexports.mem = mem;\nexports.memq = memq;\nexports.find = find;\nexports.filter = filter;\nexports.find_all = find_all;\nexports.partition = partition;\nexports.assoc = assoc;\nexports.assq = assq;\nexports.mem_assoc = mem_assoc;\nexports.mem_assq = mem_assq;\nexports.remove_assoc = remove_assoc;\nexports.remove_assq = remove_assq;\nexports.split = split;\nexports.combine = combine;\nexports.sort = sort;\nexports.stable_sort = stable_sort;\nexports.fast_sort = fast_sort;\nexports.sort_uniq = sort_uniq;\nexports.merge = merge;\n/* No side effect */\n"
},
{
"id": 15,
"identifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/bs-platform/lib/js/pervasives.js",
"name": "./node_modules/bs-platform/lib/js/pervasives.js",
"index": 21,
"index2": 26,
"size": 18042,
"cacheable": true,
"built": true,
"optional": false,
"prefetched": false,
"chunks": [
0
],
"assets": [],
"issuer": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/bs-platform/lib/js/list.js",
"issuerId": 14,
"issuerName": "./node_modules/bs-platform/lib/js/list.js",
"failed": false,
"errors": 0,
"warnings": 0,
"reasons": [
{
"moduleId": 14,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/bs-platform/lib/js/list.js",
"module": "./node_modules/bs-platform/lib/js/list.js",
"moduleName": "./node_modules/bs-platform/lib/js/list.js",
"type": "cjs require",
"userRequest": "./pervasives.js",
"loc": "5:30-56"
},
{
"moduleId": 53,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/bs-platform/lib/js/js_math.js",
"module": "./node_modules/bs-platform/lib/js/js_math.js",
"moduleName": "./node_modules/bs-platform/lib/js/js_math.js",
"type": "cjs require",
"userRequest": "./pervasives.js",
"loc": "3:17-43"
},
{
"moduleId": 62,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/bs-platform/lib/js/random.js",
"module": "./node_modules/bs-platform/lib/js/random.js",
"moduleName": "./node_modules/bs-platform/lib/js/random.js",
"type": "cjs require",
"userRequest": "./pervasives.js",
"loc": "12:30-56"
},
{
"moduleId": 65,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/bs-platform/lib/js/digest.js",
"module": "./node_modules/bs-platform/lib/js/digest.js",
"moduleName": "./node_modules/bs-platform/lib/js/digest.js",
"type": "cjs require",
"userRequest": "./pervasives.js",
"loc": "6:30-56"
},
{
"moduleId": 67,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/bs-platform/lib/js/bytes.js",
"module": "./node_modules/bs-platform/lib/js/bytes.js",
"moduleName": "./node_modules/bs-platform/lib/js/bytes.js",
"type": "cjs require",
"userRequest": "./pervasives.js",
"loc": "8:30-56"
}
],
"usedExports": true,
"providedExports": null,
"optimizationBailout": [],
"depth": 3,
"source": "'use strict';\n\nvar Curry = require(\"./curry.js\");\nvar Caml_io = require(\"./caml_io.js\");\nvar Caml_obj = require(\"./caml_obj.js\");\nvar Caml_sys = require(\"./caml_sys.js\");\nvar Caml_format = require(\"./caml_format.js\");\nvar Caml_string = require(\"./caml_string.js\");\nvar Caml_exceptions = require(\"./caml_exceptions.js\");\nvar Caml_missing_polyfill = require(\"./caml_missing_polyfill.js\");\nvar Caml_builtin_exceptions = require(\"./caml_builtin_exceptions.js\");\nvar CamlinternalFormatBasics = require(\"./camlinternalFormatBasics.js\");\n\nfunction failwith(s) {\n throw [\n Caml_builtin_exceptions.failure,\n s\n ];\n}\n\nfunction invalid_arg(s) {\n throw [\n Caml_builtin_exceptions.invalid_argument,\n s\n ];\n}\n\nvar Exit = Caml_exceptions.create(\"Pervasives.Exit\");\n\nfunction min(x, y) {\n if (Caml_obj.caml_lessequal(x, y)) {\n return x;\n } else {\n return y;\n }\n}\n\nfunction max(x, y) {\n if (Caml_obj.caml_greaterequal(x, y)) {\n return x;\n } else {\n return y;\n }\n}\n\nfunction abs(x) {\n if (x >= 0) {\n return x;\n } else {\n return -x | 0;\n }\n}\n\nfunction lnot(x) {\n return x ^ -1;\n}\n\nvar min_int = -2147483648;\n\nfunction $caret(a, b) {\n return a + b;\n}\n\nfunction char_of_int(n) {\n if (n < 0 || n > 255) {\n throw [\n Caml_builtin_exceptions.invalid_argument,\n \"char_of_int\"\n ];\n } else {\n return n;\n }\n}\n\nfunction string_of_bool(b) {\n if (b) {\n return \"true\";\n } else {\n return \"false\";\n }\n}\n\nfunction bool_of_string(param) {\n switch (param) {\n case \"false\" : \n return /* false */0;\n case \"true\" : \n return /* true */1;\n default:\n throw [\n Caml_builtin_exceptions.invalid_argument,\n \"bool_of_string\"\n ];\n }\n}\n\nfunction string_of_int(param) {\n return \"\" + param;\n}\n\nfunction valid_float_lexem(s) {\n var l = s.length;\n var _i = 0;\n while(true) {\n var i = _i;\n if (i >= l) {\n return $caret(s, \".\");\n } else {\n var match = Caml_string.get(s, i);\n if (match >= 48) {\n if (match >= 58) {\n return s;\n } else {\n _i = i + 1 | 0;\n continue ;\n \n }\n } else if (match !== 45) {\n return s;\n } else {\n _i = i + 1 | 0;\n continue ;\n \n }\n }\n };\n}\n\nfunction string_of_float(f) {\n return valid_float_lexem(Caml_format.caml_format_float(\"%.12g\", f));\n}\n\nfunction $at(l1, l2) {\n if (l1) {\n return /* :: */[\n l1[0],\n $at(l1[1], l2)\n ];\n } else {\n return l2;\n }\n}\n\nvar stdin = Caml_io.stdin;\n\nvar stdout = Caml_io.stdout;\n\nvar stderr = Caml_io.stderr;\n\nfunction open_out_gen(_, _$1, _$2) {\n return Caml_io.caml_ml_open_descriptor_out(Caml_missing_polyfill.not_implemented(\"caml_sys_open not implemented by bucklescript yet\\n\"));\n}\n\nfunction open_out(name) {\n return open_out_gen(/* :: */[\n /* Open_wronly */1,\n /* :: */[\n /* Open_creat */3,\n /* :: */[\n /* Open_trunc */4,\n /* :: */[\n /* Open_text */7,\n /* [] */0\n ]\n ]\n ]\n ], 438, name);\n}\n\nfunction open_out_bin(name) {\n return open_out_gen(/* :: */[\n /* Open_wronly */1,\n /* :: */[\n /* Open_creat */3,\n /* :: */[\n /* Open_trunc */4,\n /* :: */[\n /* Open_binary */6,\n /* [] */0\n ]\n ]\n ]\n ], 438, name);\n}\n\nfunction flush_all() {\n var _param = Caml_io.caml_ml_out_channels_list(/* () */0);\n while(true) {\n var param = _param;\n if (param) {\n try {\n Caml_io.caml_ml_flush(param[0]);\n }\n catch (exn){\n \n }\n _param = param[1];\n continue ;\n \n } else {\n return /* () */0;\n }\n };\n}\n\nfunction output_bytes(oc, s) {\n return Caml_io.caml_ml_output(oc, s, 0, s.length);\n}\n\nfunction output_string(oc, s) {\n return Caml_io.caml_ml_output(oc, s, 0, s.length);\n}\n\nfunction output(oc, s, ofs, len) {\n if (ofs < 0 || len < 0 || ofs > (s.length - len | 0)) {\n throw [\n Caml_builtin_exceptions.invalid_argument,\n \"output\"\n ];\n } else {\n return Caml_io.caml_ml_output(oc, s, ofs, len);\n }\n}\n\nfunction output_substring(oc, s, ofs, len) {\n if (ofs < 0 || len < 0 || ofs > (s.length - len | 0)) {\n throw [\n Caml_builtin_exceptions.invalid_argument,\n \"output_substring\"\n ];\n } else {\n return Caml_io.caml_ml_output(oc, s, ofs, len);\n }\n}\n\nfunction output_value(_, _$1) {\n return Caml_missing_polyfill.not_implemented(\"caml_output_value not implemented by bucklescript yet\\n\");\n}\n\nfunction close_out(oc) {\n Caml_io.caml_ml_flush(oc);\n return Caml_missing_polyfill.not_implemented(\"caml_ml_close_channel not implemented by bucklescript yet\\n\");\n}\n\nfunction close_out_noerr(oc) {\n try {\n Caml_io.caml_ml_flush(oc);\n }\n catch (exn){\n \n }\n try {\n return Caml_missing_polyfill.not_implemented(\"caml_ml_close_channel not implemented by bucklescript yet\\n\");\n }\n catch (exn$1){\n return /* () */0;\n }\n}\n\nfunction open_in_gen(_, _$1, _$2) {\n return Caml_io.caml_ml_open_descriptor_in(Caml_missing_polyfill.not_implemented(\"caml_sys_open not implemented by bucklescript yet\\n\"));\n}\n\nfunction open_in(name) {\n return open_in_gen(/* :: */[\n /* Open_rdonly */0,\n /* :: */[\n /* Open_text */7,\n /* [] */0\n ]\n ], 0, name);\n}\n\nfunction open_in_bin(name) {\n return open_in_gen(/* :: */[\n /* Open_rdonly */0,\n /* :: */[\n /* Open_binary */6,\n /* [] */0\n ]\n ], 0, name);\n}\n\nfunction input(_, s, ofs, len) {\n if (ofs < 0 || len < 0 || ofs > (s.length - len | 0)) {\n throw [\n Caml_builtin_exceptions.invalid_argument,\n \"input\"\n ];\n } else {\n return Caml_missing_polyfill.not_implemented(\"caml_ml_input not implemented by bucklescript yet\\n\");\n }\n}\n\nfunction unsafe_really_input(_, _$1, _ofs, _len) {\n while(true) {\n var len = _len;\n var ofs = _ofs;\n if (len <= 0) {\n return /* () */0;\n } else {\n var r = Caml_missing_polyfill.not_implemented(\"caml_ml_input not implemented by bucklescript yet\\n\");\n if (r) {\n _len = len - r | 0;\n _ofs = ofs + r | 0;\n continue ;\n \n } else {\n throw Caml_builtin_exceptions.end_of_file;\n }\n }\n };\n}\n\nfunction really_input(ic, s, ofs, len) {\n if (ofs < 0 || len < 0 || ofs > (s.length - len | 0)) {\n throw [\n Caml_builtin_exceptions.invalid_argument,\n \"really_input\"\n ];\n } else {\n return unsafe_really_input(ic, s, ofs, len);\n }\n}\n\nfunction really_input_string(ic, len) {\n var s = Caml_string.caml_create_string(len);\n really_input(ic, s, 0, len);\n return Caml_string.bytes_to_string(s);\n}\n\nfunction input_line(chan) {\n var build_result = function (buf, _pos, _param) {\n while(true) {\n var param = _param;\n var pos = _pos;\n if (param) {\n var hd = param[0];\n var len = hd.length;\n Caml_string.caml_blit_bytes(hd, 0, buf, pos - len | 0, len);\n _param = param[1];\n _pos = pos - len | 0;\n continue ;\n \n } else {\n return buf;\n }\n };\n };\n var scan = function (_accu, _len) {\n while(true) {\n var len = _len;\n var accu = _accu;\n var n = Caml_missing_polyfill.not_implemented(\"caml_ml_input_scan_line not implemented by bucklescript yet\\n\");\n if (n) {\n if (n > 0) {\n var res = Caml_string.caml_create_string(n - 1 | 0);\n Caml_missing_polyfill.not_implemented(\"caml_ml_input not implemented by bucklescript yet\\n\");\n Caml_io.caml_ml_input_char(chan);\n if (accu) {\n var len$1 = (len + n | 0) - 1 | 0;\n return build_result(Caml_string.caml_create_string(len$1), len$1, /* :: */[\n res,\n accu\n ]);\n } else {\n return res;\n }\n } else {\n var beg = Caml_string.caml_create_string(-n | 0);\n Caml_missing_polyfill.not_implemented(\"caml_ml_input not implemented by bucklescript yet\\n\");\n _len = len - n | 0;\n _accu = /* :: */[\n beg,\n accu\n ];\n continue ;\n \n }\n } else if (accu) {\n return build_result(Caml_string.caml_create_string(len), len, accu);\n } else {\n throw Caml_builtin_exceptions.end_of_file;\n }\n };\n };\n return Caml_string.bytes_to_string(scan(/* [] */0, 0));\n}\n\nfunction close_in_noerr() {\n try {\n return Caml_missing_polyfill.not_implemented(\"caml_ml_close_channel not implemented by bucklescript yet\\n\");\n }\n catch (exn){\n return /* () */0;\n }\n}\n\nfunction print_char(c) {\n return Caml_io.caml_ml_output_char(stdout, c);\n}\n\nfunction print_string(s) {\n return output_string(stdout, s);\n}\n\nfunction print_bytes(s) {\n return output_bytes(stdout, s);\n}\n\nfunction print_int(i) {\n return output_string(stdout, \"\" + i);\n}\n\nfunction print_float(f) {\n return output_string(stdout, valid_float_lexem(Caml_format.caml_format_float(\"%.12g\", f)));\n}\n\nfunction print_endline(param) {\n console.log(param);\n return 0;\n}\n\nfunction print_newline() {\n Caml_io.caml_ml_output_char(stdout, /* \"\\n\" */10);\n return Caml_io.caml_ml_flush(stdout);\n}\n\nfunction prerr_char(c) {\n return Caml_io.caml_ml_output_char(stderr, c);\n}\n\nfunction prerr_string(s) {\n return output_string(stderr, s);\n}\n\nfunction prerr_bytes(s) {\n return output_bytes(stderr, s);\n}\n\nfunction prerr_int(i) {\n return output_string(stderr, \"\" + i);\n}\n\nfunction prerr_float(f) {\n return output_string(stderr, valid_float_lexem(Caml_format.caml_format_float(\"%.12g\", f)));\n}\n\nfunction prerr_endline(param) {\n console.error(param);\n return 0;\n}\n\nfunction prerr_newline() {\n Caml_io.caml_ml_output_char(stderr, /* \"\\n\" */10);\n return Caml_io.caml_ml_flush(stderr);\n}\n\nfunction read_line() {\n Caml_io.caml_ml_flush(stdout);\n return input_line(stdin);\n}\n\nfunction read_int() {\n return Caml_format.caml_int_of_string((Caml_io.caml_ml_flush(stdout), input_line(stdin)));\n}\n\nfunction read_float() {\n return Caml_format.caml_float_of_string((Caml_io.caml_ml_flush(stdout), input_line(stdin)));\n}\n\nfunction string_of_format(param) {\n return param[1];\n}\n\nfunction $caret$caret(param, param$1) {\n return /* Format */[\n CamlinternalFormatBasics.concat_fmt(param[0], param$1[0]),\n $caret(param[1], $caret(\"%,\", param$1[1]))\n ];\n}\n\nvar exit_function = [flush_all];\n\nfunction at_exit(f) {\n var g = exit_function[0];\n exit_function[0] = (function () {\n Curry._1(f, /* () */0);\n return Curry._1(g, /* () */0);\n });\n return /* () */0;\n}\n\nfunction do_at_exit() {\n return Curry._1(exit_function[0], /* () */0);\n}\n\nfunction exit(retcode) {\n do_at_exit(/* () */0);\n return Caml_sys.caml_sys_exit(retcode);\n}\n\nvar max_int = 2147483647;\n\nvar infinity = Infinity;\n\nvar neg_infinity = -Infinity;\n\nvar nan = NaN;\n\nvar max_float = Number.MAX_VALUE;\n\nvar min_float = Number.MIN_VALUE;\n\nvar epsilon_float = 2.220446049250313e-16;\n\nvar flush = Caml_io.caml_ml_flush;\n\nvar output_char = Caml_io.caml_ml_output_char;\n\nvar output_byte = Caml_io.caml_ml_output_char;\n\nfunction output_binary_int(_, _$1) {\n return Caml_missing_polyfill.not_implemented(\"caml_ml_output_int not implemented by bucklescript yet\\n\");\n}\n\nfunction seek_out(_, _$1) {\n return Caml_missing_polyfill.not_implemented(\"caml_ml_seek_out not implemented by bucklescript yet\\n\");\n}\n\nfunction pos_out() {\n return Caml_missing_polyfill.not_implemented(\"caml_ml_pos_out not implemented by bucklescript yet\\n\");\n}\n\nfunction out_channel_length() {\n return Caml_missing_polyfill.not_implemented(\"caml_ml_channel_size not implemented by bucklescript yet\\n\");\n}\n\nfunction set_binary_mode_out(_, _$1) {\n return Caml_missing_polyfill.not_implemented(\"caml_ml_set_binary_mode not implemented by bucklescript yet\\n\");\n}\n\nvar input_char = Caml_io.caml_ml_input_char;\n\nvar input_byte = Caml_io.caml_ml_input_char;\n\nfunction input_binary_int() {\n return Caml_missing_polyfill.not_implemented(\"caml_ml_input_int not implemented by bucklescript yet\\n\");\n}\n\nfunction input_value() {\n return Caml_missing_polyfill.not_implemented(\"caml_input_value not implemented by bucklescript yet\\n\");\n}\n\nfunction seek_in(_, _$1) {\n return Caml_missing_polyfill.not_implemented(\"caml_ml_seek_in not implemented by bucklescript yet\\n\");\n}\n\nfunction pos_in() {\n return Caml_missing_polyfill.not_implemented(\"caml_ml_pos_in not implemented by bucklescript yet\\n\");\n}\n\nfunction in_channel_length() {\n return Caml_missing_polyfill.not_implemented(\"caml_ml_channel_size not implemented by bucklescript yet\\n\");\n}\n\nfunction close_in() {\n return Caml_missing_polyfill.not_implemented(\"caml_ml_close_channel not implemented by bucklescript yet\\n\");\n}\n\nfunction set_binary_mode_in(_, _$1) {\n return Caml_missing_polyfill.not_implemented(\"caml_ml_set_binary_mode not implemented by bucklescript yet\\n\");\n}\n\nfunction LargeFile_000(_, _$1) {\n return Caml_missing_polyfill.not_implemented(\"caml_ml_seek_out_64 not implemented by bucklescript yet\\n\");\n}\n\nfunction LargeFile_001() {\n return Caml_missing_polyfill.not_implemented(\"caml_ml_pos_out_64 not implemented by bucklescript yet\\n\");\n}\n\nfunction LargeFile_002() {\n return Caml_missing_polyfill.not_implemented(\"caml_ml_channel_size_64 not implemented by bucklescript yet\\n\");\n}\n\nfunction LargeFile_003(_, _$1) {\n return Caml_missing_polyfill.not_implemented(\"caml_ml_seek_in_64 not implemented by bucklescript yet\\n\");\n}\n\nfunction LargeFile_004() {\n return Caml_missing_polyfill.not_implemented(\"caml_ml_pos_in_64 not implemented by bucklescript yet\\n\");\n}\n\nfunction LargeFile_005() {\n return Caml_missing_polyfill.not_implemented(\"caml_ml_channel_size_64 not implemented by bucklescript yet\\n\");\n}\n\nvar LargeFile = [\n LargeFile_000,\n LargeFile_001,\n LargeFile_002,\n LargeFile_003,\n LargeFile_004,\n LargeFile_005\n];\n\nexports.invalid_arg = invalid_arg;\nexports.failwith = failwith;\nexports.Exit = Exit;\nexports.min = min;\nexports.max = max;\nexports.abs = abs;\nexports.max_int = max_int;\nexports.min_int = min_int;\nexports.lnot = lnot;\nexports.infinity = infinity;\nexports.neg_infinity = neg_infinity;\nexports.nan = nan;\nexports.max_float = max_float;\nexports.min_float = min_float;\nexports.epsilon_float = epsilon_float;\nexports.$caret = $caret;\nexports.char_of_int = char_of_int;\nexports.string_of_bool = string_of_bool;\nexports.bool_of_string = bool_of_string;\nexports.string_of_int = string_of_int;\nexports.string_of_float = string_of_float;\nexports.$at = $at;\nexports.stdin = stdin;\nexports.stdout = stdout;\nexports.stderr = stderr;\nexports.print_char = print_char;\nexports.print_string = print_string;\nexports.print_bytes = print_bytes;\nexports.print_int = print_int;\nexports.print_float = print_float;\nexports.print_endline = print_endline;\nexports.print_newline = print_newline;\nexports.prerr_char = prerr_char;\nexports.prerr_string = prerr_string;\nexports.prerr_bytes = prerr_bytes;\nexports.prerr_int = prerr_int;\nexports.prerr_float = prerr_float;\nexports.prerr_endline = prerr_endline;\nexports.prerr_newline = prerr_newline;\nexports.read_line = read_line;\nexports.read_int = read_int;\nexports.read_float = read_float;\nexports.open_out = open_out;\nexports.open_out_bin = open_out_bin;\nexports.open_out_gen = open_out_gen;\nexports.flush = flush;\nexports.flush_all = flush_all;\nexports.output_char = output_char;\nexports.output_string = output_string;\nexports.output_bytes = output_bytes;\nexports.output = output;\nexports.output_substring = output_substring;\nexports.output_byte = output_byte;\nexports.output_binary_int = output_binary_int;\nexports.output_value = output_value;\nexports.seek_out = seek_out;\nexports.pos_out = pos_out;\nexports.out_channel_length = out_channel_length;\nexports.close_out = close_out;\nexports.close_out_noerr = close_out_noerr;\nexports.set_binary_mode_out = set_binary_mode_out;\nexports.open_in = open_in;\nexports.open_in_bin = open_in_bin;\nexports.open_in_gen = open_in_gen;\nexports.input_char = input_char;\nexports.input_line = input_line;\nexports.input = input;\nexports.really_input = really_input;\nexports.really_input_string = really_input_string;\nexports.input_byte = input_byte;\nexports.input_binary_int = input_binary_int;\nexports.input_value = input_value;\nexports.seek_in = seek_in;\nexports.pos_in = pos_in;\nexports.in_channel_length = in_channel_length;\nexports.close_in = close_in;\nexports.close_in_noerr = close_in_noerr;\nexports.set_binary_mode_in = set_binary_mode_in;\nexports.LargeFile = LargeFile;\nexports.string_of_format = string_of_format;\nexports.$caret$caret = $caret$caret;\nexports.exit = exit;\nexports.at_exit = at_exit;\nexports.valid_float_lexem = valid_float_lexem;\nexports.unsafe_really_input = unsafe_really_input;\nexports.do_at_exit = do_at_exit;\n/* No side effect */\n"
},
{
"id": 16,
"identifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/bs-platform/lib/js/caml_exceptions.js",
"name": "./node_modules/bs-platform/lib/js/caml_exceptions.js",
"index": 29,
"index2": 23,
"size": 826,
"cacheable": true,
"built": true,
"optional": false,
"prefetched": false,
"chunks": [
0
],
"assets": [],
"issuer": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/bs-platform/lib/js/array.js",
"issuerId": 21,
"issuerName": "./node_modules/bs-platform/lib/js/array.js",
"failed": false,
"errors": 0,
"warnings": 0,
"reasons": [
{
"moduleId": 15,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/bs-platform/lib/js/pervasives.js",
"module": "./node_modules/bs-platform/lib/js/pervasives.js",
"moduleName": "./node_modules/bs-platform/lib/js/pervasives.js",
"type": "cjs require",
"userRequest": "./caml_exceptions.js",
"loc": "9:31-62"
},
{
"moduleId": 21,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/bs-platform/lib/js/array.js",
"module": "./node_modules/bs-platform/lib/js/array.js",
"moduleName": "./node_modules/bs-platform/lib/js/array.js",
"type": "cjs require",
"userRequest": "./caml_exceptions.js",
"loc": "6:30-61"
},
{
"moduleId": 30,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/bs-platform/lib/js/js_exn.js",
"module": "./node_modules/bs-platform/lib/js/js_exn.js",
"moduleName": "./node_modules/bs-platform/lib/js/js_exn.js",
"type": "cjs require",
"userRequest": "./caml_exceptions.js",
"loc": "3:22-53"
},
{
"moduleId": 52,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/bs-json/lib/js/src/Json_decode.js",
"module": "./node_modules/bs-json/lib/js/src/Json_decode.js",
"moduleName": "./node_modules/bs-json/lib/js/src/Json_decode.js",
"type": "cjs require",
"userRequest": "bs-platform/lib/js/caml_exceptions.js",
"loc": "8:30-78"
},
{
"moduleId": 70,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/bs-platform/lib/js/sys.js",
"module": "./node_modules/bs-platform/lib/js/sys.js",
"moduleName": "./node_modules/bs-platform/lib/js/sys.js",
"type": "cjs require",
"userRequest": "./caml_exceptions.js",
"loc": "4:22-53"
}
],
"usedExports": true,
"providedExports": null,
"optimizationBailout": [],
"depth": 4,
"source": "'use strict';\n\n\nvar id = [0];\n\nfunction caml_set_oo_id(b) {\n b[1] = id[0];\n id[0] += 1;\n return b;\n}\n\nfunction get_id() {\n id[0] += 1;\n return id[0];\n}\n\nfunction create(str) {\n var v_001 = get_id(/* () */0);\n var v = /* tuple */[\n str,\n v_001\n ];\n v.tag = 248;\n return v;\n}\n\nfunction isCamlExceptionOrOpenVariant(e) {\n if (e === undefined) {\n return /* false */0;\n } else if (e.tag === 248) {\n return /* true */1;\n } else {\n var slot = e[0];\n if (slot !== undefined) {\n return +(slot.tag === 248);\n } else {\n return /* false */0;\n }\n }\n}\n\nexports.caml_set_oo_id = caml_set_oo_id;\nexports.get_id = get_id;\nexports.create = create;\nexports.isCamlExceptionOrOpenVariant = isCamlExceptionOrOpenVariant;\n/* No side effect */\n"
},
{
"id": 17,
"identifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/fbjs/lib/emptyObject.js",
"name": "./node_modules/fbjs/lib/emptyObject.js",
"index": 10,
"index2": 6,
"size": 332,
"cacheable": true,
"built": true,
"optional": false,
"prefetched": false,
"chunks": [
0
],
"assets": [],
"issuer": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/react/cjs/react.production.min.js",
"issuerId": 40,
"issuerName": "./node_modules/react/cjs/react.production.min.js",
"failed": false,
"errors": 0,
"warnings": 0,
"reasons": [
{
"moduleId": 40,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/react/cjs/react.production.min.js",
"module": "./node_modules/react/cjs/react.production.min.js",
"moduleName": "./node_modules/react/cjs/react.production.min.js",
"type": "cjs require",
"userRequest": "fbjs/lib/emptyObject",
"loc": "10:46-77"
},
{
"moduleId": 41,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/react/cjs/react.development.js",
"module": "./node_modules/react/cjs/react.development.js",
"moduleName": "./node_modules/react/cjs/react.development.js",
"type": "cjs require",
"userRequest": "fbjs/lib/emptyObject",
"loc": "19:18-49"
},
{
"moduleId": 77,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/react-dom/cjs/react-dom.production.min.js",
"module": "./node_modules/react-dom/cjs/react-dom.production.min.js",
"moduleName": "./node_modules/react-dom/cjs/react-dom.production.min.js",
"type": "cjs require",
"userRequest": "fbjs/lib/emptyObject",
"loc": "11:218-249"
},
{
"moduleId": 80,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/react-dom/cjs/react-dom.development.js",
"module": "./node_modules/react-dom/cjs/react-dom.development.js",
"moduleName": "./node_modules/react-dom/cjs/react-dom.development.js",
"type": "cjs require",
"userRequest": "fbjs/lib/emptyObject",
"loc": "28:18-49"
}
],
"usedExports": true,
"providedExports": null,
"optimizationBailout": [],
"depth": 4,
"source": "/**\n * Copyright (c) 2013-present, Facebook, Inc.\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 */\n\n'use strict';\n\nvar emptyObject = {};\n\nif (process.env.NODE_ENV !== 'production') {\n Object.freeze(emptyObject);\n}\n\nmodule.exports = emptyObject;"
},
{
"id": 18,
"identifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/fbjs/lib/warning.js",
"name": "./node_modules/fbjs/lib/warning.js",
"index": 14,
"index2": 10,
"size": 1897,
"cacheable": true,
"built": true,
"optional": false,
"prefetched": false,
"chunks": [
0
],
"assets": [],
"issuer": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/react/cjs/react.development.js",
"issuerId": 41,
"issuerName": "./node_modules/react/cjs/react.development.js",
"failed": false,
"errors": 0,
"warnings": 0,
"reasons": [
{
"moduleId": 22,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/prop-types/checkPropTypes.js",
"module": "./node_modules/prop-types/checkPropTypes.js",
"moduleName": "./node_modules/prop-types/checkPropTypes.js",
"type": "cjs require",
"userRequest": "fbjs/lib/warning",
"loc": "12:16-43"
},
{
"moduleId": 41,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/react/cjs/react.development.js",
"module": "./node_modules/react/cjs/react.development.js",
"moduleName": "./node_modules/react/cjs/react.development.js",
"type": "cjs require",
"userRequest": "fbjs/lib/warning",
"loc": "18:17-44"
},
{
"moduleId": 80,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/react-dom/cjs/react-dom.development.js",
"module": "./node_modules/react-dom/cjs/react-dom.development.js",
"moduleName": "./node_modules/react-dom/cjs/react-dom.development.js",
"type": "cjs require",
"userRequest": "fbjs/lib/warning",
"loc": "22:17-44"
},
{
"moduleId": 88,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/prop-types/factoryWithTypeCheckers.js",
"module": "./node_modules/prop-types/factoryWithTypeCheckers.js",
"moduleName": "./node_modules/prop-types/factoryWithTypeCheckers.js",
"type": "cjs require",
"userRequest": "fbjs/lib/warning",
"loc": "12:14-41"
}
],
"usedExports": true,
"providedExports": null,
"optimizationBailout": [],
"depth": 4,
"source": "/**\n * Copyright (c) 2014-present, Facebook, Inc.\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 */\n\n'use strict';\n\nvar emptyFunction = require('./emptyFunction');\n\n/**\n * Similar to invariant but only logs a warning if the condition is not met.\n * This can be used to log issues in development environments in critical\n * paths. Removing the logging code for production environments will keep the\n * same logic and follow the same code paths.\n */\n\nvar warning = emptyFunction;\n\nif (process.env.NODE_ENV !== 'production') {\n var printWarning = function printWarning(format) {\n for (var _len = arguments.length, args = Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) {\n args[_key - 1] = arguments[_key];\n }\n\n var argIndex = 0;\n var message = 'Warning: ' + format.replace(/%s/g, function () {\n return args[argIndex++];\n });\n if (typeof console !== 'undefined') {\n console.error(message);\n }\n try {\n // --- Welcome to debugging React ---\n // This error was thrown as a convenience so that you can use this stack\n // to find the callsite that caused this warning to fire.\n throw new Error(message);\n } catch (x) {}\n };\n\n warning = function warning(condition, format) {\n if (format === undefined) {\n throw new Error('`warning(condition, format, ...args)` requires a warning ' + 'message argument');\n }\n\n if (format.indexOf('Failed Composite propType: ') === 0) {\n return; // Ignore CompositeComponent proptype check.\n }\n\n if (!condition) {\n for (var _len2 = arguments.length, args = Array(_len2 > 2 ? _len2 - 2 : 0), _key2 = 2; _key2 < _len2; _key2++) {\n args[_key2 - 2] = arguments[_key2];\n }\n\n printWarning.apply(undefined, [format].concat(args));\n }\n };\n}\n\nmodule.exports = warning;"
},
{
"id": 19,
"identifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/bs-platform/lib/js/caml_format.js",
"name": "./node_modules/bs-platform/lib/js/caml_format.js",
"index": 24,
"index2": 21,
"size": 21555,
"cacheable": true,
"built": true,
"optional": false,
"prefetched": false,
"chunks": [
0
],
"assets": [],
"issuer": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/bs-platform/lib/js/pervasives.js",
"issuerId": 15,
"issuerName": "./node_modules/bs-platform/lib/js/pervasives.js",
"failed": false,
"errors": 0,
"warnings": 0,
"reasons": [
{
"moduleId": 15,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/bs-platform/lib/js/pervasives.js",
"module": "./node_modules/bs-platform/lib/js/pervasives.js",
"moduleName": "./node_modules/bs-platform/lib/js/pervasives.js",
"type": "cjs require",
"userRequest": "./caml_format.js",
"loc": "7:31-58"
},
{
"moduleId": 63,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/bs-platform/lib/js/int32.js",
"module": "./node_modules/bs-platform/lib/js/int32.js",
"moduleName": "./node_modules/bs-platform/lib/js/int32.js",
"type": "cjs require",
"userRequest": "./caml_format.js",
"loc": "4:18-45"
},
{
"moduleId": 64,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/bs-platform/lib/js/int64.js",
"module": "./node_modules/bs-platform/lib/js/int64.js",
"moduleName": "./node_modules/bs-platform/lib/js/int64.js",
"type": "cjs require",
"userRequest": "./caml_format.js",
"loc": "4:18-45"
},
{
"moduleId": 69,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/bs-platform/lib/js/nativeint.js",
"module": "./node_modules/bs-platform/lib/js/nativeint.js",
"moduleName": "./node_modules/bs-platform/lib/js/nativeint.js",
"type": "cjs require",
"userRequest": "./caml_format.js",
"loc": "5:18-45"
}
],
"usedExports": true,
"providedExports": null,
"optimizationBailout": [],
"depth": 4,
"source": "'use strict';\n\nvar Curry = require(\"./curry.js\");\nvar Caml_int32 = require(\"./caml_int32.js\");\nvar Caml_int64 = require(\"./caml_int64.js\");\nvar Caml_utils = require(\"./caml_utils.js\");\nvar Caml_builtin_exceptions = require(\"./caml_builtin_exceptions.js\");\n\nfunction caml_failwith(s) {\n throw [\n Caml_builtin_exceptions.failure,\n s\n ];\n}\n\nfunction parse_digit(c) {\n if (c >= 65) {\n if (c >= 97) {\n if (c >= 123) {\n return -1;\n } else {\n return c - 87 | 0;\n }\n } else if (c >= 91) {\n return -1;\n } else {\n return c - 55 | 0;\n }\n } else if (c > 57 || c < 48) {\n return -1;\n } else {\n return c - /* \"0\" */48 | 0;\n }\n}\n\nfunction int_of_string_base(param) {\n switch (param) {\n case 0 : \n return 8;\n case 1 : \n return 16;\n case 2 : \n return 10;\n case 3 : \n return 2;\n \n }\n}\n\nfunction parse_sign_and_base(s) {\n var sign = 1;\n var base = /* Dec */2;\n var i = 0;\n if (s[i] === \"-\") {\n sign = -1;\n i = i + 1 | 0;\n }\n var match = s.charCodeAt(i);\n var match$1 = s.charCodeAt(i + 1 | 0);\n if (match === 48) {\n if (match$1 >= 89) {\n if (match$1 !== 98) {\n if (match$1 !== 111) {\n if (match$1 === 120) {\n base = /* Hex */1;\n i = i + 2 | 0;\n }\n \n } else {\n base = /* Oct */0;\n i = i + 2 | 0;\n }\n } else {\n base = /* Bin */3;\n i = i + 2 | 0;\n }\n } else if (match$1 !== 66) {\n if (match$1 !== 79) {\n if (match$1 >= 88) {\n base = /* Hex */1;\n i = i + 2 | 0;\n }\n \n } else {\n base = /* Oct */0;\n i = i + 2 | 0;\n }\n } else {\n base = /* Bin */3;\n i = i + 2 | 0;\n }\n }\n return /* tuple */[\n i,\n sign,\n base\n ];\n}\n\nfunction caml_int_of_string(s) {\n var match = parse_sign_and_base(s);\n var i = match[0];\n var base = int_of_string_base(match[2]);\n var threshold = 4294967295;\n var len = s.length;\n var c = i < len ? s.charCodeAt(i) : /* \"\\000\" */0;\n var d = parse_digit(c);\n if (d < 0 || d >= base) {\n throw [\n Caml_builtin_exceptions.failure,\n \"int_of_string\"\n ];\n }\n var aux = function (_acc, _k) {\n while(true) {\n var k = _k;\n var acc = _acc;\n if (k === len) {\n return acc;\n } else {\n var a = s.charCodeAt(k);\n if (a === /* \"_\" */95) {\n _k = k + 1 | 0;\n continue ;\n \n } else {\n var v = parse_digit(a);\n if (v < 0 || v >= base) {\n throw [\n Caml_builtin_exceptions.failure,\n \"int_of_string\"\n ];\n } else {\n var acc$1 = base * acc + v;\n if (acc$1 > threshold) {\n throw [\n Caml_builtin_exceptions.failure,\n \"int_of_string\"\n ];\n } else {\n _k = k + 1 | 0;\n _acc = acc$1;\n continue ;\n \n }\n }\n }\n }\n };\n };\n var res = match[1] * aux(d, i + 1 | 0);\n var or_res = res | 0;\n if (base === 10 && res !== or_res) {\n throw [\n Caml_builtin_exceptions.failure,\n \"int_of_string\"\n ];\n }\n return or_res;\n}\n\nfunction caml_int64_of_string(s) {\n var match = parse_sign_and_base(s);\n var hbase = match[2];\n var i = match[0];\n var base = Caml_int64.of_int32(int_of_string_base(hbase));\n var sign = Caml_int64.of_int32(match[1]);\n var threshold;\n switch (hbase) {\n case 0 : \n threshold = /* int64 */[\n /* hi */536870911,\n /* lo */4294967295\n ];\n break;\n case 1 : \n threshold = /* int64 */[\n /* hi */268435455,\n /* lo */4294967295\n ];\n break;\n case 2 : \n threshold = /* int64 */[\n /* hi */429496729,\n /* lo */2576980377\n ];\n break;\n case 3 : \n threshold = /* int64 */[\n /* hi */2147483647,\n /* lo */4294967295\n ];\n break;\n \n }\n var len = s.length;\n var c = i < len ? s.charCodeAt(i) : /* \"\\000\" */0;\n var d = Caml_int64.of_int32(parse_digit(c));\n if (Caml_int64.lt(d, /* int64 */[\n /* hi */0,\n /* lo */0\n ]) || Caml_int64.ge(d, base)) {\n throw [\n Caml_builtin_exceptions.failure,\n \"int64_of_string\"\n ];\n }\n var aux = function (_acc, _k) {\n while(true) {\n var k = _k;\n var acc = _acc;\n if (k === len) {\n return acc;\n } else {\n var a = s.charCodeAt(k);\n if (a === /* \"_\" */95) {\n _k = k + 1 | 0;\n continue ;\n \n } else {\n var v = Caml_int64.of_int32(parse_digit(a));\n if (Caml_int64.lt(v, /* int64 */[\n /* hi */0,\n /* lo */0\n ]) || Caml_int64.ge(v, base) || Caml_int64.gt(acc, threshold)) {\n throw [\n Caml_builtin_exceptions.failure,\n \"int64_of_string\"\n ];\n } else {\n var acc$1 = Caml_int64.add(Caml_int64.mul(base, acc), v);\n _k = k + 1 | 0;\n _acc = acc$1;\n continue ;\n \n }\n }\n }\n };\n };\n var res = Caml_int64.mul(sign, aux(d, i + 1 | 0));\n var or_res = Caml_int64.or_(res, /* int64 */[\n /* hi */0,\n /* lo */0\n ]);\n if (Caml_int64.eq(base, /* int64 */[\n /* hi */0,\n /* lo */10\n ]) && Caml_int64.neq(res, or_res)) {\n throw [\n Caml_builtin_exceptions.failure,\n \"int64_of_string\"\n ];\n }\n return or_res;\n}\n\nfunction int_of_base(param) {\n switch (param) {\n case 0 : \n return 8;\n case 1 : \n return 16;\n case 2 : \n return 10;\n \n }\n}\n\nfunction lowercase(c) {\n if (c >= /* \"A\" */65 && c <= /* \"Z\" */90 || c >= /* \"\\192\" */192 && c <= /* \"\\214\" */214 || c >= /* \"\\216\" */216 && c <= /* \"\\222\" */222) {\n return c + 32 | 0;\n } else {\n return c;\n }\n}\n\nfunction parse_format(fmt) {\n var len = fmt.length;\n if (len > 31) {\n throw [\n Caml_builtin_exceptions.invalid_argument,\n \"format_int: format too long\"\n ];\n }\n var f = /* record */[\n /* justify */\"+\",\n /* signstyle */\"-\",\n /* filter */\" \",\n /* alternate : false */0,\n /* base : Dec */2,\n /* signedconv : false */0,\n /* width */0,\n /* uppercase : false */0,\n /* sign */1,\n /* prec */-1,\n /* conv */\"f\"\n ];\n var _i = 0;\n while(true) {\n var i = _i;\n if (i >= len) {\n return f;\n } else {\n var c = fmt.charCodeAt(i);\n var exit = 0;\n if (c >= 69) {\n if (c >= 88) {\n if (c >= 121) {\n exit = 1;\n } else {\n switch (c - 88 | 0) {\n case 0 : \n f[/* base */4] = /* Hex */1;\n f[/* uppercase */7] = /* true */1;\n _i = i + 1 | 0;\n continue ;\n case 13 : \n case 14 : \n case 15 : \n exit = 5;\n break;\n case 12 : \n case 17 : \n exit = 4;\n break;\n case 23 : \n f[/* base */4] = /* Oct */0;\n _i = i + 1 | 0;\n continue ;\n case 29 : \n f[/* base */4] = /* Dec */2;\n _i = i + 1 | 0;\n continue ;\n case 1 : \n case 2 : \n case 3 : \n case 4 : \n case 5 : \n case 6 : \n case 7 : \n case 8 : \n case 9 : \n case 10 : \n case 11 : \n case 16 : \n case 18 : \n case 19 : \n case 20 : \n case 21 : \n case 22 : \n case 24 : \n case 25 : \n case 26 : \n case 27 : \n case 28 : \n case 30 : \n case 31 : \n exit = 1;\n break;\n case 32 : \n f[/* base */4] = /* Hex */1;\n _i = i + 1 | 0;\n continue ;\n \n }\n }\n } else if (c >= 72) {\n exit = 1;\n } else {\n f[/* signedconv */5] = /* true */1;\n f[/* uppercase */7] = /* true */1;\n f[/* conv */10] = String.fromCharCode(lowercase(c));\n _i = i + 1 | 0;\n continue ;\n \n }\n } else {\n var switcher = c - 32 | 0;\n if (switcher > 25 || switcher < 0) {\n exit = 1;\n } else {\n switch (switcher) {\n case 3 : \n f[/* alternate */3] = /* true */1;\n _i = i + 1 | 0;\n continue ;\n case 0 : \n case 11 : \n exit = 2;\n break;\n case 13 : \n f[/* justify */0] = \"-\";\n _i = i + 1 | 0;\n continue ;\n case 14 : \n f[/* prec */9] = 0;\n var j = i + 1 | 0;\n while((function(j){\n return function () {\n var w = fmt.charCodeAt(j) - /* \"0\" */48 | 0;\n return +(w >= 0 && w <= 9);\n }\n }(j))()) {\n f[/* prec */9] = (Caml_int32.imul(f[/* prec */9], 10) + fmt.charCodeAt(j) | 0) - /* \"0\" */48 | 0;\n j = j + 1 | 0;\n };\n _i = j;\n continue ;\n case 1 : \n case 2 : \n case 4 : \n case 5 : \n case 6 : \n case 7 : \n case 8 : \n case 9 : \n case 10 : \n case 12 : \n case 15 : \n exit = 1;\n break;\n case 16 : \n f[/* filter */2] = \"0\";\n _i = i + 1 | 0;\n continue ;\n case 17 : \n case 18 : \n case 19 : \n case 20 : \n case 21 : \n case 22 : \n case 23 : \n case 24 : \n case 25 : \n exit = 3;\n break;\n \n }\n }\n }\n switch (exit) {\n case 1 : \n _i = i + 1 | 0;\n continue ;\n case 2 : \n f[/* signstyle */1] = String.fromCharCode(c);\n _i = i + 1 | 0;\n continue ;\n case 3 : \n f[/* width */6] = 0;\n var j$1 = i;\n while((function(j$1){\n return function () {\n var w = fmt.charCodeAt(j$1) - /* \"0\" */48 | 0;\n return +(w >= 0 && w <= 9);\n }\n }(j$1))()) {\n f[/* width */6] = (Caml_int32.imul(f[/* width */6], 10) + fmt.charCodeAt(j$1) | 0) - /* \"0\" */48 | 0;\n j$1 = j$1 + 1 | 0;\n };\n _i = j$1;\n continue ;\n case 4 : \n f[/* signedconv */5] = /* true */1;\n f[/* base */4] = /* Dec */2;\n _i = i + 1 | 0;\n continue ;\n case 5 : \n f[/* signedconv */5] = /* true */1;\n f[/* conv */10] = String.fromCharCode(c);\n _i = i + 1 | 0;\n continue ;\n \n }\n }\n };\n}\n\nfunction finish_formatting(param, rawbuffer) {\n var justify = param[/* justify */0];\n var signstyle = param[/* signstyle */1];\n var filter = param[/* filter */2];\n var alternate = param[/* alternate */3];\n var base = param[/* base */4];\n var signedconv = param[/* signedconv */5];\n var width = param[/* width */6];\n var uppercase = param[/* uppercase */7];\n var sign = param[/* sign */8];\n var len = rawbuffer.length;\n if (signedconv && (sign < 0 || signstyle !== \"-\")) {\n len = len + 1 | 0;\n }\n if (alternate) {\n if (base) {\n if (base === /* Hex */1) {\n len = len + 2 | 0;\n }\n \n } else {\n len = len + 1 | 0;\n }\n }\n var buffer = \"\";\n if (justify === \"+\" && filter === \" \") {\n for(var i = len ,i_finish = width - 1 | 0; i <= i_finish; ++i){\n buffer = buffer + filter;\n }\n }\n if (signedconv) {\n if (sign < 0) {\n buffer = buffer + \"-\";\n } else if (signstyle !== \"-\") {\n buffer = buffer + signstyle;\n }\n \n }\n if (alternate && base === /* Oct */0) {\n buffer = buffer + \"0\";\n }\n if (alternate && base === /* Hex */1) {\n buffer = buffer + \"0x\";\n }\n if (justify === \"+\" && filter === \"0\") {\n for(var i$1 = len ,i_finish$1 = width - 1 | 0; i$1 <= i_finish$1; ++i$1){\n buffer = buffer + filter;\n }\n }\n buffer = uppercase ? buffer + rawbuffer.toUpperCase() : buffer + rawbuffer;\n if (justify === \"-\") {\n for(var i$2 = len ,i_finish$2 = width - 1 | 0; i$2 <= i_finish$2; ++i$2){\n buffer = buffer + \" \";\n }\n }\n return buffer;\n}\n\nfunction caml_format_int(fmt, i) {\n if (fmt === \"%d\") {\n return String(i);\n } else {\n var f = parse_format(fmt);\n var f$1 = f;\n var i$1 = i;\n var i$2 = i$1 < 0 ? (\n f$1[/* signedconv */5] ? (f$1[/* sign */8] = -1, -i$1) : (i$1 >>> 0)\n ) : i$1;\n var s = i$2.toString(int_of_base(f$1[/* base */4]));\n if (f$1[/* prec */9] >= 0) {\n f$1[/* filter */2] = \" \";\n var n = f$1[/* prec */9] - s.length | 0;\n if (n > 0) {\n s = Caml_utils.repeat(n, \"0\") + s;\n }\n \n }\n return finish_formatting(f$1, s);\n }\n}\n\nfunction caml_int64_format(fmt, x) {\n var f = parse_format(fmt);\n var x$1 = f[/* signedconv */5] && Caml_int64.lt(x, /* int64 */[\n /* hi */0,\n /* lo */0\n ]) ? (f[/* sign */8] = -1, Caml_int64.neg(x)) : x;\n var s = \"\";\n var match = f[/* base */4];\n switch (match) {\n case 0 : \n var wbase = /* int64 */[\n /* hi */0,\n /* lo */8\n ];\n var cvtbl = \"01234567\";\n if (Caml_int64.lt(x$1, /* int64 */[\n /* hi */0,\n /* lo */0\n ])) {\n var y = Caml_int64.discard_sign(x$1);\n var match$1 = Caml_int64.div_mod(y, wbase);\n var quotient = Caml_int64.add(/* int64 */[\n /* hi */268435456,\n /* lo */0\n ], match$1[0]);\n var modulus = match$1[1];\n s = String.fromCharCode(cvtbl.charCodeAt(modulus[1] | 0)) + s;\n while(Caml_int64.neq(quotient, /* int64 */[\n /* hi */0,\n /* lo */0\n ])) {\n var match$2 = Caml_int64.div_mod(quotient, wbase);\n quotient = match$2[0];\n modulus = match$2[1];\n s = String.fromCharCode(cvtbl.charCodeAt(modulus[1] | 0)) + s;\n };\n } else {\n var match$3 = Caml_int64.div_mod(x$1, wbase);\n var quotient$1 = match$3[0];\n var modulus$1 = match$3[1];\n s = String.fromCharCode(cvtbl.charCodeAt(modulus$1[1] | 0)) + s;\n while(Caml_int64.neq(quotient$1, /* int64 */[\n /* hi */0,\n /* lo */0\n ])) {\n var match$4 = Caml_int64.div_mod(quotient$1, wbase);\n quotient$1 = match$4[0];\n modulus$1 = match$4[1];\n s = String.fromCharCode(cvtbl.charCodeAt(modulus$1[1] | 0)) + s;\n };\n }\n break;\n case 1 : \n s = Caml_int64.to_hex(x$1) + s;\n break;\n case 2 : \n var wbase$1 = /* int64 */[\n /* hi */0,\n /* lo */10\n ];\n var cvtbl$1 = \"0123456789\";\n if (Caml_int64.lt(x$1, /* int64 */[\n /* hi */0,\n /* lo */0\n ])) {\n var y$1 = Caml_int64.discard_sign(x$1);\n var match$5 = Caml_int64.div_mod(y$1, wbase$1);\n var match$6 = Caml_int64.div_mod(Caml_int64.add(/* int64 */[\n /* hi */0,\n /* lo */8\n ], match$5[1]), wbase$1);\n var quotient$2 = Caml_int64.add(Caml_int64.add(/* int64 */[\n /* hi */214748364,\n /* lo */3435973836\n ], match$5[0]), match$6[0]);\n var modulus$2 = match$6[1];\n s = String.fromCharCode(cvtbl$1.charCodeAt(modulus$2[1] | 0)) + s;\n while(Caml_int64.neq(quotient$2, /* int64 */[\n /* hi */0,\n /* lo */0\n ])) {\n var match$7 = Caml_int64.div_mod(quotient$2, wbase$1);\n quotient$2 = match$7[0];\n modulus$2 = match$7[1];\n s = String.fromCharCode(cvtbl$1.charCodeAt(modulus$2[1] | 0)) + s;\n };\n } else {\n var match$8 = Caml_int64.div_mod(x$1, wbase$1);\n var quotient$3 = match$8[0];\n var modulus$3 = match$8[1];\n s = String.fromCharCode(cvtbl$1.charCodeAt(modulus$3[1] | 0)) + s;\n while(Caml_int64.neq(quotient$3, /* int64 */[\n /* hi */0,\n /* lo */0\n ])) {\n var match$9 = Caml_int64.div_mod(quotient$3, wbase$1);\n quotient$3 = match$9[0];\n modulus$3 = match$9[1];\n s = String.fromCharCode(cvtbl$1.charCodeAt(modulus$3[1] | 0)) + s;\n };\n }\n break;\n \n }\n if (f[/* prec */9] >= 0) {\n f[/* filter */2] = \" \";\n var n = f[/* prec */9] - s.length | 0;\n if (n > 0) {\n s = Caml_utils.repeat(n, \"0\") + s;\n }\n \n }\n return finish_formatting(f, s);\n}\n\nfunction caml_format_float(fmt, x) {\n var f = parse_format(fmt);\n var prec = f[/* prec */9] < 0 ? 6 : f[/* prec */9];\n var x$1 = x < 0 ? (f[/* sign */8] = -1, -x) : x;\n var s = \"\";\n if (isNaN(x$1)) {\n s = \"nan\";\n f[/* filter */2] = \" \";\n } else if (isFinite(x$1)) {\n var match = f[/* conv */10];\n switch (match) {\n case \"e\" : \n s = x$1.toExponential(prec);\n var i = s.length;\n if (s[i - 3 | 0] === \"e\") {\n s = s.slice(0, i - 1 | 0) + (\"0\" + s.slice(i - 1 | 0));\n }\n break;\n case \"f\" : \n s = x$1.toFixed(prec);\n break;\n case \"g\" : \n var prec$1 = prec !== 0 ? prec : 1;\n s = x$1.toExponential(prec$1 - 1 | 0);\n var j = s.indexOf(\"e\");\n var exp = Number(s.slice(j + 1 | 0)) | 0;\n if (exp < -4 || x$1 >= 1e21 || x$1.toFixed().length > prec$1) {\n var i$1 = j - 1 | 0;\n while(s[i$1] === \"0\") {\n i$1 = i$1 - 1 | 0;\n };\n if (s[i$1] === \".\") {\n i$1 = i$1 - 1 | 0;\n }\n s = s.slice(0, i$1 + 1 | 0) + s.slice(j);\n var i$2 = s.length;\n if (s[i$2 - 3 | 0] === \"e\") {\n s = s.slice(0, i$2 - 1 | 0) + (\"0\" + s.slice(i$2 - 1 | 0));\n }\n \n } else {\n var p = prec$1;\n if (exp < 0) {\n p = p - (exp + 1 | 0) | 0;\n s = x$1.toFixed(p);\n } else {\n while((function () {\n s = x$1.toFixed(p);\n return +(s.length > (prec$1 + 1 | 0));\n })()) {\n p = p - 1 | 0;\n };\n }\n if (p !== 0) {\n var k = s.length - 1 | 0;\n while(s[k] === \"0\") {\n k = k - 1 | 0;\n };\n if (s[k] === \".\") {\n k = k - 1 | 0;\n }\n s = s.slice(0, k + 1 | 0);\n }\n \n }\n break;\n default:\n \n }\n } else {\n s = \"inf\";\n f[/* filter */2] = \" \";\n }\n return finish_formatting(f, s);\n}\n\nvar float_of_string = (\n function (s, caml_failwith) {\n var res = +s;\n if ((s.length > 0) && (res === res))\n return res;\n s = s.replace(/_/g, \"\");\n res = +s;\n if (((s.length > 0) && (res === res)) || /^[+-]?nan$/i.test(s)) {\n return res;\n }\n ;\n if (/^ *0x[0-9a-f_]+p[+-]?[0-9_]+/i.test(s)) {\n var pidx = s.indexOf('p');\n pidx = (pidx == -1) ? s.indexOf('P') : pidx;\n var exp = +s.substring(pidx + 1);\n res = +s.substring(0, pidx);\n return res * Math.pow(2, exp);\n }\n if (/^\\+?inf(inity)?$/i.test(s))\n return Infinity;\n if (/^-inf(inity)?$/i.test(s))\n return -Infinity;\n caml_failwith(\"float_of_string\");\n}\n\n);\n\nfunction caml_float_of_string(s) {\n return Curry._2(float_of_string, s, caml_failwith);\n}\n\nvar caml_nativeint_format = caml_format_int;\n\nvar caml_int32_format = caml_format_int;\n\nvar caml_int32_of_string = caml_int_of_string;\n\nvar caml_nativeint_of_string = caml_int_of_string;\n\nexports.caml_format_float = caml_format_float;\nexports.caml_format_int = caml_format_int;\nexports.caml_nativeint_format = caml_nativeint_format;\nexports.caml_int32_format = caml_int32_format;\nexports.caml_float_of_string = caml_float_of_string;\nexports.caml_int64_format = caml_int64_format;\nexports.caml_int_of_string = caml_int_of_string;\nexports.caml_int32_of_string = caml_int32_of_string;\nexports.caml_int64_of_string = caml_int64_of_string;\nexports.caml_nativeint_of_string = caml_nativeint_of_string;\n/* float_of_string Not a pure module */\n"
},
{
"id": 20,
"identifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/bs-platform/lib/js/caml_int32.js",
"name": "./node_modules/bs-platform/lib/js/caml_int32.js",
"index": 25,
"index2": 18,
"size": 1006,
"cacheable": true,
"built": true,
"optional": false,
"prefetched": false,
"chunks": [
0
],
"assets": [],
"issuer": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/bs-platform/lib/js/caml_int64.js",
"issuerId": 25,
"issuerName": "./node_modules/bs-platform/lib/js/caml_int64.js",
"failed": false,
"errors": 0,
"warnings": 0,
"reasons": [
{
"moduleId": 19,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/bs-platform/lib/js/caml_format.js",
"module": "./node_modules/bs-platform/lib/js/caml_format.js",
"moduleName": "./node_modules/bs-platform/lib/js/caml_format.js",
"type": "cjs require",
"userRequest": "./caml_int32.js",
"loc": "4:30-56"
},
{
"moduleId": 25,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/bs-platform/lib/js/caml_int64.js",
"module": "./node_modules/bs-platform/lib/js/caml_int64.js",
"moduleName": "./node_modules/bs-platform/lib/js/caml_int64.js",
"type": "cjs require",
"userRequest": "./caml_int32.js",
"loc": "4:30-56"
},
{
"moduleId": 66,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/bs-platform/lib/js/string.js",
"module": "./node_modules/bs-platform/lib/js/string.js",
"moduleName": "./node_modules/bs-platform/lib/js/string.js",
"type": "cjs require",
"userRequest": "./caml_int32.js",
"loc": "5:18-44"
},
{
"moduleId": 67,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/bs-platform/lib/js/bytes.js",
"module": "./node_modules/bs-platform/lib/js/bytes.js",
"moduleName": "./node_modules/bs-platform/lib/js/bytes.js",
"type": "cjs require",
"userRequest": "./caml_int32.js",
"loc": "7:30-56"
}
],
"usedExports": true,
"providedExports": null,
"optimizationBailout": [],
"depth": 5,
"source": "'use strict';\n\nvar Caml_builtin_exceptions = require(\"./caml_builtin_exceptions.js\");\n\nfunction div(x, y) {\n if (y === 0) {\n throw Caml_builtin_exceptions.division_by_zero;\n } else {\n return x / y | 0;\n }\n}\n\nfunction mod_(x, y) {\n if (y === 0) {\n throw Caml_builtin_exceptions.division_by_zero;\n } else {\n return x % y;\n }\n}\n\nfunction caml_bswap16(x) {\n return ((x & 255) << 8) | ((x & 65280) >>> 8);\n}\n\nfunction caml_int32_bswap(x) {\n return ((x & 255) << 24) | ((x & 65280) << 8) | ((x & 16711680) >>> 8) | ((x & 4278190080) >>> 24);\n}\n\nvar imul = ( Math.imul || function (x,y) {\n y |= 0; return ((((x >> 16) * y) << 16) + (x & 0xffff) * y)|0; \n}\n);\n\nvar caml_nativeint_bswap = caml_int32_bswap;\n\nexports.div = div;\nexports.mod_ = mod_;\nexports.caml_bswap16 = caml_bswap16;\nexports.caml_int32_bswap = caml_int32_bswap;\nexports.caml_nativeint_bswap = caml_nativeint_bswap;\nexports.imul = imul;\n/* imul Not a pure module */\n"
},
{
"id": 21,
"identifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/bs-platform/lib/js/array.js",
"name": "./node_modules/bs-platform/lib/js/array.js",
"index": 42,
"index2": 39,
"size": 10708,
"cacheable": true,
"built": true,
"optional": false,
"prefetched": false,
"chunks": [
0
],
"assets": [],
"issuer": "/home/x/zzz/github/douglasduteil/RePeople/lib/js/src/components/listAll.js",
"issuerId": 54,
"issuerName": "./lib/js/src/components/listAll.js",
"failed": false,
"errors": 0,
"warnings": 0,
"reasons": [
{
"moduleId": 52,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/bs-json/lib/js/src/Json_decode.js",
"module": "./node_modules/bs-json/lib/js/src/Json_decode.js",
"moduleName": "./node_modules/bs-json/lib/js/src/Json_decode.js",
"type": "cjs require",
"userRequest": "bs-platform/lib/js/array.js",
"loc": "4:30-68"
},
{
"moduleId": 54,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/lib/js/src/components/listAll.js",
"module": "./lib/js/src/components/listAll.js",
"moduleName": "./lib/js/src/components/listAll.js",
"type": "cjs require",
"userRequest": "bs-platform/lib/js/array.js",
"loc": "5:18-56"
},
{
"moduleId": 61,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/lib/js/src/components/discover.js",
"module": "./lib/js/src/components/discover.js",
"moduleName": "./lib/js/src/components/discover.js",
"type": "cjs require",
"userRequest": "bs-platform/lib/js/array.js",
"loc": "4:18-56"
},
{
"moduleId": 62,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/bs-platform/lib/js/random.js",
"module": "./node_modules/bs-platform/lib/js/random.js",
"moduleName": "./node_modules/bs-platform/lib/js/random.js",
"type": "cjs require",
"userRequest": "./array.js",
"loc": "3:30-51"
}
],
"usedExports": true,
"providedExports": null,
"optimizationBailout": [],
"depth": 3,
"source": "'use strict';\n\nvar Curry = require(\"./curry.js\");\nvar Js_exn = require(\"./js_exn.js\");\nvar Caml_array = require(\"./caml_array.js\");\nvar Caml_exceptions = require(\"./caml_exceptions.js\");\nvar Caml_builtin_exceptions = require(\"./caml_builtin_exceptions.js\");\n\nfunction init(l, f) {\n if (l) {\n if (l < 0) {\n throw [\n Caml_builtin_exceptions.invalid_argument,\n \"Array.init\"\n ];\n } else {\n var res = Caml_array.caml_make_vect(l, Curry._1(f, 0));\n for(var i = 1 ,i_finish = l - 1 | 0; i <= i_finish; ++i){\n res[i] = Curry._1(f, i);\n }\n return res;\n }\n } else {\n return /* array */[];\n }\n}\n\nfunction make_matrix(sx, sy, init) {\n var res = Caml_array.caml_make_vect(sx, /* array */[]);\n for(var x = 0 ,x_finish = sx - 1 | 0; x <= x_finish; ++x){\n res[x] = Caml_array.caml_make_vect(sy, init);\n }\n return res;\n}\n\nfunction copy(a) {\n var l = a.length;\n if (l) {\n return Caml_array.caml_array_sub(a, 0, l);\n } else {\n return /* array */[];\n }\n}\n\nfunction append(a1, a2) {\n var l1 = a1.length;\n if (l1) {\n if (a2.length) {\n return a1.concat(a2);\n } else {\n return Caml_array.caml_array_sub(a1, 0, l1);\n }\n } else {\n return copy(a2);\n }\n}\n\nfunction sub(a, ofs, len) {\n if (len < 0 || ofs > (a.length - len | 0)) {\n throw [\n Caml_builtin_exceptions.invalid_argument,\n \"Array.sub\"\n ];\n } else {\n return Caml_array.caml_array_sub(a, ofs, len);\n }\n}\n\nfunction fill(a, ofs, len, v) {\n if (ofs < 0 || len < 0 || ofs > (a.length - len | 0)) {\n throw [\n Caml_builtin_exceptions.invalid_argument,\n \"Array.fill\"\n ];\n } else {\n for(var i = ofs ,i_finish = (ofs + len | 0) - 1 | 0; i <= i_finish; ++i){\n a[i] = v;\n }\n return /* () */0;\n }\n}\n\nfunction blit(a1, ofs1, a2, ofs2, len) {\n if (len < 0 || ofs1 < 0 || ofs1 > (a1.length - len | 0) || ofs2 < 0 || ofs2 > (a2.length - len | 0)) {\n throw [\n Caml_builtin_exceptions.invalid_argument,\n \"Array.blit\"\n ];\n } else {\n return Caml_array.caml_array_blit(a1, ofs1, a2, ofs2, len);\n }\n}\n\nfunction iter(f, a) {\n for(var i = 0 ,i_finish = a.length - 1 | 0; i <= i_finish; ++i){\n Curry._1(f, a[i]);\n }\n return /* () */0;\n}\n\nfunction map(f, a) {\n var l = a.length;\n if (l) {\n var r = Caml_array.caml_make_vect(l, Curry._1(f, a[0]));\n for(var i = 1 ,i_finish = l - 1 | 0; i <= i_finish; ++i){\n r[i] = Curry._1(f, a[i]);\n }\n return r;\n } else {\n return /* array */[];\n }\n}\n\nfunction iteri(f, a) {\n for(var i = 0 ,i_finish = a.length - 1 | 0; i <= i_finish; ++i){\n Curry._2(f, i, a[i]);\n }\n return /* () */0;\n}\n\nfunction mapi(f, a) {\n var l = a.length;\n if (l) {\n var r = Caml_array.caml_make_vect(l, Curry._2(f, 0, a[0]));\n for(var i = 1 ,i_finish = l - 1 | 0; i <= i_finish; ++i){\n r[i] = Curry._2(f, i, a[i]);\n }\n return r;\n } else {\n return /* array */[];\n }\n}\n\nfunction to_list(a) {\n var _i = a.length - 1 | 0;\n var _res = /* [] */0;\n while(true) {\n var res = _res;\n var i = _i;\n if (i < 0) {\n return res;\n } else {\n _res = /* :: */[\n a[i],\n res\n ];\n _i = i - 1 | 0;\n continue ;\n \n }\n };\n}\n\nfunction list_length(_accu, _param) {\n while(true) {\n var param = _param;\n var accu = _accu;\n if (param) {\n _param = param[1];\n _accu = accu + 1 | 0;\n continue ;\n \n } else {\n return accu;\n }\n };\n}\n\nfunction of_list(l) {\n if (l) {\n var a = Caml_array.caml_make_vect(list_length(0, l), l[0]);\n var _i = 1;\n var _param = l[1];\n while(true) {\n var param = _param;\n var i = _i;\n if (param) {\n a[i] = param[0];\n _param = param[1];\n _i = i + 1 | 0;\n continue ;\n \n } else {\n return a;\n }\n };\n } else {\n return /* array */[];\n }\n}\n\nfunction fold_left(f, x, a) {\n var r = x;\n for(var i = 0 ,i_finish = a.length - 1 | 0; i <= i_finish; ++i){\n r = Curry._2(f, r, a[i]);\n }\n return r;\n}\n\nfunction fold_right(f, a, x) {\n var r = x;\n for(var i = a.length - 1 | 0; i >= 0; --i){\n r = Curry._2(f, a[i], r);\n }\n return r;\n}\n\nvar Bottom = Caml_exceptions.create(\"Array.Bottom\");\n\nfunction sort(cmp, a) {\n var maxson = function (l, i) {\n var i31 = ((i + i | 0) + i | 0) + 1 | 0;\n var x = i31;\n if ((i31 + 2 | 0) < l) {\n if (Curry._2(cmp, Caml_array.caml_array_get(a, i31), Caml_array.caml_array_get(a, i31 + 1 | 0)) < 0) {\n x = i31 + 1 | 0;\n }\n if (Curry._2(cmp, Caml_array.caml_array_get(a, x), Caml_array.caml_array_get(a, i31 + 2 | 0)) < 0) {\n x = i31 + 2 | 0;\n }\n return x;\n } else if ((i31 + 1 | 0) < l && Curry._2(cmp, Caml_array.caml_array_get(a, i31), Caml_array.caml_array_get(a, i31 + 1 | 0)) < 0) {\n return i31 + 1 | 0;\n } else if (i31 < l) {\n return i31;\n } else {\n throw [\n Bottom,\n i\n ];\n }\n };\n var trickle = function (l, i, e) {\n try {\n var l$1 = l;\n var _i = i;\n var e$1 = e;\n while(true) {\n var i$1 = _i;\n var j = maxson(l$1, i$1);\n if (Curry._2(cmp, Caml_array.caml_array_get(a, j), e$1) > 0) {\n Caml_array.caml_array_set(a, i$1, Caml_array.caml_array_get(a, j));\n _i = j;\n continue ;\n \n } else {\n return Caml_array.caml_array_set(a, i$1, e$1);\n }\n };\n }\n catch (raw_exn){\n var exn = Js_exn.internalToOCamlException(raw_exn);\n if (exn[0] === Bottom) {\n return Caml_array.caml_array_set(a, exn[1], e);\n } else {\n throw exn;\n }\n }\n };\n var bubble = function (l, i) {\n try {\n var l$1 = l;\n var _i = i;\n while(true) {\n var i$1 = _i;\n var j = maxson(l$1, i$1);\n Caml_array.caml_array_set(a, i$1, Caml_array.caml_array_get(a, j));\n _i = j;\n continue ;\n \n };\n }\n catch (raw_exn){\n var exn = Js_exn.internalToOCamlException(raw_exn);\n if (exn[0] === Bottom) {\n return exn[1];\n } else {\n throw exn;\n }\n }\n };\n var trickleup = function (_i, e) {\n while(true) {\n var i = _i;\n var father = (i - 1 | 0) / 3 | 0;\n if (i === father) {\n throw [\n Caml_builtin_exceptions.assert_failure,\n [\n \"array.ml\",\n 168,\n 4\n ]\n ];\n }\n if (Curry._2(cmp, Caml_array.caml_array_get(a, father), e) < 0) {\n Caml_array.caml_array_set(a, i, Caml_array.caml_array_get(a, father));\n if (father > 0) {\n _i = father;\n continue ;\n \n } else {\n return Caml_array.caml_array_set(a, 0, e);\n }\n } else {\n return Caml_array.caml_array_set(a, i, e);\n }\n };\n };\n var l = a.length;\n for(var i = ((l + 1 | 0) / 3 | 0) - 1 | 0; i >= 0; --i){\n trickle(l, i, Caml_array.caml_array_get(a, i));\n }\n for(var i$1 = l - 1 | 0; i$1 >= 2; --i$1){\n var e = Caml_array.caml_array_get(a, i$1);\n Caml_array.caml_array_set(a, i$1, Caml_array.caml_array_get(a, 0));\n trickleup(bubble(i$1, 0), e);\n }\n if (l > 1) {\n var e$1 = Caml_array.caml_array_get(a, 1);\n Caml_array.caml_array_set(a, 1, Caml_array.caml_array_get(a, 0));\n return Caml_array.caml_array_set(a, 0, e$1);\n } else {\n return 0;\n }\n}\n\nfunction stable_sort(cmp, a) {\n var merge = function (src1ofs, src1len, src2, src2ofs, src2len, dst, dstofs) {\n var src1r = src1ofs + src1len | 0;\n var src2r = src2ofs + src2len | 0;\n var _i1 = src1ofs;\n var _s1 = Caml_array.caml_array_get(a, src1ofs);\n var _i2 = src2ofs;\n var _s2 = Caml_array.caml_array_get(src2, src2ofs);\n var _d = dstofs;\n while(true) {\n var d = _d;\n var s2 = _s2;\n var i2 = _i2;\n var s1 = _s1;\n var i1 = _i1;\n if (Curry._2(cmp, s1, s2) <= 0) {\n Caml_array.caml_array_set(dst, d, s1);\n var i1$1 = i1 + 1 | 0;\n if (i1$1 < src1r) {\n _d = d + 1 | 0;\n _s1 = Caml_array.caml_array_get(a, i1$1);\n _i1 = i1$1;\n continue ;\n \n } else {\n return blit(src2, i2, dst, d + 1 | 0, src2r - i2 | 0);\n }\n } else {\n Caml_array.caml_array_set(dst, d, s2);\n var i2$1 = i2 + 1 | 0;\n if (i2$1 < src2r) {\n _d = d + 1 | 0;\n _s2 = Caml_array.caml_array_get(src2, i2$1);\n _i2 = i2$1;\n continue ;\n \n } else {\n return blit(a, i1, dst, d + 1 | 0, src1r - i1 | 0);\n }\n }\n };\n };\n var isortto = function (srcofs, dst, dstofs, len) {\n for(var i = 0 ,i_finish = len - 1 | 0; i <= i_finish; ++i){\n var e = Caml_array.caml_array_get(a, srcofs + i | 0);\n var j = (dstofs + i | 0) - 1 | 0;\n while(j >= dstofs && Curry._2(cmp, Caml_array.caml_array_get(dst, j), e) > 0) {\n Caml_array.caml_array_set(dst, j + 1 | 0, Caml_array.caml_array_get(dst, j));\n j = j - 1 | 0;\n };\n Caml_array.caml_array_set(dst, j + 1 | 0, e);\n }\n return /* () */0;\n };\n var sortto = function (srcofs, dst, dstofs, len) {\n if (len <= 5) {\n return isortto(srcofs, dst, dstofs, len);\n } else {\n var l1 = len / 2 | 0;\n var l2 = len - l1 | 0;\n sortto(srcofs + l1 | 0, dst, dstofs + l1 | 0, l2);\n sortto(srcofs, a, srcofs + l2 | 0, l1);\n return merge(srcofs + l2 | 0, l1, dst, dstofs + l1 | 0, l2, dst, dstofs);\n }\n };\n var l = a.length;\n if (l <= 5) {\n return isortto(0, a, 0, l);\n } else {\n var l1 = l / 2 | 0;\n var l2 = l - l1 | 0;\n var t = Caml_array.caml_make_vect(l2, Caml_array.caml_array_get(a, 0));\n sortto(l1, t, 0, l2);\n sortto(0, a, l2, l1);\n return merge(l2, l1, t, 0, l2, a, 0);\n }\n}\n\nvar create_matrix = make_matrix;\n\nvar concat = Caml_array.caml_array_concat;\n\nvar fast_sort = stable_sort;\n\nexports.init = init;\nexports.make_matrix = make_matrix;\nexports.create_matrix = create_matrix;\nexports.append = append;\nexports.concat = concat;\nexports.sub = sub;\nexports.copy = copy;\nexports.fill = fill;\nexports.blit = blit;\nexports.to_list = to_list;\nexports.of_list = of_list;\nexports.iter = iter;\nexports.map = map;\nexports.iteri = iteri;\nexports.mapi = mapi;\nexports.fold_left = fold_left;\nexports.fold_right = fold_right;\nexports.sort = sort;\nexports.stable_sort = stable_sort;\nexports.fast_sort = fast_sort;\n/* No side effect */\n"
},
{
"id": 22,
"identifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/prop-types/checkPropTypes.js",
"name": "./node_modules/prop-types/checkPropTypes.js",
"index": 15,
"index2": 12,
"size": 2873,
"cacheable": true,
"built": true,
"optional": false,
"prefetched": false,
"chunks": [
0
],
"assets": [],
"issuer": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/react/cjs/react.development.js",
"issuerId": 41,
"issuerName": "./node_modules/react/cjs/react.development.js",
"failed": false,
"errors": 0,
"warnings": 0,
"reasons": [
{
"moduleId": 41,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/react/cjs/react.development.js",
"module": "./node_modules/react/cjs/react.development.js",
"moduleName": "./node_modules/react/cjs/react.development.js",
"type": "cjs require",
"userRequest": "prop-types/checkPropTypes",
"loc": "22:21-57"
},
{
"moduleId": 80,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/react-dom/cjs/react-dom.development.js",
"module": "./node_modules/react-dom/cjs/react-dom.development.js",
"moduleName": "./node_modules/react-dom/cjs/react-dom.development.js",
"type": "cjs require",
"userRequest": "prop-types/checkPropTypes",
"loc": "29:21-57"
},
{
"moduleId": 88,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/prop-types/factoryWithTypeCheckers.js",
"module": "./node_modules/prop-types/factoryWithTypeCheckers.js",
"moduleName": "./node_modules/prop-types/factoryWithTypeCheckers.js",
"type": "cjs require",
"userRequest": "./checkPropTypes",
"loc": "16:21-48"
}
],
"usedExports": true,
"providedExports": null,
"optimizationBailout": [],
"depth": 4,
"source": "/**\n * Copyright (c) 2013-present, Facebook, Inc.\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\n'use strict';\n\nif (process.env.NODE_ENV !== 'production') {\n var invariant = require('fbjs/lib/invariant');\n var warning = require('fbjs/lib/warning');\n var ReactPropTypesSecret = require('./lib/ReactPropTypesSecret');\n var loggedTypeFailures = {};\n}\n\n/**\n * Assert that the values match with the type specs.\n * Error messages are memorized and will only be shown once.\n *\n * @param {object} typeSpecs Map of name to a ReactPropType\n * @param {object} values Runtime values that need to be type-checked\n * @param {string} location e.g. \"prop\", \"context\", \"child context\"\n * @param {string} componentName Name of the component for error messages.\n * @param {?Function} getStack Returns the component stack.\n * @private\n */\nfunction checkPropTypes(typeSpecs, values, location, componentName, getStack) {\n if (process.env.NODE_ENV !== 'production') {\n for (var typeSpecName in typeSpecs) {\n if (typeSpecs.hasOwnProperty(typeSpecName)) {\n var error;\n // Prop type validation may throw. In case they do, we don't want to\n // fail the render phase where it didn't fail before. So we log it.\n // After these have been cleaned up, we'll let them throw.\n try {\n // This is intentionally an invariant that gets caught. It's the same\n // behavior as without this statement except with a better message.\n invariant(typeof typeSpecs[typeSpecName] === 'function', '%s: %s type `%s` is invalid; it must be a function, usually from ' + 'the `prop-types` package, but received `%s`.', componentName || 'React class', location, typeSpecName, typeof typeSpecs[typeSpecName]);\n error = typeSpecs[typeSpecName](values, typeSpecName, componentName, location, null, ReactPropTypesSecret);\n } catch (ex) {\n error = ex;\n }\n warning(!error || error instanceof Error, '%s: type specification of %s `%s` is invalid; the type checker ' + 'function must return `null` or an `Error` but returned a %s. ' + 'You may have forgotten to pass an argument to the type checker ' + 'creator (arrayOf, instanceOf, objectOf, oneOf, oneOfType, and ' + 'shape all require an argument).', componentName || 'React class', location, typeSpecName, typeof error);\n if (error instanceof Error && !(error.message in loggedTypeFailures)) {\n // Only monitor this failure once because there tends to be a lot of the\n // same error.\n loggedTypeFailures[error.message] = true;\n\n var stack = getStack ? getStack() : '';\n\n warning(false, 'Failed %s type: %s%s', location, error.message, stack != null ? stack : '');\n }\n }\n }\n }\n}\n\nmodule.exports = checkPropTypes;\n"
},
{
"id": 23,
"identifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/prop-types/lib/ReactPropTypesSecret.js",
"name": "./node_modules/prop-types/lib/ReactPropTypesSecret.js",
"index": 16,
"index2": 11,
"size": 314,
"cacheable": true,
"built": true,
"optional": false,
"prefetched": false,
"chunks": [
0
],
"assets": [],
"issuer": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/prop-types/checkPropTypes.js",
"issuerId": 22,
"issuerName": "./node_modules/prop-types/checkPropTypes.js",
"failed": false,
"errors": 0,
"warnings": 0,
"reasons": [
{
"moduleId": 22,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/prop-types/checkPropTypes.js",
"module": "./node_modules/prop-types/checkPropTypes.js",
"moduleName": "./node_modules/prop-types/checkPropTypes.js",
"type": "cjs require",
"userRequest": "./lib/ReactPropTypesSecret",
"loc": "13:29-66"
},
{
"moduleId": 88,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/prop-types/factoryWithTypeCheckers.js",
"module": "./node_modules/prop-types/factoryWithTypeCheckers.js",
"moduleName": "./node_modules/prop-types/factoryWithTypeCheckers.js",
"type": "cjs require",
"userRequest": "./lib/ReactPropTypesSecret",
"loc": "15:27-64"
},
{
"moduleId": 89,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/prop-types/factoryWithThrowingShims.js",
"module": "./node_modules/prop-types/factoryWithThrowingShims.js",
"moduleName": "./node_modules/prop-types/factoryWithThrowingShims.js",
"type": "cjs require",
"userRequest": "./lib/ReactPropTypesSecret",
"loc": "12:27-64"
}
],
"usedExports": true,
"providedExports": null,
"optimizationBailout": [],
"depth": 5,
"source": "/**\n * Copyright (c) 2013-present, Facebook, Inc.\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\n'use strict';\n\nvar ReactPropTypesSecret = 'SECRET_DO_NOT_PASS_THIS_OR_YOU_WILL_BE_FIRED';\n\nmodule.exports = ReactPropTypesSecret;\n"
},
{
"id": 24,
"identifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/bs-platform/lib/js/caml_sys.js",
"name": "./node_modules/bs-platform/lib/js/caml_sys.js",
"index": 23,
"index2": 17,
"size": 2297,
"cacheable": true,
"built": true,
"optional": false,
"prefetched": false,
"chunks": [
0
],
"assets": [],
"issuer": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/bs-platform/lib/js/random.js",
"issuerId": 62,
"issuerName": "./node_modules/bs-platform/lib/js/random.js",
"failed": false,
"errors": 0,
"warnings": 0,
"reasons": [
{
"moduleId": 15,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/bs-platform/lib/js/pervasives.js",
"module": "./node_modules/bs-platform/lib/js/pervasives.js",
"moduleName": "./node_modules/bs-platform/lib/js/pervasives.js",
"type": "cjs require",
"userRequest": "./caml_sys.js",
"loc": "6:31-55"
},
{
"moduleId": 62,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/bs-platform/lib/js/random.js",
"module": "./node_modules/bs-platform/lib/js/random.js",
"moduleName": "./node_modules/bs-platform/lib/js/random.js",
"type": "cjs require",
"userRequest": "./caml_sys.js",
"loc": "8:30-54"
},
{
"moduleId": 70,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/bs-platform/lib/js/sys.js",
"module": "./node_modules/bs-platform/lib/js/sys.js",
"moduleName": "./node_modules/bs-platform/lib/js/sys.js",
"type": "cjs require",
"userRequest": "./caml_sys.js",
"loc": "3:22-46"
}
],
"usedExports": true,
"providedExports": null,
"optimizationBailout": [],
"depth": 4,
"source": "'use strict';\n\nvar Caml_builtin_exceptions = require(\"./caml_builtin_exceptions.js\");\n\nfunction caml_sys_getenv(s) {\n var match = typeof (process) === \"undefined\" ? undefined : (process);\n if (match !== undefined) {\n var match$1 = match.env[s];\n if (match$1 !== undefined) {\n return match$1;\n } else {\n throw Caml_builtin_exceptions.not_found;\n }\n } else {\n throw Caml_builtin_exceptions.not_found;\n }\n}\n\nfunction caml_sys_time() {\n var match = typeof (process) === \"undefined\" ? undefined : (process);\n if (match !== undefined) {\n return match.uptime();\n } else {\n return -1;\n }\n}\n\nfunction caml_sys_random_seed() {\n return /* array */[((Date.now() | 0) ^ 4294967295) * Math.random() | 0];\n}\n\nfunction caml_sys_system_command() {\n return 127;\n}\n\nfunction caml_sys_getcwd() {\n var match = typeof (process) === \"undefined\" ? undefined : (process);\n if (match !== undefined) {\n return match.cwd();\n } else {\n return \"/\";\n }\n}\n\nfunction caml_sys_get_argv() {\n var match = typeof (process) === \"undefined\" ? undefined : (process);\n if (match !== undefined) {\n return /* tuple */[\n match.argv[0],\n match.argv\n ];\n } else {\n return /* tuple */[\n \"\",\n /* array */[\"\"]\n ];\n }\n}\n\nfunction caml_sys_exit(exit_code) {\n var match = typeof (process) === \"undefined\" ? undefined : (process);\n if (match !== undefined) {\n return match.exit(exit_code);\n } else {\n return /* () */0;\n }\n}\n\nfunction caml_sys_is_directory() {\n throw [\n Caml_builtin_exceptions.failure,\n \"caml_sys_is_directory not implemented\"\n ];\n}\n\nfunction caml_sys_file_exists() {\n throw [\n Caml_builtin_exceptions.failure,\n \"caml_sys_file_exists not implemented\"\n ];\n}\n\nexports.caml_sys_getenv = caml_sys_getenv;\nexports.caml_sys_time = caml_sys_time;\nexports.caml_sys_random_seed = caml_sys_random_seed;\nexports.caml_sys_system_command = caml_sys_system_command;\nexports.caml_sys_getcwd = caml_sys_getcwd;\nexports.caml_sys_get_argv = caml_sys_get_argv;\nexports.caml_sys_exit = caml_sys_exit;\nexports.caml_sys_is_directory = caml_sys_is_directory;\nexports.caml_sys_file_exists = caml_sys_file_exists;\n/* No side effect */\n"
},
{
"id": 25,
"identifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/bs-platform/lib/js/caml_int64.js",
"name": "./node_modules/bs-platform/lib/js/caml_int64.js",
"index": 26,
"index2": 20,
"size": 14536,
"cacheable": true,
"built": true,
"optional": false,
"prefetched": false,
"chunks": [
0
],
"assets": [],
"issuer": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/bs-platform/lib/js/random.js",
"issuerId": 62,
"issuerName": "./node_modules/bs-platform/lib/js/random.js",
"failed": false,
"errors": 0,
"warnings": 0,
"reasons": [
{
"moduleId": 19,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/bs-platform/lib/js/caml_format.js",
"module": "./node_modules/bs-platform/lib/js/caml_format.js",
"moduleName": "./node_modules/bs-platform/lib/js/caml_format.js",
"type": "cjs require",
"userRequest": "./caml_int64.js",
"loc": "5:30-56"
},
{
"moduleId": 62,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/bs-platform/lib/js/random.js",
"module": "./node_modules/bs-platform/lib/js/random.js",
"moduleName": "./node_modules/bs-platform/lib/js/random.js",
"type": "cjs require",
"userRequest": "./caml_int64.js",
"loc": "11:30-56"
},
{
"moduleId": 64,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/bs-platform/lib/js/int64.js",
"module": "./node_modules/bs-platform/lib/js/int64.js",
"moduleName": "./node_modules/bs-platform/lib/js/int64.js",
"type": "cjs require",
"userRequest": "./caml_int64.js",
"loc": "3:18-44"
}
],
"usedExports": true,
"providedExports": null,
"optimizationBailout": [],
"depth": 4,
"source": "'use strict';\n\nvar Caml_obj = require(\"./caml_obj.js\");\nvar Caml_int32 = require(\"./caml_int32.js\");\nvar Caml_utils = require(\"./caml_utils.js\");\nvar Caml_builtin_exceptions = require(\"./caml_builtin_exceptions.js\");\n\nvar min_int = /* record */[\n /* hi */-2147483648,\n /* lo */0\n];\n\nvar max_int = /* record */[\n /* hi */134217727,\n /* lo */1\n];\n\nvar one = /* record */[\n /* hi */0,\n /* lo */1\n];\n\nvar zero = /* record */[\n /* hi */0,\n /* lo */0\n];\n\nvar neg_one = /* record */[\n /* hi */-1,\n /* lo */4294967295\n];\n\nfunction neg_signed(x) {\n return +((x & 2147483648) !== 0);\n}\n\nfunction add(param, param$1) {\n var other_low_ = param$1[/* lo */1];\n var this_low_ = param[/* lo */1];\n var lo = this_low_ + other_low_ & 4294967295;\n var overflow = neg_signed(this_low_) && (neg_signed(other_low_) || !neg_signed(lo)) || neg_signed(other_low_) && !neg_signed(lo) ? 1 : 0;\n var hi = param[/* hi */0] + param$1[/* hi */0] + overflow & 4294967295;\n return /* record */[\n /* hi */hi,\n /* lo */(lo >>> 0)\n ];\n}\n\nfunction not(param) {\n var hi = param[/* hi */0] ^ -1;\n var lo = param[/* lo */1] ^ -1;\n return /* record */[\n /* hi */hi,\n /* lo */(lo >>> 0)\n ];\n}\n\nfunction eq(x, y) {\n if (x[/* hi */0] === y[/* hi */0]) {\n return +(x[/* lo */1] === y[/* lo */1]);\n } else {\n return /* false */0;\n }\n}\n\nfunction neg(x) {\n if (eq(x, min_int)) {\n return min_int;\n } else {\n return add(not(x), one);\n }\n}\n\nfunction sub(x, y) {\n return add(x, neg(y));\n}\n\nfunction lsl_(x, numBits) {\n if (numBits) {\n var lo = x[/* lo */1];\n if (numBits >= 32) {\n return /* record */[\n /* hi */(lo << (numBits - 32 | 0)),\n /* lo */0\n ];\n } else {\n var hi = (lo >>> (32 - numBits | 0)) | (x[/* hi */0] << numBits);\n return /* record */[\n /* hi */hi,\n /* lo */((lo << numBits) >>> 0)\n ];\n }\n } else {\n return x;\n }\n}\n\nfunction lsr_(x, numBits) {\n if (numBits) {\n var hi = x[/* hi */0];\n var offset = numBits - 32 | 0;\n if (offset) {\n if (offset > 0) {\n var lo = (hi >>> offset);\n return /* record */[\n /* hi */0,\n /* lo */(lo >>> 0)\n ];\n } else {\n var hi$1 = (hi >>> numBits);\n var lo$1 = (hi << (-offset | 0)) | (x[/* lo */1] >>> numBits);\n return /* record */[\n /* hi */hi$1,\n /* lo */(lo$1 >>> 0)\n ];\n }\n } else {\n return /* record */[\n /* hi */0,\n /* lo */(hi >>> 0)\n ];\n }\n } else {\n return x;\n }\n}\n\nfunction asr_(x, numBits) {\n if (numBits) {\n var hi = x[/* hi */0];\n if (numBits < 32) {\n var hi$1 = (hi >> numBits);\n var lo = (hi << (32 - numBits | 0)) | (x[/* lo */1] >>> numBits);\n return /* record */[\n /* hi */hi$1,\n /* lo */(lo >>> 0)\n ];\n } else {\n var lo$1 = (hi >> (numBits - 32 | 0));\n return /* record */[\n /* hi */hi >= 0 ? 0 : -1,\n /* lo */(lo$1 >>> 0)\n ];\n }\n } else {\n return x;\n }\n}\n\nfunction is_zero(param) {\n if (param[/* hi */0] !== 0 || param[/* lo */1] !== 0) {\n return /* false */0;\n } else {\n return /* true */1;\n }\n}\n\nfunction mul(_this, _other) {\n while(true) {\n var other = _other;\n var $$this = _this;\n var exit = 0;\n var lo;\n var this_hi = $$this[/* hi */0];\n var exit$1 = 0;\n var exit$2 = 0;\n var exit$3 = 0;\n if (this_hi !== 0) {\n exit$3 = 4;\n } else if ($$this[/* lo */1] !== 0) {\n exit$3 = 4;\n } else {\n return zero;\n }\n if (exit$3 === 4) {\n if (other[/* hi */0] !== 0) {\n exit$2 = 3;\n } else if (other[/* lo */1] !== 0) {\n exit$2 = 3;\n } else {\n return zero;\n }\n }\n if (exit$2 === 3) {\n if (this_hi !== -2147483648) {\n exit$1 = 2;\n } else if ($$this[/* lo */1] !== 0) {\n exit$1 = 2;\n } else {\n lo = other[/* lo */1];\n exit = 1;\n }\n }\n if (exit$1 === 2) {\n var other_hi = other[/* hi */0];\n var lo$1 = $$this[/* lo */1];\n var exit$4 = 0;\n if (other_hi !== -2147483648) {\n exit$4 = 3;\n } else if (other[/* lo */1] !== 0) {\n exit$4 = 3;\n } else {\n lo = lo$1;\n exit = 1;\n }\n if (exit$4 === 3) {\n var other_lo = other[/* lo */1];\n if (this_hi < 0) {\n if (other_hi < 0) {\n _other = neg(other);\n _this = neg($$this);\n continue ;\n \n } else {\n return neg(mul(neg($$this), other));\n }\n } else if (other_hi < 0) {\n return neg(mul($$this, neg(other)));\n } else {\n var a48 = (this_hi >>> 16);\n var a32 = this_hi & 65535;\n var a16 = (lo$1 >>> 16);\n var a00 = lo$1 & 65535;\n var b48 = (other_hi >>> 16);\n var b32 = other_hi & 65535;\n var b16 = (other_lo >>> 16);\n var b00 = other_lo & 65535;\n var c48 = 0;\n var c32 = 0;\n var c16 = 0;\n var c00 = a00 * b00;\n c16 = (c00 >>> 16) + a16 * b00;\n c32 = (c16 >>> 16);\n c16 = (c16 & 65535) + a00 * b16;\n c32 = c32 + (c16 >>> 16) + a32 * b00;\n c48 = (c32 >>> 16);\n c32 = (c32 & 65535) + a16 * b16;\n c48 += (c32 >>> 16);\n c32 = (c32 & 65535) + a00 * b32;\n c48 += (c32 >>> 16);\n c32 = c32 & 65535;\n c48 = c48 + (a48 * b00 + a32 * b16 + a16 * b32 + a00 * b48) & 65535;\n var hi = c32 | (c48 << 16);\n var lo$2 = c00 & 65535 | ((c16 & 65535) << 16);\n return /* record */[\n /* hi */hi,\n /* lo */(lo$2 >>> 0)\n ];\n }\n }\n \n }\n if (exit === 1) {\n if ((lo & 1) === 0) {\n return zero;\n } else {\n return min_int;\n }\n }\n \n };\n}\n\nfunction swap(param) {\n var hi = Caml_int32.caml_int32_bswap(param[/* lo */1]);\n var lo = Caml_int32.caml_int32_bswap(param[/* hi */0]);\n return /* record */[\n /* hi */hi,\n /* lo */(lo >>> 0)\n ];\n}\n\nfunction xor(param, param$1) {\n return /* record */[\n /* hi */param[/* hi */0] ^ param$1[/* hi */0],\n /* lo */((param[/* lo */1] ^ param$1[/* lo */1]) >>> 0)\n ];\n}\n\nfunction or_(param, param$1) {\n return /* record */[\n /* hi */param[/* hi */0] | param$1[/* hi */0],\n /* lo */((param[/* lo */1] | param$1[/* lo */1]) >>> 0)\n ];\n}\n\nfunction and_(param, param$1) {\n return /* record */[\n /* hi */param[/* hi */0] & param$1[/* hi */0],\n /* lo */((param[/* lo */1] & param$1[/* lo */1]) >>> 0)\n ];\n}\n\nfunction ge(param, param$1) {\n var other_hi = param$1[/* hi */0];\n var hi = param[/* hi */0];\n if (hi > other_hi) {\n return /* true */1;\n } else if (hi < other_hi) {\n return /* false */0;\n } else {\n return +(param[/* lo */1] >= param$1[/* lo */1]);\n }\n}\n\nfunction neq(x, y) {\n return 1 - eq(x, y);\n}\n\nfunction lt(x, y) {\n return 1 - ge(x, y);\n}\n\nfunction gt(x, y) {\n if (x[/* hi */0] > y[/* hi */0]) {\n return /* true */1;\n } else if (x[/* hi */0] < y[/* hi */0]) {\n return /* false */0;\n } else {\n return +(x[/* lo */1] > y[/* lo */1]);\n }\n}\n\nfunction le(x, y) {\n return 1 - gt(x, y);\n}\n\nfunction to_float(param) {\n return param[/* hi */0] * (0x100000000) + param[/* lo */1];\n}\n\nvar two_ptr_32_dbl = Math.pow(2, 32);\n\nvar two_ptr_63_dbl = Math.pow(2, 63);\n\nvar neg_two_ptr_63 = -Math.pow(2, 63);\n\nfunction of_float(x) {\n if (isNaN(x) || !isFinite(x)) {\n return zero;\n } else if (x <= neg_two_ptr_63) {\n return min_int;\n } else if (x + 1 >= two_ptr_63_dbl) {\n return max_int;\n } else if (x < 0) {\n return neg(of_float(-x));\n } else {\n var hi = x / two_ptr_32_dbl | 0;\n var lo = x % two_ptr_32_dbl | 0;\n return /* record */[\n /* hi */hi,\n /* lo */(lo >>> 0)\n ];\n }\n}\n\nfunction div(_self, _other) {\n while(true) {\n var other = _other;\n var self = _self;\n var self_hi = self[/* hi */0];\n var exit = 0;\n var exit$1 = 0;\n if (other[/* hi */0] !== 0) {\n exit$1 = 2;\n } else if (other[/* lo */1] !== 0) {\n exit$1 = 2;\n } else {\n throw Caml_builtin_exceptions.division_by_zero;\n }\n if (exit$1 === 2) {\n if (self_hi !== -2147483648) {\n if (self_hi !== 0) {\n exit = 1;\n } else if (self[/* lo */1] !== 0) {\n exit = 1;\n } else {\n return zero;\n }\n } else if (self[/* lo */1] !== 0) {\n exit = 1;\n } else if (eq(other, one) || eq(other, neg_one)) {\n return self;\n } else if (eq(other, min_int)) {\n return one;\n } else {\n var other_hi = other[/* hi */0];\n var half_this = asr_(self, 1);\n var approx = lsl_(div(half_this, other), 1);\n var exit$2 = 0;\n if (approx[/* hi */0] !== 0) {\n exit$2 = 3;\n } else if (approx[/* lo */1] !== 0) {\n exit$2 = 3;\n } else if (other_hi < 0) {\n return one;\n } else {\n return neg(one);\n }\n if (exit$2 === 3) {\n var y = mul(other, approx);\n var rem = add(self, neg(y));\n return add(approx, div(rem, other));\n }\n \n }\n }\n if (exit === 1) {\n var other_hi$1 = other[/* hi */0];\n var exit$3 = 0;\n if (other_hi$1 !== -2147483648) {\n exit$3 = 2;\n } else if (other[/* lo */1] !== 0) {\n exit$3 = 2;\n } else {\n return zero;\n }\n if (exit$3 === 2) {\n if (self_hi < 0) {\n if (other_hi$1 < 0) {\n _other = neg(other);\n _self = neg(self);\n continue ;\n \n } else {\n return neg(div(neg(self), other));\n }\n } else if (other_hi$1 < 0) {\n return neg(div(self, neg(other)));\n } else {\n var res = zero;\n var rem$1 = self;\n while(ge(rem$1, other)) {\n var approx$1 = Math.max(1, Math.floor(to_float(rem$1) / to_float(other)));\n var log2 = Math.ceil(Math.log(approx$1) / Math.LN2);\n var delta = log2 <= 48 ? 1 : Math.pow(2, log2 - 48);\n var approxRes = of_float(approx$1);\n var approxRem = mul(approxRes, other);\n while(approxRem[/* hi */0] < 0 || gt(approxRem, rem$1)) {\n approx$1 -= delta;\n approxRes = of_float(approx$1);\n approxRem = mul(approxRes, other);\n };\n if (is_zero(approxRes)) {\n approxRes = one;\n }\n res = add(res, approxRes);\n rem$1 = add(rem$1, neg(approxRem));\n };\n return res;\n }\n }\n \n }\n \n };\n}\n\nfunction mod_(self, other) {\n var y = mul(div(self, other), other);\n return add(self, neg(y));\n}\n\nfunction div_mod(self, other) {\n var quotient = div(self, other);\n var y = mul(quotient, other);\n return /* tuple */[\n quotient,\n add(self, neg(y))\n ];\n}\n\nfunction compare(self, other) {\n var v = Caml_obj.caml_nativeint_compare(self[/* hi */0], other[/* hi */0]);\n if (v) {\n return v;\n } else {\n return Caml_obj.caml_nativeint_compare(self[/* lo */1], other[/* lo */1]);\n }\n}\n\nfunction of_int32(lo) {\n return /* record */[\n /* hi */lo < 0 ? -1 : 0,\n /* lo */(lo >>> 0)\n ];\n}\n\nfunction to_int32(x) {\n return x[/* lo */1] | 0;\n}\n\nfunction to_hex(x) {\n var aux = function (v) {\n return (v >>> 0).toString(16);\n };\n var match = x[/* hi */0];\n var match$1 = x[/* lo */1];\n var exit = 0;\n if (match !== 0) {\n exit = 1;\n } else if (match$1 !== 0) {\n exit = 1;\n } else {\n return \"0\";\n }\n if (exit === 1) {\n if (match$1 !== 0) {\n if (match !== 0) {\n var lo = aux(x[/* lo */1]);\n var pad = 8 - lo.length | 0;\n if (pad <= 0) {\n return aux(x[/* hi */0]) + lo;\n } else {\n return aux(x[/* hi */0]) + (Caml_utils.repeat(pad, \"0\") + lo);\n }\n } else {\n return aux(x[/* lo */1]);\n }\n } else {\n return aux(x[/* hi */0]) + \"00000000\";\n }\n }\n \n}\n\nfunction discard_sign(x) {\n return /* record */[\n /* hi */2147483647 & x[/* hi */0],\n /* lo */x[/* lo */1]\n ];\n}\n\nfunction float_of_bits(x) {\n var int32 = new Int32Array(/* array */[\n x[/* lo */1],\n x[/* hi */0]\n ]);\n return new Float64Array(int32.buffer)[0];\n}\n\nfunction bits_of_float(x) {\n var u = new Float64Array(/* float array */[x]);\n var int32 = new Int32Array(u.buffer);\n var x$1 = int32[1];\n var hi = x$1;\n var x$2 = int32[0];\n var lo = x$2;\n return /* record */[\n /* hi */hi,\n /* lo */(lo >>> 0)\n ];\n}\n\nfunction get64(s, i) {\n var hi = (s.charCodeAt(i + 4 | 0) << 32) | (s.charCodeAt(i + 5 | 0) << 40) | (s.charCodeAt(i + 6 | 0) << 48) | (s.charCodeAt(i + 7 | 0) << 56);\n var lo = s.charCodeAt(i) | (s.charCodeAt(i + 1 | 0) << 8) | (s.charCodeAt(i + 2 | 0) << 16) | (s.charCodeAt(i + 3 | 0) << 24);\n return /* record */[\n /* hi */hi,\n /* lo */(lo >>> 0)\n ];\n}\n\nexports.min_int = min_int;\nexports.max_int = max_int;\nexports.one = one;\nexports.zero = zero;\nexports.not = not;\nexports.of_int32 = of_int32;\nexports.to_int32 = to_int32;\nexports.add = add;\nexports.neg = neg;\nexports.sub = sub;\nexports.lsl_ = lsl_;\nexports.lsr_ = lsr_;\nexports.asr_ = asr_;\nexports.is_zero = is_zero;\nexports.mul = mul;\nexports.xor = xor;\nexports.or_ = or_;\nexports.and_ = and_;\nexports.swap = swap;\nexports.ge = ge;\nexports.eq = eq;\nexports.neq = neq;\nexports.lt = lt;\nexports.gt = gt;\nexports.le = le;\nexports.to_float = to_float;\nexports.of_float = of_float;\nexports.div = div;\nexports.mod_ = mod_;\nexports.div_mod = div_mod;\nexports.compare = compare;\nexports.to_hex = to_hex;\nexports.discard_sign = discard_sign;\nexports.float_of_bits = float_of_bits;\nexports.bits_of_float = bits_of_float;\nexports.get64 = get64;\n/* two_ptr_32_dbl Not a pure module */\n"
},
{
"id": 26,
"identifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/fbjs/lib/ExecutionEnvironment.js",
"name": "./node_modules/fbjs/lib/ExecutionEnvironment.js",
"index": 71,
"index2": 67,
"size": 935,
"cacheable": true,
"built": true,
"optional": false,
"prefetched": false,
"chunks": [
0
],
"assets": [],
"issuer": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/react-dom/cjs/react-dom.production.min.js",
"issuerId": 77,
"issuerName": "./node_modules/react-dom/cjs/react-dom.production.min.js",
"failed": false,
"errors": 0,
"warnings": 0,
"reasons": [
{
"moduleId": 77,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/react-dom/cjs/react-dom.production.min.js",
"module": "./node_modules/react-dom/cjs/react-dom.production.min.js",
"moduleName": "./node_modules/react-dom/cjs/react-dom.production.min.js",
"type": "cjs require",
"userRequest": "fbjs/lib/ExecutionEnvironment",
"loc": "11:73-113"
},
{
"moduleId": 80,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/react-dom/cjs/react-dom.development.js",
"module": "./node_modules/react-dom/cjs/react-dom.development.js",
"moduleName": "./node_modules/react-dom/cjs/react-dom.development.js",
"type": "cjs require",
"userRequest": "fbjs/lib/ExecutionEnvironment",
"loc": "19:27-67"
},
{
"moduleId": 86,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/fbjs/lib/performance.js",
"module": "./node_modules/fbjs/lib/performance.js",
"moduleName": "./node_modules/fbjs/lib/performance.js",
"type": "cjs require",
"userRequest": "./ExecutionEnvironment",
"loc": "12:27-60"
}
],
"usedExports": true,
"providedExports": null,
"optimizationBailout": [],
"depth": 4,
"source": "/**\n * Copyright (c) 2013-present, Facebook, Inc.\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 */\n\n'use strict';\n\nvar canUseDOM = !!(typeof window !== 'undefined' && window.document && window.document.createElement);\n\n/**\n * Simple, lightweight module assisting with the detection and context of\n * Worker. Helps avoid circular dependencies and allows code to reason about\n * whether or not they are in a Worker, even if they never include the main\n * `ReactWorker` dependency.\n */\nvar ExecutionEnvironment = {\n\n canUseDOM: canUseDOM,\n\n canUseWorkers: typeof Worker !== 'undefined',\n\n canUseEventListeners: canUseDOM && !!(window.addEventListener || window.attachEvent),\n\n canUseViewport: canUseDOM && !!window.screen,\n\n isInWorker: !canUseDOM // For now, this is true - might change in the future.\n\n};\n\nmodule.exports = ExecutionEnvironment;"
},
{
"id": 27,
"identifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/jquery/dist/jquery.js",
"name": "./node_modules/jquery/dist/jquery.js",
"index": 91,
"index2": 89,
"size": 268039,
"cacheable": true,
"built": true,
"optional": false,
"prefetched": false,
"chunks": [
0
],
"assets": [],
"issuer": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/materialize-css/dist/js/materialize.js",
"issuerId": 90,
"issuerName": "./node_modules/materialize-css/dist/js/materialize.js",
"failed": false,
"errors": 0,
"warnings": 0,
"reasons": [
{
"moduleId": 90,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/materialize-css/dist/js/materialize.js",
"module": "./node_modules/materialize-css/dist/js/materialize.js",
"moduleName": "./node_modules/materialize-css/dist/js/materialize.js",
"type": "cjs require",
"userRequest": "jquery",
"loc": "14:17-34"
},
{
"moduleId": 90,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/materialize-css/dist/js/materialize.js",
"module": "./node_modules/materialize-css/dist/js/materialize.js",
"moduleName": "./node_modules/materialize-css/dist/js/materialize.js",
"type": "amd require",
"userRequest": "jquery",
"loc": "30:4-32:6"
},
{
"moduleId": 90,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/materialize-css/dist/js/materialize.js",
"module": "./node_modules/materialize-css/dist/js/materialize.js",
"moduleName": "./node_modules/materialize-css/dist/js/materialize.js",
"type": "amd require",
"userRequest": "jquery",
"loc": "1220:4-43"
}
],
"usedExports": true,
"providedExports": null,
"optimizationBailout": [],
"depth": 2,
"source": "/*!\n * jQuery JavaScript Library v3.2.1\n * https://jquery.com/\n *\n * Includes Sizzle.js\n * https://sizzlejs.com/\n *\n * Copyright JS Foundation and other contributors\n * Released under the MIT license\n * https://jquery.org/license\n *\n * Date: 2017-03-20T18:59Z\n */\n( function( global, factory ) {\n\n\t\"use strict\";\n\n\tif ( typeof module === \"object\" && typeof module.exports === \"object\" ) {\n\n\t\t// For CommonJS and CommonJS-like environments where a proper `window`\n\t\t// is present, execute the factory and get jQuery.\n\t\t// For environments that do not have a `window` with a `document`\n\t\t// (such as Node.js), expose a factory as module.exports.\n\t\t// This accentuates the need for the creation of a real `window`.\n\t\t// e.g. var jQuery = require(\"jquery\")(window);\n\t\t// See ticket #14549 for more info.\n\t\tmodule.exports = global.document ?\n\t\t\tfactory( global, true ) :\n\t\t\tfunction( w ) {\n\t\t\t\tif ( !w.document ) {\n\t\t\t\t\tthrow new Error( \"jQuery requires a window with a document\" );\n\t\t\t\t}\n\t\t\t\treturn factory( w );\n\t\t\t};\n\t} else {\n\t\tfactory( global );\n\t}\n\n// Pass this if window is not defined yet\n} )( typeof window !== \"undefined\" ? window : this, function( window, noGlobal ) {\n\n// Edge <= 12 - 13+, Firefox <=18 - 45+, IE 10 - 11, Safari 5.1 - 9+, iOS 6 - 9.1\n// throw exceptions when non-strict code (e.g., ASP.NET 4.5) accesses strict mode\n// arguments.callee.caller (trac-13335). But as of jQuery 3.0 (2016), strict mode should be common\n// enough that all such attempts are guarded in a try block.\n\"use strict\";\n\nvar arr = [];\n\nvar document = window.document;\n\nvar getProto = Object.getPrototypeOf;\n\nvar slice = arr.slice;\n\nvar concat = arr.concat;\n\nvar push = arr.push;\n\nvar indexOf = arr.indexOf;\n\nvar class2type = {};\n\nvar toString = class2type.toString;\n\nvar hasOwn = class2type.hasOwnProperty;\n\nvar fnToString = hasOwn.toString;\n\nvar ObjectFunctionString = fnToString.call( Object );\n\nvar support = {};\n\n\n\n\tfunction DOMEval( code, doc ) {\n\t\tdoc = doc || document;\n\n\t\tvar script = doc.createElement( \"script\" );\n\n\t\tscript.text = code;\n\t\tdoc.head.appendChild( script ).parentNode.removeChild( script );\n\t}\n/* global Symbol */\n// Defining this global in .eslintrc.json would create a danger of using the global\n// unguarded in another place, it seems safer to define global only for this module\n\n\n\nvar\n\tversion = \"3.2.1\",\n\n\t// Define a local copy of jQuery\n\tjQuery = function( selector, context ) {\n\n\t\t// The jQuery object is actually just the init constructor 'enhanced'\n\t\t// Need init if jQuery is called (just allow error to be thrown if not included)\n\t\treturn new jQuery.fn.init( selector, context );\n\t},\n\n\t// Support: Android <=4.0 only\n\t// Make sure we trim BOM and NBSP\n\trtrim = /^[\\s\\uFEFF\\xA0]+|[\\s\\uFEFF\\xA0]+$/g,\n\n\t// Matches dashed string for camelizing\n\trmsPrefix = /^-ms-/,\n\trdashAlpha = /-([a-z])/g,\n\n\t// Used by jQuery.camelCase as callback to replace()\n\tfcamelCase = function( all, letter ) {\n\t\treturn letter.toUpperCase();\n\t};\n\njQuery.fn = jQuery.prototype = {\n\n\t// The current version of jQuery being used\n\tjquery: version,\n\n\tconstructor: jQuery,\n\n\t// The default length of a jQuery object is 0\n\tlength: 0,\n\n\ttoArray: function() {\n\t\treturn slice.call( this );\n\t},\n\n\t// Get the Nth element in the matched element set OR\n\t// Get the whole matched element set as a clean array\n\tget: function( num ) {\n\n\t\t// Return all the elements in a clean array\n\t\tif ( num == null ) {\n\t\t\treturn slice.call( this );\n\t\t}\n\n\t\t// Return just the one element from the set\n\t\treturn num < 0 ? this[ num + this.length ] : this[ num ];\n\t},\n\n\t// Take an array of elements and push it onto the stack\n\t// (returning the new matched element set)\n\tpushStack: function( elems ) {\n\n\t\t// Build a new jQuery matched element set\n\t\tvar ret = jQuery.merge( this.constructor(), elems );\n\n\t\t// Add the old object onto the stack (as a reference)\n\t\tret.prevObject = this;\n\n\t\t// Return the newly-formed element set\n\t\treturn ret;\n\t},\n\n\t// Execute a callback for every element in the matched set.\n\teach: function( callback ) {\n\t\treturn jQuery.each( this, callback );\n\t},\n\n\tmap: function( callback ) {\n\t\treturn this.pushStack( jQuery.map( this, function( elem, i ) {\n\t\t\treturn callback.call( elem, i, elem );\n\t\t} ) );\n\t},\n\n\tslice: function() {\n\t\treturn this.pushStack( slice.apply( this, arguments ) );\n\t},\n\n\tfirst: function() {\n\t\treturn this.eq( 0 );\n\t},\n\n\tlast: function() {\n\t\treturn this.eq( -1 );\n\t},\n\n\teq: function( i ) {\n\t\tvar len = this.length,\n\t\t\tj = +i + ( i < 0 ? len : 0 );\n\t\treturn this.pushStack( j >= 0 && j < len ? [ this[ j ] ] : [] );\n\t},\n\n\tend: function() {\n\t\treturn this.prevObject || this.constructor();\n\t},\n\n\t// For internal use only.\n\t// Behaves like an Array's method, not like a jQuery method.\n\tpush: push,\n\tsort: arr.sort,\n\tsplice: arr.splice\n};\n\njQuery.extend = jQuery.fn.extend = function() {\n\tvar options, name, src, copy, copyIsArray, clone,\n\t\ttarget = arguments[ 0 ] || {},\n\t\ti = 1,\n\t\tlength = arguments.length,\n\t\tdeep = false;\n\n\t// Handle a deep copy situation\n\tif ( typeof target === \"boolean\" ) {\n\t\tdeep = target;\n\n\t\t// Skip the boolean and the target\n\t\ttarget = arguments[ i ] || {};\n\t\ti++;\n\t}\n\n\t// Handle case when target is a string or something (possible in deep copy)\n\tif ( typeof target !== \"object\" && !jQuery.isFunction( target ) ) {\n\t\ttarget = {};\n\t}\n\n\t// Extend jQuery itself if only one argument is passed\n\tif ( i === length ) {\n\t\ttarget = this;\n\t\ti--;\n\t}\n\n\tfor ( ; i < length; i++ ) {\n\n\t\t// Only deal with non-null/undefined values\n\t\tif ( ( options = arguments[ i ] ) != null ) {\n\n\t\t\t// Extend the base object\n\t\t\tfor ( name in options ) {\n\t\t\t\tsrc = target[ name ];\n\t\t\t\tcopy = options[ name ];\n\n\t\t\t\t// Prevent never-ending loop\n\t\t\t\tif ( target === copy ) {\n\t\t\t\t\tcontinue;\n\t\t\t\t}\n\n\t\t\t\t// Recurse if we're merging plain objects or arrays\n\t\t\t\tif ( deep && copy && ( jQuery.isPlainObject( copy ) ||\n\t\t\t\t\t( copyIsArray = Array.isArray( copy ) ) ) ) {\n\n\t\t\t\t\tif ( copyIsArray ) {\n\t\t\t\t\t\tcopyIsArray = false;\n\t\t\t\t\t\tclone = src && Array.isArray( src ) ? src : [];\n\n\t\t\t\t\t} else {\n\t\t\t\t\t\tclone = src && jQuery.isPlainObject( src ) ? src : {};\n\t\t\t\t\t}\n\n\t\t\t\t\t// Never move original objects, clone them\n\t\t\t\t\ttarget[ name ] = jQuery.extend( deep, clone, copy );\n\n\t\t\t\t// Don't bring in undefined values\n\t\t\t\t} else if ( copy !== undefined ) {\n\t\t\t\t\ttarget[ name ] = copy;\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n\n\t// Return the modified object\n\treturn target;\n};\n\njQuery.extend( {\n\n\t// Unique for each copy of jQuery on the page\n\texpando: \"jQuery\" + ( version + Math.random() ).replace( /\\D/g, \"\" ),\n\n\t// Assume jQuery is ready without the ready module\n\tisReady: true,\n\n\terror: function( msg ) {\n\t\tthrow new Error( msg );\n\t},\n\n\tnoop: function() {},\n\n\tisFunction: function( obj ) {\n\t\treturn jQuery.type( obj ) === \"function\";\n\t},\n\n\tisWindow: function( obj ) {\n\t\treturn obj != null && obj === obj.window;\n\t},\n\n\tisNumeric: function( obj ) {\n\n\t\t// As of jQuery 3.0, isNumeric is limited to\n\t\t// strings and numbers (primitives or objects)\n\t\t// that can be coerced to finite numbers (gh-2662)\n\t\tvar type = jQuery.type( obj );\n\t\treturn ( type === \"number\" || type === \"string\" ) &&\n\n\t\t\t// parseFloat NaNs numeric-cast false positives (\"\")\n\t\t\t// ...but misinterprets leading-number strings, particularly hex literals (\"0x...\")\n\t\t\t// subtraction forces infinities to NaN\n\t\t\t!isNaN( obj - parseFloat( obj ) );\n\t},\n\n\tisPlainObject: function( obj ) {\n\t\tvar proto, Ctor;\n\n\t\t// Detect obvious negatives\n\t\t// Use toString instead of jQuery.type to catch host objects\n\t\tif ( !obj || toString.call( obj ) !== \"[object Object]\" ) {\n\t\t\treturn false;\n\t\t}\n\n\t\tproto = getProto( obj );\n\n\t\t// Objects with no prototype (e.g., `Object.create( null )`) are plain\n\t\tif ( !proto ) {\n\t\t\treturn true;\n\t\t}\n\n\t\t// Objects with prototype are plain iff they were constructed by a global Object function\n\t\tCtor = hasOwn.call( proto, \"constructor\" ) && proto.constructor;\n\t\treturn typeof Ctor === \"function\" && fnToString.call( Ctor ) === ObjectFunctionString;\n\t},\n\n\tisEmptyObject: function( obj ) {\n\n\t\t/* eslint-disable no-unused-vars */\n\t\t// See https://github.com/eslint/eslint/issues/6125\n\t\tvar name;\n\n\t\tfor ( name in obj ) {\n\t\t\treturn false;\n\t\t}\n\t\treturn true;\n\t},\n\n\ttype: function( obj ) {\n\t\tif ( obj == null ) {\n\t\t\treturn obj + \"\";\n\t\t}\n\n\t\t// Support: Android <=2.3 only (functionish RegExp)\n\t\treturn typeof obj === \"object\" || typeof obj === \"function\" ?\n\t\t\tclass2type[ toString.call( obj ) ] || \"object\" :\n\t\t\ttypeof obj;\n\t},\n\n\t// Evaluates a script in a global context\n\tglobalEval: function( code ) {\n\t\tDOMEval( code );\n\t},\n\n\t// Convert dashed to camelCase; used by the css and data modules\n\t// Support: IE <=9 - 11, Edge 12 - 13\n\t// Microsoft forgot to hump their vendor prefix (#9572)\n\tcamelCase: function( string ) {\n\t\treturn string.replace( rmsPrefix, \"ms-\" ).replace( rdashAlpha, fcamelCase );\n\t},\n\n\teach: function( obj, callback ) {\n\t\tvar length, i = 0;\n\n\t\tif ( isArrayLike( obj ) ) {\n\t\t\tlength = obj.length;\n\t\t\tfor ( ; i < length; i++ ) {\n\t\t\t\tif ( callback.call( obj[ i ], i, obj[ i ] ) === false ) {\n\t\t\t\t\tbreak;\n\t\t\t\t}\n\t\t\t}\n\t\t} else {\n\t\t\tfor ( i in obj ) {\n\t\t\t\tif ( callback.call( obj[ i ], i, obj[ i ] ) === false ) {\n\t\t\t\t\tbreak;\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\treturn obj;\n\t},\n\n\t// Support: Android <=4.0 only\n\ttrim: function( text ) {\n\t\treturn text == null ?\n\t\t\t\"\" :\n\t\t\t( text + \"\" ).replace( rtrim, \"\" );\n\t},\n\n\t// results is for internal usage only\n\tmakeArray: function( arr, results ) {\n\t\tvar ret = results || [];\n\n\t\tif ( arr != null ) {\n\t\t\tif ( isArrayLike( Object( arr ) ) ) {\n\t\t\t\tjQuery.merge( ret,\n\t\t\t\t\ttypeof arr === \"string\" ?\n\t\t\t\t\t[ arr ] : arr\n\t\t\t\t);\n\t\t\t} else {\n\t\t\t\tpush.call( ret, arr );\n\t\t\t}\n\t\t}\n\n\t\treturn ret;\n\t},\n\n\tinArray: function( elem, arr, i ) {\n\t\treturn arr == null ? -1 : indexOf.call( arr, elem, i );\n\t},\n\n\t// Support: Android <=4.0 only, PhantomJS 1 only\n\t// push.apply(_, arraylike) throws on ancient WebKit\n\tmerge: function( first, second ) {\n\t\tvar len = +second.length,\n\t\t\tj = 0,\n\t\t\ti = first.length;\n\n\t\tfor ( ; j < len; j++ ) {\n\t\t\tfirst[ i++ ] = second[ j ];\n\t\t}\n\n\t\tfirst.length = i;\n\n\t\treturn first;\n\t},\n\n\tgrep: function( elems, callback, invert ) {\n\t\tvar callbackInverse,\n\t\t\tmatches = [],\n\t\t\ti = 0,\n\t\t\tlength = elems.length,\n\t\t\tcallbackExpect = !invert;\n\n\t\t// Go through the array, only saving the items\n\t\t// that pass the validator function\n\t\tfor ( ; i < length; i++ ) {\n\t\t\tcallbackInverse = !callback( elems[ i ], i );\n\t\t\tif ( callbackInverse !== callbackExpect ) {\n\t\t\t\tmatches.push( elems[ i ] );\n\t\t\t}\n\t\t}\n\n\t\treturn matches;\n\t},\n\n\t// arg is for internal usage only\n\tmap: function( elems, callback, arg ) {\n\t\tvar length, value,\n\t\t\ti = 0,\n\t\t\tret = [];\n\n\t\t// Go through the array, translating each of the items to their new values\n\t\tif ( isArrayLike( elems ) ) {\n\t\t\tlength = elems.length;\n\t\t\tfor ( ; i < length; i++ ) {\n\t\t\t\tvalue = callback( elems[ i ], i, arg );\n\n\t\t\t\tif ( value != null ) {\n\t\t\t\t\tret.push( value );\n\t\t\t\t}\n\t\t\t}\n\n\t\t// Go through every key on the object,\n\t\t} else {\n\t\t\tfor ( i in elems ) {\n\t\t\t\tvalue = callback( elems[ i ], i, arg );\n\n\t\t\t\tif ( value != null ) {\n\t\t\t\t\tret.push( value );\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\t// Flatten any nested arrays\n\t\treturn concat.apply( [], ret );\n\t},\n\n\t// A global GUID counter for objects\n\tguid: 1,\n\n\t// Bind a function to a context, optionally partially applying any\n\t// arguments.\n\tproxy: function( fn, context ) {\n\t\tvar tmp, args, proxy;\n\n\t\tif ( typeof context === \"string\" ) {\n\t\t\ttmp = fn[ context ];\n\t\t\tcontext = fn;\n\t\t\tfn = tmp;\n\t\t}\n\n\t\t// Quick check to determine if target is callable, in the spec\n\t\t// this throws a TypeError, but we will just return undefined.\n\t\tif ( !jQuery.isFunction( fn ) ) {\n\t\t\treturn undefined;\n\t\t}\n\n\t\t// Simulated bind\n\t\targs = slice.call( arguments, 2 );\n\t\tproxy = function() {\n\t\t\treturn fn.apply( context || this, args.concat( slice.call( arguments ) ) );\n\t\t};\n\n\t\t// Set the guid of unique handler to the same of original handler, so it can be removed\n\t\tproxy.guid = fn.guid = fn.guid || jQuery.guid++;\n\n\t\treturn proxy;\n\t},\n\n\tnow: Date.now,\n\n\t// jQuery.support is not used in Core but other projects attach their\n\t// properties to it so it needs to exist.\n\tsupport: support\n} );\n\nif ( typeof Symbol === \"function\" ) {\n\tjQuery.fn[ Symbol.iterator ] = arr[ Symbol.iterator ];\n}\n\n// Populate the class2type map\njQuery.each( \"Boolean Number String Function Array Date RegExp Object Error Symbol\".split( \" \" ),\nfunction( i, name ) {\n\tclass2type[ \"[object \" + name + \"]\" ] = name.toLowerCase();\n} );\n\nfunction isArrayLike( obj ) {\n\n\t// Support: real iOS 8.2 only (not reproducible in simulator)\n\t// `in` check used to prevent JIT error (gh-2145)\n\t// hasOwn isn't used here due to false negatives\n\t// regarding Nodelist length in IE\n\tvar length = !!obj && \"length\" in obj && obj.length,\n\t\ttype = jQuery.type( obj );\n\n\tif ( type === \"function\" || jQuery.isWindow( obj ) ) {\n\t\treturn false;\n\t}\n\n\treturn type === \"array\" || length === 0 ||\n\t\ttypeof length === \"number\" && length > 0 && ( length - 1 ) in obj;\n}\nvar Sizzle =\n/*!\n * Sizzle CSS Selector Engine v2.3.3\n * https://sizzlejs.com/\n *\n * Copyright jQuery Foundation and other contributors\n * Released under the MIT license\n * http://jquery.org/license\n *\n * Date: 2016-08-08\n */\n(function( window ) {\n\nvar i,\n\tsupport,\n\tExpr,\n\tgetText,\n\tisXML,\n\ttokenize,\n\tcompile,\n\tselect,\n\toutermostContext,\n\tsortInput,\n\thasDuplicate,\n\n\t// Local document vars\n\tsetDocument,\n\tdocument,\n\tdocElem,\n\tdocumentIsHTML,\n\trbuggyQSA,\n\trbuggyMatches,\n\tmatches,\n\tcontains,\n\n\t// Instance-specific data\n\texpando = \"sizzle\" + 1 * new Date(),\n\tpreferredDoc = window.document,\n\tdirruns = 0,\n\tdone = 0,\n\tclassCache = createCache(),\n\ttokenCache = createCache(),\n\tcompilerCache = createCache(),\n\tsortOrder = function( a, b ) {\n\t\tif ( a === b ) {\n\t\t\thasDuplicate = true;\n\t\t}\n\t\treturn 0;\n\t},\n\n\t// Instance methods\n\thasOwn = ({}).hasOwnProperty,\n\tarr = [],\n\tpop = arr.pop,\n\tpush_native = arr.push,\n\tpush = arr.push,\n\tslice = arr.slice,\n\t// Use a stripped-down indexOf as it's faster than native\n\t// https://jsperf.com/thor-indexof-vs-for/5\n\tindexOf = function( list, elem ) {\n\t\tvar i = 0,\n\t\t\tlen = list.length;\n\t\tfor ( ; i < len; i++ ) {\n\t\t\tif ( list[i] === elem ) {\n\t\t\t\treturn i;\n\t\t\t}\n\t\t}\n\t\treturn -1;\n\t},\n\n\tbooleans = \"checked|selected|async|autofocus|autoplay|controls|defer|disabled|hidden|ismap|loop|multiple|open|readonly|required|scoped\",\n\n\t// Regular expressions\n\n\t// http://www.w3.org/TR/css3-selectors/#whitespace\n\twhitespace = \"[\\\\x20\\\\t\\\\r\\\\n\\\\f]\",\n\n\t// http://www.w3.org/TR/CSS21/syndata.html#value-def-identifier\n\tidentifier = \"(?:\\\\\\\\.|[\\\\w-]|[^\\0-\\\\xa0])+\",\n\n\t// Attribute selectors: http://www.w3.org/TR/selectors/#attribute-selectors\n\tattributes = \"\\\\[\" + whitespace + \"*(\" + identifier + \")(?:\" + whitespace +\n\t\t// Operator (capture 2)\n\t\t\"*([*^$|!~]?=)\" + whitespace +\n\t\t// \"Attribute values must be CSS identifiers [capture 5] or strings [capture 3 or capture 4]\"\n\t\t\"*(?:'((?:\\\\\\\\.|[^\\\\\\\\'])*)'|\\\"((?:\\\\\\\\.|[^\\\\\\\\\\\"])*)\\\"|(\" + identifier + \"))|)\" + whitespace +\n\t\t\"*\\\\]\",\n\n\tpseudos = \":(\" + identifier + \")(?:\\\\((\" +\n\t\t// To reduce the number of selectors needing tokenize in the preFilter, prefer arguments:\n\t\t// 1. quoted (capture 3; capture 4 or capture 5)\n\t\t\"('((?:\\\\\\\\.|[^\\\\\\\\'])*)'|\\\"((?:\\\\\\\\.|[^\\\\\\\\\\\"])*)\\\")|\" +\n\t\t// 2. simple (capture 6)\n\t\t\"((?:\\\\\\\\.|[^\\\\\\\\()[\\\\]]|\" + attributes + \")*)|\" +\n\t\t// 3. anything else (capture 2)\n\t\t\".*\" +\n\t\t\")\\\\)|)\",\n\n\t// Leading and non-escaped trailing whitespace, capturing some non-whitespace characters preceding the latter\n\trwhitespace = new RegExp( whitespace + \"+\", \"g\" ),\n\trtrim = new RegExp( \"^\" + whitespace + \"+|((?:^|[^\\\\\\\\])(?:\\\\\\\\.)*)\" + whitespace + \"+$\", \"g\" ),\n\n\trcomma = new RegExp( \"^\" + whitespace + \"*,\" + whitespace + \"*\" ),\n\trcombinators = new RegExp( \"^\" + whitespace + \"*([>+~]|\" + whitespace + \")\" + whitespace + \"*\" ),\n\n\trattributeQuotes = new RegExp( \"=\" + whitespace + \"*([^\\\\]'\\\"]*?)\" + whitespace + \"*\\\\]\", \"g\" ),\n\n\trpseudo = new RegExp( pseudos ),\n\tridentifier = new RegExp( \"^\" + identifier + \"$\" ),\n\n\tmatchExpr = {\n\t\t\"ID\": new RegExp( \"^#(\" + identifier + \")\" ),\n\t\t\"CLASS\": new RegExp( \"^\\\\.(\" + identifier + \")\" ),\n\t\t\"TAG\": new RegExp( \"^(\" + identifier + \"|[*])\" ),\n\t\t\"ATTR\": new RegExp( \"^\" + attributes ),\n\t\t\"PSEUDO\": new RegExp( \"^\" + pseudos ),\n\t\t\"CHILD\": new RegExp( \"^:(only|first|last|nth|nth-last)-(child|of-type)(?:\\\\(\" + whitespace +\n\t\t\t\"*(even|odd|(([+-]|)(\\\\d*)n|)\" + whitespace + \"*(?:([+-]|)\" + whitespace +\n\t\t\t\"*(\\\\d+)|))\" + whitespace + \"*\\\\)|)\", \"i\" ),\n\t\t\"bool\": new RegExp( \"^(?:\" + booleans + \")$\", \"i\" ),\n\t\t// For use in libraries implementing .is()\n\t\t// We use this for POS matching in `select`\n\t\t\"needsContext\": new RegExp( \"^\" + whitespace + \"*[>+~]|:(even|odd|eq|gt|lt|nth|first|last)(?:\\\\(\" +\n\t\t\twhitespace + \"*((?:-\\\\d)?\\\\d*)\" + whitespace + \"*\\\\)|)(?=[^-]|$)\", \"i\" )\n\t},\n\n\trinputs = /^(?:input|select|textarea|button)$/i,\n\trheader = /^h\\d$/i,\n\n\trnative = /^[^{]+\\{\\s*\\[native \\w/,\n\n\t// Easily-parseable/retrievable ID or TAG or CLASS selectors\n\trquickExpr = /^(?:#([\\w-]+)|(\\w+)|\\.([\\w-]+))$/,\n\n\trsibling = /[+~]/,\n\n\t// CSS escapes\n\t// http://www.w3.org/TR/CSS21/syndata.html#escaped-characters\n\trunescape = new RegExp( \"\\\\\\\\([\\\\da-f]{1,6}\" + whitespace + \"?|(\" + whitespace + \")|.)\", \"ig\" ),\n\tfunescape = function( _, escaped, escapedWhitespace ) {\n\t\tvar high = \"0x\" + escaped - 0x10000;\n\t\t// NaN means non-codepoint\n\t\t// Support: Firefox<24\n\t\t// Workaround erroneous numeric interpretation of +\"0x\"\n\t\treturn high !== high || escapedWhitespace ?\n\t\t\tescaped :\n\t\t\thigh < 0 ?\n\t\t\t\t// BMP codepoint\n\t\t\t\tString.fromCharCode( high + 0x10000 ) :\n\t\t\t\t// Supplemental Plane codepoint (surrogate pair)\n\t\t\t\tString.fromCharCode( high >> 10 | 0xD800, high & 0x3FF | 0xDC00 );\n\t},\n\n\t// CSS string/identifier serialization\n\t// https://drafts.csswg.org/cssom/#common-serializing-idioms\n\trcssescape = /([\\0-\\x1f\\x7f]|^-?\\d)|^-$|[^\\0-\\x1f\\x7f-\\uFFFF\\w-]/g,\n\tfcssescape = function( ch, asCodePoint ) {\n\t\tif ( asCodePoint ) {\n\n\t\t\t// U+0000 NULL becomes U+FFFD REPLACEMENT CHARACTER\n\t\t\tif ( ch === \"\\0\" ) {\n\t\t\t\treturn \"\\uFFFD\";\n\t\t\t}\n\n\t\t\t// Control characters and (dependent upon position) numbers get escaped as code points\n\t\t\treturn ch.slice( 0, -1 ) + \"\\\\\" + ch.charCodeAt( ch.length - 1 ).toString( 16 ) + \" \";\n\t\t}\n\n\t\t// Other potentially-special ASCII characters get backslash-escaped\n\t\treturn \"\\\\\" + ch;\n\t},\n\n\t// Used for iframes\n\t// See setDocument()\n\t// Removing the function wrapper causes a \"Permission Denied\"\n\t// error in IE\n\tunloadHandler = function() {\n\t\tsetDocument();\n\t},\n\n\tdisabledAncestor = addCombinator(\n\t\tfunction( elem ) {\n\t\t\treturn elem.disabled === true && (\"form\" in elem || \"label\" in elem);\n\t\t},\n\t\t{ dir: \"parentNode\", next: \"legend\" }\n\t);\n\n// Optimize for push.apply( _, NodeList )\ntry {\n\tpush.apply(\n\t\t(arr = slice.call( preferredDoc.childNodes )),\n\t\tpreferredDoc.childNodes\n\t);\n\t// Support: Android<4.0\n\t// Detect silently failing push.apply\n\tarr[ preferredDoc.childNodes.length ].nodeType;\n} catch ( e ) {\n\tpush = { apply: arr.length ?\n\n\t\t// Leverage slice if possible\n\t\tfunction( target, els ) {\n\t\t\tpush_native.apply( target, slice.call(els) );\n\t\t} :\n\n\t\t// Support: IE<9\n\t\t// Otherwise append directly\n\t\tfunction( target, els ) {\n\t\t\tvar j = target.length,\n\t\t\t\ti = 0;\n\t\t\t// Can't trust NodeList.length\n\t\t\twhile ( (target[j++] = els[i++]) ) {}\n\t\t\ttarget.length = j - 1;\n\t\t}\n\t};\n}\n\nfunction Sizzle( selector, context, results, seed ) {\n\tvar m, i, elem, nid, match, groups, newSelector,\n\t\tnewContext = context && context.ownerDocument,\n\n\t\t// nodeType defaults to 9, since context defaults to document\n\t\tnodeType = context ? context.nodeType : 9;\n\n\tresults = results || [];\n\n\t// Return early from calls with invalid selector or context\n\tif ( typeof selector !== \"string\" || !selector ||\n\t\tnodeType !== 1 && nodeType !== 9 && nodeType !== 11 ) {\n\n\t\treturn results;\n\t}\n\n\t// Try to shortcut find operations (as opposed to filters) in HTML documents\n\tif ( !seed ) {\n\n\t\tif ( ( context ? context.ownerDocument || context : preferredDoc ) !== document ) {\n\t\t\tsetDocument( context );\n\t\t}\n\t\tcontext = context || document;\n\n\t\tif ( documentIsHTML ) {\n\n\t\t\t// If the selector is sufficiently simple, try using a \"get*By*\" DOM method\n\t\t\t// (excepting DocumentFragment context, where the methods don't exist)\n\t\t\tif ( nodeType !== 11 && (match = rquickExpr.exec( selector )) ) {\n\n\t\t\t\t// ID selector\n\t\t\t\tif ( (m = match[1]) ) {\n\n\t\t\t\t\t// Document context\n\t\t\t\t\tif ( nodeType === 9 ) {\n\t\t\t\t\t\tif ( (elem = context.getElementById( m )) ) {\n\n\t\t\t\t\t\t\t// Support: IE, Opera, Webkit\n\t\t\t\t\t\t\t// TODO: identify versions\n\t\t\t\t\t\t\t// getElementById can match elements by name instead of ID\n\t\t\t\t\t\t\tif ( elem.id === m ) {\n\t\t\t\t\t\t\t\tresults.push( elem );\n\t\t\t\t\t\t\t\treturn results;\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\treturn results;\n\t\t\t\t\t\t}\n\n\t\t\t\t\t// Element context\n\t\t\t\t\t} else {\n\n\t\t\t\t\t\t// Support: IE, Opera, Webkit\n\t\t\t\t\t\t// TODO: identify versions\n\t\t\t\t\t\t// getElementById can match elements by name instead of ID\n\t\t\t\t\t\tif ( newContext && (elem = newContext.getElementById( m )) &&\n\t\t\t\t\t\t\tcontains( context, elem ) &&\n\t\t\t\t\t\t\telem.id === m ) {\n\n\t\t\t\t\t\t\tresults.push( elem );\n\t\t\t\t\t\t\treturn results;\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\n\t\t\t\t// Type selector\n\t\t\t\t} else if ( match[2] ) {\n\t\t\t\t\tpush.apply( results, context.getElementsByTagName( selector ) );\n\t\t\t\t\treturn results;\n\n\t\t\t\t// Class selector\n\t\t\t\t} else if ( (m = match[3]) && support.getElementsByClassName &&\n\t\t\t\t\tcontext.getElementsByClassName ) {\n\n\t\t\t\t\tpush.apply( results, context.getElementsByClassName( m ) );\n\t\t\t\t\treturn results;\n\t\t\t\t}\n\t\t\t}\n\n\t\t\t// Take advantage of querySelectorAll\n\t\t\tif ( support.qsa &&\n\t\t\t\t!compilerCache[ selector + \" \" ] &&\n\t\t\t\t(!rbuggyQSA || !rbuggyQSA.test( selector )) ) {\n\n\t\t\t\tif ( nodeType !== 1 ) {\n\t\t\t\t\tnewContext = context;\n\t\t\t\t\tnewSelector = selector;\n\n\t\t\t\t// qSA looks outside Element context, which is not what we want\n\t\t\t\t// Thanks to Andrew Dupont for this workaround technique\n\t\t\t\t// Support: IE <=8\n\t\t\t\t// Exclude object elements\n\t\t\t\t} else if ( context.nodeName.toLowerCase() !== \"object\" ) {\n\n\t\t\t\t\t// Capture the context ID, setting it first if necessary\n\t\t\t\t\tif ( (nid = context.getAttribute( \"id\" )) ) {\n\t\t\t\t\t\tnid = nid.replace( rcssescape, fcssescape );\n\t\t\t\t\t} else {\n\t\t\t\t\t\tcontext.setAttribute( \"id\", (nid = expando) );\n\t\t\t\t\t}\n\n\t\t\t\t\t// Prefix every selector in the list\n\t\t\t\t\tgroups = tokenize( selector );\n\t\t\t\t\ti = groups.length;\n\t\t\t\t\twhile ( i-- ) {\n\t\t\t\t\t\tgroups[i] = \"#\" + nid + \" \" + toSelector( groups[i] );\n\t\t\t\t\t}\n\t\t\t\t\tnewSelector = groups.join( \",\" );\n\n\t\t\t\t\t// Expand context for sibling selectors\n\t\t\t\t\tnewContext = rsibling.test( selector ) && testContext( context.parentNode ) ||\n\t\t\t\t\t\tcontext;\n\t\t\t\t}\n\n\t\t\t\tif ( newSelector ) {\n\t\t\t\t\ttry {\n\t\t\t\t\t\tpush.apply( results,\n\t\t\t\t\t\t\tnewContext.querySelectorAll( newSelector )\n\t\t\t\t\t\t);\n\t\t\t\t\t\treturn results;\n\t\t\t\t\t} catch ( qsaError ) {\n\t\t\t\t\t} finally {\n\t\t\t\t\t\tif ( nid === expando ) {\n\t\t\t\t\t\t\tcontext.removeAttribute( \"id\" );\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n\n\t// All others\n\treturn select( selector.replace( rtrim, \"$1\" ), context, results, seed );\n}\n\n/**\n * Create key-value caches of limited size\n * @returns {function(string, object)} Returns the Object data after storing it on itself with\n *\tproperty name the (space-suffixed) string and (if the cache is larger than Expr.cacheLength)\n *\tdeleting the oldest entry\n */\nfunction createCache() {\n\tvar keys = [];\n\n\tfunction cache( key, value ) {\n\t\t// Use (key + \" \") to avoid collision with native prototype properties (see Issue #157)\n\t\tif ( keys.push( key + \" \" ) > Expr.cacheLength ) {\n\t\t\t// Only keep the most recent entries\n\t\t\tdelete cache[ keys.shift() ];\n\t\t}\n\t\treturn (cache[ key + \" \" ] = value);\n\t}\n\treturn cache;\n}\n\n/**\n * Mark a function for special use by Sizzle\n * @param {Function} fn The function to mark\n */\nfunction markFunction( fn ) {\n\tfn[ expando ] = true;\n\treturn fn;\n}\n\n/**\n * Support testing using an element\n * @param {Function} fn Passed the created element and returns a boolean result\n */\nfunction assert( fn ) {\n\tvar el = document.createElement(\"fieldset\");\n\n\ttry {\n\t\treturn !!fn( el );\n\t} catch (e) {\n\t\treturn false;\n\t} finally {\n\t\t// Remove from its parent by default\n\t\tif ( el.parentNode ) {\n\t\t\tel.parentNode.removeChild( el );\n\t\t}\n\t\t// release memory in IE\n\t\tel = null;\n\t}\n}\n\n/**\n * Adds the same handler for all of the specified attrs\n * @param {String} attrs Pipe-separated list of attributes\n * @param {Function} handler The method that will be applied\n */\nfunction addHandle( attrs, handler ) {\n\tvar arr = attrs.split(\"|\"),\n\t\ti = arr.length;\n\n\twhile ( i-- ) {\n\t\tExpr.attrHandle[ arr[i] ] = handler;\n\t}\n}\n\n/**\n * Checks document order of two siblings\n * @param {Element} a\n * @param {Element} b\n * @returns {Number} Returns less than 0 if a precedes b, greater than 0 if a follows b\n */\nfunction siblingCheck( a, b ) {\n\tvar cur = b && a,\n\t\tdiff = cur && a.nodeType === 1 && b.nodeType === 1 &&\n\t\t\ta.sourceIndex - b.sourceIndex;\n\n\t// Use IE sourceIndex if available on both nodes\n\tif ( diff ) {\n\t\treturn diff;\n\t}\n\n\t// Check if b follows a\n\tif ( cur ) {\n\t\twhile ( (cur = cur.nextSibling) ) {\n\t\t\tif ( cur === b ) {\n\t\t\t\treturn -1;\n\t\t\t}\n\t\t}\n\t}\n\n\treturn a ? 1 : -1;\n}\n\n/**\n * Returns a function to use in pseudos for input types\n * @param {String} type\n */\nfunction createInputPseudo( type ) {\n\treturn function( elem ) {\n\t\tvar name = elem.nodeName.toLowerCase();\n\t\treturn name === \"input\" && elem.type === type;\n\t};\n}\n\n/**\n * Returns a function to use in pseudos for buttons\n * @param {String} type\n */\nfunction createButtonPseudo( type ) {\n\treturn function( elem ) {\n\t\tvar name = elem.nodeName.toLowerCase();\n\t\treturn (name === \"input\" || name === \"button\") && elem.type === type;\n\t};\n}\n\n/**\n * Returns a function to use in pseudos for :enabled/:disabled\n * @param {Boolean} disabled true for :disabled; false for :enabled\n */\nfunction createDisabledPseudo( disabled ) {\n\n\t// Known :disabled false positives: fieldset[disabled] > legend:nth-of-type(n+2) :can-disable\n\treturn function( elem ) {\n\n\t\t// Only certain elements can match :enabled or :disabled\n\t\t// https://html.spec.whatwg.org/multipage/scripting.html#selector-enabled\n\t\t// https://html.spec.whatwg.org/multipage/scripting.html#selector-disabled\n\t\tif ( \"form\" in elem ) {\n\n\t\t\t// Check for inherited disabledness on relevant non-disabled elements:\n\t\t\t// * listed form-associated elements in a disabled fieldset\n\t\t\t// https://html.spec.whatwg.org/multipage/forms.html#category-listed\n\t\t\t// https://html.spec.whatwg.org/multipage/forms.html#concept-fe-disabled\n\t\t\t// * option elements in a disabled optgroup\n\t\t\t// https://html.spec.whatwg.org/multipage/forms.html#concept-option-disabled\n\t\t\t// All such elements have a \"form\" property.\n\t\t\tif ( elem.parentNode && elem.disabled === false ) {\n\n\t\t\t\t// Option elements defer to a parent optgroup if present\n\t\t\t\tif ( \"label\" in elem ) {\n\t\t\t\t\tif ( \"label\" in elem.parentNode ) {\n\t\t\t\t\t\treturn elem.parentNode.disabled === disabled;\n\t\t\t\t\t} else {\n\t\t\t\t\t\treturn elem.disabled === disabled;\n\t\t\t\t\t}\n\t\t\t\t}\n\n\t\t\t\t// Support: IE 6 - 11\n\t\t\t\t// Use the isDisabled shortcut property to check for disabled fieldset ancestors\n\t\t\t\treturn elem.isDisabled === disabled ||\n\n\t\t\t\t\t// Where there is no isDisabled, check manually\n\t\t\t\t\t/* jshint -W018 */\n\t\t\t\t\telem.isDisabled !== !disabled &&\n\t\t\t\t\t\tdisabledAncestor( elem ) === disabled;\n\t\t\t}\n\n\t\t\treturn elem.disabled === disabled;\n\n\t\t// Try to winnow out elements that can't be disabled before trusting the disabled property.\n\t\t// Some victims get caught in our net (label, legend, menu, track), but it shouldn't\n\t\t// even exist on them, let alone have a boolean value.\n\t\t} else if ( \"label\" in elem ) {\n\t\t\treturn elem.disabled === disabled;\n\t\t}\n\n\t\t// Remaining elements are neither :enabled nor :disabled\n\t\treturn false;\n\t};\n}\n\n/**\n * Returns a function to use in pseudos for positionals\n * @param {Function} fn\n */\nfunction createPositionalPseudo( fn ) {\n\treturn markFunction(function( argument ) {\n\t\targument = +argument;\n\t\treturn markFunction(function( seed, matches ) {\n\t\t\tvar j,\n\t\t\t\tmatchIndexes = fn( [], seed.length, argument ),\n\t\t\t\ti = matchIndexes.length;\n\n\t\t\t// Match elements found at the specified indexes\n\t\t\twhile ( i-- ) {\n\t\t\t\tif ( seed[ (j = matchIndexes[i]) ] ) {\n\t\t\t\t\tseed[j] = !(matches[j] = seed[j]);\n\t\t\t\t}\n\t\t\t}\n\t\t});\n\t});\n}\n\n/**\n * Checks a node for validity as a Sizzle context\n * @param {Element|Object=} context\n * @returns {Element|Object|Boolean} The input node if acceptable, otherwise a falsy value\n */\nfunction testContext( context ) {\n\treturn context && typeof context.getElementsByTagName !== \"undefined\" && context;\n}\n\n// Expose support vars for convenience\nsupport = Sizzle.support = {};\n\n/**\n * Detects XML nodes\n * @param {Element|Object} elem An element or a document\n * @returns {Boolean} True iff elem is a non-HTML XML node\n */\nisXML = Sizzle.isXML = function( elem ) {\n\t// documentElement is verified for cases where it doesn't yet exist\n\t// (such as loading iframes in IE - #4833)\n\tvar documentElement = elem && (elem.ownerDocument || elem).documentElement;\n\treturn documentElement ? documentElement.nodeName !== \"HTML\" : false;\n};\n\n/**\n * Sets document-related variables once based on the current document\n * @param {Element|Object} [doc] An element or document object to use to set the document\n * @returns {Object} Returns the current document\n */\nsetDocument = Sizzle.setDocument = function( node ) {\n\tvar hasCompare, subWindow,\n\t\tdoc = node ? node.ownerDocument || node : preferredDoc;\n\n\t// Return early if doc is invalid or already selected\n\tif ( doc === document || doc.nodeType !== 9 || !doc.documentElement ) {\n\t\treturn document;\n\t}\n\n\t// Update global variables\n\tdocument = doc;\n\tdocElem = document.documentElement;\n\tdocumentIsHTML = !isXML( document );\n\n\t// Support: IE 9-11, Edge\n\t// Accessing iframe documents after unload throws \"permission denied\" errors (jQuery #13936)\n\tif ( preferredDoc !== document &&\n\t\t(subWindow = document.defaultView) && subWindow.top !== subWindow ) {\n\n\t\t// Support: IE 11, Edge\n\t\tif ( subWindow.addEventListener ) {\n\t\t\tsubWindow.addEventListener( \"unload\", unloadHandler, false );\n\n\t\t// Support: IE 9 - 10 only\n\t\t} else if ( subWindow.attachEvent ) {\n\t\t\tsubWindow.attachEvent( \"onunload\", unloadHandler );\n\t\t}\n\t}\n\n\t/* Attributes\n\t---------------------------------------------------------------------- */\n\n\t// Support: IE<8\n\t// Verify that getAttribute really returns attributes and not properties\n\t// (excepting IE8 booleans)\n\tsupport.attributes = assert(function( el ) {\n\t\tel.className = \"i\";\n\t\treturn !el.getAttribute(\"className\");\n\t});\n\n\t/* getElement(s)By*\n\t---------------------------------------------------------------------- */\n\n\t// Check if getElementsByTagName(\"*\") returns only elements\n\tsupport.getElementsByTagName = assert(function( el ) {\n\t\tel.appendChild( document.createComment(\"\") );\n\t\treturn !el.getElementsByTagName(\"*\").length;\n\t});\n\n\t// Support: IE<9\n\tsupport.getElementsByClassName = rnative.test( document.getElementsByClassName );\n\n\t// Support: IE<10\n\t// Check if getElementById returns elements by name\n\t// The broken getElementById methods don't pick up programmatically-set names,\n\t// so use a roundabout getElementsByName test\n\tsupport.getById = assert(function( el ) {\n\t\tdocElem.appendChild( el ).id = expando;\n\t\treturn !document.getElementsByName || !document.getElementsByName( expando ).length;\n\t});\n\n\t// ID filter and find\n\tif ( support.getById ) {\n\t\tExpr.filter[\"ID\"] = function( id ) {\n\t\t\tvar attrId = id.replace( runescape, funescape );\n\t\t\treturn function( elem ) {\n\t\t\t\treturn elem.getAttribute(\"id\") === attrId;\n\t\t\t};\n\t\t};\n\t\tExpr.find[\"ID\"] = function( id, context ) {\n\t\t\tif ( typeof context.getElementById !== \"undefined\" && documentIsHTML ) {\n\t\t\t\tvar elem = context.getElementById( id );\n\t\t\t\treturn elem ? [ elem ] : [];\n\t\t\t}\n\t\t};\n\t} else {\n\t\tExpr.filter[\"ID\"] = function( id ) {\n\t\t\tvar attrId = id.replace( runescape, funescape );\n\t\t\treturn function( elem ) {\n\t\t\t\tvar node = typeof elem.getAttributeNode !== \"undefined\" &&\n\t\t\t\t\telem.getAttributeNode(\"id\");\n\t\t\t\treturn node && node.value === attrId;\n\t\t\t};\n\t\t};\n\n\t\t// Support: IE 6 - 7 only\n\t\t// getElementById is not reliable as a find shortcut\n\t\tExpr.find[\"ID\"] = function( id, context ) {\n\t\t\tif ( typeof context.getElementById !== \"undefined\" && documentIsHTML ) {\n\t\t\t\tvar node, i, elems,\n\t\t\t\t\telem = context.getElementById( id );\n\n\t\t\t\tif ( elem ) {\n\n\t\t\t\t\t// Verify the id attribute\n\t\t\t\t\tnode = elem.getAttributeNode(\"id\");\n\t\t\t\t\tif ( node && node.value === id ) {\n\t\t\t\t\t\treturn [ elem ];\n\t\t\t\t\t}\n\n\t\t\t\t\t// Fall back on getElementsByName\n\t\t\t\t\telems = context.getElementsByName( id );\n\t\t\t\t\ti = 0;\n\t\t\t\t\twhile ( (elem = elems[i++]) ) {\n\t\t\t\t\t\tnode = elem.getAttributeNode(\"id\");\n\t\t\t\t\t\tif ( node && node.value === id ) {\n\t\t\t\t\t\t\treturn [ elem ];\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t}\n\n\t\t\t\treturn [];\n\t\t\t}\n\t\t};\n\t}\n\n\t// Tag\n\tExpr.find[\"TAG\"] = support.getElementsByTagName ?\n\t\tfunction( tag, context ) {\n\t\t\tif ( typeof context.getElementsByTagName !== \"undefined\" ) {\n\t\t\t\treturn context.getElementsByTagName( tag );\n\n\t\t\t// DocumentFragment nodes don't have gEBTN\n\t\t\t} else if ( support.qsa ) {\n\t\t\t\treturn context.querySelectorAll( tag );\n\t\t\t}\n\t\t} :\n\n\t\tfunction( tag, context ) {\n\t\t\tvar elem,\n\t\t\t\ttmp = [],\n\t\t\t\ti = 0,\n\t\t\t\t// By happy coincidence, a (broken) gEBTN appears on DocumentFragment nodes too\n\t\t\t\tresults = context.getElementsByTagName( tag );\n\n\t\t\t// Filter out possible comments\n\t\t\tif ( tag === \"*\" ) {\n\t\t\t\twhile ( (elem = results[i++]) ) {\n\t\t\t\t\tif ( elem.nodeType === 1 ) {\n\t\t\t\t\t\ttmp.push( elem );\n\t\t\t\t\t}\n\t\t\t\t}\n\n\t\t\t\treturn tmp;\n\t\t\t}\n\t\t\treturn results;\n\t\t};\n\n\t// Class\n\tExpr.find[\"CLASS\"] = support.getElementsByClassName && function( className, context ) {\n\t\tif ( typeof context.getElementsByClassName !== \"undefined\" && documentIsHTML ) {\n\t\t\treturn context.getElementsByClassName( className );\n\t\t}\n\t};\n\n\t/* QSA/matchesSelector\n\t---------------------------------------------------------------------- */\n\n\t// QSA and matchesSelector support\n\n\t// matchesSelector(:active) reports false when true (IE9/Opera 11.5)\n\trbuggyMatches = [];\n\n\t// qSa(:focus) reports false when true (Chrome 21)\n\t// We allow this because of a bug in IE8/9 that throws an error\n\t// whenever `document.activeElement` is accessed on an iframe\n\t// So, we allow :focus to pass through QSA all the time to avoid the IE error\n\t// See https://bugs.jquery.com/ticket/13378\n\trbuggyQSA = [];\n\n\tif ( (support.qsa = rnative.test( document.querySelectorAll )) ) {\n\t\t// Build QSA regex\n\t\t// Regex strategy adopted from Diego Perini\n\t\tassert(function( el ) {\n\t\t\t// Select is set to empty string on purpose\n\t\t\t// This is to test IE's treatment of not explicitly\n\t\t\t// setting a boolean content attribute,\n\t\t\t// since its presence should be enough\n\t\t\t// https://bugs.jquery.com/ticket/12359\n\t\t\tdocElem.appendChild( el ).innerHTML = \"<a id='\" + expando + \"'></a>\" +\n\t\t\t\t\"<select id='\" + expando + \"-\\r\\\\' msallowcapture=''>\" +\n\t\t\t\t\"<option selected=''></option></select>\";\n\n\t\t\t// Support: IE8, Opera 11-12.16\n\t\t\t// Nothing should be selected when empty strings follow ^= or $= or *=\n\t\t\t// The test attribute must be unknown in Opera but \"safe\" for WinRT\n\t\t\t// https://msdn.microsoft.com/en-us/library/ie/hh465388.aspx#attribute_section\n\t\t\tif ( el.querySelectorAll(\"[msallowcapture^='']\").length ) {\n\t\t\t\trbuggyQSA.push( \"[*^$]=\" + whitespace + \"*(?:''|\\\"\\\")\" );\n\t\t\t}\n\n\t\t\t// Support: IE8\n\t\t\t// Boolean attributes and \"value\" are not treated correctly\n\t\t\tif ( !el.querySelectorAll(\"[selected]\").length ) {\n\t\t\t\trbuggyQSA.push( \"\\\\[\" + whitespace + \"*(?:value|\" + booleans + \")\" );\n\t\t\t}\n\n\t\t\t// Support: Chrome<29, Android<4.4, Safari<7.0+, iOS<7.0+, PhantomJS<1.9.8+\n\t\t\tif ( !el.querySelectorAll( \"[id~=\" + expando + \"-]\" ).length ) {\n\t\t\t\trbuggyQSA.push(\"~=\");\n\t\t\t}\n\n\t\t\t// Webkit/Opera - :checked should return selected option elements\n\t\t\t// http://www.w3.org/TR/2011/REC-css3-selectors-20110929/#checked\n\t\t\t// IE8 throws error here and will not see later tests\n\t\t\tif ( !el.querySelectorAll(\":checked\").length ) {\n\t\t\t\trbuggyQSA.push(\":checked\");\n\t\t\t}\n\n\t\t\t// Support: Safari 8+, iOS 8+\n\t\t\t// https://bugs.webkit.org/show_bug.cgi?id=136851\n\t\t\t// In-page `selector#id sibling-combinator selector` fails\n\t\t\tif ( !el.querySelectorAll( \"a#\" + expando + \"+*\" ).length ) {\n\t\t\t\trbuggyQSA.push(\".#.+[+~]\");\n\t\t\t}\n\t\t});\n\n\t\tassert(function( el ) {\n\t\t\tel.innerHTML = \"<a href='' disabled='disabled'></a>\" +\n\t\t\t\t\"<select disabled='disabled'><option/></select>\";\n\n\t\t\t// Support: Windows 8 Native Apps\n\t\t\t// The type and name attributes are restricted during .innerHTML assignment\n\t\t\tvar input = document.createElement(\"input\");\n\t\t\tinput.setAttribute( \"type\", \"hidden\" );\n\t\t\tel.appendChild( input ).setAttribute( \"name\", \"D\" );\n\n\t\t\t// Support: IE8\n\t\t\t// Enforce case-sensitivity of name attribute\n\t\t\tif ( el.querySelectorAll(\"[name=d]\").length ) {\n\t\t\t\trbuggyQSA.push( \"name\" + whitespace + \"*[*^$|!~]?=\" );\n\t\t\t}\n\n\t\t\t// FF 3.5 - :enabled/:disabled and hidden elements (hidden elements are still enabled)\n\t\t\t// IE8 throws error here and will not see later tests\n\t\t\tif ( el.querySelectorAll(\":enabled\").length !== 2 ) {\n\t\t\t\trbuggyQSA.push( \":enabled\", \":disabled\" );\n\t\t\t}\n\n\t\t\t// Support: IE9-11+\n\t\t\t// IE's :disabled selector does not pick up the children of disabled fieldsets\n\t\t\tdocElem.appendChild( el ).disabled = true;\n\t\t\tif ( el.querySelectorAll(\":disabled\").length !== 2 ) {\n\t\t\t\trbuggyQSA.push( \":enabled\", \":disabled\" );\n\t\t\t}\n\n\t\t\t// Opera 10-11 does not throw on post-comma invalid pseudos\n\t\t\tel.querySelectorAll(\"*,:x\");\n\t\t\trbuggyQSA.push(\",.*:\");\n\t\t});\n\t}\n\n\tif ( (support.matchesSelector = rnative.test( (matches = docElem.matches ||\n\t\tdocElem.webkitMatchesSelector ||\n\t\tdocElem.mozMatchesSelector ||\n\t\tdocElem.oMatchesSelector ||\n\t\tdocElem.msMatchesSelector) )) ) {\n\n\t\tassert(function( el ) {\n\t\t\t// Check to see if it's possible to do matchesSelector\n\t\t\t// on a disconnected node (IE 9)\n\t\t\tsupport.disconnectedMatch = matches.call( el, \"*\" );\n\n\t\t\t// This should fail with an exception\n\t\t\t// Gecko does not error, returns false instead\n\t\t\tmatches.call( el, \"[s!='']:x\" );\n\t\t\trbuggyMatches.push( \"!=\", pseudos );\n\t\t});\n\t}\n\n\trbuggyQSA = rbuggyQSA.length && new RegExp( rbuggyQSA.join(\"|\") );\n\trbuggyMatches = rbuggyMatches.length && new RegExp( rbuggyMatches.join(\"|\") );\n\n\t/* Contains\n\t---------------------------------------------------------------------- */\n\thasCompare = rnative.test( docElem.compareDocumentPosition );\n\n\t// Element contains another\n\t// Purposefully self-exclusive\n\t// As in, an element does not contain itself\n\tcontains = hasCompare || rnative.test( docElem.contains ) ?\n\t\tfunction( a, b ) {\n\t\t\tvar adown = a.nodeType === 9 ? a.documentElement : a,\n\t\t\t\tbup = b && b.parentNode;\n\t\t\treturn a === bup || !!( bup && bup.nodeType === 1 && (\n\t\t\t\tadown.contains ?\n\t\t\t\t\tadown.contains( bup ) :\n\t\t\t\t\ta.compareDocumentPosition && a.compareDocumentPosition( bup ) & 16\n\t\t\t));\n\t\t} :\n\t\tfunction( a, b ) {\n\t\t\tif ( b ) {\n\t\t\t\twhile ( (b = b.parentNode) ) {\n\t\t\t\t\tif ( b === a ) {\n\t\t\t\t\t\treturn true;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t\treturn false;\n\t\t};\n\n\t/* Sorting\n\t---------------------------------------------------------------------- */\n\n\t// Document order sorting\n\tsortOrder = hasCompare ?\n\tfunction( a, b ) {\n\n\t\t// Flag for duplicate removal\n\t\tif ( a === b ) {\n\t\t\thasDuplicate = true;\n\t\t\treturn 0;\n\t\t}\n\n\t\t// Sort on method existence if only one input has compareDocumentPosition\n\t\tvar compare = !a.compareDocumentPosition - !b.compareDocumentPosition;\n\t\tif ( compare ) {\n\t\t\treturn compare;\n\t\t}\n\n\t\t// Calculate position if both inputs belong to the same document\n\t\tcompare = ( a.ownerDocument || a ) === ( b.ownerDocument || b ) ?\n\t\t\ta.compareDocumentPosition( b ) :\n\n\t\t\t// Otherwise we know they are disconnected\n\t\t\t1;\n\n\t\t// Disconnected nodes\n\t\tif ( compare & 1 ||\n\t\t\t(!support.sortDetached && b.compareDocumentPosition( a ) === compare) ) {\n\n\t\t\t// Choose the first element that is related to our preferred document\n\t\t\tif ( a === document || a.ownerDocument === preferredDoc && contains(preferredDoc, a) ) {\n\t\t\t\treturn -1;\n\t\t\t}\n\t\t\tif ( b === document || b.ownerDocument === preferredDoc && contains(preferredDoc, b) ) {\n\t\t\t\treturn 1;\n\t\t\t}\n\n\t\t\t// Maintain original order\n\t\t\treturn sortInput ?\n\t\t\t\t( indexOf( sortInput, a ) - indexOf( sortInput, b ) ) :\n\t\t\t\t0;\n\t\t}\n\n\t\treturn compare & 4 ? -1 : 1;\n\t} :\n\tfunction( a, b ) {\n\t\t// Exit early if the nodes are identical\n\t\tif ( a === b ) {\n\t\t\thasDuplicate = true;\n\t\t\treturn 0;\n\t\t}\n\n\t\tvar cur,\n\t\t\ti = 0,\n\t\t\taup = a.parentNode,\n\t\t\tbup = b.parentNode,\n\t\t\tap = [ a ],\n\t\t\tbp = [ b ];\n\n\t\t// Parentless nodes are either documents or disconnected\n\t\tif ( !aup || !bup ) {\n\t\t\treturn a === document ? -1 :\n\t\t\t\tb === document ? 1 :\n\t\t\t\taup ? -1 :\n\t\t\t\tbup ? 1 :\n\t\t\t\tsortInput ?\n\t\t\t\t( indexOf( sortInput, a ) - indexOf( sortInput, b ) ) :\n\t\t\t\t0;\n\n\t\t// If the nodes are siblings, we can do a quick check\n\t\t} else if ( aup === bup ) {\n\t\t\treturn siblingCheck( a, b );\n\t\t}\n\n\t\t// Otherwise we need full lists of their ancestors for comparison\n\t\tcur = a;\n\t\twhile ( (cur = cur.parentNode) ) {\n\t\t\tap.unshift( cur );\n\t\t}\n\t\tcur = b;\n\t\twhile ( (cur = cur.parentNode) ) {\n\t\t\tbp.unshift( cur );\n\t\t}\n\n\t\t// Walk down the tree looking for a discrepancy\n\t\twhile ( ap[i] === bp[i] ) {\n\t\t\ti++;\n\t\t}\n\n\t\treturn i ?\n\t\t\t// Do a sibling check if the nodes have a common ancestor\n\t\t\tsiblingCheck( ap[i], bp[i] ) :\n\n\t\t\t// Otherwise nodes in our document sort first\n\t\t\tap[i] === preferredDoc ? -1 :\n\t\t\tbp[i] === preferredDoc ? 1 :\n\t\t\t0;\n\t};\n\n\treturn document;\n};\n\nSizzle.matches = function( expr, elements ) {\n\treturn Sizzle( expr, null, null, elements );\n};\n\nSizzle.matchesSelector = function( elem, expr ) {\n\t// Set document vars if needed\n\tif ( ( elem.ownerDocument || elem ) !== document ) {\n\t\tsetDocument( elem );\n\t}\n\n\t// Make sure that attribute selectors are quoted\n\texpr = expr.replace( rattributeQuotes, \"='$1']\" );\n\n\tif ( support.matchesSelector && documentIsHTML &&\n\t\t!compilerCache[ expr + \" \" ] &&\n\t\t( !rbuggyMatches || !rbuggyMatches.test( expr ) ) &&\n\t\t( !rbuggyQSA || !rbuggyQSA.test( expr ) ) ) {\n\n\t\ttry {\n\t\t\tvar ret = matches.call( elem, expr );\n\n\t\t\t// IE 9's matchesSelector returns false on disconnected nodes\n\t\t\tif ( ret || support.disconnectedMatch ||\n\t\t\t\t\t// As well, disconnected nodes are said to be in a document\n\t\t\t\t\t// fragment in IE 9\n\t\t\t\t\telem.document && elem.document.nodeType !== 11 ) {\n\t\t\t\treturn ret;\n\t\t\t}\n\t\t} catch (e) {}\n\t}\n\n\treturn Sizzle( expr, document, null, [ elem ] ).length > 0;\n};\n\nSizzle.contains = function( context, elem ) {\n\t// Set document vars if needed\n\tif ( ( context.ownerDocument || context ) !== document ) {\n\t\tsetDocument( context );\n\t}\n\treturn contains( context, elem );\n};\n\nSizzle.attr = function( elem, name ) {\n\t// Set document vars if needed\n\tif ( ( elem.ownerDocument || elem ) !== document ) {\n\t\tsetDocument( elem );\n\t}\n\n\tvar fn = Expr.attrHandle[ name.toLowerCase() ],\n\t\t// Don't get fooled by Object.prototype properties (jQuery #13807)\n\t\tval = fn && hasOwn.call( Expr.attrHandle, name.toLowerCase() ) ?\n\t\t\tfn( elem, name, !documentIsHTML ) :\n\t\t\tundefined;\n\n\treturn val !== undefined ?\n\t\tval :\n\t\tsupport.attributes || !documentIsHTML ?\n\t\t\telem.getAttribute( name ) :\n\t\t\t(val = elem.getAttributeNode(name)) && val.specified ?\n\t\t\t\tval.value :\n\t\t\t\tnull;\n};\n\nSizzle.escape = function( sel ) {\n\treturn (sel + \"\").replace( rcssescape, fcssescape );\n};\n\nSizzle.error = function( msg ) {\n\tthrow new Error( \"Syntax error, unrecognized expression: \" + msg );\n};\n\n/**\n * Document sorting and removing duplicates\n * @param {ArrayLike} results\n */\nSizzle.uniqueSort = function( results ) {\n\tvar elem,\n\t\tduplicates = [],\n\t\tj = 0,\n\t\ti = 0;\n\n\t// Unless we *know* we can detect duplicates, assume their presence\n\thasDuplicate = !support.detectDuplicates;\n\tsortInput = !support.sortStable && results.slice( 0 );\n\tresults.sort( sortOrder );\n\n\tif ( hasDuplicate ) {\n\t\twhile ( (elem = results[i++]) ) {\n\t\t\tif ( elem === results[ i ] ) {\n\t\t\t\tj = duplicates.push( i );\n\t\t\t}\n\t\t}\n\t\twhile ( j-- ) {\n\t\t\tresults.splice( duplicates[ j ], 1 );\n\t\t}\n\t}\n\n\t// Clear input after sorting to release objects\n\t// See https://github.com/jquery/sizzle/pull/225\n\tsortInput = null;\n\n\treturn results;\n};\n\n/**\n * Utility function for retrieving the text value of an array of DOM nodes\n * @param {Array|Element} elem\n */\ngetText = Sizzle.getText = function( elem ) {\n\tvar node,\n\t\tret = \"\",\n\t\ti = 0,\n\t\tnodeType = elem.nodeType;\n\n\tif ( !nodeType ) {\n\t\t// If no nodeType, this is expected to be an array\n\t\twhile ( (node = elem[i++]) ) {\n\t\t\t// Do not traverse comment nodes\n\t\t\tret += getText( node );\n\t\t}\n\t} else if ( nodeType === 1 || nodeType === 9 || nodeType === 11 ) {\n\t\t// Use textContent for elements\n\t\t// innerText usage removed for consistency of new lines (jQuery #11153)\n\t\tif ( typeof elem.textContent === \"string\" ) {\n\t\t\treturn elem.textContent;\n\t\t} else {\n\t\t\t// Traverse its children\n\t\t\tfor ( elem = elem.firstChild; elem; elem = elem.nextSibling ) {\n\t\t\t\tret += getText( elem );\n\t\t\t}\n\t\t}\n\t} else if ( nodeType === 3 || nodeType === 4 ) {\n\t\treturn elem.nodeValue;\n\t}\n\t// Do not include comment or processing instruction nodes\n\n\treturn ret;\n};\n\nExpr = Sizzle.selectors = {\n\n\t// Can be adjusted by the user\n\tcacheLength: 50,\n\n\tcreatePseudo: markFunction,\n\n\tmatch: matchExpr,\n\n\tattrHandle: {},\n\n\tfind: {},\n\n\trelative: {\n\t\t\">\": { dir: \"parentNode\", first: true },\n\t\t\" \": { dir: \"parentNode\" },\n\t\t\"+\": { dir: \"previousSibling\", first: true },\n\t\t\"~\": { dir: \"previousSibling\" }\n\t},\n\n\tpreFilter: {\n\t\t\"ATTR\": function( match ) {\n\t\t\tmatch[1] = match[1].replace( runescape, funescape );\n\n\t\t\t// Move the given value to match[3] whether quoted or unquoted\n\t\t\tmatch[3] = ( match[3] || match[4] || match[5] || \"\" ).replace( runescape, funescape );\n\n\t\t\tif ( match[2] === \"~=\" ) {\n\t\t\t\tmatch[3] = \" \" + match[3] + \" \";\n\t\t\t}\n\n\t\t\treturn match.slice( 0, 4 );\n\t\t},\n\n\t\t\"CHILD\": function( match ) {\n\t\t\t/* matches from matchExpr[\"CHILD\"]\n\t\t\t\t1 type (only|nth|...)\n\t\t\t\t2 what (child|of-type)\n\t\t\t\t3 argument (even|odd|\\d*|\\d*n([+-]\\d+)?|...)\n\t\t\t\t4 xn-component of xn+y argument ([+-]?\\d*n|)\n\t\t\t\t5 sign of xn-component\n\t\t\t\t6 x of xn-component\n\t\t\t\t7 sign of y-component\n\t\t\t\t8 y of y-component\n\t\t\t*/\n\t\t\tmatch[1] = match[1].toLowerCase();\n\n\t\t\tif ( match[1].slice( 0, 3 ) === \"nth\" ) {\n\t\t\t\t// nth-* requires argument\n\t\t\t\tif ( !match[3] ) {\n\t\t\t\t\tSizzle.error( match[0] );\n\t\t\t\t}\n\n\t\t\t\t// numeric x and y parameters for Expr.filter.CHILD\n\t\t\t\t// remember that false/true cast respectively to 0/1\n\t\t\t\tmatch[4] = +( match[4] ? match[5] + (match[6] || 1) : 2 * ( match[3] === \"even\" || match[3] === \"odd\" ) );\n\t\t\t\tmatch[5] = +( ( match[7] + match[8] ) || match[3] === \"odd\" );\n\n\t\t\t// other types prohibit arguments\n\t\t\t} else if ( match[3] ) {\n\t\t\t\tSizzle.error( match[0] );\n\t\t\t}\n\n\t\t\treturn match;\n\t\t},\n\n\t\t\"PSEUDO\": function( match ) {\n\t\t\tvar excess,\n\t\t\t\tunquoted = !match[6] && match[2];\n\n\t\t\tif ( matchExpr[\"CHILD\"].test( match[0] ) ) {\n\t\t\t\treturn null;\n\t\t\t}\n\n\t\t\t// Accept quoted arguments as-is\n\t\t\tif ( match[3] ) {\n\t\t\t\tmatch[2] = match[4] || match[5] || \"\";\n\n\t\t\t// Strip excess characters from unquoted arguments\n\t\t\t} else if ( unquoted && rpseudo.test( unquoted ) &&\n\t\t\t\t// Get excess from tokenize (recursively)\n\t\t\t\t(excess = tokenize( unquoted, true )) &&\n\t\t\t\t// advance to the next closing parenthesis\n\t\t\t\t(excess = unquoted.indexOf( \")\", unquoted.length - excess ) - unquoted.length) ) {\n\n\t\t\t\t// excess is a negative index\n\t\t\t\tmatch[0] = match[0].slice( 0, excess );\n\t\t\t\tmatch[2] = unquoted.slice( 0, excess );\n\t\t\t}\n\n\t\t\t// Return only captures needed by the pseudo filter method (type and argument)\n\t\t\treturn match.slice( 0, 3 );\n\t\t}\n\t},\n\n\tfilter: {\n\n\t\t\"TAG\": function( nodeNameSelector ) {\n\t\t\tvar nodeName = nodeNameSelector.replace( runescape, funescape ).toLowerCase();\n\t\t\treturn nodeNameSelector === \"*\" ?\n\t\t\t\tfunction() { return true; } :\n\t\t\t\tfunction( elem ) {\n\t\t\t\t\treturn elem.nodeName && elem.nodeName.toLowerCase() === nodeName;\n\t\t\t\t};\n\t\t},\n\n\t\t\"CLASS\": function( className ) {\n\t\t\tvar pattern = classCache[ className + \" \" ];\n\n\t\t\treturn pattern ||\n\t\t\t\t(pattern = new RegExp( \"(^|\" + whitespace + \")\" + className + \"(\" + whitespace + \"|$)\" )) &&\n\t\t\t\tclassCache( className, function( elem ) {\n\t\t\t\t\treturn pattern.test( typeof elem.className === \"string\" && elem.className || typeof elem.getAttribute !== \"undefined\" && elem.getAttribute(\"class\") || \"\" );\n\t\t\t\t});\n\t\t},\n\n\t\t\"ATTR\": function( name, operator, check ) {\n\t\t\treturn function( elem ) {\n\t\t\t\tvar result = Sizzle.attr( elem, name );\n\n\t\t\t\tif ( result == null ) {\n\t\t\t\t\treturn operator === \"!=\";\n\t\t\t\t}\n\t\t\t\tif ( !operator ) {\n\t\t\t\t\treturn true;\n\t\t\t\t}\n\n\t\t\t\tresult += \"\";\n\n\t\t\t\treturn operator === \"=\" ? result === check :\n\t\t\t\t\toperator === \"!=\" ? result !== check :\n\t\t\t\t\toperator === \"^=\" ? check && result.indexOf( check ) === 0 :\n\t\t\t\t\toperator === \"*=\" ? check && result.indexOf( check ) > -1 :\n\t\t\t\t\toperator === \"$=\" ? check && result.slice( -check.length ) === check :\n\t\t\t\t\toperator === \"~=\" ? ( \" \" + result.replace( rwhitespace, \" \" ) + \" \" ).indexOf( check ) > -1 :\n\t\t\t\t\toperator === \"|=\" ? result === check || result.slice( 0, check.length + 1 ) === check + \"-\" :\n\t\t\t\t\tfalse;\n\t\t\t};\n\t\t},\n\n\t\t\"CHILD\": function( type, what, argument, first, last ) {\n\t\t\tvar simple = type.slice( 0, 3 ) !== \"nth\",\n\t\t\t\tforward = type.slice( -4 ) !== \"last\",\n\t\t\t\tofType = what === \"of-type\";\n\n\t\t\treturn first === 1 && last === 0 ?\n\n\t\t\t\t// Shortcut for :nth-*(n)\n\t\t\t\tfunction( elem ) {\n\t\t\t\t\treturn !!elem.parentNode;\n\t\t\t\t} :\n\n\t\t\t\tfunction( elem, context, xml ) {\n\t\t\t\t\tvar cache, uniqueCache, outerCache, node, nodeIndex, start,\n\t\t\t\t\t\tdir = simple !== forward ? \"nextSibling\" : \"previousSibling\",\n\t\t\t\t\t\tparent = elem.parentNode,\n\t\t\t\t\t\tname = ofType && elem.nodeName.toLowerCase(),\n\t\t\t\t\t\tuseCache = !xml && !ofType,\n\t\t\t\t\t\tdiff = false;\n\n\t\t\t\t\tif ( parent ) {\n\n\t\t\t\t\t\t// :(first|last|only)-(child|of-type)\n\t\t\t\t\t\tif ( simple ) {\n\t\t\t\t\t\t\twhile ( dir ) {\n\t\t\t\t\t\t\t\tnode = elem;\n\t\t\t\t\t\t\t\twhile ( (node = node[ dir ]) ) {\n\t\t\t\t\t\t\t\t\tif ( ofType ?\n\t\t\t\t\t\t\t\t\t\tnode.nodeName.toLowerCase() === name :\n\t\t\t\t\t\t\t\t\t\tnode.nodeType === 1 ) {\n\n\t\t\t\t\t\t\t\t\t\treturn false;\n\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t// Reverse direction for :only-* (if we haven't yet done so)\n\t\t\t\t\t\t\t\tstart = dir = type === \"only\" && !start && \"nextSibling\";\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\treturn true;\n\t\t\t\t\t\t}\n\n\t\t\t\t\t\tstart = [ forward ? parent.firstChild : parent.lastChild ];\n\n\t\t\t\t\t\t// non-xml :nth-child(...) stores cache data on `parent`\n\t\t\t\t\t\tif ( forward && useCache ) {\n\n\t\t\t\t\t\t\t// Seek `elem` from a previously-cached index\n\n\t\t\t\t\t\t\t// ...in a gzip-friendly way\n\t\t\t\t\t\t\tnode = parent;\n\t\t\t\t\t\t\touterCache = node[ expando ] || (node[ expando ] = {});\n\n\t\t\t\t\t\t\t// Support: IE <9 only\n\t\t\t\t\t\t\t// Defend against cloned attroperties (jQuery gh-1709)\n\t\t\t\t\t\t\tuniqueCache = outerCache[ node.uniqueID ] ||\n\t\t\t\t\t\t\t\t(outerCache[ node.uniqueID ] = {});\n\n\t\t\t\t\t\t\tcache = uniqueCache[ type ] || [];\n\t\t\t\t\t\t\tnodeIndex = cache[ 0 ] === dirruns && cache[ 1 ];\n\t\t\t\t\t\t\tdiff = nodeIndex && cache[ 2 ];\n\t\t\t\t\t\t\tnode = nodeIndex && parent.childNodes[ nodeIndex ];\n\n\t\t\t\t\t\t\twhile ( (node = ++nodeIndex && node && node[ dir ] ||\n\n\t\t\t\t\t\t\t\t// Fallback to seeking `elem` from the start\n\t\t\t\t\t\t\t\t(diff = nodeIndex = 0) || start.pop()) ) {\n\n\t\t\t\t\t\t\t\t// When found, cache indexes on `parent` and break\n\t\t\t\t\t\t\t\tif ( node.nodeType === 1 && ++diff && node === elem ) {\n\t\t\t\t\t\t\t\t\tuniqueCache[ type ] = [ dirruns, nodeIndex, diff ];\n\t\t\t\t\t\t\t\t\tbreak;\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\t// Use previously-cached element index if available\n\t\t\t\t\t\t\tif ( useCache ) {\n\t\t\t\t\t\t\t\t// ...in a gzip-friendly way\n\t\t\t\t\t\t\t\tnode = elem;\n\t\t\t\t\t\t\t\touterCache = node[ expando ] || (node[ expando ] = {});\n\n\t\t\t\t\t\t\t\t// Support: IE <9 only\n\t\t\t\t\t\t\t\t// Defend against cloned attroperties (jQuery gh-1709)\n\t\t\t\t\t\t\t\tuniqueCache = outerCache[ node.uniqueID ] ||\n\t\t\t\t\t\t\t\t\t(outerCache[ node.uniqueID ] = {});\n\n\t\t\t\t\t\t\t\tcache = uniqueCache[ type ] || [];\n\t\t\t\t\t\t\t\tnodeIndex = cache[ 0 ] === dirruns && cache[ 1 ];\n\t\t\t\t\t\t\t\tdiff = nodeIndex;\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t// xml :nth-child(...)\n\t\t\t\t\t\t\t// or :nth-last-child(...) or :nth(-last)?-of-type(...)\n\t\t\t\t\t\t\tif ( diff === false ) {\n\t\t\t\t\t\t\t\t// Use the same loop as above to seek `elem` from the start\n\t\t\t\t\t\t\t\twhile ( (node = ++nodeIndex && node && node[ dir ] ||\n\t\t\t\t\t\t\t\t\t(diff = nodeIndex = 0) || start.pop()) ) {\n\n\t\t\t\t\t\t\t\t\tif ( ( ofType ?\n\t\t\t\t\t\t\t\t\t\tnode.nodeName.toLowerCase() === name :\n\t\t\t\t\t\t\t\t\t\tnode.nodeType === 1 ) &&\n\t\t\t\t\t\t\t\t\t\t++diff ) {\n\n\t\t\t\t\t\t\t\t\t\t// Cache the index of each encountered element\n\t\t\t\t\t\t\t\t\t\tif ( useCache ) {\n\t\t\t\t\t\t\t\t\t\t\touterCache = node[ expando ] || (node[ expando ] = {});\n\n\t\t\t\t\t\t\t\t\t\t\t// Support: IE <9 only\n\t\t\t\t\t\t\t\t\t\t\t// Defend against cloned attroperties (jQuery gh-1709)\n\t\t\t\t\t\t\t\t\t\t\tuniqueCache = outerCache[ node.uniqueID ] ||\n\t\t\t\t\t\t\t\t\t\t\t\t(outerCache[ node.uniqueID ] = {});\n\n\t\t\t\t\t\t\t\t\t\t\tuniqueCache[ type ] = [ dirruns, diff ];\n\t\t\t\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t\t\t\tif ( node === elem ) {\n\t\t\t\t\t\t\t\t\t\t\tbreak;\n\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\n\t\t\t\t\t\t// Incorporate the offset, then check against cycle size\n\t\t\t\t\t\tdiff -= last;\n\t\t\t\t\t\treturn diff === first || ( diff % first === 0 && diff / first >= 0 );\n\t\t\t\t\t}\n\t\t\t\t};\n\t\t},\n\n\t\t\"PSEUDO\": function( pseudo, argument ) {\n\t\t\t// pseudo-class names are case-insensitive\n\t\t\t// http://www.w3.org/TR/selectors/#pseudo-classes\n\t\t\t// Prioritize by case sensitivity in case custom pseudos are added with uppercase letters\n\t\t\t// Remember that setFilters inherits from pseudos\n\t\t\tvar args,\n\t\t\t\tfn = Expr.pseudos[ pseudo ] || Expr.setFilters[ pseudo.toLowerCase() ] ||\n\t\t\t\t\tSizzle.error( \"unsupported pseudo: \" + pseudo );\n\n\t\t\t// The user may use createPseudo to indicate that\n\t\t\t// arguments are needed to create the filter function\n\t\t\t// just as Sizzle does\n\t\t\tif ( fn[ expando ] ) {\n\t\t\t\treturn fn( argument );\n\t\t\t}\n\n\t\t\t// But maintain support for old signatures\n\t\t\tif ( fn.length > 1 ) {\n\t\t\t\targs = [ pseudo, pseudo, \"\", argument ];\n\t\t\t\treturn Expr.setFilters.hasOwnProperty( pseudo.toLowerCase() ) ?\n\t\t\t\t\tmarkFunction(function( seed, matches ) {\n\t\t\t\t\t\tvar idx,\n\t\t\t\t\t\t\tmatched = fn( seed, argument ),\n\t\t\t\t\t\t\ti = matched.length;\n\t\t\t\t\t\twhile ( i-- ) {\n\t\t\t\t\t\t\tidx = indexOf( seed, matched[i] );\n\t\t\t\t\t\t\tseed[ idx ] = !( matches[ idx ] = matched[i] );\n\t\t\t\t\t\t}\n\t\t\t\t\t}) :\n\t\t\t\t\tfunction( elem ) {\n\t\t\t\t\t\treturn fn( elem, 0, args );\n\t\t\t\t\t};\n\t\t\t}\n\n\t\t\treturn fn;\n\t\t}\n\t},\n\n\tpseudos: {\n\t\t// Potentially complex pseudos\n\t\t\"not\": markFunction(function( selector ) {\n\t\t\t// Trim the selector passed to compile\n\t\t\t// to avoid treating leading and trailing\n\t\t\t// spaces as combinators\n\t\t\tvar input = [],\n\t\t\t\tresults = [],\n\t\t\t\tmatcher = compile( selector.replace( rtrim, \"$1\" ) );\n\n\t\t\treturn matcher[ expando ] ?\n\t\t\t\tmarkFunction(function( seed, matches, context, xml ) {\n\t\t\t\t\tvar elem,\n\t\t\t\t\t\tunmatched = matcher( seed, null, xml, [] ),\n\t\t\t\t\t\ti = seed.length;\n\n\t\t\t\t\t// Match elements unmatched by `matcher`\n\t\t\t\t\twhile ( i-- ) {\n\t\t\t\t\t\tif ( (elem = unmatched[i]) ) {\n\t\t\t\t\t\t\tseed[i] = !(matches[i] = elem);\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t}) :\n\t\t\t\tfunction( elem, context, xml ) {\n\t\t\t\t\tinput[0] = elem;\n\t\t\t\t\tmatcher( input, null, xml, results );\n\t\t\t\t\t// Don't keep the element (issue #299)\n\t\t\t\t\tinput[0] = null;\n\t\t\t\t\treturn !results.pop();\n\t\t\t\t};\n\t\t}),\n\n\t\t\"has\": markFunction(function( selector ) {\n\t\t\treturn function( elem ) {\n\t\t\t\treturn Sizzle( selector, elem ).length > 0;\n\t\t\t};\n\t\t}),\n\n\t\t\"contains\": markFunction(function( text ) {\n\t\t\ttext = text.replace( runescape, funescape );\n\t\t\treturn function( elem ) {\n\t\t\t\treturn ( elem.textContent || elem.innerText || getText( elem ) ).indexOf( text ) > -1;\n\t\t\t};\n\t\t}),\n\n\t\t// \"Whether an element is represented by a :lang() selector\n\t\t// is based solely on the element's language value\n\t\t// being equal to the identifier C,\n\t\t// or beginning with the identifier C immediately followed by \"-\".\n\t\t// The matching of C against the element's language value is performed case-insensitively.\n\t\t// The identifier C does not have to be a valid language name.\"\n\t\t// http://www.w3.org/TR/selectors/#lang-pseudo\n\t\t\"lang\": markFunction( function( lang ) {\n\t\t\t// lang value must be a valid identifier\n\t\t\tif ( !ridentifier.test(lang || \"\") ) {\n\t\t\t\tSizzle.error( \"unsupported lang: \" + lang );\n\t\t\t}\n\t\t\tlang = lang.replace( runescape, funescape ).toLowerCase();\n\t\t\treturn function( elem ) {\n\t\t\t\tvar elemLang;\n\t\t\t\tdo {\n\t\t\t\t\tif ( (elemLang = documentIsHTML ?\n\t\t\t\t\t\telem.lang :\n\t\t\t\t\t\telem.getAttribute(\"xml:lang\") || elem.getAttribute(\"lang\")) ) {\n\n\t\t\t\t\t\telemLang = elemLang.toLowerCase();\n\t\t\t\t\t\treturn elemLang === lang || elemLang.indexOf( lang + \"-\" ) === 0;\n\t\t\t\t\t}\n\t\t\t\t} while ( (elem = elem.parentNode) && elem.nodeType === 1 );\n\t\t\t\treturn false;\n\t\t\t};\n\t\t}),\n\n\t\t// Miscellaneous\n\t\t\"target\": function( elem ) {\n\t\t\tvar hash = window.location && window.location.hash;\n\t\t\treturn hash && hash.slice( 1 ) === elem.id;\n\t\t},\n\n\t\t\"root\": function( elem ) {\n\t\t\treturn elem === docElem;\n\t\t},\n\n\t\t\"focus\": function( elem ) {\n\t\t\treturn elem === document.activeElement && (!document.hasFocus || document.hasFocus()) && !!(elem.type || elem.href || ~elem.tabIndex);\n\t\t},\n\n\t\t// Boolean properties\n\t\t\"enabled\": createDisabledPseudo( false ),\n\t\t\"disabled\": createDisabledPseudo( true ),\n\n\t\t\"checked\": function( elem ) {\n\t\t\t// In CSS3, :checked should return both checked and selected elements\n\t\t\t// http://www.w3.org/TR/2011/REC-css3-selectors-20110929/#checked\n\t\t\tvar nodeName = elem.nodeName.toLowerCase();\n\t\t\treturn (nodeName === \"input\" && !!elem.checked) || (nodeName === \"option\" && !!elem.selected);\n\t\t},\n\n\t\t\"selected\": function( elem ) {\n\t\t\t// Accessing this property makes selected-by-default\n\t\t\t// options in Safari work properly\n\t\t\tif ( elem.parentNode ) {\n\t\t\t\telem.parentNode.selectedIndex;\n\t\t\t}\n\n\t\t\treturn elem.selected === true;\n\t\t},\n\n\t\t// Contents\n\t\t\"empty\": function( elem ) {\n\t\t\t// http://www.w3.org/TR/selectors/#empty-pseudo\n\t\t\t// :empty is negated by element (1) or content nodes (text: 3; cdata: 4; entity ref: 5),\n\t\t\t// but not by others (comment: 8; processing instruction: 7; etc.)\n\t\t\t// nodeType < 6 works because attributes (2) do not appear as children\n\t\t\tfor ( elem = elem.firstChild; elem; elem = elem.nextSibling ) {\n\t\t\t\tif ( elem.nodeType < 6 ) {\n\t\t\t\t\treturn false;\n\t\t\t\t}\n\t\t\t}\n\t\t\treturn true;\n\t\t},\n\n\t\t\"parent\": function( elem ) {\n\t\t\treturn !Expr.pseudos[\"empty\"]( elem );\n\t\t},\n\n\t\t// Element/input types\n\t\t\"header\": function( elem ) {\n\t\t\treturn rheader.test( elem.nodeName );\n\t\t},\n\n\t\t\"input\": function( elem ) {\n\t\t\treturn rinputs.test( elem.nodeName );\n\t\t},\n\n\t\t\"button\": function( elem ) {\n\t\t\tvar name = elem.nodeName.toLowerCase();\n\t\t\treturn name === \"input\" && elem.type === \"button\" || name === \"button\";\n\t\t},\n\n\t\t\"text\": function( elem ) {\n\t\t\tvar attr;\n\t\t\treturn elem.nodeName.toLowerCase() === \"input\" &&\n\t\t\t\telem.type === \"text\" &&\n\n\t\t\t\t// Support: IE<8\n\t\t\t\t// New HTML5 attribute values (e.g., \"search\") appear with elem.type === \"text\"\n\t\t\t\t( (attr = elem.getAttribute(\"type\")) == null || attr.toLowerCase() === \"text\" );\n\t\t},\n\n\t\t// Position-in-collection\n\t\t\"first\": createPositionalPseudo(function() {\n\t\t\treturn [ 0 ];\n\t\t}),\n\n\t\t\"last\": createPositionalPseudo(function( matchIndexes, length ) {\n\t\t\treturn [ length - 1 ];\n\t\t}),\n\n\t\t\"eq\": createPositionalPseudo(function( matchIndexes, length, argument ) {\n\t\t\treturn [ argument < 0 ? argument + length : argument ];\n\t\t}),\n\n\t\t\"even\": createPositionalPseudo(function( matchIndexes, length ) {\n\t\t\tvar i = 0;\n\t\t\tfor ( ; i < length; i += 2 ) {\n\t\t\t\tmatchIndexes.push( i );\n\t\t\t}\n\t\t\treturn matchIndexes;\n\t\t}),\n\n\t\t\"odd\": createPositionalPseudo(function( matchIndexes, length ) {\n\t\t\tvar i = 1;\n\t\t\tfor ( ; i < length; i += 2 ) {\n\t\t\t\tmatchIndexes.push( i );\n\t\t\t}\n\t\t\treturn matchIndexes;\n\t\t}),\n\n\t\t\"lt\": createPositionalPseudo(function( matchIndexes, length, argument ) {\n\t\t\tvar i = argument < 0 ? argument + length : argument;\n\t\t\tfor ( ; --i >= 0; ) {\n\t\t\t\tmatchIndexes.push( i );\n\t\t\t}\n\t\t\treturn matchIndexes;\n\t\t}),\n\n\t\t\"gt\": createPositionalPseudo(function( matchIndexes, length, argument ) {\n\t\t\tvar i = argument < 0 ? argument + length : argument;\n\t\t\tfor ( ; ++i < length; ) {\n\t\t\t\tmatchIndexes.push( i );\n\t\t\t}\n\t\t\treturn matchIndexes;\n\t\t})\n\t}\n};\n\nExpr.pseudos[\"nth\"] = Expr.pseudos[\"eq\"];\n\n// Add button/input type pseudos\nfor ( i in { radio: true, checkbox: true, file: true, password: true, image: true } ) {\n\tExpr.pseudos[ i ] = createInputPseudo( i );\n}\nfor ( i in { submit: true, reset: true } ) {\n\tExpr.pseudos[ i ] = createButtonPseudo( i );\n}\n\n// Easy API for creating new setFilters\nfunction setFilters() {}\nsetFilters.prototype = Expr.filters = Expr.pseudos;\nExpr.setFilters = new setFilters();\n\ntokenize = Sizzle.tokenize = function( selector, parseOnly ) {\n\tvar matched, match, tokens, type,\n\t\tsoFar, groups, preFilters,\n\t\tcached = tokenCache[ selector + \" \" ];\n\n\tif ( cached ) {\n\t\treturn parseOnly ? 0 : cached.slice( 0 );\n\t}\n\n\tsoFar = selector;\n\tgroups = [];\n\tpreFilters = Expr.preFilter;\n\n\twhile ( soFar ) {\n\n\t\t// Comma and first run\n\t\tif ( !matched || (match = rcomma.exec( soFar )) ) {\n\t\t\tif ( match ) {\n\t\t\t\t// Don't consume trailing commas as valid\n\t\t\t\tsoFar = soFar.slice( match[0].length ) || soFar;\n\t\t\t}\n\t\t\tgroups.push( (tokens = []) );\n\t\t}\n\n\t\tmatched = false;\n\n\t\t// Combinators\n\t\tif ( (match = rcombinators.exec( soFar )) ) {\n\t\t\tmatched = match.shift();\n\t\t\ttokens.push({\n\t\t\t\tvalue: matched,\n\t\t\t\t// Cast descendant combinators to space\n\t\t\t\ttype: match[0].replace( rtrim, \" \" )\n\t\t\t});\n\t\t\tsoFar = soFar.slice( matched.length );\n\t\t}\n\n\t\t// Filters\n\t\tfor ( type in Expr.filter ) {\n\t\t\tif ( (match = matchExpr[ type ].exec( soFar )) && (!preFilters[ type ] ||\n\t\t\t\t(match = preFilters[ type ]( match ))) ) {\n\t\t\t\tmatched = match.shift();\n\t\t\t\ttokens.push({\n\t\t\t\t\tvalue: matched,\n\t\t\t\t\ttype: type,\n\t\t\t\t\tmatches: match\n\t\t\t\t});\n\t\t\t\tsoFar = soFar.slice( matched.length );\n\t\t\t}\n\t\t}\n\n\t\tif ( !matched ) {\n\t\t\tbreak;\n\t\t}\n\t}\n\n\t// Return the length of the invalid excess\n\t// if we're just parsing\n\t// Otherwise, throw an error or return tokens\n\treturn parseOnly ?\n\t\tsoFar.length :\n\t\tsoFar ?\n\t\t\tSizzle.error( selector ) :\n\t\t\t// Cache the tokens\n\t\t\ttokenCache( selector, groups ).slice( 0 );\n};\n\nfunction toSelector( tokens ) {\n\tvar i = 0,\n\t\tlen = tokens.length,\n\t\tselector = \"\";\n\tfor ( ; i < len; i++ ) {\n\t\tselector += tokens[i].value;\n\t}\n\treturn selector;\n}\n\nfunction addCombinator( matcher, combinator, base ) {\n\tvar dir = combinator.dir,\n\t\tskip = combinator.next,\n\t\tkey = skip || dir,\n\t\tcheckNonElements = base && key === \"parentNode\",\n\t\tdoneName = done++;\n\n\treturn combinator.first ?\n\t\t// Check against closest ancestor/preceding element\n\t\tfunction( elem, context, xml ) {\n\t\t\twhile ( (elem = elem[ dir ]) ) {\n\t\t\t\tif ( elem.nodeType === 1 || checkNonElements ) {\n\t\t\t\t\treturn matcher( elem, context, xml );\n\t\t\t\t}\n\t\t\t}\n\t\t\treturn false;\n\t\t} :\n\n\t\t// Check against all ancestor/preceding elements\n\t\tfunction( elem, context, xml ) {\n\t\t\tvar oldCache, uniqueCache, outerCache,\n\t\t\t\tnewCache = [ dirruns, doneName ];\n\n\t\t\t// We can't set arbitrary data on XML nodes, so they don't benefit from combinator caching\n\t\t\tif ( xml ) {\n\t\t\t\twhile ( (elem = elem[ dir ]) ) {\n\t\t\t\t\tif ( elem.nodeType === 1 || checkNonElements ) {\n\t\t\t\t\t\tif ( matcher( elem, context, xml ) ) {\n\t\t\t\t\t\t\treturn true;\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t} else {\n\t\t\t\twhile ( (elem = elem[ dir ]) ) {\n\t\t\t\t\tif ( elem.nodeType === 1 || checkNonElements ) {\n\t\t\t\t\t\touterCache = elem[ expando ] || (elem[ expando ] = {});\n\n\t\t\t\t\t\t// Support: IE <9 only\n\t\t\t\t\t\t// Defend against cloned attroperties (jQuery gh-1709)\n\t\t\t\t\t\tuniqueCache = outerCache[ elem.uniqueID ] || (outerCache[ elem.uniqueID ] = {});\n\n\t\t\t\t\t\tif ( skip && skip === elem.nodeName.toLowerCase() ) {\n\t\t\t\t\t\t\telem = elem[ dir ] || elem;\n\t\t\t\t\t\t} else if ( (oldCache = uniqueCache[ key ]) &&\n\t\t\t\t\t\t\toldCache[ 0 ] === dirruns && oldCache[ 1 ] === doneName ) {\n\n\t\t\t\t\t\t\t// Assign to newCache so results back-propagate to previous elements\n\t\t\t\t\t\t\treturn (newCache[ 2 ] = oldCache[ 2 ]);\n\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\t// Reuse newcache so results back-propagate to previous elements\n\t\t\t\t\t\t\tuniqueCache[ key ] = newCache;\n\n\t\t\t\t\t\t\t// A match means we're done; a fail means we have to keep checking\n\t\t\t\t\t\t\tif ( (newCache[ 2 ] = matcher( elem, context, xml )) ) {\n\t\t\t\t\t\t\t\treturn true;\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}\n\t\t\t}\n\t\t\treturn false;\n\t\t};\n}\n\nfunction elementMatcher( matchers ) {\n\treturn matchers.length > 1 ?\n\t\tfunction( elem, context, xml ) {\n\t\t\tvar i = matchers.length;\n\t\t\twhile ( i-- ) {\n\t\t\t\tif ( !matchers[i]( elem, context, xml ) ) {\n\t\t\t\t\treturn false;\n\t\t\t\t}\n\t\t\t}\n\t\t\treturn true;\n\t\t} :\n\t\tmatchers[0];\n}\n\nfunction multipleContexts( selector, contexts, results ) {\n\tvar i = 0,\n\t\tlen = contexts.length;\n\tfor ( ; i < len; i++ ) {\n\t\tSizzle( selector, contexts[i], results );\n\t}\n\treturn results;\n}\n\nfunction condense( unmatched, map, filter, context, xml ) {\n\tvar elem,\n\t\tnewUnmatched = [],\n\t\ti = 0,\n\t\tlen = unmatched.length,\n\t\tmapped = map != null;\n\n\tfor ( ; i < len; i++ ) {\n\t\tif ( (elem = unmatched[i]) ) {\n\t\t\tif ( !filter || filter( elem, context, xml ) ) {\n\t\t\t\tnewUnmatched.push( elem );\n\t\t\t\tif ( mapped ) {\n\t\t\t\t\tmap.push( i );\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n\n\treturn newUnmatched;\n}\n\nfunction setMatcher( preFilter, selector, matcher, postFilter, postFinder, postSelector ) {\n\tif ( postFilter && !postFilter[ expando ] ) {\n\t\tpostFilter = setMatcher( postFilter );\n\t}\n\tif ( postFinder && !postFinder[ expando ] ) {\n\t\tpostFinder = setMatcher( postFinder, postSelector );\n\t}\n\treturn markFunction(function( seed, results, context, xml ) {\n\t\tvar temp, i, elem,\n\t\t\tpreMap = [],\n\t\t\tpostMap = [],\n\t\t\tpreexisting = results.length,\n\n\t\t\t// Get initial elements from seed or context\n\t\t\telems = seed || multipleContexts( selector || \"*\", context.nodeType ? [ context ] : context, [] ),\n\n\t\t\t// Prefilter to get matcher input, preserving a map for seed-results synchronization\n\t\t\tmatcherIn = preFilter && ( seed || !selector ) ?\n\t\t\t\tcondense( elems, preMap, preFilter, context, xml ) :\n\t\t\t\telems,\n\n\t\t\tmatcherOut = matcher ?\n\t\t\t\t// If we have a postFinder, or filtered seed, or non-seed postFilter or preexisting results,\n\t\t\t\tpostFinder || ( seed ? preFilter : preexisting || postFilter ) ?\n\n\t\t\t\t\t// ...intermediate processing is necessary\n\t\t\t\t\t[] :\n\n\t\t\t\t\t// ...otherwise use results directly\n\t\t\t\t\tresults :\n\t\t\t\tmatcherIn;\n\n\t\t// Find primary matches\n\t\tif ( matcher ) {\n\t\t\tmatcher( matcherIn, matcherOut, context, xml );\n\t\t}\n\n\t\t// Apply postFilter\n\t\tif ( postFilter ) {\n\t\t\ttemp = condense( matcherOut, postMap );\n\t\t\tpostFilter( temp, [], context, xml );\n\n\t\t\t// Un-match failing elements by moving them back to matcherIn\n\t\t\ti = temp.length;\n\t\t\twhile ( i-- ) {\n\t\t\t\tif ( (elem = temp[i]) ) {\n\t\t\t\t\tmatcherOut[ postMap[i] ] = !(matcherIn[ postMap[i] ] = elem);\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\tif ( seed ) {\n\t\t\tif ( postFinder || preFilter ) {\n\t\t\t\tif ( postFinder ) {\n\t\t\t\t\t// Get the final matcherOut by condensing this intermediate into postFinder contexts\n\t\t\t\t\ttemp = [];\n\t\t\t\t\ti = matcherOut.length;\n\t\t\t\t\twhile ( i-- ) {\n\t\t\t\t\t\tif ( (elem = matcherOut[i]) ) {\n\t\t\t\t\t\t\t// Restore matcherIn since elem is not yet a final match\n\t\t\t\t\t\t\ttemp.push( (matcherIn[i] = elem) );\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t\tpostFinder( null, (matcherOut = []), temp, xml );\n\t\t\t\t}\n\n\t\t\t\t// Move matched elements from seed to results to keep them synchronized\n\t\t\t\ti = matcherOut.length;\n\t\t\t\twhile ( i-- ) {\n\t\t\t\t\tif ( (elem = matcherOut[i]) &&\n\t\t\t\t\t\t(temp = postFinder ? indexOf( seed, elem ) : preMap[i]) > -1 ) {\n\n\t\t\t\t\t\tseed[temp] = !(results[temp] = elem);\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\n\t\t// Add elements to results, through postFinder if defined\n\t\t} else {\n\t\t\tmatcherOut = condense(\n\t\t\t\tmatcherOut === results ?\n\t\t\t\t\tmatcherOut.splice( preexisting, matcherOut.length ) :\n\t\t\t\t\tmatcherOut\n\t\t\t);\n\t\t\tif ( postFinder ) {\n\t\t\t\tpostFinder( null, results, matcherOut, xml );\n\t\t\t} else {\n\t\t\t\tpush.apply( results, matcherOut );\n\t\t\t}\n\t\t}\n\t});\n}\n\nfunction matcherFromTokens( tokens ) {\n\tvar checkContext, matcher, j,\n\t\tlen = tokens.length,\n\t\tleadingRelative = Expr.relative[ tokens[0].type ],\n\t\timplicitRelative = leadingRelative || Expr.relative[\" \"],\n\t\ti = leadingRelative ? 1 : 0,\n\n\t\t// The foundational matcher ensures that elements are reachable from top-level context(s)\n\t\tmatchContext = addCombinator( function( elem ) {\n\t\t\treturn elem === checkContext;\n\t\t}, implicitRelative, true ),\n\t\tmatchAnyContext = addCombinator( function( elem ) {\n\t\t\treturn indexOf( checkContext, elem ) > -1;\n\t\t}, implicitRelative, true ),\n\t\tmatchers = [ function( elem, context, xml ) {\n\t\t\tvar ret = ( !leadingRelative && ( xml || context !== outermostContext ) ) || (\n\t\t\t\t(checkContext = context).nodeType ?\n\t\t\t\t\tmatchContext( elem, context, xml ) :\n\t\t\t\t\tmatchAnyContext( elem, context, xml ) );\n\t\t\t// Avoid hanging onto element (issue #299)\n\t\t\tcheckContext = null;\n\t\t\treturn ret;\n\t\t} ];\n\n\tfor ( ; i < len; i++ ) {\n\t\tif ( (matcher = Expr.relative[ tokens[i].type ]) ) {\n\t\t\tmatchers = [ addCombinator(elementMatcher( matchers ), matcher) ];\n\t\t} else {\n\t\t\tmatcher = Expr.filter[ tokens[i].type ].apply( null, tokens[i].matches );\n\n\t\t\t// Return special upon seeing a positional matcher\n\t\t\tif ( matcher[ expando ] ) {\n\t\t\t\t// Find the next relative operator (if any) for proper handling\n\t\t\t\tj = ++i;\n\t\t\t\tfor ( ; j < len; j++ ) {\n\t\t\t\t\tif ( Expr.relative[ tokens[j].type ] ) {\n\t\t\t\t\t\tbreak;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t\treturn setMatcher(\n\t\t\t\t\ti > 1 && elementMatcher( matchers ),\n\t\t\t\t\ti > 1 && toSelector(\n\t\t\t\t\t\t// If the preceding token was a descendant combinator, insert an implicit any-element `*`\n\t\t\t\t\t\ttokens.slice( 0, i - 1 ).concat({ value: tokens[ i - 2 ].type === \" \" ? \"*\" : \"\" })\n\t\t\t\t\t).replace( rtrim, \"$1\" ),\n\t\t\t\t\tmatcher,\n\t\t\t\t\ti < j && matcherFromTokens( tokens.slice( i, j ) ),\n\t\t\t\t\tj < len && matcherFromTokens( (tokens = tokens.slice( j )) ),\n\t\t\t\t\tj < len && toSelector( tokens )\n\t\t\t\t);\n\t\t\t}\n\t\t\tmatchers.push( matcher );\n\t\t}\n\t}\n\n\treturn elementMatcher( matchers );\n}\n\nfunction matcherFromGroupMatchers( elementMatchers, setMatchers ) {\n\tvar bySet = setMatchers.length > 0,\n\t\tbyElement = elementMatchers.length > 0,\n\t\tsuperMatcher = function( seed, context, xml, results, outermost ) {\n\t\t\tvar elem, j, matcher,\n\t\t\t\tmatchedCount = 0,\n\t\t\t\ti = \"0\",\n\t\t\t\tunmatched = seed && [],\n\t\t\t\tsetMatched = [],\n\t\t\t\tcontextBackup = outermostContext,\n\t\t\t\t// We must always have either seed elements or outermost context\n\t\t\t\telems = seed || byElement && Expr.find[\"TAG\"]( \"*\", outermost ),\n\t\t\t\t// Use integer dirruns iff this is the outermost matcher\n\t\t\t\tdirrunsUnique = (dirruns += contextBackup == null ? 1 : Math.random() || 0.1),\n\t\t\t\tlen = elems.length;\n\n\t\t\tif ( outermost ) {\n\t\t\t\toutermostContext = context === document || context || outermost;\n\t\t\t}\n\n\t\t\t// Add elements passing elementMatchers directly to results\n\t\t\t// Support: IE<9, Safari\n\t\t\t// Tolerate NodeList properties (IE: \"length\"; Safari: <number>) matching elements by id\n\t\t\tfor ( ; i !== len && (elem = elems[i]) != null; i++ ) {\n\t\t\t\tif ( byElement && elem ) {\n\t\t\t\t\tj = 0;\n\t\t\t\t\tif ( !context && elem.ownerDocument !== document ) {\n\t\t\t\t\t\tsetDocument( elem );\n\t\t\t\t\t\txml = !documentIsHTML;\n\t\t\t\t\t}\n\t\t\t\t\twhile ( (matcher = elementMatchers[j++]) ) {\n\t\t\t\t\t\tif ( matcher( elem, context || document, xml) ) {\n\t\t\t\t\t\t\tresults.push( elem );\n\t\t\t\t\t\t\tbreak;\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t\tif ( outermost ) {\n\t\t\t\t\t\tdirruns = dirrunsUnique;\n\t\t\t\t\t}\n\t\t\t\t}\n\n\t\t\t\t// Track unmatched elements for set filters\n\t\t\t\tif ( bySet ) {\n\t\t\t\t\t// They will have gone through all possible matchers\n\t\t\t\t\tif ( (elem = !matcher && elem) ) {\n\t\t\t\t\t\tmatchedCount--;\n\t\t\t\t\t}\n\n\t\t\t\t\t// Lengthen the array for every element, matched or not\n\t\t\t\t\tif ( seed ) {\n\t\t\t\t\t\tunmatched.push( elem );\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\n\t\t\t// `i` is now the count of elements visited above, and adding it to `matchedCount`\n\t\t\t// makes the latter nonnegative.\n\t\t\tmatchedCount += i;\n\n\t\t\t// Apply set filters to unmatched elements\n\t\t\t// NOTE: This can be skipped if there are no unmatched elements (i.e., `matchedCount`\n\t\t\t// equals `i`), unless we didn't visit _any_ elements in the above loop because we have\n\t\t\t// no element matchers and no seed.\n\t\t\t// Incrementing an initially-string \"0\" `i` allows `i` to remain a string only in that\n\t\t\t// case, which will result in a \"00\" `matchedCount` that differs from `i` but is also\n\t\t\t// numerically zero.\n\t\t\tif ( bySet && i !== matchedCount ) {\n\t\t\t\tj = 0;\n\t\t\t\twhile ( (matcher = setMatchers[j++]) ) {\n\t\t\t\t\tmatcher( unmatched, setMatched, context, xml );\n\t\t\t\t}\n\n\t\t\t\tif ( seed ) {\n\t\t\t\t\t// Reintegrate element matches to eliminate the need for sorting\n\t\t\t\t\tif ( matchedCount > 0 ) {\n\t\t\t\t\t\twhile ( i-- ) {\n\t\t\t\t\t\t\tif ( !(unmatched[i] || setMatched[i]) ) {\n\t\t\t\t\t\t\t\tsetMatched[i] = pop.call( results );\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\n\t\t\t\t\t// Discard index placeholder values to get only actual matches\n\t\t\t\t\tsetMatched = condense( setMatched );\n\t\t\t\t}\n\n\t\t\t\t// Add matches to results\n\t\t\t\tpush.apply( results, setMatched );\n\n\t\t\t\t// Seedless set matches succeeding multiple successful matchers stipulate sorting\n\t\t\t\tif ( outermost && !seed && setMatched.length > 0 &&\n\t\t\t\t\t( matchedCount + setMatchers.length ) > 1 ) {\n\n\t\t\t\t\tSizzle.uniqueSort( results );\n\t\t\t\t}\n\t\t\t}\n\n\t\t\t// Override manipulation of globals by nested matchers\n\t\t\tif ( outermost ) {\n\t\t\t\tdirruns = dirrunsUnique;\n\t\t\t\toutermostContext = contextBackup;\n\t\t\t}\n\n\t\t\treturn unmatched;\n\t\t};\n\n\treturn bySet ?\n\t\tmarkFunction( superMatcher ) :\n\t\tsuperMatcher;\n}\n\ncompile = Sizzle.compile = function( selector, match /* Internal Use Only */ ) {\n\tvar i,\n\t\tsetMatchers = [],\n\t\telementMatchers = [],\n\t\tcached = compilerCache[ selector + \" \" ];\n\n\tif ( !cached ) {\n\t\t// Generate a function of recursive functions that can be used to check each element\n\t\tif ( !match ) {\n\t\t\tmatch = tokenize( selector );\n\t\t}\n\t\ti = match.length;\n\t\twhile ( i-- ) {\n\t\t\tcached = matcherFromTokens( match[i] );\n\t\t\tif ( cached[ expando ] ) {\n\t\t\t\tsetMatchers.push( cached );\n\t\t\t} else {\n\t\t\t\telementMatchers.push( cached );\n\t\t\t}\n\t\t}\n\n\t\t// Cache the compiled function\n\t\tcached = compilerCache( selector, matcherFromGroupMatchers( elementMatchers, setMatchers ) );\n\n\t\t// Save selector and tokenization\n\t\tcached.selector = selector;\n\t}\n\treturn cached;\n};\n\n/**\n * A low-level selection function that works with Sizzle's compiled\n * selector functions\n * @param {String|Function} selector A selector or a pre-compiled\n * selector function built with Sizzle.compile\n * @param {Element} context\n * @param {Array} [results]\n * @param {Array} [seed] A set of elements to match against\n */\nselect = Sizzle.select = function( selector, context, results, seed ) {\n\tvar i, tokens, token, type, find,\n\t\tcompiled = typeof selector === \"function\" && selector,\n\t\tmatch = !seed && tokenize( (selector = compiled.selector || selector) );\n\n\tresults = results || [];\n\n\t// Try to minimize operations if there is only one selector in the list and no seed\n\t// (the latter of which guarantees us context)\n\tif ( match.length === 1 ) {\n\n\t\t// Reduce context if the leading compound selector is an ID\n\t\ttokens = match[0] = match[0].slice( 0 );\n\t\tif ( tokens.length > 2 && (token = tokens[0]).type === \"ID\" &&\n\t\t\t\tcontext.nodeType === 9 && documentIsHTML && Expr.relative[ tokens[1].type ] ) {\n\n\t\t\tcontext = ( Expr.find[\"ID\"]( token.matches[0].replace(runescape, funescape), context ) || [] )[0];\n\t\t\tif ( !context ) {\n\t\t\t\treturn results;\n\n\t\t\t// Precompiled matchers will still verify ancestry, so step up a level\n\t\t\t} else if ( compiled ) {\n\t\t\t\tcontext = context.parentNode;\n\t\t\t}\n\n\t\t\tselector = selector.slice( tokens.shift().value.length );\n\t\t}\n\n\t\t// Fetch a seed set for right-to-left matching\n\t\ti = matchExpr[\"needsContext\"].test( selector ) ? 0 : tokens.length;\n\t\twhile ( i-- ) {\n\t\t\ttoken = tokens[i];\n\n\t\t\t// Abort if we hit a combinator\n\t\t\tif ( Expr.relative[ (type = token.type) ] ) {\n\t\t\t\tbreak;\n\t\t\t}\n\t\t\tif ( (find = Expr.find[ type ]) ) {\n\t\t\t\t// Search, expanding context for leading sibling combinators\n\t\t\t\tif ( (seed = find(\n\t\t\t\t\ttoken.matches[0].replace( runescape, funescape ),\n\t\t\t\t\trsibling.test( tokens[0].type ) && testContext( context.parentNode ) || context\n\t\t\t\t)) ) {\n\n\t\t\t\t\t// If seed is empty or no tokens remain, we can return early\n\t\t\t\t\ttokens.splice( i, 1 );\n\t\t\t\t\tselector = seed.length && toSelector( tokens );\n\t\t\t\t\tif ( !selector ) {\n\t\t\t\t\t\tpush.apply( results, seed );\n\t\t\t\t\t\treturn results;\n\t\t\t\t\t}\n\n\t\t\t\t\tbreak;\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n\n\t// Compile and execute a filtering function if one is not provided\n\t// Provide `match` to avoid retokenization if we modified the selector above\n\t( compiled || compile( selector, match ) )(\n\t\tseed,\n\t\tcontext,\n\t\t!documentIsHTML,\n\t\tresults,\n\t\t!context || rsibling.test( selector ) && testContext( context.parentNode ) || context\n\t);\n\treturn results;\n};\n\n// One-time assignments\n\n// Sort stability\nsupport.sortStable = expando.split(\"\").sort( sortOrder ).join(\"\") === expando;\n\n// Support: Chrome 14-35+\n// Always assume duplicates if they aren't passed to the comparison function\nsupport.detectDuplicates = !!hasDuplicate;\n\n// Initialize against the default document\nsetDocument();\n\n// Support: Webkit<537.32 - Safari 6.0.3/Chrome 25 (fixed in Chrome 27)\n// Detached nodes confoundingly follow *each other*\nsupport.sortDetached = assert(function( el ) {\n\t// Should return 1, but returns 4 (following)\n\treturn el.compareDocumentPosition( document.createElement(\"fieldset\") ) & 1;\n});\n\n// Support: IE<8\n// Prevent attribute/property \"interpolation\"\n// https://msdn.microsoft.com/en-us/library/ms536429%28VS.85%29.aspx\nif ( !assert(function( el ) {\n\tel.innerHTML = \"<a href='#'></a>\";\n\treturn el.firstChild.getAttribute(\"href\") === \"#\" ;\n}) ) {\n\taddHandle( \"type|href|height|width\", function( elem, name, isXML ) {\n\t\tif ( !isXML ) {\n\t\t\treturn elem.getAttribute( name, name.toLowerCase() === \"type\" ? 1 : 2 );\n\t\t}\n\t});\n}\n\n// Support: IE<9\n// Use defaultValue in place of getAttribute(\"value\")\nif ( !support.attributes || !assert(function( el ) {\n\tel.innerHTML = \"<input/>\";\n\tel.firstChild.setAttribute( \"value\", \"\" );\n\treturn el.firstChild.getAttribute( \"value\" ) === \"\";\n}) ) {\n\taddHandle( \"value\", function( elem, name, isXML ) {\n\t\tif ( !isXML && elem.nodeName.toLowerCase() === \"input\" ) {\n\t\t\treturn elem.defaultValue;\n\t\t}\n\t});\n}\n\n// Support: IE<9\n// Use getAttributeNode to fetch booleans when getAttribute lies\nif ( !assert(function( el ) {\n\treturn el.getAttribute(\"disabled\") == null;\n}) ) {\n\taddHandle( booleans, function( elem, name, isXML ) {\n\t\tvar val;\n\t\tif ( !isXML ) {\n\t\t\treturn elem[ name ] === true ? name.toLowerCase() :\n\t\t\t\t\t(val = elem.getAttributeNode( name )) && val.specified ?\n\t\t\t\t\tval.value :\n\t\t\t\tnull;\n\t\t}\n\t});\n}\n\nreturn Sizzle;\n\n})( window );\n\n\n\njQuery.find = Sizzle;\njQuery.expr = Sizzle.selectors;\n\n// Deprecated\njQuery.expr[ \":\" ] = jQuery.expr.pseudos;\njQuery.uniqueSort = jQuery.unique = Sizzle.uniqueSort;\njQuery.text = Sizzle.getText;\njQuery.isXMLDoc = Sizzle.isXML;\njQuery.contains = Sizzle.contains;\njQuery.escapeSelector = Sizzle.escape;\n\n\n\n\nvar dir = function( elem, dir, until ) {\n\tvar matched = [],\n\t\ttruncate = until !== undefined;\n\n\twhile ( ( elem = elem[ dir ] ) && elem.nodeType !== 9 ) {\n\t\tif ( elem.nodeType === 1 ) {\n\t\t\tif ( truncate && jQuery( elem ).is( until ) ) {\n\t\t\t\tbreak;\n\t\t\t}\n\t\t\tmatched.push( elem );\n\t\t}\n\t}\n\treturn matched;\n};\n\n\nvar siblings = function( n, elem ) {\n\tvar matched = [];\n\n\tfor ( ; n; n = n.nextSibling ) {\n\t\tif ( n.nodeType === 1 && n !== elem ) {\n\t\t\tmatched.push( n );\n\t\t}\n\t}\n\n\treturn matched;\n};\n\n\nvar rneedsContext = jQuery.expr.match.needsContext;\n\n\n\nfunction nodeName( elem, name ) {\n\n return elem.nodeName && elem.nodeName.toLowerCase() === name.toLowerCase();\n\n};\nvar rsingleTag = ( /^<([a-z][^\\/\\0>:\\x20\\t\\r\\n\\f]*)[\\x20\\t\\r\\n\\f]*\\/?>(?:<\\/\\1>|)$/i );\n\n\n\nvar risSimple = /^.[^:#\\[\\.,]*$/;\n\n// Implement the identical functionality for filter and not\nfunction winnow( elements, qualifier, not ) {\n\tif ( jQuery.isFunction( qualifier ) ) {\n\t\treturn jQuery.grep( elements, function( elem, i ) {\n\t\t\treturn !!qualifier.call( elem, i, elem ) !== not;\n\t\t} );\n\t}\n\n\t// Single element\n\tif ( qualifier.nodeType ) {\n\t\treturn jQuery.grep( elements, function( elem ) {\n\t\t\treturn ( elem === qualifier ) !== not;\n\t\t} );\n\t}\n\n\t// Arraylike of elements (jQuery, arguments, Array)\n\tif ( typeof qualifier !== \"string\" ) {\n\t\treturn jQuery.grep( elements, function( elem ) {\n\t\t\treturn ( indexOf.call( qualifier, elem ) > -1 ) !== not;\n\t\t} );\n\t}\n\n\t// Simple selector that can be filtered directly, removing non-Elements\n\tif ( risSimple.test( qualifier ) ) {\n\t\treturn jQuery.filter( qualifier, elements, not );\n\t}\n\n\t// Complex selector, compare the two sets, removing non-Elements\n\tqualifier = jQuery.filter( qualifier, elements );\n\treturn jQuery.grep( elements, function( elem ) {\n\t\treturn ( indexOf.call( qualifier, elem ) > -1 ) !== not && elem.nodeType === 1;\n\t} );\n}\n\njQuery.filter = function( expr, elems, not ) {\n\tvar elem = elems[ 0 ];\n\n\tif ( not ) {\n\t\texpr = \":not(\" + expr + \")\";\n\t}\n\n\tif ( elems.length === 1 && elem.nodeType === 1 ) {\n\t\treturn jQuery.find.matchesSelector( elem, expr ) ? [ elem ] : [];\n\t}\n\n\treturn jQuery.find.matches( expr, jQuery.grep( elems, function( elem ) {\n\t\treturn elem.nodeType === 1;\n\t} ) );\n};\n\njQuery.fn.extend( {\n\tfind: function( selector ) {\n\t\tvar i, ret,\n\t\t\tlen = this.length,\n\t\t\tself = this;\n\n\t\tif ( typeof selector !== \"string\" ) {\n\t\t\treturn this.pushStack( jQuery( selector ).filter( function() {\n\t\t\t\tfor ( i = 0; i < len; i++ ) {\n\t\t\t\t\tif ( jQuery.contains( self[ i ], this ) ) {\n\t\t\t\t\t\treturn true;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t} ) );\n\t\t}\n\n\t\tret = this.pushStack( [] );\n\n\t\tfor ( i = 0; i < len; i++ ) {\n\t\t\tjQuery.find( selector, self[ i ], ret );\n\t\t}\n\n\t\treturn len > 1 ? jQuery.uniqueSort( ret ) : ret;\n\t},\n\tfilter: function( selector ) {\n\t\treturn this.pushStack( winnow( this, selector || [], false ) );\n\t},\n\tnot: function( selector ) {\n\t\treturn this.pushStack( winnow( this, selector || [], true ) );\n\t},\n\tis: function( selector ) {\n\t\treturn !!winnow(\n\t\t\tthis,\n\n\t\t\t// If this is a positional/relative selector, check membership in the returned set\n\t\t\t// so $(\"p:first\").is(\"p:last\") won't return true for a doc with two \"p\".\n\t\t\ttypeof selector === \"string\" && rneedsContext.test( selector ) ?\n\t\t\t\tjQuery( selector ) :\n\t\t\t\tselector || [],\n\t\t\tfalse\n\t\t).length;\n\t}\n} );\n\n\n// Initialize a jQuery object\n\n\n// A central reference to the root jQuery(document)\nvar rootjQuery,\n\n\t// A simple way to check for HTML strings\n\t// Prioritize #id over <tag> to avoid XSS via location.hash (#9521)\n\t// Strict HTML recognition (#11290: must start with <)\n\t// Shortcut simple #id case for speed\n\trquickExpr = /^(?:\\s*(<[\\w\\W]+>)[^>]*|#([\\w-]+))$/,\n\n\tinit = jQuery.fn.init = function( selector, context, root ) {\n\t\tvar match, elem;\n\n\t\t// HANDLE: $(\"\"), $(null), $(undefined), $(false)\n\t\tif ( !selector ) {\n\t\t\treturn this;\n\t\t}\n\n\t\t// Method init() accepts an alternate rootjQuery\n\t\t// so migrate can support jQuery.sub (gh-2101)\n\t\troot = root || rootjQuery;\n\n\t\t// Handle HTML strings\n\t\tif ( typeof selector === \"string\" ) {\n\t\t\tif ( selector[ 0 ] === \"<\" &&\n\t\t\t\tselector[ selector.length - 1 ] === \">\" &&\n\t\t\t\tselector.length >= 3 ) {\n\n\t\t\t\t// Assume that strings that start and end with <> are HTML and skip the regex check\n\t\t\t\tmatch = [ null, selector, null ];\n\n\t\t\t} else {\n\t\t\t\tmatch = rquickExpr.exec( selector );\n\t\t\t}\n\n\t\t\t// Match html or make sure no context is specified for #id\n\t\t\tif ( match && ( match[ 1 ] || !context ) ) {\n\n\t\t\t\t// HANDLE: $(html) -> $(array)\n\t\t\t\tif ( match[ 1 ] ) {\n\t\t\t\t\tcontext = context instanceof jQuery ? context[ 0 ] : context;\n\n\t\t\t\t\t// Option to run scripts is true for back-compat\n\t\t\t\t\t// Intentionally let the error be thrown if parseHTML is not present\n\t\t\t\t\tjQuery.merge( this, jQuery.parseHTML(\n\t\t\t\t\t\tmatch[ 1 ],\n\t\t\t\t\t\tcontext && context.nodeType ? context.ownerDocument || context : document,\n\t\t\t\t\t\ttrue\n\t\t\t\t\t) );\n\n\t\t\t\t\t// HANDLE: $(html, props)\n\t\t\t\t\tif ( rsingleTag.test( match[ 1 ] ) && jQuery.isPlainObject( context ) ) {\n\t\t\t\t\t\tfor ( match in context ) {\n\n\t\t\t\t\t\t\t// Properties of context are called as methods if possible\n\t\t\t\t\t\t\tif ( jQuery.isFunction( this[ match ] ) ) {\n\t\t\t\t\t\t\t\tthis[ match ]( context[ match ] );\n\n\t\t\t\t\t\t\t// ...and otherwise set as attributes\n\t\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\t\tthis.attr( match, context[ match ] );\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\n\t\t\t\t\treturn this;\n\n\t\t\t\t// HANDLE: $(#id)\n\t\t\t\t} else {\n\t\t\t\t\telem = document.getElementById( match[ 2 ] );\n\n\t\t\t\t\tif ( elem ) {\n\n\t\t\t\t\t\t// Inject the element directly into the jQuery object\n\t\t\t\t\t\tthis[ 0 ] = elem;\n\t\t\t\t\t\tthis.length = 1;\n\t\t\t\t\t}\n\t\t\t\t\treturn this;\n\t\t\t\t}\n\n\t\t\t// HANDLE: $(expr, $(...))\n\t\t\t} else if ( !context || context.jquery ) {\n\t\t\t\treturn ( context || root ).find( selector );\n\n\t\t\t// HANDLE: $(expr, context)\n\t\t\t// (which is just equivalent to: $(context).find(expr)\n\t\t\t} else {\n\t\t\t\treturn this.constructor( context ).find( selector );\n\t\t\t}\n\n\t\t// HANDLE: $(DOMElement)\n\t\t} else if ( selector.nodeType ) {\n\t\t\tthis[ 0 ] = selector;\n\t\t\tthis.length = 1;\n\t\t\treturn this;\n\n\t\t// HANDLE: $(function)\n\t\t// Shortcut for document ready\n\t\t} else if ( jQuery.isFunction( selector ) ) {\n\t\t\treturn root.ready !== undefined ?\n\t\t\t\troot.ready( selector ) :\n\n\t\t\t\t// Execute immediately if ready is not present\n\t\t\t\tselector( jQuery );\n\t\t}\n\n\t\treturn jQuery.makeArray( selector, this );\n\t};\n\n// Give the init function the jQuery prototype for later instantiation\ninit.prototype = jQuery.fn;\n\n// Initialize central reference\nrootjQuery = jQuery( document );\n\n\nvar rparentsprev = /^(?:parents|prev(?:Until|All))/,\n\n\t// Methods guaranteed to produce a unique set when starting from a unique set\n\tguaranteedUnique = {\n\t\tchildren: true,\n\t\tcontents: true,\n\t\tnext: true,\n\t\tprev: true\n\t};\n\njQuery.fn.extend( {\n\thas: function( target ) {\n\t\tvar targets = jQuery( target, this ),\n\t\t\tl = targets.length;\n\n\t\treturn this.filter( function() {\n\t\t\tvar i = 0;\n\t\t\tfor ( ; i < l; i++ ) {\n\t\t\t\tif ( jQuery.contains( this, targets[ i ] ) ) {\n\t\t\t\t\treturn true;\n\t\t\t\t}\n\t\t\t}\n\t\t} );\n\t},\n\n\tclosest: function( selectors, context ) {\n\t\tvar cur,\n\t\t\ti = 0,\n\t\t\tl = this.length,\n\t\t\tmatched = [],\n\t\t\ttargets = typeof selectors !== \"string\" && jQuery( selectors );\n\n\t\t// Positional selectors never match, since there's no _selection_ context\n\t\tif ( !rneedsContext.test( selectors ) ) {\n\t\t\tfor ( ; i < l; i++ ) {\n\t\t\t\tfor ( cur = this[ i ]; cur && cur !== context; cur = cur.parentNode ) {\n\n\t\t\t\t\t// Always skip document fragments\n\t\t\t\t\tif ( cur.nodeType < 11 && ( targets ?\n\t\t\t\t\t\ttargets.index( cur ) > -1 :\n\n\t\t\t\t\t\t// Don't pass non-elements to Sizzle\n\t\t\t\t\t\tcur.nodeType === 1 &&\n\t\t\t\t\t\t\tjQuery.find.matchesSelector( cur, selectors ) ) ) {\n\n\t\t\t\t\t\tmatched.push( cur );\n\t\t\t\t\t\tbreak;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\treturn this.pushStack( matched.length > 1 ? jQuery.uniqueSort( matched ) : matched );\n\t},\n\n\t// Determine the position of an element within the set\n\tindex: function( elem ) {\n\n\t\t// No argument, return index in parent\n\t\tif ( !elem ) {\n\t\t\treturn ( this[ 0 ] && this[ 0 ].parentNode ) ? this.first().prevAll().length : -1;\n\t\t}\n\n\t\t// Index in selector\n\t\tif ( typeof elem === \"string\" ) {\n\t\t\treturn indexOf.call( jQuery( elem ), this[ 0 ] );\n\t\t}\n\n\t\t// Locate the position of the desired element\n\t\treturn indexOf.call( this,\n\n\t\t\t// If it receives a jQuery object, the first element is used\n\t\t\telem.jquery ? elem[ 0 ] : elem\n\t\t);\n\t},\n\n\tadd: function( selector, context ) {\n\t\treturn this.pushStack(\n\t\t\tjQuery.uniqueSort(\n\t\t\t\tjQuery.merge( this.get(), jQuery( selector, context ) )\n\t\t\t)\n\t\t);\n\t},\n\n\taddBack: function( selector ) {\n\t\treturn this.add( selector == null ?\n\t\t\tthis.prevObject : this.prevObject.filter( selector )\n\t\t);\n\t}\n} );\n\nfunction sibling( cur, dir ) {\n\twhile ( ( cur = cur[ dir ] ) && cur.nodeType !== 1 ) {}\n\treturn cur;\n}\n\njQuery.each( {\n\tparent: function( elem ) {\n\t\tvar parent = elem.parentNode;\n\t\treturn parent && parent.nodeType !== 11 ? parent : null;\n\t},\n\tparents: function( elem ) {\n\t\treturn dir( elem, \"parentNode\" );\n\t},\n\tparentsUntil: function( elem, i, until ) {\n\t\treturn dir( elem, \"parentNode\", until );\n\t},\n\tnext: function( elem ) {\n\t\treturn sibling( elem, \"nextSibling\" );\n\t},\n\tprev: function( elem ) {\n\t\treturn sibling( elem, \"previousSibling\" );\n\t},\n\tnextAll: function( elem ) {\n\t\treturn dir( elem, \"nextSibling\" );\n\t},\n\tprevAll: function( elem ) {\n\t\treturn dir( elem, \"previousSibling\" );\n\t},\n\tnextUntil: function( elem, i, until ) {\n\t\treturn dir( elem, \"nextSibling\", until );\n\t},\n\tprevUntil: function( elem, i, until ) {\n\t\treturn dir( elem, \"previousSibling\", until );\n\t},\n\tsiblings: function( elem ) {\n\t\treturn siblings( ( elem.parentNode || {} ).firstChild, elem );\n\t},\n\tchildren: function( elem ) {\n\t\treturn siblings( elem.firstChild );\n\t},\n\tcontents: function( elem ) {\n if ( nodeName( elem, \"iframe\" ) ) {\n return elem.contentDocument;\n }\n\n // Support: IE 9 - 11 only, iOS 7 only, Android Browser <=4.3 only\n // Treat the template element as a regular one in browsers that\n // don't support it.\n if ( nodeName( elem, \"template\" ) ) {\n elem = elem.content || elem;\n }\n\n return jQuery.merge( [], elem.childNodes );\n\t}\n}, function( name, fn ) {\n\tjQuery.fn[ name ] = function( until, selector ) {\n\t\tvar matched = jQuery.map( this, fn, until );\n\n\t\tif ( name.slice( -5 ) !== \"Until\" ) {\n\t\t\tselector = until;\n\t\t}\n\n\t\tif ( selector && typeof selector === \"string\" ) {\n\t\t\tmatched = jQuery.filter( selector, matched );\n\t\t}\n\n\t\tif ( this.length > 1 ) {\n\n\t\t\t// Remove duplicates\n\t\t\tif ( !guaranteedUnique[ name ] ) {\n\t\t\t\tjQuery.uniqueSort( matched );\n\t\t\t}\n\n\t\t\t// Reverse order for parents* and prev-derivatives\n\t\t\tif ( rparentsprev.test( name ) ) {\n\t\t\t\tmatched.reverse();\n\t\t\t}\n\t\t}\n\n\t\treturn this.pushStack( matched );\n\t};\n} );\nvar rnothtmlwhite = ( /[^\\x20\\t\\r\\n\\f]+/g );\n\n\n\n// Convert String-formatted options into Object-formatted ones\nfunction createOptions( options ) {\n\tvar object = {};\n\tjQuery.each( options.match( rnothtmlwhite ) || [], function( _, flag ) {\n\t\tobject[ flag ] = true;\n\t} );\n\treturn object;\n}\n\n/*\n * Create a callback list using the following parameters:\n *\n *\toptions: an optional list of space-separated options that will change how\n *\t\t\tthe callback list behaves or a more traditional option object\n *\n * By default a callback list will act like an event callback list and can be\n * \"fired\" multiple times.\n *\n * Possible options:\n *\n *\tonce:\t\t\twill ensure the callback list can only be fired once (like a Deferred)\n *\n *\tmemory:\t\t\twill keep track of previous values and will call any callback added\n *\t\t\t\t\tafter the list has been fired right away with the latest \"memorized\"\n *\t\t\t\t\tvalues (like a Deferred)\n *\n *\tunique:\t\t\twill ensure a callback can only be added once (no duplicate in the list)\n *\n *\tstopOnFalse:\tinterrupt callings when a callback returns false\n *\n */\njQuery.Callbacks = function( options ) {\n\n\t// Convert options from String-formatted to Object-formatted if needed\n\t// (we check in cache first)\n\toptions = typeof options === \"string\" ?\n\t\tcreateOptions( options ) :\n\t\tjQuery.extend( {}, options );\n\n\tvar // Flag to know if list is currently firing\n\t\tfiring,\n\n\t\t// Last fire value for non-forgettable lists\n\t\tmemory,\n\n\t\t// Flag to know if list was already fired\n\t\tfired,\n\n\t\t// Flag to prevent firing\n\t\tlocked,\n\n\t\t// Actual callback list\n\t\tlist = [],\n\n\t\t// Queue of execution data for repeatable lists\n\t\tqueue = [],\n\n\t\t// Index of currently firing callback (modified by add/remove as needed)\n\t\tfiringIndex = -1,\n\n\t\t// Fire callbacks\n\t\tfire = function() {\n\n\t\t\t// Enforce single-firing\n\t\t\tlocked = locked || options.once;\n\n\t\t\t// Execute callbacks for all pending executions,\n\t\t\t// respecting firingIndex overrides and runtime changes\n\t\t\tfired = firing = true;\n\t\t\tfor ( ; queue.length; firingIndex = -1 ) {\n\t\t\t\tmemory = queue.shift();\n\t\t\t\twhile ( ++firingIndex < list.length ) {\n\n\t\t\t\t\t// Run callback and check for early termination\n\t\t\t\t\tif ( list[ firingIndex ].apply( memory[ 0 ], memory[ 1 ] ) === false &&\n\t\t\t\t\t\toptions.stopOnFalse ) {\n\n\t\t\t\t\t\t// Jump to end and forget the data so .add doesn't re-fire\n\t\t\t\t\t\tfiringIndex = list.length;\n\t\t\t\t\t\tmemory = false;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\n\t\t\t// Forget the data if we're done with it\n\t\t\tif ( !options.memory ) {\n\t\t\t\tmemory = false;\n\t\t\t}\n\n\t\t\tfiring = false;\n\n\t\t\t// Clean up if we're done firing for good\n\t\t\tif ( locked ) {\n\n\t\t\t\t// Keep an empty list if we have data for future add calls\n\t\t\t\tif ( memory ) {\n\t\t\t\t\tlist = [];\n\n\t\t\t\t// Otherwise, this object is spent\n\t\t\t\t} else {\n\t\t\t\t\tlist = \"\";\n\t\t\t\t}\n\t\t\t}\n\t\t},\n\n\t\t// Actual Callbacks object\n\t\tself = {\n\n\t\t\t// Add a callback or a collection of callbacks to the list\n\t\t\tadd: function() {\n\t\t\t\tif ( list ) {\n\n\t\t\t\t\t// If we have memory from a past run, we should fire after adding\n\t\t\t\t\tif ( memory && !firing ) {\n\t\t\t\t\t\tfiringIndex = list.length - 1;\n\t\t\t\t\t\tqueue.push( memory );\n\t\t\t\t\t}\n\n\t\t\t\t\t( function add( args ) {\n\t\t\t\t\t\tjQuery.each( args, function( _, arg ) {\n\t\t\t\t\t\t\tif ( jQuery.isFunction( arg ) ) {\n\t\t\t\t\t\t\t\tif ( !options.unique || !self.has( arg ) ) {\n\t\t\t\t\t\t\t\t\tlist.push( arg );\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t} else if ( arg && arg.length && jQuery.type( arg ) !== \"string\" ) {\n\n\t\t\t\t\t\t\t\t// Inspect recursively\n\t\t\t\t\t\t\t\tadd( arg );\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t} );\n\t\t\t\t\t} )( arguments );\n\n\t\t\t\t\tif ( memory && !firing ) {\n\t\t\t\t\t\tfire();\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t\treturn this;\n\t\t\t},\n\n\t\t\t// Remove a callback from the list\n\t\t\tremove: function() {\n\t\t\t\tjQuery.each( arguments, function( _, arg ) {\n\t\t\t\t\tvar index;\n\t\t\t\t\twhile ( ( index = jQuery.inArray( arg, list, index ) ) > -1 ) {\n\t\t\t\t\t\tlist.splice( index, 1 );\n\n\t\t\t\t\t\t// Handle firing indexes\n\t\t\t\t\t\tif ( index <= firingIndex ) {\n\t\t\t\t\t\t\tfiringIndex--;\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t} );\n\t\t\t\treturn this;\n\t\t\t},\n\n\t\t\t// Check if a given callback is in the list.\n\t\t\t// If no argument is given, return whether or not list has callbacks attached.\n\t\t\thas: function( fn ) {\n\t\t\t\treturn fn ?\n\t\t\t\t\tjQuery.inArray( fn, list ) > -1 :\n\t\t\t\t\tlist.length > 0;\n\t\t\t},\n\n\t\t\t// Remove all callbacks from the list\n\t\t\tempty: function() {\n\t\t\t\tif ( list ) {\n\t\t\t\t\tlist = [];\n\t\t\t\t}\n\t\t\t\treturn this;\n\t\t\t},\n\n\t\t\t// Disable .fire and .add\n\t\t\t// Abort any current/pending executions\n\t\t\t// Clear all callbacks and values\n\t\t\tdisable: function() {\n\t\t\t\tlocked = queue = [];\n\t\t\t\tlist = memory = \"\";\n\t\t\t\treturn this;\n\t\t\t},\n\t\t\tdisabled: function() {\n\t\t\t\treturn !list;\n\t\t\t},\n\n\t\t\t// Disable .fire\n\t\t\t// Also disable .add unless we have memory (since it would have no effect)\n\t\t\t// Abort any pending executions\n\t\t\tlock: function() {\n\t\t\t\tlocked = queue = [];\n\t\t\t\tif ( !memory && !firing ) {\n\t\t\t\t\tlist = memory = \"\";\n\t\t\t\t}\n\t\t\t\treturn this;\n\t\t\t},\n\t\t\tlocked: function() {\n\t\t\t\treturn !!locked;\n\t\t\t},\n\n\t\t\t// Call all callbacks with the given context and arguments\n\t\t\tfireWith: function( context, args ) {\n\t\t\t\tif ( !locked ) {\n\t\t\t\t\targs = args || [];\n\t\t\t\t\targs = [ context, args.slice ? args.slice() : args ];\n\t\t\t\t\tqueue.push( args );\n\t\t\t\t\tif ( !firing ) {\n\t\t\t\t\t\tfire();\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t\treturn this;\n\t\t\t},\n\n\t\t\t// Call all the callbacks with the given arguments\n\t\t\tfire: function() {\n\t\t\t\tself.fireWith( this, arguments );\n\t\t\t\treturn this;\n\t\t\t},\n\n\t\t\t// To know if the callbacks have already been called at least once\n\t\t\tfired: function() {\n\t\t\t\treturn !!fired;\n\t\t\t}\n\t\t};\n\n\treturn self;\n};\n\n\nfunction Identity( v ) {\n\treturn v;\n}\nfunction Thrower( ex ) {\n\tthrow ex;\n}\n\nfunction adoptValue( value, resolve, reject, noValue ) {\n\tvar method;\n\n\ttry {\n\n\t\t// Check for promise aspect first to privilege synchronous behavior\n\t\tif ( value && jQuery.isFunction( ( method = value.promise ) ) ) {\n\t\t\tmethod.call( value ).done( resolve ).fail( reject );\n\n\t\t// Other thenables\n\t\t} else if ( value && jQuery.isFunction( ( method = value.then ) ) ) {\n\t\t\tmethod.call( value, resolve, reject );\n\n\t\t// Other non-thenables\n\t\t} else {\n\n\t\t\t// Control `resolve` arguments by letting Array#slice cast boolean `noValue` to integer:\n\t\t\t// * false: [ value ].slice( 0 ) => resolve( value )\n\t\t\t// * true: [ value ].slice( 1 ) => resolve()\n\t\t\tresolve.apply( undefined, [ value ].slice( noValue ) );\n\t\t}\n\n\t// For Promises/A+, convert exceptions into rejections\n\t// Since jQuery.when doesn't unwrap thenables, we can skip the extra checks appearing in\n\t// Deferred#then to conditionally suppress rejection.\n\t} catch ( value ) {\n\n\t\t// Support: Android 4.0 only\n\t\t// Strict mode functions invoked without .call/.apply get global-object context\n\t\treject.apply( undefined, [ value ] );\n\t}\n}\n\njQuery.extend( {\n\n\tDeferred: function( func ) {\n\t\tvar tuples = [\n\n\t\t\t\t// action, add listener, callbacks,\n\t\t\t\t// ... .then handlers, argument index, [final state]\n\t\t\t\t[ \"notify\", \"progress\", jQuery.Callbacks( \"memory\" ),\n\t\t\t\t\tjQuery.Callbacks( \"memory\" ), 2 ],\n\t\t\t\t[ \"resolve\", \"done\", jQuery.Callbacks( \"once memory\" ),\n\t\t\t\t\tjQuery.Callbacks( \"once memory\" ), 0, \"resolved\" ],\n\t\t\t\t[ \"reject\", \"fail\", jQuery.Callbacks( \"once memory\" ),\n\t\t\t\t\tjQuery.Callbacks( \"once memory\" ), 1, \"rejected\" ]\n\t\t\t],\n\t\t\tstate = \"pending\",\n\t\t\tpromise = {\n\t\t\t\tstate: function() {\n\t\t\t\t\treturn state;\n\t\t\t\t},\n\t\t\t\talways: function() {\n\t\t\t\t\tdeferred.done( arguments ).fail( arguments );\n\t\t\t\t\treturn this;\n\t\t\t\t},\n\t\t\t\t\"catch\": function( fn ) {\n\t\t\t\t\treturn promise.then( null, fn );\n\t\t\t\t},\n\n\t\t\t\t// Keep pipe for back-compat\n\t\t\t\tpipe: function( /* fnDone, fnFail, fnProgress */ ) {\n\t\t\t\t\tvar fns = arguments;\n\n\t\t\t\t\treturn jQuery.Deferred( function( newDefer ) {\n\t\t\t\t\t\tjQuery.each( tuples, function( i, tuple ) {\n\n\t\t\t\t\t\t\t// Map tuples (progress, done, fail) to arguments (done, fail, progress)\n\t\t\t\t\t\t\tvar fn = jQuery.isFunction( fns[ tuple[ 4 ] ] ) && fns[ tuple[ 4 ] ];\n\n\t\t\t\t\t\t\t// deferred.progress(function() { bind to newDefer or newDefer.notify })\n\t\t\t\t\t\t\t// deferred.done(function() { bind to newDefer or newDefer.resolve })\n\t\t\t\t\t\t\t// deferred.fail(function() { bind to newDefer or newDefer.reject })\n\t\t\t\t\t\t\tdeferred[ tuple[ 1 ] ]( function() {\n\t\t\t\t\t\t\t\tvar returned = fn && fn.apply( this, arguments );\n\t\t\t\t\t\t\t\tif ( returned && jQuery.isFunction( returned.promise ) ) {\n\t\t\t\t\t\t\t\t\treturned.promise()\n\t\t\t\t\t\t\t\t\t\t.progress( newDefer.notify )\n\t\t\t\t\t\t\t\t\t\t.done( newDefer.resolve )\n\t\t\t\t\t\t\t\t\t\t.fail( newDefer.reject );\n\t\t\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\t\t\tnewDefer[ tuple[ 0 ] + \"With\" ](\n\t\t\t\t\t\t\t\t\t\tthis,\n\t\t\t\t\t\t\t\t\t\tfn ? [ returned ] : arguments\n\t\t\t\t\t\t\t\t\t);\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t} );\n\t\t\t\t\t\t} );\n\t\t\t\t\t\tfns = null;\n\t\t\t\t\t} ).promise();\n\t\t\t\t},\n\t\t\t\tthen: function( onFulfilled, onRejected, onProgress ) {\n\t\t\t\t\tvar maxDepth = 0;\n\t\t\t\t\tfunction resolve( depth, deferred, handler, special ) {\n\t\t\t\t\t\treturn function() {\n\t\t\t\t\t\t\tvar that = this,\n\t\t\t\t\t\t\t\targs = arguments,\n\t\t\t\t\t\t\t\tmightThrow = function() {\n\t\t\t\t\t\t\t\t\tvar returned, then;\n\n\t\t\t\t\t\t\t\t\t// Support: Promises/A+ section 2.3.3.3.3\n\t\t\t\t\t\t\t\t\t// https://promisesaplus.com/#point-59\n\t\t\t\t\t\t\t\t\t// Ignore double-resolution attempts\n\t\t\t\t\t\t\t\t\tif ( depth < maxDepth ) {\n\t\t\t\t\t\t\t\t\t\treturn;\n\t\t\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t\t\treturned = handler.apply( that, args );\n\n\t\t\t\t\t\t\t\t\t// Support: Promises/A+ section 2.3.1\n\t\t\t\t\t\t\t\t\t// https://promisesaplus.com/#point-48\n\t\t\t\t\t\t\t\t\tif ( returned === deferred.promise() ) {\n\t\t\t\t\t\t\t\t\t\tthrow new TypeError( \"Thenable self-resolution\" );\n\t\t\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t\t\t// Support: Promises/A+ sections 2.3.3.1, 3.5\n\t\t\t\t\t\t\t\t\t// https://promisesaplus.com/#point-54\n\t\t\t\t\t\t\t\t\t// https://promisesaplus.com/#point-75\n\t\t\t\t\t\t\t\t\t// Retrieve `then` only once\n\t\t\t\t\t\t\t\t\tthen = returned &&\n\n\t\t\t\t\t\t\t\t\t\t// Support: Promises/A+ section 2.3.4\n\t\t\t\t\t\t\t\t\t\t// https://promisesaplus.com/#point-64\n\t\t\t\t\t\t\t\t\t\t// Only check objects and functions for thenability\n\t\t\t\t\t\t\t\t\t\t( typeof returned === \"object\" ||\n\t\t\t\t\t\t\t\t\t\t\ttypeof returned === \"function\" ) &&\n\t\t\t\t\t\t\t\t\t\treturned.then;\n\n\t\t\t\t\t\t\t\t\t// Handle a returned thenable\n\t\t\t\t\t\t\t\t\tif ( jQuery.isFunction( then ) ) {\n\n\t\t\t\t\t\t\t\t\t\t// Special processors (notify) just wait for resolution\n\t\t\t\t\t\t\t\t\t\tif ( special ) {\n\t\t\t\t\t\t\t\t\t\t\tthen.call(\n\t\t\t\t\t\t\t\t\t\t\t\treturned,\n\t\t\t\t\t\t\t\t\t\t\t\tresolve( maxDepth, deferred, Identity, special ),\n\t\t\t\t\t\t\t\t\t\t\t\tresolve( maxDepth, deferred, Thrower, special )\n\t\t\t\t\t\t\t\t\t\t\t);\n\n\t\t\t\t\t\t\t\t\t\t// Normal processors (resolve) also hook into progress\n\t\t\t\t\t\t\t\t\t\t} else {\n\n\t\t\t\t\t\t\t\t\t\t\t// ...and disregard older resolution values\n\t\t\t\t\t\t\t\t\t\t\tmaxDepth++;\n\n\t\t\t\t\t\t\t\t\t\t\tthen.call(\n\t\t\t\t\t\t\t\t\t\t\t\treturned,\n\t\t\t\t\t\t\t\t\t\t\t\tresolve( maxDepth, deferred, Identity, special ),\n\t\t\t\t\t\t\t\t\t\t\t\tresolve( maxDepth, deferred, Thrower, special ),\n\t\t\t\t\t\t\t\t\t\t\t\tresolve( maxDepth, deferred, Identity,\n\t\t\t\t\t\t\t\t\t\t\t\t\tdeferred.notifyWith )\n\t\t\t\t\t\t\t\t\t\t\t);\n\t\t\t\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t\t\t// Handle all other returned values\n\t\t\t\t\t\t\t\t\t} else {\n\n\t\t\t\t\t\t\t\t\t\t// Only substitute handlers pass on context\n\t\t\t\t\t\t\t\t\t\t// and multiple values (non-spec behavior)\n\t\t\t\t\t\t\t\t\t\tif ( handler !== Identity ) {\n\t\t\t\t\t\t\t\t\t\t\tthat = undefined;\n\t\t\t\t\t\t\t\t\t\t\targs = [ returned ];\n\t\t\t\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t\t\t\t// Process the value(s)\n\t\t\t\t\t\t\t\t\t\t// Default process is resolve\n\t\t\t\t\t\t\t\t\t\t( special || deferred.resolveWith )( that, args );\n\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t},\n\n\t\t\t\t\t\t\t\t// Only normal processors (resolve) catch and reject exceptions\n\t\t\t\t\t\t\t\tprocess = special ?\n\t\t\t\t\t\t\t\t\tmightThrow :\n\t\t\t\t\t\t\t\t\tfunction() {\n\t\t\t\t\t\t\t\t\t\ttry {\n\t\t\t\t\t\t\t\t\t\t\tmightThrow();\n\t\t\t\t\t\t\t\t\t\t} catch ( e ) {\n\n\t\t\t\t\t\t\t\t\t\t\tif ( jQuery.Deferred.exceptionHook ) {\n\t\t\t\t\t\t\t\t\t\t\t\tjQuery.Deferred.exceptionHook( e,\n\t\t\t\t\t\t\t\t\t\t\t\t\tprocess.stackTrace );\n\t\t\t\t\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t\t\t\t\t// Support: Promises/A+ section 2.3.3.3.4.1\n\t\t\t\t\t\t\t\t\t\t\t// https://promisesaplus.com/#point-61\n\t\t\t\t\t\t\t\t\t\t\t// Ignore post-resolution exceptions\n\t\t\t\t\t\t\t\t\t\t\tif ( depth + 1 >= maxDepth ) {\n\n\t\t\t\t\t\t\t\t\t\t\t\t// Only substitute handlers pass on context\n\t\t\t\t\t\t\t\t\t\t\t\t// and multiple values (non-spec behavior)\n\t\t\t\t\t\t\t\t\t\t\t\tif ( handler !== Thrower ) {\n\t\t\t\t\t\t\t\t\t\t\t\t\tthat = undefined;\n\t\t\t\t\t\t\t\t\t\t\t\t\targs = [ e ];\n\t\t\t\t\t\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t\t\t\t\t\tdeferred.rejectWith( that, args );\n\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t};\n\n\t\t\t\t\t\t\t// Support: Promises/A+ section 2.3.3.3.1\n\t\t\t\t\t\t\t// https://promisesaplus.com/#point-57\n\t\t\t\t\t\t\t// Re-resolve promises immediately to dodge false rejection from\n\t\t\t\t\t\t\t// subsequent errors\n\t\t\t\t\t\t\tif ( depth ) {\n\t\t\t\t\t\t\t\tprocess();\n\t\t\t\t\t\t\t} else {\n\n\t\t\t\t\t\t\t\t// Call an optional hook to record the stack, in case of exception\n\t\t\t\t\t\t\t\t// since it's otherwise lost when execution goes async\n\t\t\t\t\t\t\t\tif ( jQuery.Deferred.getStackHook ) {\n\t\t\t\t\t\t\t\t\tprocess.stackTrace = jQuery.Deferred.getStackHook();\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\twindow.setTimeout( process );\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t};\n\t\t\t\t\t}\n\n\t\t\t\t\treturn jQuery.Deferred( function( newDefer ) {\n\n\t\t\t\t\t\t// progress_handlers.add( ... )\n\t\t\t\t\t\ttuples[ 0 ][ 3 ].add(\n\t\t\t\t\t\t\tresolve(\n\t\t\t\t\t\t\t\t0,\n\t\t\t\t\t\t\t\tnewDefer,\n\t\t\t\t\t\t\t\tjQuery.isFunction( onProgress ) ?\n\t\t\t\t\t\t\t\t\tonProgress :\n\t\t\t\t\t\t\t\t\tIdentity,\n\t\t\t\t\t\t\t\tnewDefer.notifyWith\n\t\t\t\t\t\t\t)\n\t\t\t\t\t\t);\n\n\t\t\t\t\t\t// fulfilled_handlers.add( ... )\n\t\t\t\t\t\ttuples[ 1 ][ 3 ].add(\n\t\t\t\t\t\t\tresolve(\n\t\t\t\t\t\t\t\t0,\n\t\t\t\t\t\t\t\tnewDefer,\n\t\t\t\t\t\t\t\tjQuery.isFunction( onFulfilled ) ?\n\t\t\t\t\t\t\t\t\tonFulfilled :\n\t\t\t\t\t\t\t\t\tIdentity\n\t\t\t\t\t\t\t)\n\t\t\t\t\t\t);\n\n\t\t\t\t\t\t// rejected_handlers.add( ... )\n\t\t\t\t\t\ttuples[ 2 ][ 3 ].add(\n\t\t\t\t\t\t\tresolve(\n\t\t\t\t\t\t\t\t0,\n\t\t\t\t\t\t\t\tnewDefer,\n\t\t\t\t\t\t\t\tjQuery.isFunction( onRejected ) ?\n\t\t\t\t\t\t\t\t\tonRejected :\n\t\t\t\t\t\t\t\t\tThrower\n\t\t\t\t\t\t\t)\n\t\t\t\t\t\t);\n\t\t\t\t\t} ).promise();\n\t\t\t\t},\n\n\t\t\t\t// Get a promise for this deferred\n\t\t\t\t// If obj is provided, the promise aspect is added to the object\n\t\t\t\tpromise: function( obj ) {\n\t\t\t\t\treturn obj != null ? jQuery.extend( obj, promise ) : promise;\n\t\t\t\t}\n\t\t\t},\n\t\t\tdeferred = {};\n\n\t\t// Add list-specific methods\n\t\tjQuery.each( tuples, function( i, tuple ) {\n\t\t\tvar list = tuple[ 2 ],\n\t\t\t\tstateString = tuple[ 5 ];\n\n\t\t\t// promise.progress = list.add\n\t\t\t// promise.done = list.add\n\t\t\t// promise.fail = list.add\n\t\t\tpromise[ tuple[ 1 ] ] = list.add;\n\n\t\t\t// Handle state\n\t\t\tif ( stateString ) {\n\t\t\t\tlist.add(\n\t\t\t\t\tfunction() {\n\n\t\t\t\t\t\t// state = \"resolved\" (i.e., fulfilled)\n\t\t\t\t\t\t// state = \"rejected\"\n\t\t\t\t\t\tstate = stateString;\n\t\t\t\t\t},\n\n\t\t\t\t\t// rejected_callbacks.disable\n\t\t\t\t\t// fulfilled_callbacks.disable\n\t\t\t\t\ttuples[ 3 - i ][ 2 ].disable,\n\n\t\t\t\t\t// progress_callbacks.lock\n\t\t\t\t\ttuples[ 0 ][ 2 ].lock\n\t\t\t\t);\n\t\t\t}\n\n\t\t\t// progress_handlers.fire\n\t\t\t// fulfilled_handlers.fire\n\t\t\t// rejected_handlers.fire\n\t\t\tlist.add( tuple[ 3 ].fire );\n\n\t\t\t// deferred.notify = function() { deferred.notifyWith(...) }\n\t\t\t// deferred.resolve = function() { deferred.resolveWith(...) }\n\t\t\t// deferred.reject = function() { deferred.rejectWith(...) }\n\t\t\tdeferred[ tuple[ 0 ] ] = function() {\n\t\t\t\tdeferred[ tuple[ 0 ] + \"With\" ]( this === deferred ? undefined : this, arguments );\n\t\t\t\treturn this;\n\t\t\t};\n\n\t\t\t// deferred.notifyWith = list.fireWith\n\t\t\t// deferred.resolveWith = list.fireWith\n\t\t\t// deferred.rejectWith = list.fireWith\n\t\t\tdeferred[ tuple[ 0 ] + \"With\" ] = list.fireWith;\n\t\t} );\n\n\t\t// Make the deferred a promise\n\t\tpromise.promise( deferred );\n\n\t\t// Call given func if any\n\t\tif ( func ) {\n\t\t\tfunc.call( deferred, deferred );\n\t\t}\n\n\t\t// All done!\n\t\treturn deferred;\n\t},\n\n\t// Deferred helper\n\twhen: function( singleValue ) {\n\t\tvar\n\n\t\t\t// count of uncompleted subordinates\n\t\t\tremaining = arguments.length,\n\n\t\t\t// count of unprocessed arguments\n\t\t\ti = remaining,\n\n\t\t\t// subordinate fulfillment data\n\t\t\tresolveContexts = Array( i ),\n\t\t\tresolveValues = slice.call( arguments ),\n\n\t\t\t// the master Deferred\n\t\t\tmaster = jQuery.Deferred(),\n\n\t\t\t// subordinate callback factory\n\t\t\tupdateFunc = function( i ) {\n\t\t\t\treturn function( value ) {\n\t\t\t\t\tresolveContexts[ i ] = this;\n\t\t\t\t\tresolveValues[ i ] = arguments.length > 1 ? slice.call( arguments ) : value;\n\t\t\t\t\tif ( !( --remaining ) ) {\n\t\t\t\t\t\tmaster.resolveWith( resolveContexts, resolveValues );\n\t\t\t\t\t}\n\t\t\t\t};\n\t\t\t};\n\n\t\t// Single- and empty arguments are adopted like Promise.resolve\n\t\tif ( remaining <= 1 ) {\n\t\t\tadoptValue( singleValue, master.done( updateFunc( i ) ).resolve, master.reject,\n\t\t\t\t!remaining );\n\n\t\t\t// Use .then() to unwrap secondary thenables (cf. gh-3000)\n\t\t\tif ( master.state() === \"pending\" ||\n\t\t\t\tjQuery.isFunction( resolveValues[ i ] && resolveValues[ i ].then ) ) {\n\n\t\t\t\treturn master.then();\n\t\t\t}\n\t\t}\n\n\t\t// Multiple arguments are aggregated like Promise.all array elements\n\t\twhile ( i-- ) {\n\t\t\tadoptValue( resolveValues[ i ], updateFunc( i ), master.reject );\n\t\t}\n\n\t\treturn master.promise();\n\t}\n} );\n\n\n// These usually indicate a programmer mistake during development,\n// warn about them ASAP rather than swallowing them by default.\nvar rerrorNames = /^(Eval|Internal|Range|Reference|Syntax|Type|URI)Error$/;\n\njQuery.Deferred.exceptionHook = function( error, stack ) {\n\n\t// Support: IE 8 - 9 only\n\t// Console exists when dev tools are open, which can happen at any time\n\tif ( window.console && window.console.warn && error && rerrorNames.test( error.name ) ) {\n\t\twindow.console.warn( \"jQuery.Deferred exception: \" + error.message, error.stack, stack );\n\t}\n};\n\n\n\n\njQuery.readyException = function( error ) {\n\twindow.setTimeout( function() {\n\t\tthrow error;\n\t} );\n};\n\n\n\n\n// The deferred used on DOM ready\nvar readyList = jQuery.Deferred();\n\njQuery.fn.ready = function( fn ) {\n\n\treadyList\n\t\t.then( fn )\n\n\t\t// Wrap jQuery.readyException in a function so that the lookup\n\t\t// happens at the time of error handling instead of callback\n\t\t// registration.\n\t\t.catch( function( error ) {\n\t\t\tjQuery.readyException( error );\n\t\t} );\n\n\treturn this;\n};\n\njQuery.extend( {\n\n\t// Is the DOM ready to be used? Set to true once it occurs.\n\tisReady: false,\n\n\t// A counter to track how many items to wait for before\n\t// the ready event fires. See #6781\n\treadyWait: 1,\n\n\t// Handle when the DOM is ready\n\tready: function( wait ) {\n\n\t\t// Abort if there are pending holds or we're already ready\n\t\tif ( wait === true ? --jQuery.readyWait : jQuery.isReady ) {\n\t\t\treturn;\n\t\t}\n\n\t\t// Remember that the DOM is ready\n\t\tjQuery.isReady = true;\n\n\t\t// If a normal DOM Ready event fired, decrement, and wait if need be\n\t\tif ( wait !== true && --jQuery.readyWait > 0 ) {\n\t\t\treturn;\n\t\t}\n\n\t\t// If there are functions bound, to execute\n\t\treadyList.resolveWith( document, [ jQuery ] );\n\t}\n} );\n\njQuery.ready.then = readyList.then;\n\n// The ready event handler and self cleanup method\nfunction completed() {\n\tdocument.removeEventListener( \"DOMContentLoaded\", completed );\n\twindow.removeEventListener( \"load\", completed );\n\tjQuery.ready();\n}\n\n// Catch cases where $(document).ready() is called\n// after the browser event has already occurred.\n// Support: IE <=9 - 10 only\n// Older IE sometimes signals \"interactive\" too soon\nif ( document.readyState === \"complete\" ||\n\t( document.readyState !== \"loading\" && !document.documentElement.doScroll ) ) {\n\n\t// Handle it asynchronously to allow scripts the opportunity to delay ready\n\twindow.setTimeout( jQuery.ready );\n\n} else {\n\n\t// Use the handy event callback\n\tdocument.addEventListener( \"DOMContentLoaded\", completed );\n\n\t// A fallback to window.onload, that will always work\n\twindow.addEventListener( \"load\", completed );\n}\n\n\n\n\n// Multifunctional method to get and set values of a collection\n// The value/s can optionally be executed if it's a function\nvar access = function( elems, fn, key, value, chainable, emptyGet, raw ) {\n\tvar i = 0,\n\t\tlen = elems.length,\n\t\tbulk = key == null;\n\n\t// Sets many values\n\tif ( jQuery.type( key ) === \"object\" ) {\n\t\tchainable = true;\n\t\tfor ( i in key ) {\n\t\t\taccess( elems, fn, i, key[ i ], true, emptyGet, raw );\n\t\t}\n\n\t// Sets one value\n\t} else if ( value !== undefined ) {\n\t\tchainable = true;\n\n\t\tif ( !jQuery.isFunction( value ) ) {\n\t\t\traw = true;\n\t\t}\n\n\t\tif ( bulk ) {\n\n\t\t\t// Bulk operations run against the entire set\n\t\t\tif ( raw ) {\n\t\t\t\tfn.call( elems, value );\n\t\t\t\tfn = null;\n\n\t\t\t// ...except when executing function values\n\t\t\t} else {\n\t\t\t\tbulk = fn;\n\t\t\t\tfn = function( elem, key, value ) {\n\t\t\t\t\treturn bulk.call( jQuery( elem ), value );\n\t\t\t\t};\n\t\t\t}\n\t\t}\n\n\t\tif ( fn ) {\n\t\t\tfor ( ; i < len; i++ ) {\n\t\t\t\tfn(\n\t\t\t\t\telems[ i ], key, raw ?\n\t\t\t\t\tvalue :\n\t\t\t\t\tvalue.call( elems[ i ], i, fn( elems[ i ], key ) )\n\t\t\t\t);\n\t\t\t}\n\t\t}\n\t}\n\n\tif ( chainable ) {\n\t\treturn elems;\n\t}\n\n\t// Gets\n\tif ( bulk ) {\n\t\treturn fn.call( elems );\n\t}\n\n\treturn len ? fn( elems[ 0 ], key ) : emptyGet;\n};\nvar acceptData = function( owner ) {\n\n\t// Accepts only:\n\t// - Node\n\t// - Node.ELEMENT_NODE\n\t// - Node.DOCUMENT_NODE\n\t// - Object\n\t// - Any\n\treturn owner.nodeType === 1 || owner.nodeType === 9 || !( +owner.nodeType );\n};\n\n\n\n\nfunction Data() {\n\tthis.expando = jQuery.expando + Data.uid++;\n}\n\nData.uid = 1;\n\nData.prototype = {\n\n\tcache: function( owner ) {\n\n\t\t// Check if the owner object already has a cache\n\t\tvar value = owner[ this.expando ];\n\n\t\t// If not, create one\n\t\tif ( !value ) {\n\t\t\tvalue = {};\n\n\t\t\t// We can accept data for non-element nodes in modern browsers,\n\t\t\t// but we should not, see #8335.\n\t\t\t// Always return an empty object.\n\t\t\tif ( acceptData( owner ) ) {\n\n\t\t\t\t// If it is a node unlikely to be stringify-ed or looped over\n\t\t\t\t// use plain assignment\n\t\t\t\tif ( owner.nodeType ) {\n\t\t\t\t\towner[ this.expando ] = value;\n\n\t\t\t\t// Otherwise secure it in a non-enumerable property\n\t\t\t\t// configurable must be true to allow the property to be\n\t\t\t\t// deleted when data is removed\n\t\t\t\t} else {\n\t\t\t\t\tObject.defineProperty( owner, this.expando, {\n\t\t\t\t\t\tvalue: value,\n\t\t\t\t\t\tconfigurable: true\n\t\t\t\t\t} );\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\treturn value;\n\t},\n\tset: function( owner, data, value ) {\n\t\tvar prop,\n\t\t\tcache = this.cache( owner );\n\n\t\t// Handle: [ owner, key, value ] args\n\t\t// Always use camelCase key (gh-2257)\n\t\tif ( typeof data === \"string\" ) {\n\t\t\tcache[ jQuery.camelCase( data ) ] = value;\n\n\t\t// Handle: [ owner, { properties } ] args\n\t\t} else {\n\n\t\t\t// Copy the properties one-by-one to the cache object\n\t\t\tfor ( prop in data ) {\n\t\t\t\tcache[ jQuery.camelCase( prop ) ] = data[ prop ];\n\t\t\t}\n\t\t}\n\t\treturn cache;\n\t},\n\tget: function( owner, key ) {\n\t\treturn key === undefined ?\n\t\t\tthis.cache( owner ) :\n\n\t\t\t// Always use camelCase key (gh-2257)\n\t\t\towner[ this.expando ] && owner[ this.expando ][ jQuery.camelCase( key ) ];\n\t},\n\taccess: function( owner, key, value ) {\n\n\t\t// In cases where either:\n\t\t//\n\t\t// 1. No key was specified\n\t\t// 2. A string key was specified, but no value provided\n\t\t//\n\t\t// Take the \"read\" path and allow the get method to determine\n\t\t// which value to return, respectively either:\n\t\t//\n\t\t// 1. The entire cache object\n\t\t// 2. The data stored at the key\n\t\t//\n\t\tif ( key === undefined ||\n\t\t\t\t( ( key && typeof key === \"string\" ) && value === undefined ) ) {\n\n\t\t\treturn this.get( owner, key );\n\t\t}\n\n\t\t// When the key is not a string, or both a key and value\n\t\t// are specified, set or extend (existing objects) with either:\n\t\t//\n\t\t// 1. An object of properties\n\t\t// 2. A key and value\n\t\t//\n\t\tthis.set( owner, key, value );\n\n\t\t// Since the \"set\" path can have two possible entry points\n\t\t// return the expected data based on which path was taken[*]\n\t\treturn value !== undefined ? value : key;\n\t},\n\tremove: function( owner, key ) {\n\t\tvar i,\n\t\t\tcache = owner[ this.expando ];\n\n\t\tif ( cache === undefined ) {\n\t\t\treturn;\n\t\t}\n\n\t\tif ( key !== undefined ) {\n\n\t\t\t// Support array or space separated string of keys\n\t\t\tif ( Array.isArray( key ) ) {\n\n\t\t\t\t// If key is an array of keys...\n\t\t\t\t// We always set camelCase keys, so remove that.\n\t\t\t\tkey = key.map( jQuery.camelCase );\n\t\t\t} else {\n\t\t\t\tkey = jQuery.camelCase( key );\n\n\t\t\t\t// If a key with the spaces exists, use it.\n\t\t\t\t// Otherwise, create an array by matching non-whitespace\n\t\t\t\tkey = key in cache ?\n\t\t\t\t\t[ key ] :\n\t\t\t\t\t( key.match( rnothtmlwhite ) || [] );\n\t\t\t}\n\n\t\t\ti = key.length;\n\n\t\t\twhile ( i-- ) {\n\t\t\t\tdelete cache[ key[ i ] ];\n\t\t\t}\n\t\t}\n\n\t\t// Remove the expando if there's no more data\n\t\tif ( key === undefined || jQuery.isEmptyObject( cache ) ) {\n\n\t\t\t// Support: Chrome <=35 - 45\n\t\t\t// Webkit & Blink performance suffers when deleting properties\n\t\t\t// from DOM nodes, so set to undefined instead\n\t\t\t// https://bugs.chromium.org/p/chromium/issues/detail?id=378607 (bug restricted)\n\t\t\tif ( owner.nodeType ) {\n\t\t\t\towner[ this.expando ] = undefined;\n\t\t\t} else {\n\t\t\t\tdelete owner[ this.expando ];\n\t\t\t}\n\t\t}\n\t},\n\thasData: function( owner ) {\n\t\tvar cache = owner[ this.expando ];\n\t\treturn cache !== undefined && !jQuery.isEmptyObject( cache );\n\t}\n};\nvar dataPriv = new Data();\n\nvar dataUser = new Data();\n\n\n\n//\tImplementation Summary\n//\n//\t1. Enforce API surface and semantic compatibility with 1.9.x branch\n//\t2. Improve the module's maintainability by reducing the storage\n//\t\tpaths to a single mechanism.\n//\t3. Use the same single mechanism to support \"private\" and \"user\" data.\n//\t4. _Never_ expose \"private\" data to user code (TODO: Drop _data, _removeData)\n//\t5. Avoid exposing implementation details on user objects (eg. expando properties)\n//\t6. Provide a clear path for implementation upgrade to WeakMap in 2014\n\nvar rbrace = /^(?:\\{[\\w\\W]*\\}|\\[[\\w\\W]*\\])$/,\n\trmultiDash = /[A-Z]/g;\n\nfunction getData( data ) {\n\tif ( data === \"true\" ) {\n\t\treturn true;\n\t}\n\n\tif ( data === \"false\" ) {\n\t\treturn false;\n\t}\n\n\tif ( data === \"null\" ) {\n\t\treturn null;\n\t}\n\n\t// Only convert to a number if it doesn't change the string\n\tif ( data === +data + \"\" ) {\n\t\treturn +data;\n\t}\n\n\tif ( rbrace.test( data ) ) {\n\t\treturn JSON.parse( data );\n\t}\n\n\treturn data;\n}\n\nfunction dataAttr( elem, key, data ) {\n\tvar name;\n\n\t// If nothing was found internally, try to fetch any\n\t// data from the HTML5 data-* attribute\n\tif ( data === undefined && elem.nodeType === 1 ) {\n\t\tname = \"data-\" + key.replace( rmultiDash, \"-$&\" ).toLowerCase();\n\t\tdata = elem.getAttribute( name );\n\n\t\tif ( typeof data === \"string\" ) {\n\t\t\ttry {\n\t\t\t\tdata = getData( data );\n\t\t\t} catch ( e ) {}\n\n\t\t\t// Make sure we set the data so it isn't changed later\n\t\t\tdataUser.set( elem, key, data );\n\t\t} else {\n\t\t\tdata = undefined;\n\t\t}\n\t}\n\treturn data;\n}\n\njQuery.extend( {\n\thasData: function( elem ) {\n\t\treturn dataUser.hasData( elem ) || dataPriv.hasData( elem );\n\t},\n\n\tdata: function( elem, name, data ) {\n\t\treturn dataUser.access( elem, name, data );\n\t},\n\n\tremoveData: function( elem, name ) {\n\t\tdataUser.remove( elem, name );\n\t},\n\n\t// TODO: Now that all calls to _data and _removeData have been replaced\n\t// with direct calls to dataPriv methods, these can be deprecated.\n\t_data: function( elem, name, data ) {\n\t\treturn dataPriv.access( elem, name, data );\n\t},\n\n\t_removeData: function( elem, name ) {\n\t\tdataPriv.remove( elem, name );\n\t}\n} );\n\njQuery.fn.extend( {\n\tdata: function( key, value ) {\n\t\tvar i, name, data,\n\t\t\telem = this[ 0 ],\n\t\t\tattrs = elem && elem.attributes;\n\n\t\t// Gets all values\n\t\tif ( key === undefined ) {\n\t\t\tif ( this.length ) {\n\t\t\t\tdata = dataUser.get( elem );\n\n\t\t\t\tif ( elem.nodeType === 1 && !dataPriv.get( elem, \"hasDataAttrs\" ) ) {\n\t\t\t\t\ti = attrs.length;\n\t\t\t\t\twhile ( i-- ) {\n\n\t\t\t\t\t\t// Support: IE 11 only\n\t\t\t\t\t\t// The attrs elements can be null (#14894)\n\t\t\t\t\t\tif ( attrs[ i ] ) {\n\t\t\t\t\t\t\tname = attrs[ i ].name;\n\t\t\t\t\t\t\tif ( name.indexOf( \"data-\" ) === 0 ) {\n\t\t\t\t\t\t\t\tname = jQuery.camelCase( name.slice( 5 ) );\n\t\t\t\t\t\t\t\tdataAttr( elem, name, data[ name ] );\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\tdataPriv.set( elem, \"hasDataAttrs\", true );\n\t\t\t\t}\n\t\t\t}\n\n\t\t\treturn data;\n\t\t}\n\n\t\t// Sets multiple values\n\t\tif ( typeof key === \"object\" ) {\n\t\t\treturn this.each( function() {\n\t\t\t\tdataUser.set( this, key );\n\t\t\t} );\n\t\t}\n\n\t\treturn access( this, function( value ) {\n\t\t\tvar data;\n\n\t\t\t// The calling jQuery object (element matches) is not empty\n\t\t\t// (and therefore has an element appears at this[ 0 ]) and the\n\t\t\t// `value` parameter was not undefined. An empty jQuery object\n\t\t\t// will result in `undefined` for elem = this[ 0 ] which will\n\t\t\t// throw an exception if an attempt to read a data cache is made.\n\t\t\tif ( elem && value === undefined ) {\n\n\t\t\t\t// Attempt to get data from the cache\n\t\t\t\t// The key will always be camelCased in Data\n\t\t\t\tdata = dataUser.get( elem, key );\n\t\t\t\tif ( data !== undefined ) {\n\t\t\t\t\treturn data;\n\t\t\t\t}\n\n\t\t\t\t// Attempt to \"discover\" the data in\n\t\t\t\t// HTML5 custom data-* attrs\n\t\t\t\tdata = dataAttr( elem, key );\n\t\t\t\tif ( data !== undefined ) {\n\t\t\t\t\treturn data;\n\t\t\t\t}\n\n\t\t\t\t// We tried really hard, but the data doesn't exist.\n\t\t\t\treturn;\n\t\t\t}\n\n\t\t\t// Set the data...\n\t\t\tthis.each( function() {\n\n\t\t\t\t// We always store the camelCased key\n\t\t\t\tdataUser.set( this, key, value );\n\t\t\t} );\n\t\t}, null, value, arguments.length > 1, null, true );\n\t},\n\n\tremoveData: function( key ) {\n\t\treturn this.each( function() {\n\t\t\tdataUser.remove( this, key );\n\t\t} );\n\t}\n} );\n\n\njQuery.extend( {\n\tqueue: function( elem, type, data ) {\n\t\tvar queue;\n\n\t\tif ( elem ) {\n\t\t\ttype = ( type || \"fx\" ) + \"queue\";\n\t\t\tqueue = dataPriv.get( elem, type );\n\n\t\t\t// Speed up dequeue by getting out quickly if this is just a lookup\n\t\t\tif ( data ) {\n\t\t\t\tif ( !queue || Array.isArray( data ) ) {\n\t\t\t\t\tqueue = dataPriv.access( elem, type, jQuery.makeArray( data ) );\n\t\t\t\t} else {\n\t\t\t\t\tqueue.push( data );\n\t\t\t\t}\n\t\t\t}\n\t\t\treturn queue || [];\n\t\t}\n\t},\n\n\tdequeue: function( elem, type ) {\n\t\ttype = type || \"fx\";\n\n\t\tvar queue = jQuery.queue( elem, type ),\n\t\t\tstartLength = queue.length,\n\t\t\tfn = queue.shift(),\n\t\t\thooks = jQuery._queueHooks( elem, type ),\n\t\t\tnext = function() {\n\t\t\t\tjQuery.dequeue( elem, type );\n\t\t\t};\n\n\t\t// If the fx queue is dequeued, always remove the progress sentinel\n\t\tif ( fn === \"inprogress\" ) {\n\t\t\tfn = queue.shift();\n\t\t\tstartLength--;\n\t\t}\n\n\t\tif ( fn ) {\n\n\t\t\t// Add a progress sentinel to prevent the fx queue from being\n\t\t\t// automatically dequeued\n\t\t\tif ( type === \"fx\" ) {\n\t\t\t\tqueue.unshift( \"inprogress\" );\n\t\t\t}\n\n\t\t\t// Clear up the last queue stop function\n\t\t\tdelete hooks.stop;\n\t\t\tfn.call( elem, next, hooks );\n\t\t}\n\n\t\tif ( !startLength && hooks ) {\n\t\t\thooks.empty.fire();\n\t\t}\n\t},\n\n\t// Not public - generate a queueHooks object, or return the current one\n\t_queueHooks: function( elem, type ) {\n\t\tvar key = type + \"queueHooks\";\n\t\treturn dataPriv.get( elem, key ) || dataPriv.access( elem, key, {\n\t\t\tempty: jQuery.Callbacks( \"once memory\" ).add( function() {\n\t\t\t\tdataPriv.remove( elem, [ type + \"queue\", key ] );\n\t\t\t} )\n\t\t} );\n\t}\n} );\n\njQuery.fn.extend( {\n\tqueue: function( type, data ) {\n\t\tvar setter = 2;\n\n\t\tif ( typeof type !== \"string\" ) {\n\t\t\tdata = type;\n\t\t\ttype = \"fx\";\n\t\t\tsetter--;\n\t\t}\n\n\t\tif ( arguments.length < setter ) {\n\t\t\treturn jQuery.queue( this[ 0 ], type );\n\t\t}\n\n\t\treturn data === undefined ?\n\t\t\tthis :\n\t\t\tthis.each( function() {\n\t\t\t\tvar queue = jQuery.queue( this, type, data );\n\n\t\t\t\t// Ensure a hooks for this queue\n\t\t\t\tjQuery._queueHooks( this, type );\n\n\t\t\t\tif ( type === \"fx\" && queue[ 0 ] !== \"inprogress\" ) {\n\t\t\t\t\tjQuery.dequeue( this, type );\n\t\t\t\t}\n\t\t\t} );\n\t},\n\tdequeue: function( type ) {\n\t\treturn this.each( function() {\n\t\t\tjQuery.dequeue( this, type );\n\t\t} );\n\t},\n\tclearQueue: function( type ) {\n\t\treturn this.queue( type || \"fx\", [] );\n\t},\n\n\t// Get a promise resolved when queues of a certain type\n\t// are emptied (fx is the type by default)\n\tpromise: function( type, obj ) {\n\t\tvar tmp,\n\t\t\tcount = 1,\n\t\t\tdefer = jQuery.Deferred(),\n\t\t\telements = this,\n\t\t\ti = this.length,\n\t\t\tresolve = function() {\n\t\t\t\tif ( !( --count ) ) {\n\t\t\t\t\tdefer.resolveWith( elements, [ elements ] );\n\t\t\t\t}\n\t\t\t};\n\n\t\tif ( typeof type !== \"string\" ) {\n\t\t\tobj = type;\n\t\t\ttype = undefined;\n\t\t}\n\t\ttype = type || \"fx\";\n\n\t\twhile ( i-- ) {\n\t\t\ttmp = dataPriv.get( elements[ i ], type + \"queueHooks\" );\n\t\t\tif ( tmp && tmp.empty ) {\n\t\t\t\tcount++;\n\t\t\t\ttmp.empty.add( resolve );\n\t\t\t}\n\t\t}\n\t\tresolve();\n\t\treturn defer.promise( obj );\n\t}\n} );\nvar pnum = ( /[+-]?(?:\\d*\\.|)\\d+(?:[eE][+-]?\\d+|)/ ).source;\n\nvar rcssNum = new RegExp( \"^(?:([+-])=|)(\" + pnum + \")([a-z%]*)$\", \"i\" );\n\n\nvar cssExpand = [ \"Top\", \"Right\", \"Bottom\", \"Left\" ];\n\nvar isHiddenWithinTree = function( elem, el ) {\n\n\t\t// isHiddenWithinTree might be called from jQuery#filter function;\n\t\t// in that case, element will be second argument\n\t\telem = el || elem;\n\n\t\t// Inline style trumps all\n\t\treturn elem.style.display === \"none\" ||\n\t\t\telem.style.display === \"\" &&\n\n\t\t\t// Otherwise, check computed style\n\t\t\t// Support: Firefox <=43 - 45\n\t\t\t// Disconnected elements can have computed display: none, so first confirm that elem is\n\t\t\t// in the document.\n\t\t\tjQuery.contains( elem.ownerDocument, elem ) &&\n\n\t\t\tjQuery.css( elem, \"display\" ) === \"none\";\n\t};\n\nvar swap = function( elem, options, callback, args ) {\n\tvar ret, name,\n\t\told = {};\n\n\t// Remember the old values, and insert the new ones\n\tfor ( name in options ) {\n\t\told[ name ] = elem.style[ name ];\n\t\telem.style[ name ] = options[ name ];\n\t}\n\n\tret = callback.apply( elem, args || [] );\n\n\t// Revert the old values\n\tfor ( name in options ) {\n\t\telem.style[ name ] = old[ name ];\n\t}\n\n\treturn ret;\n};\n\n\n\n\nfunction adjustCSS( elem, prop, valueParts, tween ) {\n\tvar adjusted,\n\t\tscale = 1,\n\t\tmaxIterations = 20,\n\t\tcurrentValue = tween ?\n\t\t\tfunction() {\n\t\t\t\treturn tween.cur();\n\t\t\t} :\n\t\t\tfunction() {\n\t\t\t\treturn jQuery.css( elem, prop, \"\" );\n\t\t\t},\n\t\tinitial = currentValue(),\n\t\tunit = valueParts && valueParts[ 3 ] || ( jQuery.cssNumber[ prop ] ? \"\" : \"px\" ),\n\n\t\t// Starting value computation is required for potential unit mismatches\n\t\tinitialInUnit = ( jQuery.cssNumber[ prop ] || unit !== \"px\" && +initial ) &&\n\t\t\trcssNum.exec( jQuery.css( elem, prop ) );\n\n\tif ( initialInUnit && initialInUnit[ 3 ] !== unit ) {\n\n\t\t// Trust units reported by jQuery.css\n\t\tunit = unit || initialInUnit[ 3 ];\n\n\t\t// Make sure we update the tween properties later on\n\t\tvalueParts = valueParts || [];\n\n\t\t// Iteratively approximate from a nonzero starting point\n\t\tinitialInUnit = +initial || 1;\n\n\t\tdo {\n\n\t\t\t// If previous iteration zeroed out, double until we get *something*.\n\t\t\t// Use string for doubling so we don't accidentally see scale as unchanged below\n\t\t\tscale = scale || \".5\";\n\n\t\t\t// Adjust and apply\n\t\t\tinitialInUnit = initialInUnit / scale;\n\t\t\tjQuery.style( elem, prop, initialInUnit + unit );\n\n\t\t// Update scale, tolerating zero or NaN from tween.cur()\n\t\t// Break the loop if scale is unchanged or perfect, or if we've just had enough.\n\t\t} while (\n\t\t\tscale !== ( scale = currentValue() / initial ) && scale !== 1 && --maxIterations\n\t\t);\n\t}\n\n\tif ( valueParts ) {\n\t\tinitialInUnit = +initialInUnit || +initial || 0;\n\n\t\t// Apply relative offset (+=/-=) if specified\n\t\tadjusted = valueParts[ 1 ] ?\n\t\t\tinitialInUnit + ( valueParts[ 1 ] + 1 ) * valueParts[ 2 ] :\n\t\t\t+valueParts[ 2 ];\n\t\tif ( tween ) {\n\t\t\ttween.unit = unit;\n\t\t\ttween.start = initialInUnit;\n\t\t\ttween.end = adjusted;\n\t\t}\n\t}\n\treturn adjusted;\n}\n\n\nvar defaultDisplayMap = {};\n\nfunction getDefaultDisplay( elem ) {\n\tvar temp,\n\t\tdoc = elem.ownerDocument,\n\t\tnodeName = elem.nodeName,\n\t\tdisplay = defaultDisplayMap[ nodeName ];\n\n\tif ( display ) {\n\t\treturn display;\n\t}\n\n\ttemp = doc.body.appendChild( doc.createElement( nodeName ) );\n\tdisplay = jQuery.css( temp, \"display\" );\n\n\ttemp.parentNode.removeChild( temp );\n\n\tif ( display === \"none\" ) {\n\t\tdisplay = \"block\";\n\t}\n\tdefaultDisplayMap[ nodeName ] = display;\n\n\treturn display;\n}\n\nfunction showHide( elements, show ) {\n\tvar display, elem,\n\t\tvalues = [],\n\t\tindex = 0,\n\t\tlength = elements.length;\n\n\t// Determine new display value for elements that need to change\n\tfor ( ; index < length; index++ ) {\n\t\telem = elements[ index ];\n\t\tif ( !elem.style ) {\n\t\t\tcontinue;\n\t\t}\n\n\t\tdisplay = elem.style.display;\n\t\tif ( show ) {\n\n\t\t\t// Since we force visibility upon cascade-hidden elements, an immediate (and slow)\n\t\t\t// check is required in this first loop unless we have a nonempty display value (either\n\t\t\t// inline or about-to-be-restored)\n\t\t\tif ( display === \"none\" ) {\n\t\t\t\tvalues[ index ] = dataPriv.get( elem, \"display\" ) || null;\n\t\t\t\tif ( !values[ index ] ) {\n\t\t\t\t\telem.style.display = \"\";\n\t\t\t\t}\n\t\t\t}\n\t\t\tif ( elem.style.display === \"\" && isHiddenWithinTree( elem ) ) {\n\t\t\t\tvalues[ index ] = getDefaultDisplay( elem );\n\t\t\t}\n\t\t} else {\n\t\t\tif ( display !== \"none\" ) {\n\t\t\t\tvalues[ index ] = \"none\";\n\n\t\t\t\t// Remember what we're overwriting\n\t\t\t\tdataPriv.set( elem, \"display\", display );\n\t\t\t}\n\t\t}\n\t}\n\n\t// Set the display of the elements in a second loop to avoid constant reflow\n\tfor ( index = 0; index < length; index++ ) {\n\t\tif ( values[ index ] != null ) {\n\t\t\telements[ index ].style.display = values[ index ];\n\t\t}\n\t}\n\n\treturn elements;\n}\n\njQuery.fn.extend( {\n\tshow: function() {\n\t\treturn showHide( this, true );\n\t},\n\thide: function() {\n\t\treturn showHide( this );\n\t},\n\ttoggle: function( state ) {\n\t\tif ( typeof state === \"boolean\" ) {\n\t\t\treturn state ? this.show() : this.hide();\n\t\t}\n\n\t\treturn this.each( function() {\n\t\t\tif ( isHiddenWithinTree( this ) ) {\n\t\t\t\tjQuery( this ).show();\n\t\t\t} else {\n\t\t\t\tjQuery( this ).hide();\n\t\t\t}\n\t\t} );\n\t}\n} );\nvar rcheckableType = ( /^(?:checkbox|radio)$/i );\n\nvar rtagName = ( /<([a-z][^\\/\\0>\\x20\\t\\r\\n\\f]+)/i );\n\nvar rscriptType = ( /^$|\\/(?:java|ecma)script/i );\n\n\n\n// We have to close these tags to support XHTML (#13200)\nvar wrapMap = {\n\n\t// Support: IE <=9 only\n\toption: [ 1, \"<select multiple='multiple'>\", \"</select>\" ],\n\n\t// XHTML parsers do not magically insert elements in the\n\t// same way that tag soup parsers do. So we cannot shorten\n\t// this by omitting <tbody> or other required elements.\n\tthead: [ 1, \"<table>\", \"</table>\" ],\n\tcol: [ 2, \"<table><colgroup>\", \"</colgroup></table>\" ],\n\ttr: [ 2, \"<table><tbody>\", \"</tbody></table>\" ],\n\ttd: [ 3, \"<table><tbody><tr>\", \"</tr></tbody></table>\" ],\n\n\t_default: [ 0, \"\", \"\" ]\n};\n\n// Support: IE <=9 only\nwrapMap.optgroup = wrapMap.option;\n\nwrapMap.tbody = wrapMap.tfoot = wrapMap.colgroup = wrapMap.caption = wrapMap.thead;\nwrapMap.th = wrapMap.td;\n\n\nfunction getAll( context, tag ) {\n\n\t// Support: IE <=9 - 11 only\n\t// Use typeof to avoid zero-argument method invocation on host objects (#15151)\n\tvar ret;\n\n\tif ( typeof context.getElementsByTagName !== \"undefined\" ) {\n\t\tret = context.getElementsByTagName( tag || \"*\" );\n\n\t} else if ( typeof context.querySelectorAll !== \"undefined\" ) {\n\t\tret = context.querySelectorAll( tag || \"*\" );\n\n\t} else {\n\t\tret = [];\n\t}\n\n\tif ( tag === undefined || tag && nodeName( context, tag ) ) {\n\t\treturn jQuery.merge( [ context ], ret );\n\t}\n\n\treturn ret;\n}\n\n\n// Mark scripts as having already been evaluated\nfunction setGlobalEval( elems, refElements ) {\n\tvar i = 0,\n\t\tl = elems.length;\n\n\tfor ( ; i < l; i++ ) {\n\t\tdataPriv.set(\n\t\t\telems[ i ],\n\t\t\t\"globalEval\",\n\t\t\t!refElements || dataPriv.get( refElements[ i ], \"globalEval\" )\n\t\t);\n\t}\n}\n\n\nvar rhtml = /<|&#?\\w+;/;\n\nfunction buildFragment( elems, context, scripts, selection, ignored ) {\n\tvar elem, tmp, tag, wrap, contains, j,\n\t\tfragment = context.createDocumentFragment(),\n\t\tnodes = [],\n\t\ti = 0,\n\t\tl = elems.length;\n\n\tfor ( ; i < l; i++ ) {\n\t\telem = elems[ i ];\n\n\t\tif ( elem || elem === 0 ) {\n\n\t\t\t// Add nodes directly\n\t\t\tif ( jQuery.type( elem ) === \"object\" ) {\n\n\t\t\t\t// Support: Android <=4.0 only, PhantomJS 1 only\n\t\t\t\t// push.apply(_, arraylike) throws on ancient WebKit\n\t\t\t\tjQuery.merge( nodes, elem.nodeType ? [ elem ] : elem );\n\n\t\t\t// Convert non-html into a text node\n\t\t\t} else if ( !rhtml.test( elem ) ) {\n\t\t\t\tnodes.push( context.createTextNode( elem ) );\n\n\t\t\t// Convert html into DOM nodes\n\t\t\t} else {\n\t\t\t\ttmp = tmp || fragment.appendChild( context.createElement( \"div\" ) );\n\n\t\t\t\t// Deserialize a standard representation\n\t\t\t\ttag = ( rtagName.exec( elem ) || [ \"\", \"\" ] )[ 1 ].toLowerCase();\n\t\t\t\twrap = wrapMap[ tag ] || wrapMap._default;\n\t\t\t\ttmp.innerHTML = wrap[ 1 ] + jQuery.htmlPrefilter( elem ) + wrap[ 2 ];\n\n\t\t\t\t// Descend through wrappers to the right content\n\t\t\t\tj = wrap[ 0 ];\n\t\t\t\twhile ( j-- ) {\n\t\t\t\t\ttmp = tmp.lastChild;\n\t\t\t\t}\n\n\t\t\t\t// Support: Android <=4.0 only, PhantomJS 1 only\n\t\t\t\t// push.apply(_, arraylike) throws on ancient WebKit\n\t\t\t\tjQuery.merge( nodes, tmp.childNodes );\n\n\t\t\t\t// Remember the top-level container\n\t\t\t\ttmp = fragment.firstChild;\n\n\t\t\t\t// Ensure the created nodes are orphaned (#12392)\n\t\t\t\ttmp.textContent = \"\";\n\t\t\t}\n\t\t}\n\t}\n\n\t// Remove wrapper from fragment\n\tfragment.textContent = \"\";\n\n\ti = 0;\n\twhile ( ( elem = nodes[ i++ ] ) ) {\n\n\t\t// Skip elements already in the context collection (trac-4087)\n\t\tif ( selection && jQuery.inArray( elem, selection ) > -1 ) {\n\t\t\tif ( ignored ) {\n\t\t\t\tignored.push( elem );\n\t\t\t}\n\t\t\tcontinue;\n\t\t}\n\n\t\tcontains = jQuery.contains( elem.ownerDocument, elem );\n\n\t\t// Append to fragment\n\t\ttmp = getAll( fragment.appendChild( elem ), \"script\" );\n\n\t\t// Preserve script evaluation history\n\t\tif ( contains ) {\n\t\t\tsetGlobalEval( tmp );\n\t\t}\n\n\t\t// Capture executables\n\t\tif ( scripts ) {\n\t\t\tj = 0;\n\t\t\twhile ( ( elem = tmp[ j++ ] ) ) {\n\t\t\t\tif ( rscriptType.test( elem.type || \"\" ) ) {\n\t\t\t\t\tscripts.push( elem );\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n\n\treturn fragment;\n}\n\n\n( function() {\n\tvar fragment = document.createDocumentFragment(),\n\t\tdiv = fragment.appendChild( document.createElement( \"div\" ) ),\n\t\tinput = document.createElement( \"input\" );\n\n\t// Support: Android 4.0 - 4.3 only\n\t// Check state lost if the name is set (#11217)\n\t// Support: Windows Web Apps (WWA)\n\t// `name` and `type` must use .setAttribute for WWA (#14901)\n\tinput.setAttribute( \"type\", \"radio\" );\n\tinput.setAttribute( \"checked\", \"checked\" );\n\tinput.setAttribute( \"name\", \"t\" );\n\n\tdiv.appendChild( input );\n\n\t// Support: Android <=4.1 only\n\t// Older WebKit doesn't clone checked state correctly in fragments\n\tsupport.checkClone = div.cloneNode( true ).cloneNode( true ).lastChild.checked;\n\n\t// Support: IE <=11 only\n\t// Make sure textarea (and checkbox) defaultValue is properly cloned\n\tdiv.innerHTML = \"<textarea>x</textarea>\";\n\tsupport.noCloneChecked = !!div.cloneNode( true ).lastChild.defaultValue;\n} )();\nvar documentElement = document.documentElement;\n\n\n\nvar\n\trkeyEvent = /^key/,\n\trmouseEvent = /^(?:mouse|pointer|contextmenu|drag|drop)|click/,\n\trtypenamespace = /^([^.]*)(?:\\.(.+)|)/;\n\nfunction returnTrue() {\n\treturn true;\n}\n\nfunction returnFalse() {\n\treturn false;\n}\n\n// Support: IE <=9 only\n// See #13393 for more info\nfunction safeActiveElement() {\n\ttry {\n\t\treturn document.activeElement;\n\t} catch ( err ) { }\n}\n\nfunction on( elem, types, selector, data, fn, one ) {\n\tvar origFn, type;\n\n\t// Types can be a map of types/handlers\n\tif ( typeof types === \"object\" ) {\n\n\t\t// ( types-Object, selector, data )\n\t\tif ( typeof selector !== \"string\" ) {\n\n\t\t\t// ( types-Object, data )\n\t\t\tdata = data || selector;\n\t\t\tselector = undefined;\n\t\t}\n\t\tfor ( type in types ) {\n\t\t\ton( elem, type, selector, data, types[ type ], one );\n\t\t}\n\t\treturn elem;\n\t}\n\n\tif ( data == null && fn == null ) {\n\n\t\t// ( types, fn )\n\t\tfn = selector;\n\t\tdata = selector = undefined;\n\t} else if ( fn == null ) {\n\t\tif ( typeof selector === \"string\" ) {\n\n\t\t\t// ( types, selector, fn )\n\t\t\tfn = data;\n\t\t\tdata = undefined;\n\t\t} else {\n\n\t\t\t// ( types, data, fn )\n\t\t\tfn = data;\n\t\t\tdata = selector;\n\t\t\tselector = undefined;\n\t\t}\n\t}\n\tif ( fn === false ) {\n\t\tfn = returnFalse;\n\t} else if ( !fn ) {\n\t\treturn elem;\n\t}\n\n\tif ( one === 1 ) {\n\t\torigFn = fn;\n\t\tfn = function( event ) {\n\n\t\t\t// Can use an empty set, since event contains the info\n\t\t\tjQuery().off( event );\n\t\t\treturn origFn.apply( this, arguments );\n\t\t};\n\n\t\t// Use same guid so caller can remove using origFn\n\t\tfn.guid = origFn.guid || ( origFn.guid = jQuery.guid++ );\n\t}\n\treturn elem.each( function() {\n\t\tjQuery.event.add( this, types, fn, data, selector );\n\t} );\n}\n\n/*\n * Helper functions for managing events -- not part of the public interface.\n * Props to Dean Edwards' addEvent library for many of the ideas.\n */\njQuery.event = {\n\n\tglobal: {},\n\n\tadd: function( elem, types, handler, data, selector ) {\n\n\t\tvar handleObjIn, eventHandle, tmp,\n\t\t\tevents, t, handleObj,\n\t\t\tspecial, handlers, type, namespaces, origType,\n\t\t\telemData = dataPriv.get( elem );\n\n\t\t// Don't attach events to noData or text/comment nodes (but allow plain objects)\n\t\tif ( !elemData ) {\n\t\t\treturn;\n\t\t}\n\n\t\t// Caller can pass in an object of custom data in lieu of the handler\n\t\tif ( handler.handler ) {\n\t\t\thandleObjIn = handler;\n\t\t\thandler = handleObjIn.handler;\n\t\t\tselector = handleObjIn.selector;\n\t\t}\n\n\t\t// Ensure that invalid selectors throw exceptions at attach time\n\t\t// Evaluate against documentElement in case elem is a non-element node (e.g., document)\n\t\tif ( selector ) {\n\t\t\tjQuery.find.matchesSelector( documentElement, selector );\n\t\t}\n\n\t\t// Make sure that the handler has a unique ID, used to find/remove it later\n\t\tif ( !handler.guid ) {\n\t\t\thandler.guid = jQuery.guid++;\n\t\t}\n\n\t\t// Init the element's event structure and main handler, if this is the first\n\t\tif ( !( events = elemData.events ) ) {\n\t\t\tevents = elemData.events = {};\n\t\t}\n\t\tif ( !( eventHandle = elemData.handle ) ) {\n\t\t\teventHandle = elemData.handle = function( e ) {\n\n\t\t\t\t// Discard the second event of a jQuery.event.trigger() and\n\t\t\t\t// when an event is called after a page has unloaded\n\t\t\t\treturn typeof jQuery !== \"undefined\" && jQuery.event.triggered !== e.type ?\n\t\t\t\t\tjQuery.event.dispatch.apply( elem, arguments ) : undefined;\n\t\t\t};\n\t\t}\n\n\t\t// Handle multiple events separated by a space\n\t\ttypes = ( types || \"\" ).match( rnothtmlwhite ) || [ \"\" ];\n\t\tt = types.length;\n\t\twhile ( t-- ) {\n\t\t\ttmp = rtypenamespace.exec( types[ t ] ) || [];\n\t\t\ttype = origType = tmp[ 1 ];\n\t\t\tnamespaces = ( tmp[ 2 ] || \"\" ).split( \".\" ).sort();\n\n\t\t\t// There *must* be a type, no attaching namespace-only handlers\n\t\t\tif ( !type ) {\n\t\t\t\tcontinue;\n\t\t\t}\n\n\t\t\t// If event changes its type, use the special event handlers for the changed type\n\t\t\tspecial = jQuery.event.special[ type ] || {};\n\n\t\t\t// If selector defined, determine special event api type, otherwise given type\n\t\t\ttype = ( selector ? special.delegateType : special.bindType ) || type;\n\n\t\t\t// Update special based on newly reset type\n\t\t\tspecial = jQuery.event.special[ type ] || {};\n\n\t\t\t// handleObj is passed to all event handlers\n\t\t\thandleObj = jQuery.extend( {\n\t\t\t\ttype: type,\n\t\t\t\torigType: origType,\n\t\t\t\tdata: data,\n\t\t\t\thandler: handler,\n\t\t\t\tguid: handler.guid,\n\t\t\t\tselector: selector,\n\t\t\t\tneedsContext: selector && jQuery.expr.match.needsContext.test( selector ),\n\t\t\t\tnamespace: namespaces.join( \".\" )\n\t\t\t}, handleObjIn );\n\n\t\t\t// Init the event handler queue if we're the first\n\t\t\tif ( !( handlers = events[ type ] ) ) {\n\t\t\t\thandlers = events[ type ] = [];\n\t\t\t\thandlers.delegateCount = 0;\n\n\t\t\t\t// Only use addEventListener if the special events handler returns false\n\t\t\t\tif ( !special.setup ||\n\t\t\t\t\tspecial.setup.call( elem, data, namespaces, eventHandle ) === false ) {\n\n\t\t\t\t\tif ( elem.addEventListener ) {\n\t\t\t\t\t\telem.addEventListener( type, eventHandle );\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tif ( special.add ) {\n\t\t\t\tspecial.add.call( elem, handleObj );\n\n\t\t\t\tif ( !handleObj.handler.guid ) {\n\t\t\t\t\thandleObj.handler.guid = handler.guid;\n\t\t\t\t}\n\t\t\t}\n\n\t\t\t// Add to the element's handler list, delegates in front\n\t\t\tif ( selector ) {\n\t\t\t\thandlers.splice( handlers.delegateCount++, 0, handleObj );\n\t\t\t} else {\n\t\t\t\thandlers.push( handleObj );\n\t\t\t}\n\n\t\t\t// Keep track of which events have ever been used, for event optimization\n\t\t\tjQuery.event.global[ type ] = true;\n\t\t}\n\n\t},\n\n\t// Detach an event or set of events from an element\n\tremove: function( elem, types, handler, selector, mappedTypes ) {\n\n\t\tvar j, origCount, tmp,\n\t\t\tevents, t, handleObj,\n\t\t\tspecial, handlers, type, namespaces, origType,\n\t\t\telemData = dataPriv.hasData( elem ) && dataPriv.get( elem );\n\n\t\tif ( !elemData || !( events = elemData.events ) ) {\n\t\t\treturn;\n\t\t}\n\n\t\t// Once for each type.namespace in types; type may be omitted\n\t\ttypes = ( types || \"\" ).match( rnothtmlwhite ) || [ \"\" ];\n\t\tt = types.length;\n\t\twhile ( t-- ) {\n\t\t\ttmp = rtypenamespace.exec( types[ t ] ) || [];\n\t\t\ttype = origType = tmp[ 1 ];\n\t\t\tnamespaces = ( tmp[ 2 ] || \"\" ).split( \".\" ).sort();\n\n\t\t\t// Unbind all events (on this namespace, if provided) for the element\n\t\t\tif ( !type ) {\n\t\t\t\tfor ( type in events ) {\n\t\t\t\t\tjQuery.event.remove( elem, type + types[ t ], handler, selector, true );\n\t\t\t\t}\n\t\t\t\tcontinue;\n\t\t\t}\n\n\t\t\tspecial = jQuery.event.special[ type ] || {};\n\t\t\ttype = ( selector ? special.delegateType : special.bindType ) || type;\n\t\t\thandlers = events[ type ] || [];\n\t\t\ttmp = tmp[ 2 ] &&\n\t\t\t\tnew RegExp( \"(^|\\\\.)\" + namespaces.join( \"\\\\.(?:.*\\\\.|)\" ) + \"(\\\\.|$)\" );\n\n\t\t\t// Remove matching events\n\t\t\torigCount = j = handlers.length;\n\t\t\twhile ( j-- ) {\n\t\t\t\thandleObj = handlers[ j ];\n\n\t\t\t\tif ( ( mappedTypes || origType === handleObj.origType ) &&\n\t\t\t\t\t( !handler || handler.guid === handleObj.guid ) &&\n\t\t\t\t\t( !tmp || tmp.test( handleObj.namespace ) ) &&\n\t\t\t\t\t( !selector || selector === handleObj.selector ||\n\t\t\t\t\t\tselector === \"**\" && handleObj.selector ) ) {\n\t\t\t\t\thandlers.splice( j, 1 );\n\n\t\t\t\t\tif ( handleObj.selector ) {\n\t\t\t\t\t\thandlers.delegateCount--;\n\t\t\t\t\t}\n\t\t\t\t\tif ( special.remove ) {\n\t\t\t\t\t\tspecial.remove.call( elem, handleObj );\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\n\t\t\t// Remove generic event handler if we removed something and no more handlers exist\n\t\t\t// (avoids potential for endless recursion during removal of special event handlers)\n\t\t\tif ( origCount && !handlers.length ) {\n\t\t\t\tif ( !special.teardown ||\n\t\t\t\t\tspecial.teardown.call( elem, namespaces, elemData.handle ) === false ) {\n\n\t\t\t\t\tjQuery.removeEvent( elem, type, elemData.handle );\n\t\t\t\t}\n\n\t\t\t\tdelete events[ type ];\n\t\t\t}\n\t\t}\n\n\t\t// Remove data and the expando if it's no longer used\n\t\tif ( jQuery.isEmptyObject( events ) ) {\n\t\t\tdataPriv.remove( elem, \"handle events\" );\n\t\t}\n\t},\n\n\tdispatch: function( nativeEvent ) {\n\n\t\t// Make a writable jQuery.Event from the native event object\n\t\tvar event = jQuery.event.fix( nativeEvent );\n\n\t\tvar i, j, ret, matched, handleObj, handlerQueue,\n\t\t\targs = new Array( arguments.length ),\n\t\t\thandlers = ( dataPriv.get( this, \"events\" ) || {} )[ event.type ] || [],\n\t\t\tspecial = jQuery.event.special[ event.type ] || {};\n\n\t\t// Use the fix-ed jQuery.Event rather than the (read-only) native event\n\t\targs[ 0 ] = event;\n\n\t\tfor ( i = 1; i < arguments.length; i++ ) {\n\t\t\targs[ i ] = arguments[ i ];\n\t\t}\n\n\t\tevent.delegateTarget = this;\n\n\t\t// Call the preDispatch hook for the mapped type, and let it bail if desired\n\t\tif ( special.preDispatch && special.preDispatch.call( this, event ) === false ) {\n\t\t\treturn;\n\t\t}\n\n\t\t// Determine handlers\n\t\thandlerQueue = jQuery.event.handlers.call( this, event, handlers );\n\n\t\t// Run delegates first; they may want to stop propagation beneath us\n\t\ti = 0;\n\t\twhile ( ( matched = handlerQueue[ i++ ] ) && !event.isPropagationStopped() ) {\n\t\t\tevent.currentTarget = matched.elem;\n\n\t\t\tj = 0;\n\t\t\twhile ( ( handleObj = matched.handlers[ j++ ] ) &&\n\t\t\t\t!event.isImmediatePropagationStopped() ) {\n\n\t\t\t\t// Triggered event must either 1) have no namespace, or 2) have namespace(s)\n\t\t\t\t// a subset or equal to those in the bound event (both can have no namespace).\n\t\t\t\tif ( !event.rnamespace || event.rnamespace.test( handleObj.namespace ) ) {\n\n\t\t\t\t\tevent.handleObj = handleObj;\n\t\t\t\t\tevent.data = handleObj.data;\n\n\t\t\t\t\tret = ( ( jQuery.event.special[ handleObj.origType ] || {} ).handle ||\n\t\t\t\t\t\thandleObj.handler ).apply( matched.elem, args );\n\n\t\t\t\t\tif ( ret !== undefined ) {\n\t\t\t\t\t\tif ( ( event.result = ret ) === false ) {\n\t\t\t\t\t\t\tevent.preventDefault();\n\t\t\t\t\t\t\tevent.stopPropagation();\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\t// Call the postDispatch hook for the mapped type\n\t\tif ( special.postDispatch ) {\n\t\t\tspecial.postDispatch.call( this, event );\n\t\t}\n\n\t\treturn event.result;\n\t},\n\n\thandlers: function( event, handlers ) {\n\t\tvar i, handleObj, sel, matchedHandlers, matchedSelectors,\n\t\t\thandlerQueue = [],\n\t\t\tdelegateCount = handlers.delegateCount,\n\t\t\tcur = event.target;\n\n\t\t// Find delegate handlers\n\t\tif ( delegateCount &&\n\n\t\t\t// Support: IE <=9\n\t\t\t// Black-hole SVG <use> instance trees (trac-13180)\n\t\t\tcur.nodeType &&\n\n\t\t\t// Support: Firefox <=42\n\t\t\t// Suppress spec-violating clicks indicating a non-primary pointer button (trac-3861)\n\t\t\t// https://www.w3.org/TR/DOM-Level-3-Events/#event-type-click\n\t\t\t// Support: IE 11 only\n\t\t\t// ...but not arrow key \"clicks\" of radio inputs, which can have `button` -1 (gh-2343)\n\t\t\t!( event.type === \"click\" && event.button >= 1 ) ) {\n\n\t\t\tfor ( ; cur !== this; cur = cur.parentNode || this ) {\n\n\t\t\t\t// Don't check non-elements (#13208)\n\t\t\t\t// Don't process clicks on disabled elements (#6911, #8165, #11382, #11764)\n\t\t\t\tif ( cur.nodeType === 1 && !( event.type === \"click\" && cur.disabled === true ) ) {\n\t\t\t\t\tmatchedHandlers = [];\n\t\t\t\t\tmatchedSelectors = {};\n\t\t\t\t\tfor ( i = 0; i < delegateCount; i++ ) {\n\t\t\t\t\t\thandleObj = handlers[ i ];\n\n\t\t\t\t\t\t// Don't conflict with Object.prototype properties (#13203)\n\t\t\t\t\t\tsel = handleObj.selector + \" \";\n\n\t\t\t\t\t\tif ( matchedSelectors[ sel ] === undefined ) {\n\t\t\t\t\t\t\tmatchedSelectors[ sel ] = handleObj.needsContext ?\n\t\t\t\t\t\t\t\tjQuery( sel, this ).index( cur ) > -1 :\n\t\t\t\t\t\t\t\tjQuery.find( sel, this, null, [ cur ] ).length;\n\t\t\t\t\t\t}\n\t\t\t\t\t\tif ( matchedSelectors[ sel ] ) {\n\t\t\t\t\t\t\tmatchedHandlers.push( handleObj );\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t\tif ( matchedHandlers.length ) {\n\t\t\t\t\t\thandlerQueue.push( { elem: cur, handlers: matchedHandlers } );\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\t// Add the remaining (directly-bound) handlers\n\t\tcur = this;\n\t\tif ( delegateCount < handlers.length ) {\n\t\t\thandlerQueue.push( { elem: cur, handlers: handlers.slice( delegateCount ) } );\n\t\t}\n\n\t\treturn handlerQueue;\n\t},\n\n\taddProp: function( name, hook ) {\n\t\tObject.defineProperty( jQuery.Event.prototype, name, {\n\t\t\tenumerable: true,\n\t\t\tconfigurable: true,\n\n\t\t\tget: jQuery.isFunction( hook ) ?\n\t\t\t\tfunction() {\n\t\t\t\t\tif ( this.originalEvent ) {\n\t\t\t\t\t\t\treturn hook( this.originalEvent );\n\t\t\t\t\t}\n\t\t\t\t} :\n\t\t\t\tfunction() {\n\t\t\t\t\tif ( this.originalEvent ) {\n\t\t\t\t\t\t\treturn this.originalEvent[ name ];\n\t\t\t\t\t}\n\t\t\t\t},\n\n\t\t\tset: function( value ) {\n\t\t\t\tObject.defineProperty( this, name, {\n\t\t\t\t\tenumerable: true,\n\t\t\t\t\tconfigurable: true,\n\t\t\t\t\twritable: true,\n\t\t\t\t\tvalue: value\n\t\t\t\t} );\n\t\t\t}\n\t\t} );\n\t},\n\n\tfix: function( originalEvent ) {\n\t\treturn originalEvent[ jQuery.expando ] ?\n\t\t\toriginalEvent :\n\t\t\tnew jQuery.Event( originalEvent );\n\t},\n\n\tspecial: {\n\t\tload: {\n\n\t\t\t// Prevent triggered image.load events from bubbling to window.load\n\t\t\tnoBubble: true\n\t\t},\n\t\tfocus: {\n\n\t\t\t// Fire native event if possible so blur/focus sequence is correct\n\t\t\ttrigger: function() {\n\t\t\t\tif ( this !== safeActiveElement() && this.focus ) {\n\t\t\t\t\tthis.focus();\n\t\t\t\t\treturn false;\n\t\t\t\t}\n\t\t\t},\n\t\t\tdelegateType: \"focusin\"\n\t\t},\n\t\tblur: {\n\t\t\ttrigger: function() {\n\t\t\t\tif ( this === safeActiveElement() && this.blur ) {\n\t\t\t\t\tthis.blur();\n\t\t\t\t\treturn false;\n\t\t\t\t}\n\t\t\t},\n\t\t\tdelegateType: \"focusout\"\n\t\t},\n\t\tclick: {\n\n\t\t\t// For checkbox, fire native event so checked state will be right\n\t\t\ttrigger: function() {\n\t\t\t\tif ( this.type === \"checkbox\" && this.click && nodeName( this, \"input\" ) ) {\n\t\t\t\t\tthis.click();\n\t\t\t\t\treturn false;\n\t\t\t\t}\n\t\t\t},\n\n\t\t\t// For cross-browser consistency, don't fire native .click() on links\n\t\t\t_default: function( event ) {\n\t\t\t\treturn nodeName( event.target, \"a\" );\n\t\t\t}\n\t\t},\n\n\t\tbeforeunload: {\n\t\t\tpostDispatch: function( event ) {\n\n\t\t\t\t// Support: Firefox 20+\n\t\t\t\t// Firefox doesn't alert if the returnValue field is not set.\n\t\t\t\tif ( event.result !== undefined && event.originalEvent ) {\n\t\t\t\t\tevent.originalEvent.returnValue = event.result;\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n};\n\njQuery.removeEvent = function( elem, type, handle ) {\n\n\t// This \"if\" is needed for plain objects\n\tif ( elem.removeEventListener ) {\n\t\telem.removeEventListener( type, handle );\n\t}\n};\n\njQuery.Event = function( src, props ) {\n\n\t// Allow instantiation without the 'new' keyword\n\tif ( !( this instanceof jQuery.Event ) ) {\n\t\treturn new jQuery.Event( src, props );\n\t}\n\n\t// Event object\n\tif ( src && src.type ) {\n\t\tthis.originalEvent = src;\n\t\tthis.type = src.type;\n\n\t\t// Events bubbling up the document may have been marked as prevented\n\t\t// by a handler lower down the tree; reflect the correct value.\n\t\tthis.isDefaultPrevented = src.defaultPrevented ||\n\t\t\t\tsrc.defaultPrevented === undefined &&\n\n\t\t\t\t// Support: Android <=2.3 only\n\t\t\t\tsrc.returnValue === false ?\n\t\t\treturnTrue :\n\t\t\treturnFalse;\n\n\t\t// Create target properties\n\t\t// Support: Safari <=6 - 7 only\n\t\t// Target should not be a text node (#504, #13143)\n\t\tthis.target = ( src.target && src.target.nodeType === 3 ) ?\n\t\t\tsrc.target.parentNode :\n\t\t\tsrc.target;\n\n\t\tthis.currentTarget = src.currentTarget;\n\t\tthis.relatedTarget = src.relatedTarget;\n\n\t// Event type\n\t} else {\n\t\tthis.type = src;\n\t}\n\n\t// Put explicitly provided properties onto the event object\n\tif ( props ) {\n\t\tjQuery.extend( this, props );\n\t}\n\n\t// Create a timestamp if incoming event doesn't have one\n\tthis.timeStamp = src && src.timeStamp || jQuery.now();\n\n\t// Mark it as fixed\n\tthis[ jQuery.expando ] = true;\n};\n\n// jQuery.Event is based on DOM3 Events as specified by the ECMAScript Language Binding\n// https://www.w3.org/TR/2003/WD-DOM-Level-3-Events-20030331/ecma-script-binding.html\njQuery.Event.prototype = {\n\tconstructor: jQuery.Event,\n\tisDefaultPrevented: returnFalse,\n\tisPropagationStopped: returnFalse,\n\tisImmediatePropagationStopped: returnFalse,\n\tisSimulated: false,\n\n\tpreventDefault: function() {\n\t\tvar e = this.originalEvent;\n\n\t\tthis.isDefaultPrevented = returnTrue;\n\n\t\tif ( e && !this.isSimulated ) {\n\t\t\te.preventDefault();\n\t\t}\n\t},\n\tstopPropagation: function() {\n\t\tvar e = this.originalEvent;\n\n\t\tthis.isPropagationStopped = returnTrue;\n\n\t\tif ( e && !this.isSimulated ) {\n\t\t\te.stopPropagation();\n\t\t}\n\t},\n\tstopImmediatePropagation: function() {\n\t\tvar e = this.originalEvent;\n\n\t\tthis.isImmediatePropagationStopped = returnTrue;\n\n\t\tif ( e && !this.isSimulated ) {\n\t\t\te.stopImmediatePropagation();\n\t\t}\n\n\t\tthis.stopPropagation();\n\t}\n};\n\n// Includes all common event props including KeyEvent and MouseEvent specific props\njQuery.each( {\n\taltKey: true,\n\tbubbles: true,\n\tcancelable: true,\n\tchangedTouches: true,\n\tctrlKey: true,\n\tdetail: true,\n\teventPhase: true,\n\tmetaKey: true,\n\tpageX: true,\n\tpageY: true,\n\tshiftKey: true,\n\tview: true,\n\t\"char\": true,\n\tcharCode: true,\n\tkey: true,\n\tkeyCode: true,\n\tbutton: true,\n\tbuttons: true,\n\tclientX: true,\n\tclientY: true,\n\toffsetX: true,\n\toffsetY: true,\n\tpointerId: true,\n\tpointerType: true,\n\tscreenX: true,\n\tscreenY: true,\n\ttargetTouches: true,\n\ttoElement: true,\n\ttouches: true,\n\n\twhich: function( event ) {\n\t\tvar button = event.button;\n\n\t\t// Add which for key events\n\t\tif ( event.which == null && rkeyEvent.test( event.type ) ) {\n\t\t\treturn event.charCode != null ? event.charCode : event.keyCode;\n\t\t}\n\n\t\t// Add which for click: 1 === left; 2 === middle; 3 === right\n\t\tif ( !event.which && button !== undefined && rmouseEvent.test( event.type ) ) {\n\t\t\tif ( button & 1 ) {\n\t\t\t\treturn 1;\n\t\t\t}\n\n\t\t\tif ( button & 2 ) {\n\t\t\t\treturn 3;\n\t\t\t}\n\n\t\t\tif ( button & 4 ) {\n\t\t\t\treturn 2;\n\t\t\t}\n\n\t\t\treturn 0;\n\t\t}\n\n\t\treturn event.which;\n\t}\n}, jQuery.event.addProp );\n\n// Create mouseenter/leave events using mouseover/out and event-time checks\n// so that event delegation works in jQuery.\n// Do the same for pointerenter/pointerleave and pointerover/pointerout\n//\n// Support: Safari 7 only\n// Safari sends mouseenter too often; see:\n// https://bugs.chromium.org/p/chromium/issues/detail?id=470258\n// for the description of the bug (it existed in older Chrome versions as well).\njQuery.each( {\n\tmouseenter: \"mouseover\",\n\tmouseleave: \"mouseout\",\n\tpointerenter: \"pointerover\",\n\tpointerleave: \"pointerout\"\n}, function( orig, fix ) {\n\tjQuery.event.special[ orig ] = {\n\t\tdelegateType: fix,\n\t\tbindType: fix,\n\n\t\thandle: function( event ) {\n\t\t\tvar ret,\n\t\t\t\ttarget = this,\n\t\t\t\trelated = event.relatedTarget,\n\t\t\t\thandleObj = event.handleObj;\n\n\t\t\t// For mouseenter/leave call the handler if related is outside the target.\n\t\t\t// NB: No relatedTarget if the mouse left/entered the browser window\n\t\t\tif ( !related || ( related !== target && !jQuery.contains( target, related ) ) ) {\n\t\t\t\tevent.type = handleObj.origType;\n\t\t\t\tret = handleObj.handler.apply( this, arguments );\n\t\t\t\tevent.type = fix;\n\t\t\t}\n\t\t\treturn ret;\n\t\t}\n\t};\n} );\n\njQuery.fn.extend( {\n\n\ton: function( types, selector, data, fn ) {\n\t\treturn on( this, types, selector, data, fn );\n\t},\n\tone: function( types, selector, data, fn ) {\n\t\treturn on( this, types, selector, data, fn, 1 );\n\t},\n\toff: function( types, selector, fn ) {\n\t\tvar handleObj, type;\n\t\tif ( types && types.preventDefault && types.handleObj ) {\n\n\t\t\t// ( event ) dispatched jQuery.Event\n\t\t\thandleObj = types.handleObj;\n\t\t\tjQuery( types.delegateTarget ).off(\n\t\t\t\thandleObj.namespace ?\n\t\t\t\t\thandleObj.origType + \".\" + handleObj.namespace :\n\t\t\t\t\thandleObj.origType,\n\t\t\t\thandleObj.selector,\n\t\t\t\thandleObj.handler\n\t\t\t);\n\t\t\treturn this;\n\t\t}\n\t\tif ( typeof types === \"object\" ) {\n\n\t\t\t// ( types-object [, selector] )\n\t\t\tfor ( type in types ) {\n\t\t\t\tthis.off( type, selector, types[ type ] );\n\t\t\t}\n\t\t\treturn this;\n\t\t}\n\t\tif ( selector === false || typeof selector === \"function\" ) {\n\n\t\t\t// ( types [, fn] )\n\t\t\tfn = selector;\n\t\t\tselector = undefined;\n\t\t}\n\t\tif ( fn === false ) {\n\t\t\tfn = returnFalse;\n\t\t}\n\t\treturn this.each( function() {\n\t\t\tjQuery.event.remove( this, types, fn, selector );\n\t\t} );\n\t}\n} );\n\n\nvar\n\n\t/* eslint-disable max-len */\n\n\t// See https://github.com/eslint/eslint/issues/3229\n\trxhtmlTag = /<(?!area|br|col|embed|hr|img|input|link|meta|param)(([a-z][^\\/\\0>\\x20\\t\\r\\n\\f]*)[^>]*)\\/>/gi,\n\n\t/* eslint-enable */\n\n\t// Support: IE <=10 - 11, Edge 12 - 13\n\t// In IE/Edge using regex groups here causes severe slowdowns.\n\t// See https://connect.microsoft.com/IE/feedback/details/1736512/\n\trnoInnerhtml = /<script|<style|<link/i,\n\n\t// checked=\"checked\" or checked\n\trchecked = /checked\\s*(?:[^=]|=\\s*.checked.)/i,\n\trscriptTypeMasked = /^true\\/(.*)/,\n\trcleanScript = /^\\s*<!(?:\\[CDATA\\[|--)|(?:\\]\\]|--)>\\s*$/g;\n\n// Prefer a tbody over its parent table for containing new rows\nfunction manipulationTarget( elem, content ) {\n\tif ( nodeName( elem, \"table\" ) &&\n\t\tnodeName( content.nodeType !== 11 ? content : content.firstChild, \"tr\" ) ) {\n\n\t\treturn jQuery( \">tbody\", elem )[ 0 ] || elem;\n\t}\n\n\treturn elem;\n}\n\n// Replace/restore the type attribute of script elements for safe DOM manipulation\nfunction disableScript( elem ) {\n\telem.type = ( elem.getAttribute( \"type\" ) !== null ) + \"/\" + elem.type;\n\treturn elem;\n}\nfunction restoreScript( elem ) {\n\tvar match = rscriptTypeMasked.exec( elem.type );\n\n\tif ( match ) {\n\t\telem.type = match[ 1 ];\n\t} else {\n\t\telem.removeAttribute( \"type\" );\n\t}\n\n\treturn elem;\n}\n\nfunction cloneCopyEvent( src, dest ) {\n\tvar i, l, type, pdataOld, pdataCur, udataOld, udataCur, events;\n\n\tif ( dest.nodeType !== 1 ) {\n\t\treturn;\n\t}\n\n\t// 1. Copy private data: events, handlers, etc.\n\tif ( dataPriv.hasData( src ) ) {\n\t\tpdataOld = dataPriv.access( src );\n\t\tpdataCur = dataPriv.set( dest, pdataOld );\n\t\tevents = pdataOld.events;\n\n\t\tif ( events ) {\n\t\t\tdelete pdataCur.handle;\n\t\t\tpdataCur.events = {};\n\n\t\t\tfor ( type in events ) {\n\t\t\t\tfor ( i = 0, l = events[ type ].length; i < l; i++ ) {\n\t\t\t\t\tjQuery.event.add( dest, type, events[ type ][ i ] );\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n\n\t// 2. Copy user data\n\tif ( dataUser.hasData( src ) ) {\n\t\tudataOld = dataUser.access( src );\n\t\tudataCur = jQuery.extend( {}, udataOld );\n\n\t\tdataUser.set( dest, udataCur );\n\t}\n}\n\n// Fix IE bugs, see support tests\nfunction fixInput( src, dest ) {\n\tvar nodeName = dest.nodeName.toLowerCase();\n\n\t// Fails to persist the checked state of a cloned checkbox or radio button.\n\tif ( nodeName === \"input\" && rcheckableType.test( src.type ) ) {\n\t\tdest.checked = src.checked;\n\n\t// Fails to return the selected option to the default selected state when cloning options\n\t} else if ( nodeName === \"input\" || nodeName === \"textarea\" ) {\n\t\tdest.defaultValue = src.defaultValue;\n\t}\n}\n\nfunction domManip( collection, args, callback, ignored ) {\n\n\t// Flatten any nested arrays\n\targs = concat.apply( [], args );\n\n\tvar fragment, first, scripts, hasScripts, node, doc,\n\t\ti = 0,\n\t\tl = collection.length,\n\t\tiNoClone = l - 1,\n\t\tvalue = args[ 0 ],\n\t\tisFunction = jQuery.isFunction( value );\n\n\t// We can't cloneNode fragments that contain checked, in WebKit\n\tif ( isFunction ||\n\t\t\t( l > 1 && typeof value === \"string\" &&\n\t\t\t\t!support.checkClone && rchecked.test( value ) ) ) {\n\t\treturn collection.each( function( index ) {\n\t\t\tvar self = collection.eq( index );\n\t\t\tif ( isFunction ) {\n\t\t\t\targs[ 0 ] = value.call( this, index, self.html() );\n\t\t\t}\n\t\t\tdomManip( self, args, callback, ignored );\n\t\t} );\n\t}\n\n\tif ( l ) {\n\t\tfragment = buildFragment( args, collection[ 0 ].ownerDocument, false, collection, ignored );\n\t\tfirst = fragment.firstChild;\n\n\t\tif ( fragment.childNodes.length === 1 ) {\n\t\t\tfragment = first;\n\t\t}\n\n\t\t// Require either new content or an interest in ignored elements to invoke the callback\n\t\tif ( first || ignored ) {\n\t\t\tscripts = jQuery.map( getAll( fragment, \"script\" ), disableScript );\n\t\t\thasScripts = scripts.length;\n\n\t\t\t// Use the original fragment for the last item\n\t\t\t// instead of the first because it can end up\n\t\t\t// being emptied incorrectly in certain situations (#8070).\n\t\t\tfor ( ; i < l; i++ ) {\n\t\t\t\tnode = fragment;\n\n\t\t\t\tif ( i !== iNoClone ) {\n\t\t\t\t\tnode = jQuery.clone( node, true, true );\n\n\t\t\t\t\t// Keep references to cloned scripts for later restoration\n\t\t\t\t\tif ( hasScripts ) {\n\n\t\t\t\t\t\t// Support: Android <=4.0 only, PhantomJS 1 only\n\t\t\t\t\t\t// push.apply(_, arraylike) throws on ancient WebKit\n\t\t\t\t\t\tjQuery.merge( scripts, getAll( node, \"script\" ) );\n\t\t\t\t\t}\n\t\t\t\t}\n\n\t\t\t\tcallback.call( collection[ i ], node, i );\n\t\t\t}\n\n\t\t\tif ( hasScripts ) {\n\t\t\t\tdoc = scripts[ scripts.length - 1 ].ownerDocument;\n\n\t\t\t\t// Reenable scripts\n\t\t\t\tjQuery.map( scripts, restoreScript );\n\n\t\t\t\t// Evaluate executable scripts on first document insertion\n\t\t\t\tfor ( i = 0; i < hasScripts; i++ ) {\n\t\t\t\t\tnode = scripts[ i ];\n\t\t\t\t\tif ( rscriptType.test( node.type || \"\" ) &&\n\t\t\t\t\t\t!dataPriv.access( node, \"globalEval\" ) &&\n\t\t\t\t\t\tjQuery.contains( doc, node ) ) {\n\n\t\t\t\t\t\tif ( node.src ) {\n\n\t\t\t\t\t\t\t// Optional AJAX dependency, but won't run scripts if not present\n\t\t\t\t\t\t\tif ( jQuery._evalUrl ) {\n\t\t\t\t\t\t\t\tjQuery._evalUrl( node.src );\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\tDOMEval( node.textContent.replace( rcleanScript, \"\" ), doc );\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n\n\treturn collection;\n}\n\nfunction remove( elem, selector, keepData ) {\n\tvar node,\n\t\tnodes = selector ? jQuery.filter( selector, elem ) : elem,\n\t\ti = 0;\n\n\tfor ( ; ( node = nodes[ i ] ) != null; i++ ) {\n\t\tif ( !keepData && node.nodeType === 1 ) {\n\t\t\tjQuery.cleanData( getAll( node ) );\n\t\t}\n\n\t\tif ( node.parentNode ) {\n\t\t\tif ( keepData && jQuery.contains( node.ownerDocument, node ) ) {\n\t\t\t\tsetGlobalEval( getAll( node, \"script\" ) );\n\t\t\t}\n\t\t\tnode.parentNode.removeChild( node );\n\t\t}\n\t}\n\n\treturn elem;\n}\n\njQuery.extend( {\n\thtmlPrefilter: function( html ) {\n\t\treturn html.replace( rxhtmlTag, \"<$1></$2>\" );\n\t},\n\n\tclone: function( elem, dataAndEvents, deepDataAndEvents ) {\n\t\tvar i, l, srcElements, destElements,\n\t\t\tclone = elem.cloneNode( true ),\n\t\t\tinPage = jQuery.contains( elem.ownerDocument, elem );\n\n\t\t// Fix IE cloning issues\n\t\tif ( !support.noCloneChecked && ( elem.nodeType === 1 || elem.nodeType === 11 ) &&\n\t\t\t\t!jQuery.isXMLDoc( elem ) ) {\n\n\t\t\t// We eschew Sizzle here for performance reasons: https://jsperf.com/getall-vs-sizzle/2\n\t\t\tdestElements = getAll( clone );\n\t\t\tsrcElements = getAll( elem );\n\n\t\t\tfor ( i = 0, l = srcElements.length; i < l; i++ ) {\n\t\t\t\tfixInput( srcElements[ i ], destElements[ i ] );\n\t\t\t}\n\t\t}\n\n\t\t// Copy the events from the original to the clone\n\t\tif ( dataAndEvents ) {\n\t\t\tif ( deepDataAndEvents ) {\n\t\t\t\tsrcElements = srcElements || getAll( elem );\n\t\t\t\tdestElements = destElements || getAll( clone );\n\n\t\t\t\tfor ( i = 0, l = srcElements.length; i < l; i++ ) {\n\t\t\t\t\tcloneCopyEvent( srcElements[ i ], destElements[ i ] );\n\t\t\t\t}\n\t\t\t} else {\n\t\t\t\tcloneCopyEvent( elem, clone );\n\t\t\t}\n\t\t}\n\n\t\t// Preserve script evaluation history\n\t\tdestElements = getAll( clone, \"script\" );\n\t\tif ( destElements.length > 0 ) {\n\t\t\tsetGlobalEval( destElements, !inPage && getAll( elem, \"script\" ) );\n\t\t}\n\n\t\t// Return the cloned set\n\t\treturn clone;\n\t},\n\n\tcleanData: function( elems ) {\n\t\tvar data, elem, type,\n\t\t\tspecial = jQuery.event.special,\n\t\t\ti = 0;\n\n\t\tfor ( ; ( elem = elems[ i ] ) !== undefined; i++ ) {\n\t\t\tif ( acceptData( elem ) ) {\n\t\t\t\tif ( ( data = elem[ dataPriv.expando ] ) ) {\n\t\t\t\t\tif ( data.events ) {\n\t\t\t\t\t\tfor ( type in data.events ) {\n\t\t\t\t\t\t\tif ( special[ type ] ) {\n\t\t\t\t\t\t\t\tjQuery.event.remove( elem, type );\n\n\t\t\t\t\t\t\t// This is a shortcut to avoid jQuery.event.remove's overhead\n\t\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\t\tjQuery.removeEvent( elem, type, data.handle );\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\n\t\t\t\t\t// Support: Chrome <=35 - 45+\n\t\t\t\t\t// Assign undefined instead of using delete, see Data#remove\n\t\t\t\t\telem[ dataPriv.expando ] = undefined;\n\t\t\t\t}\n\t\t\t\tif ( elem[ dataUser.expando ] ) {\n\n\t\t\t\t\t// Support: Chrome <=35 - 45+\n\t\t\t\t\t// Assign undefined instead of using delete, see Data#remove\n\t\t\t\t\telem[ dataUser.expando ] = undefined;\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n} );\n\njQuery.fn.extend( {\n\tdetach: function( selector ) {\n\t\treturn remove( this, selector, true );\n\t},\n\n\tremove: function( selector ) {\n\t\treturn remove( this, selector );\n\t},\n\n\ttext: function( value ) {\n\t\treturn access( this, function( value ) {\n\t\t\treturn value === undefined ?\n\t\t\t\tjQuery.text( this ) :\n\t\t\t\tthis.empty().each( function() {\n\t\t\t\t\tif ( this.nodeType === 1 || this.nodeType === 11 || this.nodeType === 9 ) {\n\t\t\t\t\t\tthis.textContent = value;\n\t\t\t\t\t}\n\t\t\t\t} );\n\t\t}, null, value, arguments.length );\n\t},\n\n\tappend: function() {\n\t\treturn domManip( this, arguments, function( elem ) {\n\t\t\tif ( this.nodeType === 1 || this.nodeType === 11 || this.nodeType === 9 ) {\n\t\t\t\tvar target = manipulationTarget( this, elem );\n\t\t\t\ttarget.appendChild( elem );\n\t\t\t}\n\t\t} );\n\t},\n\n\tprepend: function() {\n\t\treturn domManip( this, arguments, function( elem ) {\n\t\t\tif ( this.nodeType === 1 || this.nodeType === 11 || this.nodeType === 9 ) {\n\t\t\t\tvar target = manipulationTarget( this, elem );\n\t\t\t\ttarget.insertBefore( elem, target.firstChild );\n\t\t\t}\n\t\t} );\n\t},\n\n\tbefore: function() {\n\t\treturn domManip( this, arguments, function( elem ) {\n\t\t\tif ( this.parentNode ) {\n\t\t\t\tthis.parentNode.insertBefore( elem, this );\n\t\t\t}\n\t\t} );\n\t},\n\n\tafter: function() {\n\t\treturn domManip( this, arguments, function( elem ) {\n\t\t\tif ( this.parentNode ) {\n\t\t\t\tthis.parentNode.insertBefore( elem, this.nextSibling );\n\t\t\t}\n\t\t} );\n\t},\n\n\tempty: function() {\n\t\tvar elem,\n\t\t\ti = 0;\n\n\t\tfor ( ; ( elem = this[ i ] ) != null; i++ ) {\n\t\t\tif ( elem.nodeType === 1 ) {\n\n\t\t\t\t// Prevent memory leaks\n\t\t\t\tjQuery.cleanData( getAll( elem, false ) );\n\n\t\t\t\t// Remove any remaining nodes\n\t\t\t\telem.textContent = \"\";\n\t\t\t}\n\t\t}\n\n\t\treturn this;\n\t},\n\n\tclone: function( dataAndEvents, deepDataAndEvents ) {\n\t\tdataAndEvents = dataAndEvents == null ? false : dataAndEvents;\n\t\tdeepDataAndEvents = deepDataAndEvents == null ? dataAndEvents : deepDataAndEvents;\n\n\t\treturn this.map( function() {\n\t\t\treturn jQuery.clone( this, dataAndEvents, deepDataAndEvents );\n\t\t} );\n\t},\n\n\thtml: function( value ) {\n\t\treturn access( this, function( value ) {\n\t\t\tvar elem = this[ 0 ] || {},\n\t\t\t\ti = 0,\n\t\t\t\tl = this.length;\n\n\t\t\tif ( value === undefined && elem.nodeType === 1 ) {\n\t\t\t\treturn elem.innerHTML;\n\t\t\t}\n\n\t\t\t// See if we can take a shortcut and just use innerHTML\n\t\t\tif ( typeof value === \"string\" && !rnoInnerhtml.test( value ) &&\n\t\t\t\t!wrapMap[ ( rtagName.exec( value ) || [ \"\", \"\" ] )[ 1 ].toLowerCase() ] ) {\n\n\t\t\t\tvalue = jQuery.htmlPrefilter( value );\n\n\t\t\t\ttry {\n\t\t\t\t\tfor ( ; i < l; i++ ) {\n\t\t\t\t\t\telem = this[ i ] || {};\n\n\t\t\t\t\t\t// Remove element nodes and prevent memory leaks\n\t\t\t\t\t\tif ( elem.nodeType === 1 ) {\n\t\t\t\t\t\t\tjQuery.cleanData( getAll( elem, false ) );\n\t\t\t\t\t\t\telem.innerHTML = value;\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\n\t\t\t\t\telem = 0;\n\n\t\t\t\t// If using innerHTML throws an exception, use the fallback method\n\t\t\t\t} catch ( e ) {}\n\t\t\t}\n\n\t\t\tif ( elem ) {\n\t\t\t\tthis.empty().append( value );\n\t\t\t}\n\t\t}, null, value, arguments.length );\n\t},\n\n\treplaceWith: function() {\n\t\tvar ignored = [];\n\n\t\t// Make the changes, replacing each non-ignored context element with the new content\n\t\treturn domManip( this, arguments, function( elem ) {\n\t\t\tvar parent = this.parentNode;\n\n\t\t\tif ( jQuery.inArray( this, ignored ) < 0 ) {\n\t\t\t\tjQuery.cleanData( getAll( this ) );\n\t\t\t\tif ( parent ) {\n\t\t\t\t\tparent.replaceChild( elem, this );\n\t\t\t\t}\n\t\t\t}\n\n\t\t// Force callback invocation\n\t\t}, ignored );\n\t}\n} );\n\njQuery.each( {\n\tappendTo: \"append\",\n\tprependTo: \"prepend\",\n\tinsertBefore: \"before\",\n\tinsertAfter: \"after\",\n\treplaceAll: \"replaceWith\"\n}, function( name, original ) {\n\tjQuery.fn[ name ] = function( selector ) {\n\t\tvar elems,\n\t\t\tret = [],\n\t\t\tinsert = jQuery( selector ),\n\t\t\tlast = insert.length - 1,\n\t\t\ti = 0;\n\n\t\tfor ( ; i <= last; i++ ) {\n\t\t\telems = i === last ? this : this.clone( true );\n\t\t\tjQuery( insert[ i ] )[ original ]( elems );\n\n\t\t\t// Support: Android <=4.0 only, PhantomJS 1 only\n\t\t\t// .get() because push.apply(_, arraylike) throws on ancient WebKit\n\t\t\tpush.apply( ret, elems.get() );\n\t\t}\n\n\t\treturn this.pushStack( ret );\n\t};\n} );\nvar rmargin = ( /^margin/ );\n\nvar rnumnonpx = new RegExp( \"^(\" + pnum + \")(?!px)[a-z%]+$\", \"i\" );\n\nvar getStyles = function( elem ) {\n\n\t\t// Support: IE <=11 only, Firefox <=30 (#15098, #14150)\n\t\t// IE throws on elements created in popups\n\t\t// FF meanwhile throws on frame elements through \"defaultView.getComputedStyle\"\n\t\tvar view = elem.ownerDocument.defaultView;\n\n\t\tif ( !view || !view.opener ) {\n\t\t\tview = window;\n\t\t}\n\n\t\treturn view.getComputedStyle( elem );\n\t};\n\n\n\n( function() {\n\n\t// Executing both pixelPosition & boxSizingReliable tests require only one layout\n\t// so they're executed at the same time to save the second computation.\n\tfunction computeStyleTests() {\n\n\t\t// This is a singleton, we need to execute it only once\n\t\tif ( !div ) {\n\t\t\treturn;\n\t\t}\n\n\t\tdiv.style.cssText =\n\t\t\t\"box-sizing:border-box;\" +\n\t\t\t\"position:relative;display:block;\" +\n\t\t\t\"margin:auto;border:1px;padding:1px;\" +\n\t\t\t\"top:1%;width:50%\";\n\t\tdiv.innerHTML = \"\";\n\t\tdocumentElement.appendChild( container );\n\n\t\tvar divStyle = window.getComputedStyle( div );\n\t\tpixelPositionVal = divStyle.top !== \"1%\";\n\n\t\t// Support: Android 4.0 - 4.3 only, Firefox <=3 - 44\n\t\treliableMarginLeftVal = divStyle.marginLeft === \"2px\";\n\t\tboxSizingReliableVal = divStyle.width === \"4px\";\n\n\t\t// Support: Android 4.0 - 4.3 only\n\t\t// Some styles come back with percentage values, even though they shouldn't\n\t\tdiv.style.marginRight = \"50%\";\n\t\tpixelMarginRightVal = divStyle.marginRight === \"4px\";\n\n\t\tdocumentElement.removeChild( container );\n\n\t\t// Nullify the div so it wouldn't be stored in the memory and\n\t\t// it will also be a sign that checks already performed\n\t\tdiv = null;\n\t}\n\n\tvar pixelPositionVal, boxSizingReliableVal, pixelMarginRightVal, reliableMarginLeftVal,\n\t\tcontainer = document.createElement( \"div\" ),\n\t\tdiv = document.createElement( \"div\" );\n\n\t// Finish early in limited (non-browser) environments\n\tif ( !div.style ) {\n\t\treturn;\n\t}\n\n\t// Support: IE <=9 - 11 only\n\t// Style of cloned element affects source element cloned (#8908)\n\tdiv.style.backgroundClip = \"content-box\";\n\tdiv.cloneNode( true ).style.backgroundClip = \"\";\n\tsupport.clearCloneStyle = div.style.backgroundClip === \"content-box\";\n\n\tcontainer.style.cssText = \"border:0;width:8px;height:0;top:0;left:-9999px;\" +\n\t\t\"padding:0;margin-top:1px;position:absolute\";\n\tcontainer.appendChild( div );\n\n\tjQuery.extend( support, {\n\t\tpixelPosition: function() {\n\t\t\tcomputeStyleTests();\n\t\t\treturn pixelPositionVal;\n\t\t},\n\t\tboxSizingReliable: function() {\n\t\t\tcomputeStyleTests();\n\t\t\treturn boxSizingReliableVal;\n\t\t},\n\t\tpixelMarginRight: function() {\n\t\t\tcomputeStyleTests();\n\t\t\treturn pixelMarginRightVal;\n\t\t},\n\t\treliableMarginLeft: function() {\n\t\t\tcomputeStyleTests();\n\t\t\treturn reliableMarginLeftVal;\n\t\t}\n\t} );\n} )();\n\n\nfunction curCSS( elem, name, computed ) {\n\tvar width, minWidth, maxWidth, ret,\n\n\t\t// Support: Firefox 51+\n\t\t// Retrieving style before computed somehow\n\t\t// fixes an issue with getting wrong values\n\t\t// on detached elements\n\t\tstyle = elem.style;\n\n\tcomputed = computed || getStyles( elem );\n\n\t// getPropertyValue is needed for:\n\t// .css('filter') (IE 9 only, #12537)\n\t// .css('--customProperty) (#3144)\n\tif ( computed ) {\n\t\tret = computed.getPropertyValue( name ) || computed[ name ];\n\n\t\tif ( ret === \"\" && !jQuery.contains( elem.ownerDocument, elem ) ) {\n\t\t\tret = jQuery.style( elem, name );\n\t\t}\n\n\t\t// A tribute to the \"awesome hack by Dean Edwards\"\n\t\t// Android Browser returns percentage for some values,\n\t\t// but width seems to be reliably pixels.\n\t\t// This is against the CSSOM draft spec:\n\t\t// https://drafts.csswg.org/cssom/#resolved-values\n\t\tif ( !support.pixelMarginRight() && rnumnonpx.test( ret ) && rmargin.test( name ) ) {\n\n\t\t\t// Remember the original values\n\t\t\twidth = style.width;\n\t\t\tminWidth = style.minWidth;\n\t\t\tmaxWidth = style.maxWidth;\n\n\t\t\t// Put in the new values to get a computed value out\n\t\t\tstyle.minWidth = style.maxWidth = style.width = ret;\n\t\t\tret = computed.width;\n\n\t\t\t// Revert the changed values\n\t\t\tstyle.width = width;\n\t\t\tstyle.minWidth = minWidth;\n\t\t\tstyle.maxWidth = maxWidth;\n\t\t}\n\t}\n\n\treturn ret !== undefined ?\n\n\t\t// Support: IE <=9 - 11 only\n\t\t// IE returns zIndex value as an integer.\n\t\tret + \"\" :\n\t\tret;\n}\n\n\nfunction addGetHookIf( conditionFn, hookFn ) {\n\n\t// Define the hook, we'll check on the first run if it's really needed.\n\treturn {\n\t\tget: function() {\n\t\t\tif ( conditionFn() ) {\n\n\t\t\t\t// Hook not needed (or it's not possible to use it due\n\t\t\t\t// to missing dependency), remove it.\n\t\t\t\tdelete this.get;\n\t\t\t\treturn;\n\t\t\t}\n\n\t\t\t// Hook needed; redefine it so that the support test is not executed again.\n\t\t\treturn ( this.get = hookFn ).apply( this, arguments );\n\t\t}\n\t};\n}\n\n\nvar\n\n\t// Swappable if display is none or starts with table\n\t// except \"table\", \"table-cell\", or \"table-caption\"\n\t// See here for display values: https://developer.mozilla.org/en-US/docs/CSS/display\n\trdisplayswap = /^(none|table(?!-c[ea]).+)/,\n\trcustomProp = /^--/,\n\tcssShow = { position: \"absolute\", visibility: \"hidden\", display: \"block\" },\n\tcssNormalTransform = {\n\t\tletterSpacing: \"0\",\n\t\tfontWeight: \"400\"\n\t},\n\n\tcssPrefixes = [ \"Webkit\", \"Moz\", \"ms\" ],\n\temptyStyle = document.createElement( \"div\" ).style;\n\n// Return a css property mapped to a potentially vendor prefixed property\nfunction vendorPropName( name ) {\n\n\t// Shortcut for names that are not vendor prefixed\n\tif ( name in emptyStyle ) {\n\t\treturn name;\n\t}\n\n\t// Check for vendor prefixed names\n\tvar capName = name[ 0 ].toUpperCase() + name.slice( 1 ),\n\t\ti = cssPrefixes.length;\n\n\twhile ( i-- ) {\n\t\tname = cssPrefixes[ i ] + capName;\n\t\tif ( name in emptyStyle ) {\n\t\t\treturn name;\n\t\t}\n\t}\n}\n\n// Return a property mapped along what jQuery.cssProps suggests or to\n// a vendor prefixed property.\nfunction finalPropName( name ) {\n\tvar ret = jQuery.cssProps[ name ];\n\tif ( !ret ) {\n\t\tret = jQuery.cssProps[ name ] = vendorPropName( name ) || name;\n\t}\n\treturn ret;\n}\n\nfunction setPositiveNumber( elem, value, subtract ) {\n\n\t// Any relative (+/-) values have already been\n\t// normalized at this point\n\tvar matches = rcssNum.exec( value );\n\treturn matches ?\n\n\t\t// Guard against undefined \"subtract\", e.g., when used as in cssHooks\n\t\tMath.max( 0, matches[ 2 ] - ( subtract || 0 ) ) + ( matches[ 3 ] || \"px\" ) :\n\t\tvalue;\n}\n\nfunction augmentWidthOrHeight( elem, name, extra, isBorderBox, styles ) {\n\tvar i,\n\t\tval = 0;\n\n\t// If we already have the right measurement, avoid augmentation\n\tif ( extra === ( isBorderBox ? \"border\" : \"content\" ) ) {\n\t\ti = 4;\n\n\t// Otherwise initialize for horizontal or vertical properties\n\t} else {\n\t\ti = name === \"width\" ? 1 : 0;\n\t}\n\n\tfor ( ; i < 4; i += 2 ) {\n\n\t\t// Both box models exclude margin, so add it if we want it\n\t\tif ( extra === \"margin\" ) {\n\t\t\tval += jQuery.css( elem, extra + cssExpand[ i ], true, styles );\n\t\t}\n\n\t\tif ( isBorderBox ) {\n\n\t\t\t// border-box includes padding, so remove it if we want content\n\t\t\tif ( extra === \"content\" ) {\n\t\t\t\tval -= jQuery.css( elem, \"padding\" + cssExpand[ i ], true, styles );\n\t\t\t}\n\n\t\t\t// At this point, extra isn't border nor margin, so remove border\n\t\t\tif ( extra !== \"margin\" ) {\n\t\t\t\tval -= jQuery.css( elem, \"border\" + cssExpand[ i ] + \"Width\", true, styles );\n\t\t\t}\n\t\t} else {\n\n\t\t\t// At this point, extra isn't content, so add padding\n\t\t\tval += jQuery.css( elem, \"padding\" + cssExpand[ i ], true, styles );\n\n\t\t\t// At this point, extra isn't content nor padding, so add border\n\t\t\tif ( extra !== \"padding\" ) {\n\t\t\t\tval += jQuery.css( elem, \"border\" + cssExpand[ i ] + \"Width\", true, styles );\n\t\t\t}\n\t\t}\n\t}\n\n\treturn val;\n}\n\nfunction getWidthOrHeight( elem, name, extra ) {\n\n\t// Start with computed style\n\tvar valueIsBorderBox,\n\t\tstyles = getStyles( elem ),\n\t\tval = curCSS( elem, name, styles ),\n\t\tisBorderBox = jQuery.css( elem, \"boxSizing\", false, styles ) === \"border-box\";\n\n\t// Computed unit is not pixels. Stop here and return.\n\tif ( rnumnonpx.test( val ) ) {\n\t\treturn val;\n\t}\n\n\t// Check for style in case a browser which returns unreliable values\n\t// for getComputedStyle silently falls back to the reliable elem.style\n\tvalueIsBorderBox = isBorderBox &&\n\t\t( support.boxSizingReliable() || val === elem.style[ name ] );\n\n\t// Fall back to offsetWidth/Height when value is \"auto\"\n\t// This happens for inline elements with no explicit setting (gh-3571)\n\tif ( val === \"auto\" ) {\n\t\tval = elem[ \"offset\" + name[ 0 ].toUpperCase() + name.slice( 1 ) ];\n\t}\n\n\t// Normalize \"\", auto, and prepare for extra\n\tval = parseFloat( val ) || 0;\n\n\t// Use the active box-sizing model to add/subtract irrelevant styles\n\treturn ( val +\n\t\taugmentWidthOrHeight(\n\t\t\telem,\n\t\t\tname,\n\t\t\textra || ( isBorderBox ? \"border\" : \"content\" ),\n\t\t\tvalueIsBorderBox,\n\t\t\tstyles\n\t\t)\n\t) + \"px\";\n}\n\njQuery.extend( {\n\n\t// Add in style property hooks for overriding the default\n\t// behavior of getting and setting a style property\n\tcssHooks: {\n\t\topacity: {\n\t\t\tget: function( elem, computed ) {\n\t\t\t\tif ( computed ) {\n\n\t\t\t\t\t// We should always get a number back from opacity\n\t\t\t\t\tvar ret = curCSS( elem, \"opacity\" );\n\t\t\t\t\treturn ret === \"\" ? \"1\" : ret;\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t},\n\n\t// Don't automatically add \"px\" to these possibly-unitless properties\n\tcssNumber: {\n\t\t\"animationIterationCount\": true,\n\t\t\"columnCount\": true,\n\t\t\"fillOpacity\": true,\n\t\t\"flexGrow\": true,\n\t\t\"flexShrink\": true,\n\t\t\"fontWeight\": true,\n\t\t\"lineHeight\": true,\n\t\t\"opacity\": true,\n\t\t\"order\": true,\n\t\t\"orphans\": true,\n\t\t\"widows\": true,\n\t\t\"zIndex\": true,\n\t\t\"zoom\": true\n\t},\n\n\t// Add in properties whose names you wish to fix before\n\t// setting or getting the value\n\tcssProps: {\n\t\t\"float\": \"cssFloat\"\n\t},\n\n\t// Get and set the style property on a DOM Node\n\tstyle: function( elem, name, value, extra ) {\n\n\t\t// Don't set styles on text and comment nodes\n\t\tif ( !elem || elem.nodeType === 3 || elem.nodeType === 8 || !elem.style ) {\n\t\t\treturn;\n\t\t}\n\n\t\t// Make sure that we're working with the right name\n\t\tvar ret, type, hooks,\n\t\t\torigName = jQuery.camelCase( name ),\n\t\t\tisCustomProp = rcustomProp.test( name ),\n\t\t\tstyle = elem.style;\n\n\t\t// Make sure that we're working with the right name. We don't\n\t\t// want to query the value if it is a CSS custom property\n\t\t// since they are user-defined.\n\t\tif ( !isCustomProp ) {\n\t\t\tname = finalPropName( origName );\n\t\t}\n\n\t\t// Gets hook for the prefixed version, then unprefixed version\n\t\thooks = jQuery.cssHooks[ name ] || jQuery.cssHooks[ origName ];\n\n\t\t// Check if we're setting a value\n\t\tif ( value !== undefined ) {\n\t\t\ttype = typeof value;\n\n\t\t\t// Convert \"+=\" or \"-=\" to relative numbers (#7345)\n\t\t\tif ( type === \"string\" && ( ret = rcssNum.exec( value ) ) && ret[ 1 ] ) {\n\t\t\t\tvalue = adjustCSS( elem, name, ret );\n\n\t\t\t\t// Fixes bug #9237\n\t\t\t\ttype = \"number\";\n\t\t\t}\n\n\t\t\t// Make sure that null and NaN values aren't set (#7116)\n\t\t\tif ( value == null || value !== value ) {\n\t\t\t\treturn;\n\t\t\t}\n\n\t\t\t// If a number was passed in, add the unit (except for certain CSS properties)\n\t\t\tif ( type === \"number\" ) {\n\t\t\t\tvalue += ret && ret[ 3 ] || ( jQuery.cssNumber[ origName ] ? \"\" : \"px\" );\n\t\t\t}\n\n\t\t\t// background-* props affect original clone's values\n\t\t\tif ( !support.clearCloneStyle && value === \"\" && name.indexOf( \"background\" ) === 0 ) {\n\t\t\t\tstyle[ name ] = \"inherit\";\n\t\t\t}\n\n\t\t\t// If a hook was provided, use that value, otherwise just set the specified value\n\t\t\tif ( !hooks || !( \"set\" in hooks ) ||\n\t\t\t\t( value = hooks.set( elem, value, extra ) ) !== undefined ) {\n\n\t\t\t\tif ( isCustomProp ) {\n\t\t\t\t\tstyle.setProperty( name, value );\n\t\t\t\t} else {\n\t\t\t\t\tstyle[ name ] = value;\n\t\t\t\t}\n\t\t\t}\n\n\t\t} else {\n\n\t\t\t// If a hook was provided get the non-computed value from there\n\t\t\tif ( hooks && \"get\" in hooks &&\n\t\t\t\t( ret = hooks.get( elem, false, extra ) ) !== undefined ) {\n\n\t\t\t\treturn ret;\n\t\t\t}\n\n\t\t\t// Otherwise just get the value from the style object\n\t\t\treturn style[ name ];\n\t\t}\n\t},\n\n\tcss: function( elem, name, extra, styles ) {\n\t\tvar val, num, hooks,\n\t\t\torigName = jQuery.camelCase( name ),\n\t\t\tisCustomProp = rcustomProp.test( name );\n\n\t\t// Make sure that we're working with the right name. We don't\n\t\t// want to modify the value if it is a CSS custom property\n\t\t// since they are user-defined.\n\t\tif ( !isCustomProp ) {\n\t\t\tname = finalPropName( origName );\n\t\t}\n\n\t\t// Try prefixed name followed by the unprefixed name\n\t\thooks = jQuery.cssHooks[ name ] || jQuery.cssHooks[ origName ];\n\n\t\t// If a hook was provided get the computed value from there\n\t\tif ( hooks && \"get\" in hooks ) {\n\t\t\tval = hooks.get( elem, true, extra );\n\t\t}\n\n\t\t// Otherwise, if a way to get the computed value exists, use that\n\t\tif ( val === undefined ) {\n\t\t\tval = curCSS( elem, name, styles );\n\t\t}\n\n\t\t// Convert \"normal\" to computed value\n\t\tif ( val === \"normal\" && name in cssNormalTransform ) {\n\t\t\tval = cssNormalTransform[ name ];\n\t\t}\n\n\t\t// Make numeric if forced or a qualifier was provided and val looks numeric\n\t\tif ( extra === \"\" || extra ) {\n\t\t\tnum = parseFloat( val );\n\t\t\treturn extra === true || isFinite( num ) ? num || 0 : val;\n\t\t}\n\n\t\treturn val;\n\t}\n} );\n\njQuery.each( [ \"height\", \"width\" ], function( i, name ) {\n\tjQuery.cssHooks[ name ] = {\n\t\tget: function( elem, computed, extra ) {\n\t\t\tif ( computed ) {\n\n\t\t\t\t// Certain elements can have dimension info if we invisibly show them\n\t\t\t\t// but it must have a current display style that would benefit\n\t\t\t\treturn rdisplayswap.test( jQuery.css( elem, \"display\" ) ) &&\n\n\t\t\t\t\t// Support: Safari 8+\n\t\t\t\t\t// Table columns in Safari have non-zero offsetWidth & zero\n\t\t\t\t\t// getBoundingClientRect().width unless display is changed.\n\t\t\t\t\t// Support: IE <=11 only\n\t\t\t\t\t// Running getBoundingClientRect on a disconnected node\n\t\t\t\t\t// in IE throws an error.\n\t\t\t\t\t( !elem.getClientRects().length || !elem.getBoundingClientRect().width ) ?\n\t\t\t\t\t\tswap( elem, cssShow, function() {\n\t\t\t\t\t\t\treturn getWidthOrHeight( elem, name, extra );\n\t\t\t\t\t\t} ) :\n\t\t\t\t\t\tgetWidthOrHeight( elem, name, extra );\n\t\t\t}\n\t\t},\n\n\t\tset: function( elem, value, extra ) {\n\t\t\tvar matches,\n\t\t\t\tstyles = extra && getStyles( elem ),\n\t\t\t\tsubtract = extra && augmentWidthOrHeight(\n\t\t\t\t\telem,\n\t\t\t\t\tname,\n\t\t\t\t\textra,\n\t\t\t\t\tjQuery.css( elem, \"boxSizing\", false, styles ) === \"border-box\",\n\t\t\t\t\tstyles\n\t\t\t\t);\n\n\t\t\t// Convert to pixels if value adjustment is needed\n\t\t\tif ( subtract && ( matches = rcssNum.exec( value ) ) &&\n\t\t\t\t( matches[ 3 ] || \"px\" ) !== \"px\" ) {\n\n\t\t\t\telem.style[ name ] = value;\n\t\t\t\tvalue = jQuery.css( elem, name );\n\t\t\t}\n\n\t\t\treturn setPositiveNumber( elem, value, subtract );\n\t\t}\n\t};\n} );\n\njQuery.cssHooks.marginLeft = addGetHookIf( support.reliableMarginLeft,\n\tfunction( elem, computed ) {\n\t\tif ( computed ) {\n\t\t\treturn ( parseFloat( curCSS( elem, \"marginLeft\" ) ) ||\n\t\t\t\telem.getBoundingClientRect().left -\n\t\t\t\t\tswap( elem, { marginLeft: 0 }, function() {\n\t\t\t\t\t\treturn elem.getBoundingClientRect().left;\n\t\t\t\t\t} )\n\t\t\t\t) + \"px\";\n\t\t}\n\t}\n);\n\n// These hooks are used by animate to expand properties\njQuery.each( {\n\tmargin: \"\",\n\tpadding: \"\",\n\tborder: \"Width\"\n}, function( prefix, suffix ) {\n\tjQuery.cssHooks[ prefix + suffix ] = {\n\t\texpand: function( value ) {\n\t\t\tvar i = 0,\n\t\t\t\texpanded = {},\n\n\t\t\t\t// Assumes a single number if not a string\n\t\t\t\tparts = typeof value === \"string\" ? value.split( \" \" ) : [ value ];\n\n\t\t\tfor ( ; i < 4; i++ ) {\n\t\t\t\texpanded[ prefix + cssExpand[ i ] + suffix ] =\n\t\t\t\t\tparts[ i ] || parts[ i - 2 ] || parts[ 0 ];\n\t\t\t}\n\n\t\t\treturn expanded;\n\t\t}\n\t};\n\n\tif ( !rmargin.test( prefix ) ) {\n\t\tjQuery.cssHooks[ prefix + suffix ].set = setPositiveNumber;\n\t}\n} );\n\njQuery.fn.extend( {\n\tcss: function( name, value ) {\n\t\treturn access( this, function( elem, name, value ) {\n\t\t\tvar styles, len,\n\t\t\t\tmap = {},\n\t\t\t\ti = 0;\n\n\t\t\tif ( Array.isArray( name ) ) {\n\t\t\t\tstyles = getStyles( elem );\n\t\t\t\tlen = name.length;\n\n\t\t\t\tfor ( ; i < len; i++ ) {\n\t\t\t\t\tmap[ name[ i ] ] = jQuery.css( elem, name[ i ], false, styles );\n\t\t\t\t}\n\n\t\t\t\treturn map;\n\t\t\t}\n\n\t\t\treturn value !== undefined ?\n\t\t\t\tjQuery.style( elem, name, value ) :\n\t\t\t\tjQuery.css( elem, name );\n\t\t}, name, value, arguments.length > 1 );\n\t}\n} );\n\n\nfunction Tween( elem, options, prop, end, easing ) {\n\treturn new Tween.prototype.init( elem, options, prop, end, easing );\n}\njQuery.Tween = Tween;\n\nTween.prototype = {\n\tconstructor: Tween,\n\tinit: function( elem, options, prop, end, easing, unit ) {\n\t\tthis.elem = elem;\n\t\tthis.prop = prop;\n\t\tthis.easing = easing || jQuery.easing._default;\n\t\tthis.options = options;\n\t\tthis.start = this.now = this.cur();\n\t\tthis.end = end;\n\t\tthis.unit = unit || ( jQuery.cssNumber[ prop ] ? \"\" : \"px\" );\n\t},\n\tcur: function() {\n\t\tvar hooks = Tween.propHooks[ this.prop ];\n\n\t\treturn hooks && hooks.get ?\n\t\t\thooks.get( this ) :\n\t\t\tTween.propHooks._default.get( this );\n\t},\n\trun: function( percent ) {\n\t\tvar eased,\n\t\t\thooks = Tween.propHooks[ this.prop ];\n\n\t\tif ( this.options.duration ) {\n\t\t\tthis.pos = eased = jQuery.easing[ this.easing ](\n\t\t\t\tpercent, this.options.duration * percent, 0, 1, this.options.duration\n\t\t\t);\n\t\t} else {\n\t\t\tthis.pos = eased = percent;\n\t\t}\n\t\tthis.now = ( this.end - this.start ) * eased + this.start;\n\n\t\tif ( this.options.step ) {\n\t\t\tthis.options.step.call( this.elem, this.now, this );\n\t\t}\n\n\t\tif ( hooks && hooks.set ) {\n\t\t\thooks.set( this );\n\t\t} else {\n\t\t\tTween.propHooks._default.set( this );\n\t\t}\n\t\treturn this;\n\t}\n};\n\nTween.prototype.init.prototype = Tween.prototype;\n\nTween.propHooks = {\n\t_default: {\n\t\tget: function( tween ) {\n\t\t\tvar result;\n\n\t\t\t// Use a property on the element directly when it is not a DOM element,\n\t\t\t// or when there is no matching style property that exists.\n\t\t\tif ( tween.elem.nodeType !== 1 ||\n\t\t\t\ttween.elem[ tween.prop ] != null && tween.elem.style[ tween.prop ] == null ) {\n\t\t\t\treturn tween.elem[ tween.prop ];\n\t\t\t}\n\n\t\t\t// Passing an empty string as a 3rd parameter to .css will automatically\n\t\t\t// attempt a parseFloat and fallback to a string if the parse fails.\n\t\t\t// Simple values such as \"10px\" are parsed to Float;\n\t\t\t// complex values such as \"rotate(1rad)\" are returned as-is.\n\t\t\tresult = jQuery.css( tween.elem, tween.prop, \"\" );\n\n\t\t\t// Empty strings, null, undefined and \"auto\" are converted to 0.\n\t\t\treturn !result || result === \"auto\" ? 0 : result;\n\t\t},\n\t\tset: function( tween ) {\n\n\t\t\t// Use step hook for back compat.\n\t\t\t// Use cssHook if its there.\n\t\t\t// Use .style if available and use plain properties where available.\n\t\t\tif ( jQuery.fx.step[ tween.prop ] ) {\n\t\t\t\tjQuery.fx.step[ tween.prop ]( tween );\n\t\t\t} else if ( tween.elem.nodeType === 1 &&\n\t\t\t\t( tween.elem.style[ jQuery.cssProps[ tween.prop ] ] != null ||\n\t\t\t\t\tjQuery.cssHooks[ tween.prop ] ) ) {\n\t\t\t\tjQuery.style( tween.elem, tween.prop, tween.now + tween.unit );\n\t\t\t} else {\n\t\t\t\ttween.elem[ tween.prop ] = tween.now;\n\t\t\t}\n\t\t}\n\t}\n};\n\n// Support: IE <=9 only\n// Panic based approach to setting things on disconnected nodes\nTween.propHooks.scrollTop = Tween.propHooks.scrollLeft = {\n\tset: function( tween ) {\n\t\tif ( tween.elem.nodeType && tween.elem.parentNode ) {\n\t\t\ttween.elem[ tween.prop ] = tween.now;\n\t\t}\n\t}\n};\n\njQuery.easing = {\n\tlinear: function( p ) {\n\t\treturn p;\n\t},\n\tswing: function( p ) {\n\t\treturn 0.5 - Math.cos( p * Math.PI ) / 2;\n\t},\n\t_default: \"swing\"\n};\n\njQuery.fx = Tween.prototype.init;\n\n// Back compat <1.8 extension point\njQuery.fx.step = {};\n\n\n\n\nvar\n\tfxNow, inProgress,\n\trfxtypes = /^(?:toggle|show|hide)$/,\n\trrun = /queueHooks$/;\n\nfunction schedule() {\n\tif ( inProgress ) {\n\t\tif ( document.hidden === false && window.requestAnimationFrame ) {\n\t\t\twindow.requestAnimationFrame( schedule );\n\t\t} else {\n\t\t\twindow.setTimeout( schedule, jQuery.fx.interval );\n\t\t}\n\n\t\tjQuery.fx.tick();\n\t}\n}\n\n// Animations created synchronously will run synchronously\nfunction createFxNow() {\n\twindow.setTimeout( function() {\n\t\tfxNow = undefined;\n\t} );\n\treturn ( fxNow = jQuery.now() );\n}\n\n// Generate parameters to create a standard animation\nfunction genFx( type, includeWidth ) {\n\tvar which,\n\t\ti = 0,\n\t\tattrs = { height: type };\n\n\t// If we include width, step value is 1 to do all cssExpand values,\n\t// otherwise step value is 2 to skip over Left and Right\n\tincludeWidth = includeWidth ? 1 : 0;\n\tfor ( ; i < 4; i += 2 - includeWidth ) {\n\t\twhich = cssExpand[ i ];\n\t\tattrs[ \"margin\" + which ] = attrs[ \"padding\" + which ] = type;\n\t}\n\n\tif ( includeWidth ) {\n\t\tattrs.opacity = attrs.width = type;\n\t}\n\n\treturn attrs;\n}\n\nfunction createTween( value, prop, animation ) {\n\tvar tween,\n\t\tcollection = ( Animation.tweeners[ prop ] || [] ).concat( Animation.tweeners[ \"*\" ] ),\n\t\tindex = 0,\n\t\tlength = collection.length;\n\tfor ( ; index < length; index++ ) {\n\t\tif ( ( tween = collection[ index ].call( animation, prop, value ) ) ) {\n\n\t\t\t// We're done with this property\n\t\t\treturn tween;\n\t\t}\n\t}\n}\n\nfunction defaultPrefilter( elem, props, opts ) {\n\tvar prop, value, toggle, hooks, oldfire, propTween, restoreDisplay, display,\n\t\tisBox = \"width\" in props || \"height\" in props,\n\t\tanim = this,\n\t\torig = {},\n\t\tstyle = elem.style,\n\t\thidden = elem.nodeType && isHiddenWithinTree( elem ),\n\t\tdataShow = dataPriv.get( elem, \"fxshow\" );\n\n\t// Queue-skipping animations hijack the fx hooks\n\tif ( !opts.queue ) {\n\t\thooks = jQuery._queueHooks( elem, \"fx\" );\n\t\tif ( hooks.unqueued == null ) {\n\t\t\thooks.unqueued = 0;\n\t\t\toldfire = hooks.empty.fire;\n\t\t\thooks.empty.fire = function() {\n\t\t\t\tif ( !hooks.unqueued ) {\n\t\t\t\t\toldfire();\n\t\t\t\t}\n\t\t\t};\n\t\t}\n\t\thooks.unqueued++;\n\n\t\tanim.always( function() {\n\n\t\t\t// Ensure the complete handler is called before this completes\n\t\t\tanim.always( function() {\n\t\t\t\thooks.unqueued--;\n\t\t\t\tif ( !jQuery.queue( elem, \"fx\" ).length ) {\n\t\t\t\t\thooks.empty.fire();\n\t\t\t\t}\n\t\t\t} );\n\t\t} );\n\t}\n\n\t// Detect show/hide animations\n\tfor ( prop in props ) {\n\t\tvalue = props[ prop ];\n\t\tif ( rfxtypes.test( value ) ) {\n\t\t\tdelete props[ prop ];\n\t\t\ttoggle = toggle || value === \"toggle\";\n\t\t\tif ( value === ( hidden ? \"hide\" : \"show\" ) ) {\n\n\t\t\t\t// Pretend to be hidden if this is a \"show\" and\n\t\t\t\t// there is still data from a stopped show/hide\n\t\t\t\tif ( value === \"show\" && dataShow && dataShow[ prop ] !== undefined ) {\n\t\t\t\t\thidden = true;\n\n\t\t\t\t// Ignore all other no-op show/hide data\n\t\t\t\t} else {\n\t\t\t\t\tcontinue;\n\t\t\t\t}\n\t\t\t}\n\t\t\torig[ prop ] = dataShow && dataShow[ prop ] || jQuery.style( elem, prop );\n\t\t}\n\t}\n\n\t// Bail out if this is a no-op like .hide().hide()\n\tpropTween = !jQuery.isEmptyObject( props );\n\tif ( !propTween && jQuery.isEmptyObject( orig ) ) {\n\t\treturn;\n\t}\n\n\t// Restrict \"overflow\" and \"display\" styles during box animations\n\tif ( isBox && elem.nodeType === 1 ) {\n\n\t\t// Support: IE <=9 - 11, Edge 12 - 13\n\t\t// Record all 3 overflow attributes because IE does not infer the shorthand\n\t\t// from identically-valued overflowX and overflowY\n\t\topts.overflow = [ style.overflow, style.overflowX, style.overflowY ];\n\n\t\t// Identify a display type, preferring old show/hide data over the CSS cascade\n\t\trestoreDisplay = dataShow && dataShow.display;\n\t\tif ( restoreDisplay == null ) {\n\t\t\trestoreDisplay = dataPriv.get( elem, \"display\" );\n\t\t}\n\t\tdisplay = jQuery.css( elem, \"display\" );\n\t\tif ( display === \"none\" ) {\n\t\t\tif ( restoreDisplay ) {\n\t\t\t\tdisplay = restoreDisplay;\n\t\t\t} else {\n\n\t\t\t\t// Get nonempty value(s) by temporarily forcing visibility\n\t\t\t\tshowHide( [ elem ], true );\n\t\t\t\trestoreDisplay = elem.style.display || restoreDisplay;\n\t\t\t\tdisplay = jQuery.css( elem, \"display\" );\n\t\t\t\tshowHide( [ elem ] );\n\t\t\t}\n\t\t}\n\n\t\t// Animate inline elements as inline-block\n\t\tif ( display === \"inline\" || display === \"inline-block\" && restoreDisplay != null ) {\n\t\t\tif ( jQuery.css( elem, \"float\" ) === \"none\" ) {\n\n\t\t\t\t// Restore the original display value at the end of pure show/hide animations\n\t\t\t\tif ( !propTween ) {\n\t\t\t\t\tanim.done( function() {\n\t\t\t\t\t\tstyle.display = restoreDisplay;\n\t\t\t\t\t} );\n\t\t\t\t\tif ( restoreDisplay == null ) {\n\t\t\t\t\t\tdisplay = style.display;\n\t\t\t\t\t\trestoreDisplay = display === \"none\" ? \"\" : display;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t\tstyle.display = \"inline-block\";\n\t\t\t}\n\t\t}\n\t}\n\n\tif ( opts.overflow ) {\n\t\tstyle.overflow = \"hidden\";\n\t\tanim.always( function() {\n\t\t\tstyle.overflow = opts.overflow[ 0 ];\n\t\t\tstyle.overflowX = opts.overflow[ 1 ];\n\t\t\tstyle.overflowY = opts.overflow[ 2 ];\n\t\t} );\n\t}\n\n\t// Implement show/hide animations\n\tpropTween = false;\n\tfor ( prop in orig ) {\n\n\t\t// General show/hide setup for this element animation\n\t\tif ( !propTween ) {\n\t\t\tif ( dataShow ) {\n\t\t\t\tif ( \"hidden\" in dataShow ) {\n\t\t\t\t\thidden = dataShow.hidden;\n\t\t\t\t}\n\t\t\t} else {\n\t\t\t\tdataShow = dataPriv.access( elem, \"fxshow\", { display: restoreDisplay } );\n\t\t\t}\n\n\t\t\t// Store hidden/visible for toggle so `.stop().toggle()` \"reverses\"\n\t\t\tif ( toggle ) {\n\t\t\t\tdataShow.hidden = !hidden;\n\t\t\t}\n\n\t\t\t// Show elements before animating them\n\t\t\tif ( hidden ) {\n\t\t\t\tshowHide( [ elem ], true );\n\t\t\t}\n\n\t\t\t/* eslint-disable no-loop-func */\n\n\t\t\tanim.done( function() {\n\n\t\t\t/* eslint-enable no-loop-func */\n\n\t\t\t\t// The final step of a \"hide\" animation is actually hiding the element\n\t\t\t\tif ( !hidden ) {\n\t\t\t\t\tshowHide( [ elem ] );\n\t\t\t\t}\n\t\t\t\tdataPriv.remove( elem, \"fxshow\" );\n\t\t\t\tfor ( prop in orig ) {\n\t\t\t\t\tjQuery.style( elem, prop, orig[ prop ] );\n\t\t\t\t}\n\t\t\t} );\n\t\t}\n\n\t\t// Per-property setup\n\t\tpropTween = createTween( hidden ? dataShow[ prop ] : 0, prop, anim );\n\t\tif ( !( prop in dataShow ) ) {\n\t\t\tdataShow[ prop ] = propTween.start;\n\t\t\tif ( hidden ) {\n\t\t\t\tpropTween.end = propTween.start;\n\t\t\t\tpropTween.start = 0;\n\t\t\t}\n\t\t}\n\t}\n}\n\nfunction propFilter( props, specialEasing ) {\n\tvar index, name, easing, value, hooks;\n\n\t// camelCase, specialEasing and expand cssHook pass\n\tfor ( index in props ) {\n\t\tname = jQuery.camelCase( index );\n\t\teasing = specialEasing[ name ];\n\t\tvalue = props[ index ];\n\t\tif ( Array.isArray( value ) ) {\n\t\t\teasing = value[ 1 ];\n\t\t\tvalue = props[ index ] = value[ 0 ];\n\t\t}\n\n\t\tif ( index !== name ) {\n\t\t\tprops[ name ] = value;\n\t\t\tdelete props[ index ];\n\t\t}\n\n\t\thooks = jQuery.cssHooks[ name ];\n\t\tif ( hooks && \"expand\" in hooks ) {\n\t\t\tvalue = hooks.expand( value );\n\t\t\tdelete props[ name ];\n\n\t\t\t// Not quite $.extend, this won't overwrite existing keys.\n\t\t\t// Reusing 'index' because we have the correct \"name\"\n\t\t\tfor ( index in value ) {\n\t\t\t\tif ( !( index in props ) ) {\n\t\t\t\t\tprops[ index ] = value[ index ];\n\t\t\t\t\tspecialEasing[ index ] = easing;\n\t\t\t\t}\n\t\t\t}\n\t\t} else {\n\t\t\tspecialEasing[ name ] = easing;\n\t\t}\n\t}\n}\n\nfunction Animation( elem, properties, options ) {\n\tvar result,\n\t\tstopped,\n\t\tindex = 0,\n\t\tlength = Animation.prefilters.length,\n\t\tdeferred = jQuery.Deferred().always( function() {\n\n\t\t\t// Don't match elem in the :animated selector\n\t\t\tdelete tick.elem;\n\t\t} ),\n\t\ttick = function() {\n\t\t\tif ( stopped ) {\n\t\t\t\treturn false;\n\t\t\t}\n\t\t\tvar currentTime = fxNow || createFxNow(),\n\t\t\t\tremaining = Math.max( 0, animation.startTime + animation.duration - currentTime ),\n\n\t\t\t\t// Support: Android 2.3 only\n\t\t\t\t// Archaic crash bug won't allow us to use `1 - ( 0.5 || 0 )` (#12497)\n\t\t\t\ttemp = remaining / animation.duration || 0,\n\t\t\t\tpercent = 1 - temp,\n\t\t\t\tindex = 0,\n\t\t\t\tlength = animation.tweens.length;\n\n\t\t\tfor ( ; index < length; index++ ) {\n\t\t\t\tanimation.tweens[ index ].run( percent );\n\t\t\t}\n\n\t\t\tdeferred.notifyWith( elem, [ animation, percent, remaining ] );\n\n\t\t\t// If there's more to do, yield\n\t\t\tif ( percent < 1 && length ) {\n\t\t\t\treturn remaining;\n\t\t\t}\n\n\t\t\t// If this was an empty animation, synthesize a final progress notification\n\t\t\tif ( !length ) {\n\t\t\t\tdeferred.notifyWith( elem, [ animation, 1, 0 ] );\n\t\t\t}\n\n\t\t\t// Resolve the animation and report its conclusion\n\t\t\tdeferred.resolveWith( elem, [ animation ] );\n\t\t\treturn false;\n\t\t},\n\t\tanimation = deferred.promise( {\n\t\t\telem: elem,\n\t\t\tprops: jQuery.extend( {}, properties ),\n\t\t\topts: jQuery.extend( true, {\n\t\t\t\tspecialEasing: {},\n\t\t\t\teasing: jQuery.easing._default\n\t\t\t}, options ),\n\t\t\toriginalProperties: properties,\n\t\t\toriginalOptions: options,\n\t\t\tstartTime: fxNow || createFxNow(),\n\t\t\tduration: options.duration,\n\t\t\ttweens: [],\n\t\t\tcreateTween: function( prop, end ) {\n\t\t\t\tvar tween = jQuery.Tween( elem, animation.opts, prop, end,\n\t\t\t\t\t\tanimation.opts.specialEasing[ prop ] || animation.opts.easing );\n\t\t\t\tanimation.tweens.push( tween );\n\t\t\t\treturn tween;\n\t\t\t},\n\t\t\tstop: function( gotoEnd ) {\n\t\t\t\tvar index = 0,\n\n\t\t\t\t\t// If we are going to the end, we want to run all the tweens\n\t\t\t\t\t// otherwise we skip this part\n\t\t\t\t\tlength = gotoEnd ? animation.tweens.length : 0;\n\t\t\t\tif ( stopped ) {\n\t\t\t\t\treturn this;\n\t\t\t\t}\n\t\t\t\tstopped = true;\n\t\t\t\tfor ( ; index < length; index++ ) {\n\t\t\t\t\tanimation.tweens[ index ].run( 1 );\n\t\t\t\t}\n\n\t\t\t\t// Resolve when we played the last frame; otherwise, reject\n\t\t\t\tif ( gotoEnd ) {\n\t\t\t\t\tdeferred.notifyWith( elem, [ animation, 1, 0 ] );\n\t\t\t\t\tdeferred.resolveWith( elem, [ animation, gotoEnd ] );\n\t\t\t\t} else {\n\t\t\t\t\tdeferred.rejectWith( elem, [ animation, gotoEnd ] );\n\t\t\t\t}\n\t\t\t\treturn this;\n\t\t\t}\n\t\t} ),\n\t\tprops = animation.props;\n\n\tpropFilter( props, animation.opts.specialEasing );\n\n\tfor ( ; index < length; index++ ) {\n\t\tresult = Animation.prefilters[ index ].call( animation, elem, props, animation.opts );\n\t\tif ( result ) {\n\t\t\tif ( jQuery.isFunction( result.stop ) ) {\n\t\t\t\tjQuery._queueHooks( animation.elem, animation.opts.queue ).stop =\n\t\t\t\t\tjQuery.proxy( result.stop, result );\n\t\t\t}\n\t\t\treturn result;\n\t\t}\n\t}\n\n\tjQuery.map( props, createTween, animation );\n\n\tif ( jQuery.isFunction( animation.opts.start ) ) {\n\t\tanimation.opts.start.call( elem, animation );\n\t}\n\n\t// Attach callbacks from options\n\tanimation\n\t\t.progress( animation.opts.progress )\n\t\t.done( animation.opts.done, animation.opts.complete )\n\t\t.fail( animation.opts.fail )\n\t\t.always( animation.opts.always );\n\n\tjQuery.fx.timer(\n\t\tjQuery.extend( tick, {\n\t\t\telem: elem,\n\t\t\tanim: animation,\n\t\t\tqueue: animation.opts.queue\n\t\t} )\n\t);\n\n\treturn animation;\n}\n\njQuery.Animation = jQuery.extend( Animation, {\n\n\ttweeners: {\n\t\t\"*\": [ function( prop, value ) {\n\t\t\tvar tween = this.createTween( prop, value );\n\t\t\tadjustCSS( tween.elem, prop, rcssNum.exec( value ), tween );\n\t\t\treturn tween;\n\t\t} ]\n\t},\n\n\ttweener: function( props, callback ) {\n\t\tif ( jQuery.isFunction( props ) ) {\n\t\t\tcallback = props;\n\t\t\tprops = [ \"*\" ];\n\t\t} else {\n\t\t\tprops = props.match( rnothtmlwhite );\n\t\t}\n\n\t\tvar prop,\n\t\t\tindex = 0,\n\t\t\tlength = props.length;\n\n\t\tfor ( ; index < length; index++ ) {\n\t\t\tprop = props[ index ];\n\t\t\tAnimation.tweeners[ prop ] = Animation.tweeners[ prop ] || [];\n\t\t\tAnimation.tweeners[ prop ].unshift( callback );\n\t\t}\n\t},\n\n\tprefilters: [ defaultPrefilter ],\n\n\tprefilter: function( callback, prepend ) {\n\t\tif ( prepend ) {\n\t\t\tAnimation.prefilters.unshift( callback );\n\t\t} else {\n\t\t\tAnimation.prefilters.push( callback );\n\t\t}\n\t}\n} );\n\njQuery.speed = function( speed, easing, fn ) {\n\tvar opt = speed && typeof speed === \"object\" ? jQuery.extend( {}, speed ) : {\n\t\tcomplete: fn || !fn && easing ||\n\t\t\tjQuery.isFunction( speed ) && speed,\n\t\tduration: speed,\n\t\teasing: fn && easing || easing && !jQuery.isFunction( easing ) && easing\n\t};\n\n\t// Go to the end state if fx are off\n\tif ( jQuery.fx.off ) {\n\t\topt.duration = 0;\n\n\t} else {\n\t\tif ( typeof opt.duration !== \"number\" ) {\n\t\t\tif ( opt.duration in jQuery.fx.speeds ) {\n\t\t\t\topt.duration = jQuery.fx.speeds[ opt.duration ];\n\n\t\t\t} else {\n\t\t\t\topt.duration = jQuery.fx.speeds._default;\n\t\t\t}\n\t\t}\n\t}\n\n\t// Normalize opt.queue - true/undefined/null -> \"fx\"\n\tif ( opt.queue == null || opt.queue === true ) {\n\t\topt.queue = \"fx\";\n\t}\n\n\t// Queueing\n\topt.old = opt.complete;\n\n\topt.complete = function() {\n\t\tif ( jQuery.isFunction( opt.old ) ) {\n\t\t\topt.old.call( this );\n\t\t}\n\n\t\tif ( opt.queue ) {\n\t\t\tjQuery.dequeue( this, opt.queue );\n\t\t}\n\t};\n\n\treturn opt;\n};\n\njQuery.fn.extend( {\n\tfadeTo: function( speed, to, easing, callback ) {\n\n\t\t// Show any hidden elements after setting opacity to 0\n\t\treturn this.filter( isHiddenWithinTree ).css( \"opacity\", 0 ).show()\n\n\t\t\t// Animate to the value specified\n\t\t\t.end().animate( { opacity: to }, speed, easing, callback );\n\t},\n\tanimate: function( prop, speed, easing, callback ) {\n\t\tvar empty = jQuery.isEmptyObject( prop ),\n\t\t\toptall = jQuery.speed( speed, easing, callback ),\n\t\t\tdoAnimation = function() {\n\n\t\t\t\t// Operate on a copy of prop so per-property easing won't be lost\n\t\t\t\tvar anim = Animation( this, jQuery.extend( {}, prop ), optall );\n\n\t\t\t\t// Empty animations, or finishing resolves immediately\n\t\t\t\tif ( empty || dataPriv.get( this, \"finish\" ) ) {\n\t\t\t\t\tanim.stop( true );\n\t\t\t\t}\n\t\t\t};\n\t\t\tdoAnimation.finish = doAnimation;\n\n\t\treturn empty || optall.queue === false ?\n\t\t\tthis.each( doAnimation ) :\n\t\t\tthis.queue( optall.queue, doAnimation );\n\t},\n\tstop: function( type, clearQueue, gotoEnd ) {\n\t\tvar stopQueue = function( hooks ) {\n\t\t\tvar stop = hooks.stop;\n\t\t\tdelete hooks.stop;\n\t\t\tstop( gotoEnd );\n\t\t};\n\n\t\tif ( typeof type !== \"string\" ) {\n\t\t\tgotoEnd = clearQueue;\n\t\t\tclearQueue = type;\n\t\t\ttype = undefined;\n\t\t}\n\t\tif ( clearQueue && type !== false ) {\n\t\t\tthis.queue( type || \"fx\", [] );\n\t\t}\n\n\t\treturn this.each( function() {\n\t\t\tvar dequeue = true,\n\t\t\t\tindex = type != null && type + \"queueHooks\",\n\t\t\t\ttimers = jQuery.timers,\n\t\t\t\tdata = dataPriv.get( this );\n\n\t\t\tif ( index ) {\n\t\t\t\tif ( data[ index ] && data[ index ].stop ) {\n\t\t\t\t\tstopQueue( data[ index ] );\n\t\t\t\t}\n\t\t\t} else {\n\t\t\t\tfor ( index in data ) {\n\t\t\t\t\tif ( data[ index ] && data[ index ].stop && rrun.test( index ) ) {\n\t\t\t\t\t\tstopQueue( data[ index ] );\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tfor ( index = timers.length; index--; ) {\n\t\t\t\tif ( timers[ index ].elem === this &&\n\t\t\t\t\t( type == null || timers[ index ].queue === type ) ) {\n\n\t\t\t\t\ttimers[ index ].anim.stop( gotoEnd );\n\t\t\t\t\tdequeue = false;\n\t\t\t\t\ttimers.splice( index, 1 );\n\t\t\t\t}\n\t\t\t}\n\n\t\t\t// Start the next in the queue if the last step wasn't forced.\n\t\t\t// Timers currently will call their complete callbacks, which\n\t\t\t// will dequeue but only if they were gotoEnd.\n\t\t\tif ( dequeue || !gotoEnd ) {\n\t\t\t\tjQuery.dequeue( this, type );\n\t\t\t}\n\t\t} );\n\t},\n\tfinish: function( type ) {\n\t\tif ( type !== false ) {\n\t\t\ttype = type || \"fx\";\n\t\t}\n\t\treturn this.each( function() {\n\t\t\tvar index,\n\t\t\t\tdata = dataPriv.get( this ),\n\t\t\t\tqueue = data[ type + \"queue\" ],\n\t\t\t\thooks = data[ type + \"queueHooks\" ],\n\t\t\t\ttimers = jQuery.timers,\n\t\t\t\tlength = queue ? queue.length : 0;\n\n\t\t\t// Enable finishing flag on private data\n\t\t\tdata.finish = true;\n\n\t\t\t// Empty the queue first\n\t\t\tjQuery.queue( this, type, [] );\n\n\t\t\tif ( hooks && hooks.stop ) {\n\t\t\t\thooks.stop.call( this, true );\n\t\t\t}\n\n\t\t\t// Look for any active animations, and finish them\n\t\t\tfor ( index = timers.length; index--; ) {\n\t\t\t\tif ( timers[ index ].elem === this && timers[ index ].queue === type ) {\n\t\t\t\t\ttimers[ index ].anim.stop( true );\n\t\t\t\t\ttimers.splice( index, 1 );\n\t\t\t\t}\n\t\t\t}\n\n\t\t\t// Look for any animations in the old queue and finish them\n\t\t\tfor ( index = 0; index < length; index++ ) {\n\t\t\t\tif ( queue[ index ] && queue[ index ].finish ) {\n\t\t\t\t\tqueue[ index ].finish.call( this );\n\t\t\t\t}\n\t\t\t}\n\n\t\t\t// Turn off finishing flag\n\t\t\tdelete data.finish;\n\t\t} );\n\t}\n} );\n\njQuery.each( [ \"toggle\", \"show\", \"hide\" ], function( i, name ) {\n\tvar cssFn = jQuery.fn[ name ];\n\tjQuery.fn[ name ] = function( speed, easing, callback ) {\n\t\treturn speed == null || typeof speed === \"boolean\" ?\n\t\t\tcssFn.apply( this, arguments ) :\n\t\t\tthis.animate( genFx( name, true ), speed, easing, callback );\n\t};\n} );\n\n// Generate shortcuts for custom animations\njQuery.each( {\n\tslideDown: genFx( \"show\" ),\n\tslideUp: genFx( \"hide\" ),\n\tslideToggle: genFx( \"toggle\" ),\n\tfadeIn: { opacity: \"show\" },\n\tfadeOut: { opacity: \"hide\" },\n\tfadeToggle: { opacity: \"toggle\" }\n}, function( name, props ) {\n\tjQuery.fn[ name ] = function( speed, easing, callback ) {\n\t\treturn this.animate( props, speed, easing, callback );\n\t};\n} );\n\njQuery.timers = [];\njQuery.fx.tick = function() {\n\tvar timer,\n\t\ti = 0,\n\t\ttimers = jQuery.timers;\n\n\tfxNow = jQuery.now();\n\n\tfor ( ; i < timers.length; i++ ) {\n\t\ttimer = timers[ i ];\n\n\t\t// Run the timer and safely remove it when done (allowing for external removal)\n\t\tif ( !timer() && timers[ i ] === timer ) {\n\t\t\ttimers.splice( i--, 1 );\n\t\t}\n\t}\n\n\tif ( !timers.length ) {\n\t\tjQuery.fx.stop();\n\t}\n\tfxNow = undefined;\n};\n\njQuery.fx.timer = function( timer ) {\n\tjQuery.timers.push( timer );\n\tjQuery.fx.start();\n};\n\njQuery.fx.interval = 13;\njQuery.fx.start = function() {\n\tif ( inProgress ) {\n\t\treturn;\n\t}\n\n\tinProgress = true;\n\tschedule();\n};\n\njQuery.fx.stop = function() {\n\tinProgress = null;\n};\n\njQuery.fx.speeds = {\n\tslow: 600,\n\tfast: 200,\n\n\t// Default speed\n\t_default: 400\n};\n\n\n// Based off of the plugin by Clint Helfers, with permission.\n// https://web.archive.org/web/20100324014747/http://blindsignals.com/index.php/2009/07/jquery-delay/\njQuery.fn.delay = function( time, type ) {\n\ttime = jQuery.fx ? jQuery.fx.speeds[ time ] || time : time;\n\ttype = type || \"fx\";\n\n\treturn this.queue( type, function( next, hooks ) {\n\t\tvar timeout = window.setTimeout( next, time );\n\t\thooks.stop = function() {\n\t\t\twindow.clearTimeout( timeout );\n\t\t};\n\t} );\n};\n\n\n( function() {\n\tvar input = document.createElement( \"input\" ),\n\t\tselect = document.createElement( \"select\" ),\n\t\topt = select.appendChild( document.createElement( \"option\" ) );\n\n\tinput.type = \"checkbox\";\n\n\t// Support: Android <=4.3 only\n\t// Default value for a checkbox should be \"on\"\n\tsupport.checkOn = input.value !== \"\";\n\n\t// Support: IE <=11 only\n\t// Must access selectedIndex to make default options select\n\tsupport.optSelected = opt.selected;\n\n\t// Support: IE <=11 only\n\t// An input loses its value after becoming a radio\n\tinput = document.createElement( \"input\" );\n\tinput.value = \"t\";\n\tinput.type = \"radio\";\n\tsupport.radioValue = input.value === \"t\";\n} )();\n\n\nvar boolHook,\n\tattrHandle = jQuery.expr.attrHandle;\n\njQuery.fn.extend( {\n\tattr: function( name, value ) {\n\t\treturn access( this, jQuery.attr, name, value, arguments.length > 1 );\n\t},\n\n\tremoveAttr: function( name ) {\n\t\treturn this.each( function() {\n\t\t\tjQuery.removeAttr( this, name );\n\t\t} );\n\t}\n} );\n\njQuery.extend( {\n\tattr: function( elem, name, value ) {\n\t\tvar ret, hooks,\n\t\t\tnType = elem.nodeType;\n\n\t\t// Don't get/set attributes on text, comment and attribute nodes\n\t\tif ( nType === 3 || nType === 8 || nType === 2 ) {\n\t\t\treturn;\n\t\t}\n\n\t\t// Fallback to prop when attributes are not supported\n\t\tif ( typeof elem.getAttribute === \"undefined\" ) {\n\t\t\treturn jQuery.prop( elem, name, value );\n\t\t}\n\n\t\t// Attribute hooks are determined by the lowercase version\n\t\t// Grab necessary hook if one is defined\n\t\tif ( nType !== 1 || !jQuery.isXMLDoc( elem ) ) {\n\t\t\thooks = jQuery.attrHooks[ name.toLowerCase() ] ||\n\t\t\t\t( jQuery.expr.match.bool.test( name ) ? boolHook : undefined );\n\t\t}\n\n\t\tif ( value !== undefined ) {\n\t\t\tif ( value === null ) {\n\t\t\t\tjQuery.removeAttr( elem, name );\n\t\t\t\treturn;\n\t\t\t}\n\n\t\t\tif ( hooks && \"set\" in hooks &&\n\t\t\t\t( ret = hooks.set( elem, value, name ) ) !== undefined ) {\n\t\t\t\treturn ret;\n\t\t\t}\n\n\t\t\telem.setAttribute( name, value + \"\" );\n\t\t\treturn value;\n\t\t}\n\n\t\tif ( hooks && \"get\" in hooks && ( ret = hooks.get( elem, name ) ) !== null ) {\n\t\t\treturn ret;\n\t\t}\n\n\t\tret = jQuery.find.attr( elem, name );\n\n\t\t// Non-existent attributes return null, we normalize to undefined\n\t\treturn ret == null ? undefined : ret;\n\t},\n\n\tattrHooks: {\n\t\ttype: {\n\t\t\tset: function( elem, value ) {\n\t\t\t\tif ( !support.radioValue && value === \"radio\" &&\n\t\t\t\t\tnodeName( elem, \"input\" ) ) {\n\t\t\t\t\tvar val = elem.value;\n\t\t\t\t\telem.setAttribute( \"type\", value );\n\t\t\t\t\tif ( val ) {\n\t\t\t\t\t\telem.value = val;\n\t\t\t\t\t}\n\t\t\t\t\treturn value;\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t},\n\n\tremoveAttr: function( elem, value ) {\n\t\tvar name,\n\t\t\ti = 0,\n\n\t\t\t// Attribute names can contain non-HTML whitespace characters\n\t\t\t// https://html.spec.whatwg.org/multipage/syntax.html#attributes-2\n\t\t\tattrNames = value && value.match( rnothtmlwhite );\n\n\t\tif ( attrNames && elem.nodeType === 1 ) {\n\t\t\twhile ( ( name = attrNames[ i++ ] ) ) {\n\t\t\t\telem.removeAttribute( name );\n\t\t\t}\n\t\t}\n\t}\n} );\n\n// Hooks for boolean attributes\nboolHook = {\n\tset: function( elem, value, name ) {\n\t\tif ( value === false ) {\n\n\t\t\t// Remove boolean attributes when set to false\n\t\t\tjQuery.removeAttr( elem, name );\n\t\t} else {\n\t\t\telem.setAttribute( name, name );\n\t\t}\n\t\treturn name;\n\t}\n};\n\njQuery.each( jQuery.expr.match.bool.source.match( /\\w+/g ), function( i, name ) {\n\tvar getter = attrHandle[ name ] || jQuery.find.attr;\n\n\tattrHandle[ name ] = function( elem, name, isXML ) {\n\t\tvar ret, handle,\n\t\t\tlowercaseName = name.toLowerCase();\n\n\t\tif ( !isXML ) {\n\n\t\t\t// Avoid an infinite loop by temporarily removing this function from the getter\n\t\t\thandle = attrHandle[ lowercaseName ];\n\t\t\tattrHandle[ lowercaseName ] = ret;\n\t\t\tret = getter( elem, name, isXML ) != null ?\n\t\t\t\tlowercaseName :\n\t\t\t\tnull;\n\t\t\tattrHandle[ lowercaseName ] = handle;\n\t\t}\n\t\treturn ret;\n\t};\n} );\n\n\n\n\nvar rfocusable = /^(?:input|select|textarea|button)$/i,\n\trclickable = /^(?:a|area)$/i;\n\njQuery.fn.extend( {\n\tprop: function( name, value ) {\n\t\treturn access( this, jQuery.prop, name, value, arguments.length > 1 );\n\t},\n\n\tremoveProp: function( name ) {\n\t\treturn this.each( function() {\n\t\t\tdelete this[ jQuery.propFix[ name ] || name ];\n\t\t} );\n\t}\n} );\n\njQuery.extend( {\n\tprop: function( elem, name, value ) {\n\t\tvar ret, hooks,\n\t\t\tnType = elem.nodeType;\n\n\t\t// Don't get/set properties on text, comment and attribute nodes\n\t\tif ( nType === 3 || nType === 8 || nType === 2 ) {\n\t\t\treturn;\n\t\t}\n\n\t\tif ( nType !== 1 || !jQuery.isXMLDoc( elem ) ) {\n\n\t\t\t// Fix name and attach hooks\n\t\t\tname = jQuery.propFix[ name ] || name;\n\t\t\thooks = jQuery.propHooks[ name ];\n\t\t}\n\n\t\tif ( value !== undefined ) {\n\t\t\tif ( hooks && \"set\" in hooks &&\n\t\t\t\t( ret = hooks.set( elem, value, name ) ) !== undefined ) {\n\t\t\t\treturn ret;\n\t\t\t}\n\n\t\t\treturn ( elem[ name ] = value );\n\t\t}\n\n\t\tif ( hooks && \"get\" in hooks && ( ret = hooks.get( elem, name ) ) !== null ) {\n\t\t\treturn ret;\n\t\t}\n\n\t\treturn elem[ name ];\n\t},\n\n\tpropHooks: {\n\t\ttabIndex: {\n\t\t\tget: function( elem ) {\n\n\t\t\t\t// Support: IE <=9 - 11 only\n\t\t\t\t// elem.tabIndex doesn't always return the\n\t\t\t\t// correct value when it hasn't been explicitly set\n\t\t\t\t// https://web.archive.org/web/20141116233347/http://fluidproject.org/blog/2008/01/09/getting-setting-and-removing-tabindex-values-with-javascript/\n\t\t\t\t// Use proper attribute retrieval(#12072)\n\t\t\t\tvar tabindex = jQuery.find.attr( elem, \"tabindex\" );\n\n\t\t\t\tif ( tabindex ) {\n\t\t\t\t\treturn parseInt( tabindex, 10 );\n\t\t\t\t}\n\n\t\t\t\tif (\n\t\t\t\t\trfocusable.test( elem.nodeName ) ||\n\t\t\t\t\trclickable.test( elem.nodeName ) &&\n\t\t\t\t\telem.href\n\t\t\t\t) {\n\t\t\t\t\treturn 0;\n\t\t\t\t}\n\n\t\t\t\treturn -1;\n\t\t\t}\n\t\t}\n\t},\n\n\tpropFix: {\n\t\t\"for\": \"htmlFor\",\n\t\t\"class\": \"className\"\n\t}\n} );\n\n// Support: IE <=11 only\n// Accessing the selectedIndex property\n// forces the browser to respect setting selected\n// on the option\n// The getter ensures a default option is selected\n// when in an optgroup\n// eslint rule \"no-unused-expressions\" is disabled for this code\n// since it considers such accessions noop\nif ( !support.optSelected ) {\n\tjQuery.propHooks.selected = {\n\t\tget: function( elem ) {\n\n\t\t\t/* eslint no-unused-expressions: \"off\" */\n\n\t\t\tvar parent = elem.parentNode;\n\t\t\tif ( parent && parent.parentNode ) {\n\t\t\t\tparent.parentNode.selectedIndex;\n\t\t\t}\n\t\t\treturn null;\n\t\t},\n\t\tset: function( elem ) {\n\n\t\t\t/* eslint no-unused-expressions: \"off\" */\n\n\t\t\tvar parent = elem.parentNode;\n\t\t\tif ( parent ) {\n\t\t\t\tparent.selectedIndex;\n\n\t\t\t\tif ( parent.parentNode ) {\n\t\t\t\t\tparent.parentNode.selectedIndex;\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t};\n}\n\njQuery.each( [\n\t\"tabIndex\",\n\t\"readOnly\",\n\t\"maxLength\",\n\t\"cellSpacing\",\n\t\"cellPadding\",\n\t\"rowSpan\",\n\t\"colSpan\",\n\t\"useMap\",\n\t\"frameBorder\",\n\t\"contentEditable\"\n], function() {\n\tjQuery.propFix[ this.toLowerCase() ] = this;\n} );\n\n\n\n\n\t// Strip and collapse whitespace according to HTML spec\n\t// https://html.spec.whatwg.org/multipage/infrastructure.html#strip-and-collapse-whitespace\n\tfunction stripAndCollapse( value ) {\n\t\tvar tokens = value.match( rnothtmlwhite ) || [];\n\t\treturn tokens.join( \" \" );\n\t}\n\n\nfunction getClass( elem ) {\n\treturn elem.getAttribute && elem.getAttribute( \"class\" ) || \"\";\n}\n\njQuery.fn.extend( {\n\taddClass: function( value ) {\n\t\tvar classes, elem, cur, curValue, clazz, j, finalValue,\n\t\t\ti = 0;\n\n\t\tif ( jQuery.isFunction( value ) ) {\n\t\t\treturn this.each( function( j ) {\n\t\t\t\tjQuery( this ).addClass( value.call( this, j, getClass( this ) ) );\n\t\t\t} );\n\t\t}\n\n\t\tif ( typeof value === \"string\" && value ) {\n\t\t\tclasses = value.match( rnothtmlwhite ) || [];\n\n\t\t\twhile ( ( elem = this[ i++ ] ) ) {\n\t\t\t\tcurValue = getClass( elem );\n\t\t\t\tcur = elem.nodeType === 1 && ( \" \" + stripAndCollapse( curValue ) + \" \" );\n\n\t\t\t\tif ( cur ) {\n\t\t\t\t\tj = 0;\n\t\t\t\t\twhile ( ( clazz = classes[ j++ ] ) ) {\n\t\t\t\t\t\tif ( cur.indexOf( \" \" + clazz + \" \" ) < 0 ) {\n\t\t\t\t\t\t\tcur += clazz + \" \";\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\n\t\t\t\t\t// Only assign if different to avoid unneeded rendering.\n\t\t\t\t\tfinalValue = stripAndCollapse( cur );\n\t\t\t\t\tif ( curValue !== finalValue ) {\n\t\t\t\t\t\telem.setAttribute( \"class\", finalValue );\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\treturn this;\n\t},\n\n\tremoveClass: function( value ) {\n\t\tvar classes, elem, cur, curValue, clazz, j, finalValue,\n\t\t\ti = 0;\n\n\t\tif ( jQuery.isFunction( value ) ) {\n\t\t\treturn this.each( function( j ) {\n\t\t\t\tjQuery( this ).removeClass( value.call( this, j, getClass( this ) ) );\n\t\t\t} );\n\t\t}\n\n\t\tif ( !arguments.length ) {\n\t\t\treturn this.attr( \"class\", \"\" );\n\t\t}\n\n\t\tif ( typeof value === \"string\" && value ) {\n\t\t\tclasses = value.match( rnothtmlwhite ) || [];\n\n\t\t\twhile ( ( elem = this[ i++ ] ) ) {\n\t\t\t\tcurValue = getClass( elem );\n\n\t\t\t\t// This expression is here for better compressibility (see addClass)\n\t\t\t\tcur = elem.nodeType === 1 && ( \" \" + stripAndCollapse( curValue ) + \" \" );\n\n\t\t\t\tif ( cur ) {\n\t\t\t\t\tj = 0;\n\t\t\t\t\twhile ( ( clazz = classes[ j++ ] ) ) {\n\n\t\t\t\t\t\t// Remove *all* instances\n\t\t\t\t\t\twhile ( cur.indexOf( \" \" + clazz + \" \" ) > -1 ) {\n\t\t\t\t\t\t\tcur = cur.replace( \" \" + clazz + \" \", \" \" );\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\n\t\t\t\t\t// Only assign if different to avoid unneeded rendering.\n\t\t\t\t\tfinalValue = stripAndCollapse( cur );\n\t\t\t\t\tif ( curValue !== finalValue ) {\n\t\t\t\t\t\telem.setAttribute( \"class\", finalValue );\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\treturn this;\n\t},\n\n\ttoggleClass: function( value, stateVal ) {\n\t\tvar type = typeof value;\n\n\t\tif ( typeof stateVal === \"boolean\" && type === \"string\" ) {\n\t\t\treturn stateVal ? this.addClass( value ) : this.removeClass( value );\n\t\t}\n\n\t\tif ( jQuery.isFunction( value ) ) {\n\t\t\treturn this.each( function( i ) {\n\t\t\t\tjQuery( this ).toggleClass(\n\t\t\t\t\tvalue.call( this, i, getClass( this ), stateVal ),\n\t\t\t\t\tstateVal\n\t\t\t\t);\n\t\t\t} );\n\t\t}\n\n\t\treturn this.each( function() {\n\t\t\tvar className, i, self, classNames;\n\n\t\t\tif ( type === \"string\" ) {\n\n\t\t\t\t// Toggle individual class names\n\t\t\t\ti = 0;\n\t\t\t\tself = jQuery( this );\n\t\t\t\tclassNames = value.match( rnothtmlwhite ) || [];\n\n\t\t\t\twhile ( ( className = classNames[ i++ ] ) ) {\n\n\t\t\t\t\t// Check each className given, space separated list\n\t\t\t\t\tif ( self.hasClass( className ) ) {\n\t\t\t\t\t\tself.removeClass( className );\n\t\t\t\t\t} else {\n\t\t\t\t\t\tself.addClass( className );\n\t\t\t\t\t}\n\t\t\t\t}\n\n\t\t\t// Toggle whole class name\n\t\t\t} else if ( value === undefined || type === \"boolean\" ) {\n\t\t\t\tclassName = getClass( this );\n\t\t\t\tif ( className ) {\n\n\t\t\t\t\t// Store className if set\n\t\t\t\t\tdataPriv.set( this, \"__className__\", className );\n\t\t\t\t}\n\n\t\t\t\t// If the element has a class name or if we're passed `false`,\n\t\t\t\t// then remove the whole classname (if there was one, the above saved it).\n\t\t\t\t// Otherwise bring back whatever was previously saved (if anything),\n\t\t\t\t// falling back to the empty string if nothing was stored.\n\t\t\t\tif ( this.setAttribute ) {\n\t\t\t\t\tthis.setAttribute( \"class\",\n\t\t\t\t\t\tclassName || value === false ?\n\t\t\t\t\t\t\"\" :\n\t\t\t\t\t\tdataPriv.get( this, \"__className__\" ) || \"\"\n\t\t\t\t\t);\n\t\t\t\t}\n\t\t\t}\n\t\t} );\n\t},\n\n\thasClass: function( selector ) {\n\t\tvar className, elem,\n\t\t\ti = 0;\n\n\t\tclassName = \" \" + selector + \" \";\n\t\twhile ( ( elem = this[ i++ ] ) ) {\n\t\t\tif ( elem.nodeType === 1 &&\n\t\t\t\t( \" \" + stripAndCollapse( getClass( elem ) ) + \" \" ).indexOf( className ) > -1 ) {\n\t\t\t\t\treturn true;\n\t\t\t}\n\t\t}\n\n\t\treturn false;\n\t}\n} );\n\n\n\n\nvar rreturn = /\\r/g;\n\njQuery.fn.extend( {\n\tval: function( value ) {\n\t\tvar hooks, ret, isFunction,\n\t\t\telem = this[ 0 ];\n\n\t\tif ( !arguments.length ) {\n\t\t\tif ( elem ) {\n\t\t\t\thooks = jQuery.valHooks[ elem.type ] ||\n\t\t\t\t\tjQuery.valHooks[ elem.nodeName.toLowerCase() ];\n\n\t\t\t\tif ( hooks &&\n\t\t\t\t\t\"get\" in hooks &&\n\t\t\t\t\t( ret = hooks.get( elem, \"value\" ) ) !== undefined\n\t\t\t\t) {\n\t\t\t\t\treturn ret;\n\t\t\t\t}\n\n\t\t\t\tret = elem.value;\n\n\t\t\t\t// Handle most common string cases\n\t\t\t\tif ( typeof ret === \"string\" ) {\n\t\t\t\t\treturn ret.replace( rreturn, \"\" );\n\t\t\t\t}\n\n\t\t\t\t// Handle cases where value is null/undef or number\n\t\t\t\treturn ret == null ? \"\" : ret;\n\t\t\t}\n\n\t\t\treturn;\n\t\t}\n\n\t\tisFunction = jQuery.isFunction( value );\n\n\t\treturn this.each( function( i ) {\n\t\t\tvar val;\n\n\t\t\tif ( this.nodeType !== 1 ) {\n\t\t\t\treturn;\n\t\t\t}\n\n\t\t\tif ( isFunction ) {\n\t\t\t\tval = value.call( this, i, jQuery( this ).val() );\n\t\t\t} else {\n\t\t\t\tval = value;\n\t\t\t}\n\n\t\t\t// Treat null/undefined as \"\"; convert numbers to string\n\t\t\tif ( val == null ) {\n\t\t\t\tval = \"\";\n\n\t\t\t} else if ( typeof val === \"number\" ) {\n\t\t\t\tval += \"\";\n\n\t\t\t} else if ( Array.isArray( val ) ) {\n\t\t\t\tval = jQuery.map( val, function( value ) {\n\t\t\t\t\treturn value == null ? \"\" : value + \"\";\n\t\t\t\t} );\n\t\t\t}\n\n\t\t\thooks = jQuery.valHooks[ this.type ] || jQuery.valHooks[ this.nodeName.toLowerCase() ];\n\n\t\t\t// If set returns undefined, fall back to normal setting\n\t\t\tif ( !hooks || !( \"set\" in hooks ) || hooks.set( this, val, \"value\" ) === undefined ) {\n\t\t\t\tthis.value = val;\n\t\t\t}\n\t\t} );\n\t}\n} );\n\njQuery.extend( {\n\tvalHooks: {\n\t\toption: {\n\t\t\tget: function( elem ) {\n\n\t\t\t\tvar val = jQuery.find.attr( elem, \"value\" );\n\t\t\t\treturn val != null ?\n\t\t\t\t\tval :\n\n\t\t\t\t\t// Support: IE <=10 - 11 only\n\t\t\t\t\t// option.text throws exceptions (#14686, #14858)\n\t\t\t\t\t// Strip and collapse whitespace\n\t\t\t\t\t// https://html.spec.whatwg.org/#strip-and-collapse-whitespace\n\t\t\t\t\tstripAndCollapse( jQuery.text( elem ) );\n\t\t\t}\n\t\t},\n\t\tselect: {\n\t\t\tget: function( elem ) {\n\t\t\t\tvar value, option, i,\n\t\t\t\t\toptions = elem.options,\n\t\t\t\t\tindex = elem.selectedIndex,\n\t\t\t\t\tone = elem.type === \"select-one\",\n\t\t\t\t\tvalues = one ? null : [],\n\t\t\t\t\tmax = one ? index + 1 : options.length;\n\n\t\t\t\tif ( index < 0 ) {\n\t\t\t\t\ti = max;\n\n\t\t\t\t} else {\n\t\t\t\t\ti = one ? index : 0;\n\t\t\t\t}\n\n\t\t\t\t// Loop through all the selected options\n\t\t\t\tfor ( ; i < max; i++ ) {\n\t\t\t\t\toption = options[ i ];\n\n\t\t\t\t\t// Support: IE <=9 only\n\t\t\t\t\t// IE8-9 doesn't update selected after form reset (#2551)\n\t\t\t\t\tif ( ( option.selected || i === index ) &&\n\n\t\t\t\t\t\t\t// Don't return options that are disabled or in a disabled optgroup\n\t\t\t\t\t\t\t!option.disabled &&\n\t\t\t\t\t\t\t( !option.parentNode.disabled ||\n\t\t\t\t\t\t\t\t!nodeName( option.parentNode, \"optgroup\" ) ) ) {\n\n\t\t\t\t\t\t// Get the specific value for the option\n\t\t\t\t\t\tvalue = jQuery( option ).val();\n\n\t\t\t\t\t\t// We don't need an array for one selects\n\t\t\t\t\t\tif ( one ) {\n\t\t\t\t\t\t\treturn value;\n\t\t\t\t\t\t}\n\n\t\t\t\t\t\t// Multi-Selects return an array\n\t\t\t\t\t\tvalues.push( value );\n\t\t\t\t\t}\n\t\t\t\t}\n\n\t\t\t\treturn values;\n\t\t\t},\n\n\t\t\tset: function( elem, value ) {\n\t\t\t\tvar optionSet, option,\n\t\t\t\t\toptions = elem.options,\n\t\t\t\t\tvalues = jQuery.makeArray( value ),\n\t\t\t\t\ti = options.length;\n\n\t\t\t\twhile ( i-- ) {\n\t\t\t\t\toption = options[ i ];\n\n\t\t\t\t\t/* eslint-disable no-cond-assign */\n\n\t\t\t\t\tif ( option.selected =\n\t\t\t\t\t\tjQuery.inArray( jQuery.valHooks.option.get( option ), values ) > -1\n\t\t\t\t\t) {\n\t\t\t\t\t\toptionSet = true;\n\t\t\t\t\t}\n\n\t\t\t\t\t/* eslint-enable no-cond-assign */\n\t\t\t\t}\n\n\t\t\t\t// Force browsers to behave consistently when non-matching value is set\n\t\t\t\tif ( !optionSet ) {\n\t\t\t\t\telem.selectedIndex = -1;\n\t\t\t\t}\n\t\t\t\treturn values;\n\t\t\t}\n\t\t}\n\t}\n} );\n\n// Radios and checkboxes getter/setter\njQuery.each( [ \"radio\", \"checkbox\" ], function() {\n\tjQuery.valHooks[ this ] = {\n\t\tset: function( elem, value ) {\n\t\t\tif ( Array.isArray( value ) ) {\n\t\t\t\treturn ( elem.checked = jQuery.inArray( jQuery( elem ).val(), value ) > -1 );\n\t\t\t}\n\t\t}\n\t};\n\tif ( !support.checkOn ) {\n\t\tjQuery.valHooks[ this ].get = function( elem ) {\n\t\t\treturn elem.getAttribute( \"value\" ) === null ? \"on\" : elem.value;\n\t\t};\n\t}\n} );\n\n\n\n\n// Return jQuery for attributes-only inclusion\n\n\nvar rfocusMorph = /^(?:focusinfocus|focusoutblur)$/;\n\njQuery.extend( jQuery.event, {\n\n\ttrigger: function( event, data, elem, onlyHandlers ) {\n\n\t\tvar i, cur, tmp, bubbleType, ontype, handle, special,\n\t\t\teventPath = [ elem || document ],\n\t\t\ttype = hasOwn.call( event, \"type\" ) ? event.type : event,\n\t\t\tnamespaces = hasOwn.call( event, \"namespace\" ) ? event.namespace.split( \".\" ) : [];\n\n\t\tcur = tmp = elem = elem || document;\n\n\t\t// Don't do events on text and comment nodes\n\t\tif ( elem.nodeType === 3 || elem.nodeType === 8 ) {\n\t\t\treturn;\n\t\t}\n\n\t\t// focus/blur morphs to focusin/out; ensure we're not firing them right now\n\t\tif ( rfocusMorph.test( type + jQuery.event.triggered ) ) {\n\t\t\treturn;\n\t\t}\n\n\t\tif ( type.indexOf( \".\" ) > -1 ) {\n\n\t\t\t// Namespaced trigger; create a regexp to match event type in handle()\n\t\t\tnamespaces = type.split( \".\" );\n\t\t\ttype = namespaces.shift();\n\t\t\tnamespaces.sort();\n\t\t}\n\t\tontype = type.indexOf( \":\" ) < 0 && \"on\" + type;\n\n\t\t// Caller can pass in a jQuery.Event object, Object, or just an event type string\n\t\tevent = event[ jQuery.expando ] ?\n\t\t\tevent :\n\t\t\tnew jQuery.Event( type, typeof event === \"object\" && event );\n\n\t\t// Trigger bitmask: & 1 for native handlers; & 2 for jQuery (always true)\n\t\tevent.isTrigger = onlyHandlers ? 2 : 3;\n\t\tevent.namespace = namespaces.join( \".\" );\n\t\tevent.rnamespace = event.namespace ?\n\t\t\tnew RegExp( \"(^|\\\\.)\" + namespaces.join( \"\\\\.(?:.*\\\\.|)\" ) + \"(\\\\.|$)\" ) :\n\t\t\tnull;\n\n\t\t// Clean up the event in case it is being reused\n\t\tevent.result = undefined;\n\t\tif ( !event.target ) {\n\t\t\tevent.target = elem;\n\t\t}\n\n\t\t// Clone any incoming data and prepend the event, creating the handler arg list\n\t\tdata = data == null ?\n\t\t\t[ event ] :\n\t\t\tjQuery.makeArray( data, [ event ] );\n\n\t\t// Allow special events to draw outside the lines\n\t\tspecial = jQuery.event.special[ type ] || {};\n\t\tif ( !onlyHandlers && special.trigger && special.trigger.apply( elem, data ) === false ) {\n\t\t\treturn;\n\t\t}\n\n\t\t// Determine event propagation path in advance, per W3C events spec (#9951)\n\t\t// Bubble up to document, then to window; watch for a global ownerDocument var (#9724)\n\t\tif ( !onlyHandlers && !special.noBubble && !jQuery.isWindow( elem ) ) {\n\n\t\t\tbubbleType = special.delegateType || type;\n\t\t\tif ( !rfocusMorph.test( bubbleType + type ) ) {\n\t\t\t\tcur = cur.parentNode;\n\t\t\t}\n\t\t\tfor ( ; cur; cur = cur.parentNode ) {\n\t\t\t\teventPath.push( cur );\n\t\t\t\ttmp = cur;\n\t\t\t}\n\n\t\t\t// Only add window if we got to document (e.g., not plain obj or detached DOM)\n\t\t\tif ( tmp === ( elem.ownerDocument || document ) ) {\n\t\t\t\teventPath.push( tmp.defaultView || tmp.parentWindow || window );\n\t\t\t}\n\t\t}\n\n\t\t// Fire handlers on the event path\n\t\ti = 0;\n\t\twhile ( ( cur = eventPath[ i++ ] ) && !event.isPropagationStopped() ) {\n\n\t\t\tevent.type = i > 1 ?\n\t\t\t\tbubbleType :\n\t\t\t\tspecial.bindType || type;\n\n\t\t\t// jQuery handler\n\t\t\thandle = ( dataPriv.get( cur, \"events\" ) || {} )[ event.type ] &&\n\t\t\t\tdataPriv.get( cur, \"handle\" );\n\t\t\tif ( handle ) {\n\t\t\t\thandle.apply( cur, data );\n\t\t\t}\n\n\t\t\t// Native handler\n\t\t\thandle = ontype && cur[ ontype ];\n\t\t\tif ( handle && handle.apply && acceptData( cur ) ) {\n\t\t\t\tevent.result = handle.apply( cur, data );\n\t\t\t\tif ( event.result === false ) {\n\t\t\t\t\tevent.preventDefault();\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t\tevent.type = type;\n\n\t\t// If nobody prevented the default action, do it now\n\t\tif ( !onlyHandlers && !event.isDefaultPrevented() ) {\n\n\t\t\tif ( ( !special._default ||\n\t\t\t\tspecial._default.apply( eventPath.pop(), data ) === false ) &&\n\t\t\t\tacceptData( elem ) ) {\n\n\t\t\t\t// Call a native DOM method on the target with the same name as the event.\n\t\t\t\t// Don't do default actions on window, that's where global variables be (#6170)\n\t\t\t\tif ( ontype && jQuery.isFunction( elem[ type ] ) && !jQuery.isWindow( elem ) ) {\n\n\t\t\t\t\t// Don't re-trigger an onFOO event when we call its FOO() method\n\t\t\t\t\ttmp = elem[ ontype ];\n\n\t\t\t\t\tif ( tmp ) {\n\t\t\t\t\t\telem[ ontype ] = null;\n\t\t\t\t\t}\n\n\t\t\t\t\t// Prevent re-triggering of the same event, since we already bubbled it above\n\t\t\t\t\tjQuery.event.triggered = type;\n\t\t\t\t\telem[ type ]();\n\t\t\t\t\tjQuery.event.triggered = undefined;\n\n\t\t\t\t\tif ( tmp ) {\n\t\t\t\t\t\telem[ ontype ] = tmp;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\treturn event.result;\n\t},\n\n\t// Piggyback on a donor event to simulate a different one\n\t// Used only for `focus(in | out)` events\n\tsimulate: function( type, elem, event ) {\n\t\tvar e = jQuery.extend(\n\t\t\tnew jQuery.Event(),\n\t\t\tevent,\n\t\t\t{\n\t\t\t\ttype: type,\n\t\t\t\tisSimulated: true\n\t\t\t}\n\t\t);\n\n\t\tjQuery.event.trigger( e, null, elem );\n\t}\n\n} );\n\njQuery.fn.extend( {\n\n\ttrigger: function( type, data ) {\n\t\treturn this.each( function() {\n\t\t\tjQuery.event.trigger( type, data, this );\n\t\t} );\n\t},\n\ttriggerHandler: function( type, data ) {\n\t\tvar elem = this[ 0 ];\n\t\tif ( elem ) {\n\t\t\treturn jQuery.event.trigger( type, data, elem, true );\n\t\t}\n\t}\n} );\n\n\njQuery.each( ( \"blur focus focusin focusout resize scroll click dblclick \" +\n\t\"mousedown mouseup mousemove mouseover mouseout mouseenter mouseleave \" +\n\t\"change select submit keydown keypress keyup contextmenu\" ).split( \" \" ),\n\tfunction( i, name ) {\n\n\t// Handle event binding\n\tjQuery.fn[ name ] = function( data, fn ) {\n\t\treturn arguments.length > 0 ?\n\t\t\tthis.on( name, null, data, fn ) :\n\t\t\tthis.trigger( name );\n\t};\n} );\n\njQuery.fn.extend( {\n\thover: function( fnOver, fnOut ) {\n\t\treturn this.mouseenter( fnOver ).mouseleave( fnOut || fnOver );\n\t}\n} );\n\n\n\n\nsupport.focusin = \"onfocusin\" in window;\n\n\n// Support: Firefox <=44\n// Firefox doesn't have focus(in | out) events\n// Related ticket - https://bugzilla.mozilla.org/show_bug.cgi?id=687787\n//\n// Support: Chrome <=48 - 49, Safari <=9.0 - 9.1\n// focus(in | out) events fire after focus & blur events,\n// which is spec violation - http://www.w3.org/TR/DOM-Level-3-Events/#events-focusevent-event-order\n// Related ticket - https://bugs.chromium.org/p/chromium/issues/detail?id=449857\nif ( !support.focusin ) {\n\tjQuery.each( { focus: \"focusin\", blur: \"focusout\" }, function( orig, fix ) {\n\n\t\t// Attach a single capturing handler on the document while someone wants focusin/focusout\n\t\tvar handler = function( event ) {\n\t\t\tjQuery.event.simulate( fix, event.target, jQuery.event.fix( event ) );\n\t\t};\n\n\t\tjQuery.event.special[ fix ] = {\n\t\t\tsetup: function() {\n\t\t\t\tvar doc = this.ownerDocument || this,\n\t\t\t\t\tattaches = dataPriv.access( doc, fix );\n\n\t\t\t\tif ( !attaches ) {\n\t\t\t\t\tdoc.addEventListener( orig, handler, true );\n\t\t\t\t}\n\t\t\t\tdataPriv.access( doc, fix, ( attaches || 0 ) + 1 );\n\t\t\t},\n\t\t\tteardown: function() {\n\t\t\t\tvar doc = this.ownerDocument || this,\n\t\t\t\t\tattaches = dataPriv.access( doc, fix ) - 1;\n\n\t\t\t\tif ( !attaches ) {\n\t\t\t\t\tdoc.removeEventListener( orig, handler, true );\n\t\t\t\t\tdataPriv.remove( doc, fix );\n\n\t\t\t\t} else {\n\t\t\t\t\tdataPriv.access( doc, fix, attaches );\n\t\t\t\t}\n\t\t\t}\n\t\t};\n\t} );\n}\nvar location = window.location;\n\nvar nonce = jQuery.now();\n\nvar rquery = ( /\\?/ );\n\n\n\n// Cross-browser xml parsing\njQuery.parseXML = function( data ) {\n\tvar xml;\n\tif ( !data || typeof data !== \"string\" ) {\n\t\treturn null;\n\t}\n\n\t// Support: IE 9 - 11 only\n\t// IE throws on parseFromString with invalid input.\n\ttry {\n\t\txml = ( new window.DOMParser() ).parseFromString( data, \"text/xml\" );\n\t} catch ( e ) {\n\t\txml = undefined;\n\t}\n\n\tif ( !xml || xml.getElementsByTagName( \"parsererror\" ).length ) {\n\t\tjQuery.error( \"Invalid XML: \" + data );\n\t}\n\treturn xml;\n};\n\n\nvar\n\trbracket = /\\[\\]$/,\n\trCRLF = /\\r?\\n/g,\n\trsubmitterTypes = /^(?:submit|button|image|reset|file)$/i,\n\trsubmittable = /^(?:input|select|textarea|keygen)/i;\n\nfunction buildParams( prefix, obj, traditional, add ) {\n\tvar name;\n\n\tif ( Array.isArray( obj ) ) {\n\n\t\t// Serialize array item.\n\t\tjQuery.each( obj, function( i, v ) {\n\t\t\tif ( traditional || rbracket.test( prefix ) ) {\n\n\t\t\t\t// Treat each array item as a scalar.\n\t\t\t\tadd( prefix, v );\n\n\t\t\t} else {\n\n\t\t\t\t// Item is non-scalar (array or object), encode its numeric index.\n\t\t\t\tbuildParams(\n\t\t\t\t\tprefix + \"[\" + ( typeof v === \"object\" && v != null ? i : \"\" ) + \"]\",\n\t\t\t\t\tv,\n\t\t\t\t\ttraditional,\n\t\t\t\t\tadd\n\t\t\t\t);\n\t\t\t}\n\t\t} );\n\n\t} else if ( !traditional && jQuery.type( obj ) === \"object\" ) {\n\n\t\t// Serialize object item.\n\t\tfor ( name in obj ) {\n\t\t\tbuildParams( prefix + \"[\" + name + \"]\", obj[ name ], traditional, add );\n\t\t}\n\n\t} else {\n\n\t\t// Serialize scalar item.\n\t\tadd( prefix, obj );\n\t}\n}\n\n// Serialize an array of form elements or a set of\n// key/values into a query string\njQuery.param = function( a, traditional ) {\n\tvar prefix,\n\t\ts = [],\n\t\tadd = function( key, valueOrFunction ) {\n\n\t\t\t// If value is a function, invoke it and use its return value\n\t\t\tvar value = jQuery.isFunction( valueOrFunction ) ?\n\t\t\t\tvalueOrFunction() :\n\t\t\t\tvalueOrFunction;\n\n\t\t\ts[ s.length ] = encodeURIComponent( key ) + \"=\" +\n\t\t\t\tencodeURIComponent( value == null ? \"\" : value );\n\t\t};\n\n\t// If an array was passed in, assume that it is an array of form elements.\n\tif ( Array.isArray( a ) || ( a.jquery && !jQuery.isPlainObject( a ) ) ) {\n\n\t\t// Serialize the form elements\n\t\tjQuery.each( a, function() {\n\t\t\tadd( this.name, this.value );\n\t\t} );\n\n\t} else {\n\n\t\t// If traditional, encode the \"old\" way (the way 1.3.2 or older\n\t\t// did it), otherwise encode params recursively.\n\t\tfor ( prefix in a ) {\n\t\t\tbuildParams( prefix, a[ prefix ], traditional, add );\n\t\t}\n\t}\n\n\t// Return the resulting serialization\n\treturn s.join( \"&\" );\n};\n\njQuery.fn.extend( {\n\tserialize: function() {\n\t\treturn jQuery.param( this.serializeArray() );\n\t},\n\tserializeArray: function() {\n\t\treturn this.map( function() {\n\n\t\t\t// Can add propHook for \"elements\" to filter or add form elements\n\t\t\tvar elements = jQuery.prop( this, \"elements\" );\n\t\t\treturn elements ? jQuery.makeArray( elements ) : this;\n\t\t} )\n\t\t.filter( function() {\n\t\t\tvar type = this.type;\n\n\t\t\t// Use .is( \":disabled\" ) so that fieldset[disabled] works\n\t\t\treturn this.name && !jQuery( this ).is( \":disabled\" ) &&\n\t\t\t\trsubmittable.test( this.nodeName ) && !rsubmitterTypes.test( type ) &&\n\t\t\t\t( this.checked || !rcheckableType.test( type ) );\n\t\t} )\n\t\t.map( function( i, elem ) {\n\t\t\tvar val = jQuery( this ).val();\n\n\t\t\tif ( val == null ) {\n\t\t\t\treturn null;\n\t\t\t}\n\n\t\t\tif ( Array.isArray( val ) ) {\n\t\t\t\treturn jQuery.map( val, function( val ) {\n\t\t\t\t\treturn { name: elem.name, value: val.replace( rCRLF, \"\\r\\n\" ) };\n\t\t\t\t} );\n\t\t\t}\n\n\t\t\treturn { name: elem.name, value: val.replace( rCRLF, \"\\r\\n\" ) };\n\t\t} ).get();\n\t}\n} );\n\n\nvar\n\tr20 = /%20/g,\n\trhash = /#.*$/,\n\trantiCache = /([?&])_=[^&]*/,\n\trheaders = /^(.*?):[ \\t]*([^\\r\\n]*)$/mg,\n\n\t// #7653, #8125, #8152: local protocol detection\n\trlocalProtocol = /^(?:about|app|app-storage|.+-extension|file|res|widget):$/,\n\trnoContent = /^(?:GET|HEAD)$/,\n\trprotocol = /^\\/\\//,\n\n\t/* Prefilters\n\t * 1) They are useful to introduce custom dataTypes (see ajax/jsonp.js for an example)\n\t * 2) These are called:\n\t * - BEFORE asking for a transport\n\t * - AFTER param serialization (s.data is a string if s.processData is true)\n\t * 3) key is the dataType\n\t * 4) the catchall symbol \"*\" can be used\n\t * 5) execution will start with transport dataType and THEN continue down to \"*\" if needed\n\t */\n\tprefilters = {},\n\n\t/* Transports bindings\n\t * 1) key is the dataType\n\t * 2) the catchall symbol \"*\" can be used\n\t * 3) selection will start with transport dataType and THEN go to \"*\" if needed\n\t */\n\ttransports = {},\n\n\t// Avoid comment-prolog char sequence (#10098); must appease lint and evade compression\n\tallTypes = \"*/\".concat( \"*\" ),\n\n\t// Anchor tag for parsing the document origin\n\toriginAnchor = document.createElement( \"a\" );\n\toriginAnchor.href = location.href;\n\n// Base \"constructor\" for jQuery.ajaxPrefilter and jQuery.ajaxTransport\nfunction addToPrefiltersOrTransports( structure ) {\n\n\t// dataTypeExpression is optional and defaults to \"*\"\n\treturn function( dataTypeExpression, func ) {\n\n\t\tif ( typeof dataTypeExpression !== \"string\" ) {\n\t\t\tfunc = dataTypeExpression;\n\t\t\tdataTypeExpression = \"*\";\n\t\t}\n\n\t\tvar dataType,\n\t\t\ti = 0,\n\t\t\tdataTypes = dataTypeExpression.toLowerCase().match( rnothtmlwhite ) || [];\n\n\t\tif ( jQuery.isFunction( func ) ) {\n\n\t\t\t// For each dataType in the dataTypeExpression\n\t\t\twhile ( ( dataType = dataTypes[ i++ ] ) ) {\n\n\t\t\t\t// Prepend if requested\n\t\t\t\tif ( dataType[ 0 ] === \"+\" ) {\n\t\t\t\t\tdataType = dataType.slice( 1 ) || \"*\";\n\t\t\t\t\t( structure[ dataType ] = structure[ dataType ] || [] ).unshift( func );\n\n\t\t\t\t// Otherwise append\n\t\t\t\t} else {\n\t\t\t\t\t( structure[ dataType ] = structure[ dataType ] || [] ).push( func );\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t};\n}\n\n// Base inspection function for prefilters and transports\nfunction inspectPrefiltersOrTransports( structure, options, originalOptions, jqXHR ) {\n\n\tvar inspected = {},\n\t\tseekingTransport = ( structure === transports );\n\n\tfunction inspect( dataType ) {\n\t\tvar selected;\n\t\tinspected[ dataType ] = true;\n\t\tjQuery.each( structure[ dataType ] || [], function( _, prefilterOrFactory ) {\n\t\t\tvar dataTypeOrTransport = prefilterOrFactory( options, originalOptions, jqXHR );\n\t\t\tif ( typeof dataTypeOrTransport === \"string\" &&\n\t\t\t\t!seekingTransport && !inspected[ dataTypeOrTransport ] ) {\n\n\t\t\t\toptions.dataTypes.unshift( dataTypeOrTransport );\n\t\t\t\tinspect( dataTypeOrTransport );\n\t\t\t\treturn false;\n\t\t\t} else if ( seekingTransport ) {\n\t\t\t\treturn !( selected = dataTypeOrTransport );\n\t\t\t}\n\t\t} );\n\t\treturn selected;\n\t}\n\n\treturn inspect( options.dataTypes[ 0 ] ) || !inspected[ \"*\" ] && inspect( \"*\" );\n}\n\n// A special extend for ajax options\n// that takes \"flat\" options (not to be deep extended)\n// Fixes #9887\nfunction ajaxExtend( target, src ) {\n\tvar key, deep,\n\t\tflatOptions = jQuery.ajaxSettings.flatOptions || {};\n\n\tfor ( key in src ) {\n\t\tif ( src[ key ] !== undefined ) {\n\t\t\t( flatOptions[ key ] ? target : ( deep || ( deep = {} ) ) )[ key ] = src[ key ];\n\t\t}\n\t}\n\tif ( deep ) {\n\t\tjQuery.extend( true, target, deep );\n\t}\n\n\treturn target;\n}\n\n/* Handles responses to an ajax request:\n * - finds the right dataType (mediates between content-type and expected dataType)\n * - returns the corresponding response\n */\nfunction ajaxHandleResponses( s, jqXHR, responses ) {\n\n\tvar ct, type, finalDataType, firstDataType,\n\t\tcontents = s.contents,\n\t\tdataTypes = s.dataTypes;\n\n\t// Remove auto dataType and get content-type in the process\n\twhile ( dataTypes[ 0 ] === \"*\" ) {\n\t\tdataTypes.shift();\n\t\tif ( ct === undefined ) {\n\t\t\tct = s.mimeType || jqXHR.getResponseHeader( \"Content-Type\" );\n\t\t}\n\t}\n\n\t// Check if we're dealing with a known content-type\n\tif ( ct ) {\n\t\tfor ( type in contents ) {\n\t\t\tif ( contents[ type ] && contents[ type ].test( ct ) ) {\n\t\t\t\tdataTypes.unshift( type );\n\t\t\t\tbreak;\n\t\t\t}\n\t\t}\n\t}\n\n\t// Check to see if we have a response for the expected dataType\n\tif ( dataTypes[ 0 ] in responses ) {\n\t\tfinalDataType = dataTypes[ 0 ];\n\t} else {\n\n\t\t// Try convertible dataTypes\n\t\tfor ( type in responses ) {\n\t\t\tif ( !dataTypes[ 0 ] || s.converters[ type + \" \" + dataTypes[ 0 ] ] ) {\n\t\t\t\tfinalDataType = type;\n\t\t\t\tbreak;\n\t\t\t}\n\t\t\tif ( !firstDataType ) {\n\t\t\t\tfirstDataType = type;\n\t\t\t}\n\t\t}\n\n\t\t// Or just use first one\n\t\tfinalDataType = finalDataType || firstDataType;\n\t}\n\n\t// If we found a dataType\n\t// We add the dataType to the list if needed\n\t// and return the corresponding response\n\tif ( finalDataType ) {\n\t\tif ( finalDataType !== dataTypes[ 0 ] ) {\n\t\t\tdataTypes.unshift( finalDataType );\n\t\t}\n\t\treturn responses[ finalDataType ];\n\t}\n}\n\n/* Chain conversions given the request and the original response\n * Also sets the responseXXX fields on the jqXHR instance\n */\nfunction ajaxConvert( s, response, jqXHR, isSuccess ) {\n\tvar conv2, current, conv, tmp, prev,\n\t\tconverters = {},\n\n\t\t// Work with a copy of dataTypes in case we need to modify it for conversion\n\t\tdataTypes = s.dataTypes.slice();\n\n\t// Create converters map with lowercased keys\n\tif ( dataTypes[ 1 ] ) {\n\t\tfor ( conv in s.converters ) {\n\t\t\tconverters[ conv.toLowerCase() ] = s.converters[ conv ];\n\t\t}\n\t}\n\n\tcurrent = dataTypes.shift();\n\n\t// Convert to each sequential dataType\n\twhile ( current ) {\n\n\t\tif ( s.responseFields[ current ] ) {\n\t\t\tjqXHR[ s.responseFields[ current ] ] = response;\n\t\t}\n\n\t\t// Apply the dataFilter if provided\n\t\tif ( !prev && isSuccess && s.dataFilter ) {\n\t\t\tresponse = s.dataFilter( response, s.dataType );\n\t\t}\n\n\t\tprev = current;\n\t\tcurrent = dataTypes.shift();\n\n\t\tif ( current ) {\n\n\t\t\t// There's only work to do if current dataType is non-auto\n\t\t\tif ( current === \"*\" ) {\n\n\t\t\t\tcurrent = prev;\n\n\t\t\t// Convert response if prev dataType is non-auto and differs from current\n\t\t\t} else if ( prev !== \"*\" && prev !== current ) {\n\n\t\t\t\t// Seek a direct converter\n\t\t\t\tconv = converters[ prev + \" \" + current ] || converters[ \"* \" + current ];\n\n\t\t\t\t// If none found, seek a pair\n\t\t\t\tif ( !conv ) {\n\t\t\t\t\tfor ( conv2 in converters ) {\n\n\t\t\t\t\t\t// If conv2 outputs current\n\t\t\t\t\t\ttmp = conv2.split( \" \" );\n\t\t\t\t\t\tif ( tmp[ 1 ] === current ) {\n\n\t\t\t\t\t\t\t// If prev can be converted to accepted input\n\t\t\t\t\t\t\tconv = converters[ prev + \" \" + tmp[ 0 ] ] ||\n\t\t\t\t\t\t\t\tconverters[ \"* \" + tmp[ 0 ] ];\n\t\t\t\t\t\t\tif ( conv ) {\n\n\t\t\t\t\t\t\t\t// Condense equivalence converters\n\t\t\t\t\t\t\t\tif ( conv === true ) {\n\t\t\t\t\t\t\t\t\tconv = converters[ conv2 ];\n\n\t\t\t\t\t\t\t\t// Otherwise, insert the intermediate dataType\n\t\t\t\t\t\t\t\t} else if ( converters[ conv2 ] !== true ) {\n\t\t\t\t\t\t\t\t\tcurrent = tmp[ 0 ];\n\t\t\t\t\t\t\t\t\tdataTypes.unshift( tmp[ 1 ] );\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\tbreak;\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}\n\n\t\t\t\t// Apply converter (if not an equivalence)\n\t\t\t\tif ( conv !== true ) {\n\n\t\t\t\t\t// Unless errors are allowed to bubble, catch and return them\n\t\t\t\t\tif ( conv && s.throws ) {\n\t\t\t\t\t\tresponse = conv( response );\n\t\t\t\t\t} else {\n\t\t\t\t\t\ttry {\n\t\t\t\t\t\t\tresponse = conv( response );\n\t\t\t\t\t\t} catch ( e ) {\n\t\t\t\t\t\t\treturn {\n\t\t\t\t\t\t\t\tstate: \"parsererror\",\n\t\t\t\t\t\t\t\terror: conv ? e : \"No conversion from \" + prev + \" to \" + current\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}\n\t\t\t}\n\t\t}\n\t}\n\n\treturn { state: \"success\", data: response };\n}\n\njQuery.extend( {\n\n\t// Counter for holding the number of active queries\n\tactive: 0,\n\n\t// Last-Modified header cache for next request\n\tlastModified: {},\n\tetag: {},\n\n\tajaxSettings: {\n\t\turl: location.href,\n\t\ttype: \"GET\",\n\t\tisLocal: rlocalProtocol.test( location.protocol ),\n\t\tglobal: true,\n\t\tprocessData: true,\n\t\tasync: true,\n\t\tcontentType: \"application/x-www-form-urlencoded; charset=UTF-8\",\n\n\t\t/*\n\t\ttimeout: 0,\n\t\tdata: null,\n\t\tdataType: null,\n\t\tusername: null,\n\t\tpassword: null,\n\t\tcache: null,\n\t\tthrows: false,\n\t\ttraditional: false,\n\t\theaders: {},\n\t\t*/\n\n\t\taccepts: {\n\t\t\t\"*\": allTypes,\n\t\t\ttext: \"text/plain\",\n\t\t\thtml: \"text/html\",\n\t\t\txml: \"application/xml, text/xml\",\n\t\t\tjson: \"application/json, text/javascript\"\n\t\t},\n\n\t\tcontents: {\n\t\t\txml: /\\bxml\\b/,\n\t\t\thtml: /\\bhtml/,\n\t\t\tjson: /\\bjson\\b/\n\t\t},\n\n\t\tresponseFields: {\n\t\t\txml: \"responseXML\",\n\t\t\ttext: \"responseText\",\n\t\t\tjson: \"responseJSON\"\n\t\t},\n\n\t\t// Data converters\n\t\t// Keys separate source (or catchall \"*\") and destination types with a single space\n\t\tconverters: {\n\n\t\t\t// Convert anything to text\n\t\t\t\"* text\": String,\n\n\t\t\t// Text to html (true = no transformation)\n\t\t\t\"text html\": true,\n\n\t\t\t// Evaluate text as a json expression\n\t\t\t\"text json\": JSON.parse,\n\n\t\t\t// Parse text as xml\n\t\t\t\"text xml\": jQuery.parseXML\n\t\t},\n\n\t\t// For options that shouldn't be deep extended:\n\t\t// you can add your own custom options here if\n\t\t// and when you create one that shouldn't be\n\t\t// deep extended (see ajaxExtend)\n\t\tflatOptions: {\n\t\t\turl: true,\n\t\t\tcontext: true\n\t\t}\n\t},\n\n\t// Creates a full fledged settings object into target\n\t// with both ajaxSettings and settings fields.\n\t// If target is omitted, writes into ajaxSettings.\n\tajaxSetup: function( target, settings ) {\n\t\treturn settings ?\n\n\t\t\t// Building a settings object\n\t\t\tajaxExtend( ajaxExtend( target, jQuery.ajaxSettings ), settings ) :\n\n\t\t\t// Extending ajaxSettings\n\t\t\tajaxExtend( jQuery.ajaxSettings, target );\n\t},\n\n\tajaxPrefilter: addToPrefiltersOrTransports( prefilters ),\n\tajaxTransport: addToPrefiltersOrTransports( transports ),\n\n\t// Main method\n\tajax: function( url, options ) {\n\n\t\t// If url is an object, simulate pre-1.5 signature\n\t\tif ( typeof url === \"object\" ) {\n\t\t\toptions = url;\n\t\t\turl = undefined;\n\t\t}\n\n\t\t// Force options to be an object\n\t\toptions = options || {};\n\n\t\tvar transport,\n\n\t\t\t// URL without anti-cache param\n\t\t\tcacheURL,\n\n\t\t\t// Response headers\n\t\t\tresponseHeadersString,\n\t\t\tresponseHeaders,\n\n\t\t\t// timeout handle\n\t\t\ttimeoutTimer,\n\n\t\t\t// Url cleanup var\n\t\t\turlAnchor,\n\n\t\t\t// Request state (becomes false upon send and true upon completion)\n\t\t\tcompleted,\n\n\t\t\t// To know if global events are to be dispatched\n\t\t\tfireGlobals,\n\n\t\t\t// Loop variable\n\t\t\ti,\n\n\t\t\t// uncached part of the url\n\t\t\tuncached,\n\n\t\t\t// Create the final options object\n\t\t\ts = jQuery.ajaxSetup( {}, options ),\n\n\t\t\t// Callbacks context\n\t\t\tcallbackContext = s.context || s,\n\n\t\t\t// Context for global events is callbackContext if it is a DOM node or jQuery collection\n\t\t\tglobalEventContext = s.context &&\n\t\t\t\t( callbackContext.nodeType || callbackContext.jquery ) ?\n\t\t\t\t\tjQuery( callbackContext ) :\n\t\t\t\t\tjQuery.event,\n\n\t\t\t// Deferreds\n\t\t\tdeferred = jQuery.Deferred(),\n\t\t\tcompleteDeferred = jQuery.Callbacks( \"once memory\" ),\n\n\t\t\t// Status-dependent callbacks\n\t\t\tstatusCode = s.statusCode || {},\n\n\t\t\t// Headers (they are sent all at once)\n\t\t\trequestHeaders = {},\n\t\t\trequestHeadersNames = {},\n\n\t\t\t// Default abort message\n\t\t\tstrAbort = \"canceled\",\n\n\t\t\t// Fake xhr\n\t\t\tjqXHR = {\n\t\t\t\treadyState: 0,\n\n\t\t\t\t// Builds headers hashtable if needed\n\t\t\t\tgetResponseHeader: function( key ) {\n\t\t\t\t\tvar match;\n\t\t\t\t\tif ( completed ) {\n\t\t\t\t\t\tif ( !responseHeaders ) {\n\t\t\t\t\t\t\tresponseHeaders = {};\n\t\t\t\t\t\t\twhile ( ( match = rheaders.exec( responseHeadersString ) ) ) {\n\t\t\t\t\t\t\t\tresponseHeaders[ match[ 1 ].toLowerCase() ] = match[ 2 ];\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\t\t\t\t\t\tmatch = responseHeaders[ key.toLowerCase() ];\n\t\t\t\t\t}\n\t\t\t\t\treturn match == null ? null : match;\n\t\t\t\t},\n\n\t\t\t\t// Raw string\n\t\t\t\tgetAllResponseHeaders: function() {\n\t\t\t\t\treturn completed ? responseHeadersString : null;\n\t\t\t\t},\n\n\t\t\t\t// Caches the header\n\t\t\t\tsetRequestHeader: function( name, value ) {\n\t\t\t\t\tif ( completed == null ) {\n\t\t\t\t\t\tname = requestHeadersNames[ name.toLowerCase() ] =\n\t\t\t\t\t\t\trequestHeadersNames[ name.toLowerCase() ] || name;\n\t\t\t\t\t\trequestHeaders[ name ] = value;\n\t\t\t\t\t}\n\t\t\t\t\treturn this;\n\t\t\t\t},\n\n\t\t\t\t// Overrides response content-type header\n\t\t\t\toverrideMimeType: function( type ) {\n\t\t\t\t\tif ( completed == null ) {\n\t\t\t\t\t\ts.mimeType = type;\n\t\t\t\t\t}\n\t\t\t\t\treturn this;\n\t\t\t\t},\n\n\t\t\t\t// Status-dependent callbacks\n\t\t\t\tstatusCode: function( map ) {\n\t\t\t\t\tvar code;\n\t\t\t\t\tif ( map ) {\n\t\t\t\t\t\tif ( completed ) {\n\n\t\t\t\t\t\t\t// Execute the appropriate callbacks\n\t\t\t\t\t\t\tjqXHR.always( map[ jqXHR.status ] );\n\t\t\t\t\t\t} else {\n\n\t\t\t\t\t\t\t// Lazy-add the new callbacks in a way that preserves old ones\n\t\t\t\t\t\t\tfor ( code in map ) {\n\t\t\t\t\t\t\t\tstatusCode[ code ] = [ statusCode[ code ], map[ code ] ];\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\treturn this;\n\t\t\t\t},\n\n\t\t\t\t// Cancel the request\n\t\t\t\tabort: function( statusText ) {\n\t\t\t\t\tvar finalText = statusText || strAbort;\n\t\t\t\t\tif ( transport ) {\n\t\t\t\t\t\ttransport.abort( finalText );\n\t\t\t\t\t}\n\t\t\t\t\tdone( 0, finalText );\n\t\t\t\t\treturn this;\n\t\t\t\t}\n\t\t\t};\n\n\t\t// Attach deferreds\n\t\tdeferred.promise( jqXHR );\n\n\t\t// Add protocol if not provided (prefilters might expect it)\n\t\t// Handle falsy url in the settings object (#10093: consistency with old signature)\n\t\t// We also use the url parameter if available\n\t\ts.url = ( ( url || s.url || location.href ) + \"\" )\n\t\t\t.replace( rprotocol, location.protocol + \"//\" );\n\n\t\t// Alias method option to type as per ticket #12004\n\t\ts.type = options.method || options.type || s.method || s.type;\n\n\t\t// Extract dataTypes list\n\t\ts.dataTypes = ( s.dataType || \"*\" ).toLowerCase().match( rnothtmlwhite ) || [ \"\" ];\n\n\t\t// A cross-domain request is in order when the origin doesn't match the current origin.\n\t\tif ( s.crossDomain == null ) {\n\t\t\turlAnchor = document.createElement( \"a\" );\n\n\t\t\t// Support: IE <=8 - 11, Edge 12 - 13\n\t\t\t// IE throws exception on accessing the href property if url is malformed,\n\t\t\t// e.g. http://example.com:80x/\n\t\t\ttry {\n\t\t\t\turlAnchor.href = s.url;\n\n\t\t\t\t// Support: IE <=8 - 11 only\n\t\t\t\t// Anchor's host property isn't correctly set when s.url is relative\n\t\t\t\turlAnchor.href = urlAnchor.href;\n\t\t\t\ts.crossDomain = originAnchor.protocol + \"//\" + originAnchor.host !==\n\t\t\t\t\turlAnchor.protocol + \"//\" + urlAnchor.host;\n\t\t\t} catch ( e ) {\n\n\t\t\t\t// If there is an error parsing the URL, assume it is crossDomain,\n\t\t\t\t// it can be rejected by the transport if it is invalid\n\t\t\t\ts.crossDomain = true;\n\t\t\t}\n\t\t}\n\n\t\t// Convert data if not already a string\n\t\tif ( s.data && s.processData && typeof s.data !== \"string\" ) {\n\t\t\ts.data = jQuery.param( s.data, s.traditional );\n\t\t}\n\n\t\t// Apply prefilters\n\t\tinspectPrefiltersOrTransports( prefilters, s, options, jqXHR );\n\n\t\t// If request was aborted inside a prefilter, stop there\n\t\tif ( completed ) {\n\t\t\treturn jqXHR;\n\t\t}\n\n\t\t// We can fire global events as of now if asked to\n\t\t// Don't fire events if jQuery.event is undefined in an AMD-usage scenario (#15118)\n\t\tfireGlobals = jQuery.event && s.global;\n\n\t\t// Watch for a new set of requests\n\t\tif ( fireGlobals && jQuery.active++ === 0 ) {\n\t\t\tjQuery.event.trigger( \"ajaxStart\" );\n\t\t}\n\n\t\t// Uppercase the type\n\t\ts.type = s.type.toUpperCase();\n\n\t\t// Determine if request has content\n\t\ts.hasContent = !rnoContent.test( s.type );\n\n\t\t// Save the URL in case we're toying with the If-Modified-Since\n\t\t// and/or If-None-Match header later on\n\t\t// Remove hash to simplify url manipulation\n\t\tcacheURL = s.url.replace( rhash, \"\" );\n\n\t\t// More options handling for requests with no content\n\t\tif ( !s.hasContent ) {\n\n\t\t\t// Remember the hash so we can put it back\n\t\t\tuncached = s.url.slice( cacheURL.length );\n\n\t\t\t// If data is available, append data to url\n\t\t\tif ( s.data ) {\n\t\t\t\tcacheURL += ( rquery.test( cacheURL ) ? \"&\" : \"?\" ) + s.data;\n\n\t\t\t\t// #9682: remove data so that it's not used in an eventual retry\n\t\t\t\tdelete s.data;\n\t\t\t}\n\n\t\t\t// Add or update anti-cache param if needed\n\t\t\tif ( s.cache === false ) {\n\t\t\t\tcacheURL = cacheURL.replace( rantiCache, \"$1\" );\n\t\t\t\tuncached = ( rquery.test( cacheURL ) ? \"&\" : \"?\" ) + \"_=\" + ( nonce++ ) + uncached;\n\t\t\t}\n\n\t\t\t// Put hash and anti-cache on the URL that will be requested (gh-1732)\n\t\t\ts.url = cacheURL + uncached;\n\n\t\t// Change '%20' to '+' if this is encoded form body content (gh-2658)\n\t\t} else if ( s.data && s.processData &&\n\t\t\t( s.contentType || \"\" ).indexOf( \"application/x-www-form-urlencoded\" ) === 0 ) {\n\t\t\ts.data = s.data.replace( r20, \"+\" );\n\t\t}\n\n\t\t// Set the If-Modified-Since and/or If-None-Match header, if in ifModified mode.\n\t\tif ( s.ifModified ) {\n\t\t\tif ( jQuery.lastModified[ cacheURL ] ) {\n\t\t\t\tjqXHR.setRequestHeader( \"If-Modified-Since\", jQuery.lastModified[ cacheURL ] );\n\t\t\t}\n\t\t\tif ( jQuery.etag[ cacheURL ] ) {\n\t\t\t\tjqXHR.setRequestHeader( \"If-None-Match\", jQuery.etag[ cacheURL ] );\n\t\t\t}\n\t\t}\n\n\t\t// Set the correct header, if data is being sent\n\t\tif ( s.data && s.hasContent && s.contentType !== false || options.contentType ) {\n\t\t\tjqXHR.setRequestHeader( \"Content-Type\", s.contentType );\n\t\t}\n\n\t\t// Set the Accepts header for the server, depending on the dataType\n\t\tjqXHR.setRequestHeader(\n\t\t\t\"Accept\",\n\t\t\ts.dataTypes[ 0 ] && s.accepts[ s.dataTypes[ 0 ] ] ?\n\t\t\t\ts.accepts[ s.dataTypes[ 0 ] ] +\n\t\t\t\t\t( s.dataTypes[ 0 ] !== \"*\" ? \", \" + allTypes + \"; q=0.01\" : \"\" ) :\n\t\t\t\ts.accepts[ \"*\" ]\n\t\t);\n\n\t\t// Check for headers option\n\t\tfor ( i in s.headers ) {\n\t\t\tjqXHR.setRequestHeader( i, s.headers[ i ] );\n\t\t}\n\n\t\t// Allow custom headers/mimetypes and early abort\n\t\tif ( s.beforeSend &&\n\t\t\t( s.beforeSend.call( callbackContext, jqXHR, s ) === false || completed ) ) {\n\n\t\t\t// Abort if not done already and return\n\t\t\treturn jqXHR.abort();\n\t\t}\n\n\t\t// Aborting is no longer a cancellation\n\t\tstrAbort = \"abort\";\n\n\t\t// Install callbacks on deferreds\n\t\tcompleteDeferred.add( s.complete );\n\t\tjqXHR.done( s.success );\n\t\tjqXHR.fail( s.error );\n\n\t\t// Get transport\n\t\ttransport = inspectPrefiltersOrTransports( transports, s, options, jqXHR );\n\n\t\t// If no transport, we auto-abort\n\t\tif ( !transport ) {\n\t\t\tdone( -1, \"No Transport\" );\n\t\t} else {\n\t\t\tjqXHR.readyState = 1;\n\n\t\t\t// Send global event\n\t\t\tif ( fireGlobals ) {\n\t\t\t\tglobalEventContext.trigger( \"ajaxSend\", [ jqXHR, s ] );\n\t\t\t}\n\n\t\t\t// If request was aborted inside ajaxSend, stop there\n\t\t\tif ( completed ) {\n\t\t\t\treturn jqXHR;\n\t\t\t}\n\n\t\t\t// Timeout\n\t\t\tif ( s.async && s.timeout > 0 ) {\n\t\t\t\ttimeoutTimer = window.setTimeout( function() {\n\t\t\t\t\tjqXHR.abort( \"timeout\" );\n\t\t\t\t}, s.timeout );\n\t\t\t}\n\n\t\t\ttry {\n\t\t\t\tcompleted = false;\n\t\t\t\ttransport.send( requestHeaders, done );\n\t\t\t} catch ( e ) {\n\n\t\t\t\t// Rethrow post-completion exceptions\n\t\t\t\tif ( completed ) {\n\t\t\t\t\tthrow e;\n\t\t\t\t}\n\n\t\t\t\t// Propagate others as results\n\t\t\t\tdone( -1, e );\n\t\t\t}\n\t\t}\n\n\t\t// Callback for when everything is done\n\t\tfunction done( status, nativeStatusText, responses, headers ) {\n\t\t\tvar isSuccess, success, error, response, modified,\n\t\t\t\tstatusText = nativeStatusText;\n\n\t\t\t// Ignore repeat invocations\n\t\t\tif ( completed ) {\n\t\t\t\treturn;\n\t\t\t}\n\n\t\t\tcompleted = true;\n\n\t\t\t// Clear timeout if it exists\n\t\t\tif ( timeoutTimer ) {\n\t\t\t\twindow.clearTimeout( timeoutTimer );\n\t\t\t}\n\n\t\t\t// Dereference transport for early garbage collection\n\t\t\t// (no matter how long the jqXHR object will be used)\n\t\t\ttransport = undefined;\n\n\t\t\t// Cache response headers\n\t\t\tresponseHeadersString = headers || \"\";\n\n\t\t\t// Set readyState\n\t\t\tjqXHR.readyState = status > 0 ? 4 : 0;\n\n\t\t\t// Determine if successful\n\t\t\tisSuccess = status >= 200 && status < 300 || status === 304;\n\n\t\t\t// Get response data\n\t\t\tif ( responses ) {\n\t\t\t\tresponse = ajaxHandleResponses( s, jqXHR, responses );\n\t\t\t}\n\n\t\t\t// Convert no matter what (that way responseXXX fields are always set)\n\t\t\tresponse = ajaxConvert( s, response, jqXHR, isSuccess );\n\n\t\t\t// If successful, handle type chaining\n\t\t\tif ( isSuccess ) {\n\n\t\t\t\t// Set the If-Modified-Since and/or If-None-Match header, if in ifModified mode.\n\t\t\t\tif ( s.ifModified ) {\n\t\t\t\t\tmodified = jqXHR.getResponseHeader( \"Last-Modified\" );\n\t\t\t\t\tif ( modified ) {\n\t\t\t\t\t\tjQuery.lastModified[ cacheURL ] = modified;\n\t\t\t\t\t}\n\t\t\t\t\tmodified = jqXHR.getResponseHeader( \"etag\" );\n\t\t\t\t\tif ( modified ) {\n\t\t\t\t\t\tjQuery.etag[ cacheURL ] = modified;\n\t\t\t\t\t}\n\t\t\t\t}\n\n\t\t\t\t// if no content\n\t\t\t\tif ( status === 204 || s.type === \"HEAD\" ) {\n\t\t\t\t\tstatusText = \"nocontent\";\n\n\t\t\t\t// if not modified\n\t\t\t\t} else if ( status === 304 ) {\n\t\t\t\t\tstatusText = \"notmodified\";\n\n\t\t\t\t// If we have data, let's convert it\n\t\t\t\t} else {\n\t\t\t\t\tstatusText = response.state;\n\t\t\t\t\tsuccess = response.data;\n\t\t\t\t\terror = response.error;\n\t\t\t\t\tisSuccess = !error;\n\t\t\t\t}\n\t\t\t} else {\n\n\t\t\t\t// Extract error from statusText and normalize for non-aborts\n\t\t\t\terror = statusText;\n\t\t\t\tif ( status || !statusText ) {\n\t\t\t\t\tstatusText = \"error\";\n\t\t\t\t\tif ( status < 0 ) {\n\t\t\t\t\t\tstatus = 0;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\n\t\t\t// Set data for the fake xhr object\n\t\t\tjqXHR.status = status;\n\t\t\tjqXHR.statusText = ( nativeStatusText || statusText ) + \"\";\n\n\t\t\t// Success/Error\n\t\t\tif ( isSuccess ) {\n\t\t\t\tdeferred.resolveWith( callbackContext, [ success, statusText, jqXHR ] );\n\t\t\t} else {\n\t\t\t\tdeferred.rejectWith( callbackContext, [ jqXHR, statusText, error ] );\n\t\t\t}\n\n\t\t\t// Status-dependent callbacks\n\t\t\tjqXHR.statusCode( statusCode );\n\t\t\tstatusCode = undefined;\n\n\t\t\tif ( fireGlobals ) {\n\t\t\t\tglobalEventContext.trigger( isSuccess ? \"ajaxSuccess\" : \"ajaxError\",\n\t\t\t\t\t[ jqXHR, s, isSuccess ? success : error ] );\n\t\t\t}\n\n\t\t\t// Complete\n\t\t\tcompleteDeferred.fireWith( callbackContext, [ jqXHR, statusText ] );\n\n\t\t\tif ( fireGlobals ) {\n\t\t\t\tglobalEventContext.trigger( \"ajaxComplete\", [ jqXHR, s ] );\n\n\t\t\t\t// Handle the global AJAX counter\n\t\t\t\tif ( !( --jQuery.active ) ) {\n\t\t\t\t\tjQuery.event.trigger( \"ajaxStop\" );\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\treturn jqXHR;\n\t},\n\n\tgetJSON: function( url, data, callback ) {\n\t\treturn jQuery.get( url, data, callback, \"json\" );\n\t},\n\n\tgetScript: function( url, callback ) {\n\t\treturn jQuery.get( url, undefined, callback, \"script\" );\n\t}\n} );\n\njQuery.each( [ \"get\", \"post\" ], function( i, method ) {\n\tjQuery[ method ] = function( url, data, callback, type ) {\n\n\t\t// Shift arguments if data argument was omitted\n\t\tif ( jQuery.isFunction( data ) ) {\n\t\t\ttype = type || callback;\n\t\t\tcallback = data;\n\t\t\tdata = undefined;\n\t\t}\n\n\t\t// The url can be an options object (which then must have .url)\n\t\treturn jQuery.ajax( jQuery.extend( {\n\t\t\turl: url,\n\t\t\ttype: method,\n\t\t\tdataType: type,\n\t\t\tdata: data,\n\t\t\tsuccess: callback\n\t\t}, jQuery.isPlainObject( url ) && url ) );\n\t};\n} );\n\n\njQuery._evalUrl = function( url ) {\n\treturn jQuery.ajax( {\n\t\turl: url,\n\n\t\t// Make this explicit, since user can override this through ajaxSetup (#11264)\n\t\ttype: \"GET\",\n\t\tdataType: \"script\",\n\t\tcache: true,\n\t\tasync: false,\n\t\tglobal: false,\n\t\t\"throws\": true\n\t} );\n};\n\n\njQuery.fn.extend( {\n\twrapAll: function( html ) {\n\t\tvar wrap;\n\n\t\tif ( this[ 0 ] ) {\n\t\t\tif ( jQuery.isFunction( html ) ) {\n\t\t\t\thtml = html.call( this[ 0 ] );\n\t\t\t}\n\n\t\t\t// The elements to wrap the target around\n\t\t\twrap = jQuery( html, this[ 0 ].ownerDocument ).eq( 0 ).clone( true );\n\n\t\t\tif ( this[ 0 ].parentNode ) {\n\t\t\t\twrap.insertBefore( this[ 0 ] );\n\t\t\t}\n\n\t\t\twrap.map( function() {\n\t\t\t\tvar elem = this;\n\n\t\t\t\twhile ( elem.firstElementChild ) {\n\t\t\t\t\telem = elem.firstElementChild;\n\t\t\t\t}\n\n\t\t\t\treturn elem;\n\t\t\t} ).append( this );\n\t\t}\n\n\t\treturn this;\n\t},\n\n\twrapInner: function( html ) {\n\t\tif ( jQuery.isFunction( html ) ) {\n\t\t\treturn this.each( function( i ) {\n\t\t\t\tjQuery( this ).wrapInner( html.call( this, i ) );\n\t\t\t} );\n\t\t}\n\n\t\treturn this.each( function() {\n\t\t\tvar self = jQuery( this ),\n\t\t\t\tcontents = self.contents();\n\n\t\t\tif ( contents.length ) {\n\t\t\t\tcontents.wrapAll( html );\n\n\t\t\t} else {\n\t\t\t\tself.append( html );\n\t\t\t}\n\t\t} );\n\t},\n\n\twrap: function( html ) {\n\t\tvar isFunction = jQuery.isFunction( html );\n\n\t\treturn this.each( function( i ) {\n\t\t\tjQuery( this ).wrapAll( isFunction ? html.call( this, i ) : html );\n\t\t} );\n\t},\n\n\tunwrap: function( selector ) {\n\t\tthis.parent( selector ).not( \"body\" ).each( function() {\n\t\t\tjQuery( this ).replaceWith( this.childNodes );\n\t\t} );\n\t\treturn this;\n\t}\n} );\n\n\njQuery.expr.pseudos.hidden = function( elem ) {\n\treturn !jQuery.expr.pseudos.visible( elem );\n};\njQuery.expr.pseudos.visible = function( elem ) {\n\treturn !!( elem.offsetWidth || elem.offsetHeight || elem.getClientRects().length );\n};\n\n\n\n\njQuery.ajaxSettings.xhr = function() {\n\ttry {\n\t\treturn new window.XMLHttpRequest();\n\t} catch ( e ) {}\n};\n\nvar xhrSuccessStatus = {\n\n\t\t// File protocol always yields status code 0, assume 200\n\t\t0: 200,\n\n\t\t// Support: IE <=9 only\n\t\t// #1450: sometimes IE returns 1223 when it should be 204\n\t\t1223: 204\n\t},\n\txhrSupported = jQuery.ajaxSettings.xhr();\n\nsupport.cors = !!xhrSupported && ( \"withCredentials\" in xhrSupported );\nsupport.ajax = xhrSupported = !!xhrSupported;\n\njQuery.ajaxTransport( function( options ) {\n\tvar callback, errorCallback;\n\n\t// Cross domain only allowed if supported through XMLHttpRequest\n\tif ( support.cors || xhrSupported && !options.crossDomain ) {\n\t\treturn {\n\t\t\tsend: function( headers, complete ) {\n\t\t\t\tvar i,\n\t\t\t\t\txhr = options.xhr();\n\n\t\t\t\txhr.open(\n\t\t\t\t\toptions.type,\n\t\t\t\t\toptions.url,\n\t\t\t\t\toptions.async,\n\t\t\t\t\toptions.username,\n\t\t\t\t\toptions.password\n\t\t\t\t);\n\n\t\t\t\t// Apply custom fields if provided\n\t\t\t\tif ( options.xhrFields ) {\n\t\t\t\t\tfor ( i in options.xhrFields ) {\n\t\t\t\t\t\txhr[ i ] = options.xhrFields[ i ];\n\t\t\t\t\t}\n\t\t\t\t}\n\n\t\t\t\t// Override mime type if needed\n\t\t\t\tif ( options.mimeType && xhr.overrideMimeType ) {\n\t\t\t\t\txhr.overrideMimeType( options.mimeType );\n\t\t\t\t}\n\n\t\t\t\t// X-Requested-With header\n\t\t\t\t// For cross-domain requests, seeing as conditions for a preflight are\n\t\t\t\t// akin to a jigsaw puzzle, we simply never set it to be sure.\n\t\t\t\t// (it can always be set on a per-request basis or even using ajaxSetup)\n\t\t\t\t// For same-domain requests, won't change header if already provided.\n\t\t\t\tif ( !options.crossDomain && !headers[ \"X-Requested-With\" ] ) {\n\t\t\t\t\theaders[ \"X-Requested-With\" ] = \"XMLHttpRequest\";\n\t\t\t\t}\n\n\t\t\t\t// Set headers\n\t\t\t\tfor ( i in headers ) {\n\t\t\t\t\txhr.setRequestHeader( i, headers[ i ] );\n\t\t\t\t}\n\n\t\t\t\t// Callback\n\t\t\t\tcallback = function( type ) {\n\t\t\t\t\treturn function() {\n\t\t\t\t\t\tif ( callback ) {\n\t\t\t\t\t\t\tcallback = errorCallback = xhr.onload =\n\t\t\t\t\t\t\t\txhr.onerror = xhr.onabort = xhr.onreadystatechange = null;\n\n\t\t\t\t\t\t\tif ( type === \"abort\" ) {\n\t\t\t\t\t\t\t\txhr.abort();\n\t\t\t\t\t\t\t} else if ( type === \"error\" ) {\n\n\t\t\t\t\t\t\t\t// Support: IE <=9 only\n\t\t\t\t\t\t\t\t// On a manual native abort, IE9 throws\n\t\t\t\t\t\t\t\t// errors on any property access that is not readyState\n\t\t\t\t\t\t\t\tif ( typeof xhr.status !== \"number\" ) {\n\t\t\t\t\t\t\t\t\tcomplete( 0, \"error\" );\n\t\t\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\t\t\tcomplete(\n\n\t\t\t\t\t\t\t\t\t\t// File: protocol always yields status 0; see #8605, #14207\n\t\t\t\t\t\t\t\t\t\txhr.status,\n\t\t\t\t\t\t\t\t\t\txhr.statusText\n\t\t\t\t\t\t\t\t\t);\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\t\tcomplete(\n\t\t\t\t\t\t\t\t\txhrSuccessStatus[ xhr.status ] || xhr.status,\n\t\t\t\t\t\t\t\t\txhr.statusText,\n\n\t\t\t\t\t\t\t\t\t// Support: IE <=9 only\n\t\t\t\t\t\t\t\t\t// IE9 has no XHR2 but throws on binary (trac-11426)\n\t\t\t\t\t\t\t\t\t// For XHR2 non-text, let the caller handle it (gh-2498)\n\t\t\t\t\t\t\t\t\t( xhr.responseType || \"text\" ) !== \"text\" ||\n\t\t\t\t\t\t\t\t\ttypeof xhr.responseText !== \"string\" ?\n\t\t\t\t\t\t\t\t\t\t{ binary: xhr.response } :\n\t\t\t\t\t\t\t\t\t\t{ text: xhr.responseText },\n\t\t\t\t\t\t\t\t\txhr.getAllResponseHeaders()\n\t\t\t\t\t\t\t\t);\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};\n\n\t\t\t\t// Listen to events\n\t\t\t\txhr.onload = callback();\n\t\t\t\terrorCallback = xhr.onerror = callback( \"error\" );\n\n\t\t\t\t// Support: IE 9 only\n\t\t\t\t// Use onreadystatechange to replace onabort\n\t\t\t\t// to handle uncaught aborts\n\t\t\t\tif ( xhr.onabort !== undefined ) {\n\t\t\t\t\txhr.onabort = errorCallback;\n\t\t\t\t} else {\n\t\t\t\t\txhr.onreadystatechange = function() {\n\n\t\t\t\t\t\t// Check readyState before timeout as it changes\n\t\t\t\t\t\tif ( xhr.readyState === 4 ) {\n\n\t\t\t\t\t\t\t// Allow onerror to be called first,\n\t\t\t\t\t\t\t// but that will not handle a native abort\n\t\t\t\t\t\t\t// Also, save errorCallback to a variable\n\t\t\t\t\t\t\t// as xhr.onerror cannot be accessed\n\t\t\t\t\t\t\twindow.setTimeout( function() {\n\t\t\t\t\t\t\t\tif ( callback ) {\n\t\t\t\t\t\t\t\t\terrorCallback();\n\t\t\t\t\t\t\t\t}\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}\n\n\t\t\t\t// Create the abort callback\n\t\t\t\tcallback = callback( \"abort\" );\n\n\t\t\t\ttry {\n\n\t\t\t\t\t// Do send the request (this may raise an exception)\n\t\t\t\t\txhr.send( options.hasContent && options.data || null );\n\t\t\t\t} catch ( e ) {\n\n\t\t\t\t\t// #14683: Only rethrow if this hasn't been notified as an error yet\n\t\t\t\t\tif ( callback ) {\n\t\t\t\t\t\tthrow e;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t},\n\n\t\t\tabort: function() {\n\t\t\t\tif ( callback ) {\n\t\t\t\t\tcallback();\n\t\t\t\t}\n\t\t\t}\n\t\t};\n\t}\n} );\n\n\n\n\n// Prevent auto-execution of scripts when no explicit dataType was provided (See gh-2432)\njQuery.ajaxPrefilter( function( s ) {\n\tif ( s.crossDomain ) {\n\t\ts.contents.script = false;\n\t}\n} );\n\n// Install script dataType\njQuery.ajaxSetup( {\n\taccepts: {\n\t\tscript: \"text/javascript, application/javascript, \" +\n\t\t\t\"application/ecmascript, application/x-ecmascript\"\n\t},\n\tcontents: {\n\t\tscript: /\\b(?:java|ecma)script\\b/\n\t},\n\tconverters: {\n\t\t\"text script\": function( text ) {\n\t\t\tjQuery.globalEval( text );\n\t\t\treturn text;\n\t\t}\n\t}\n} );\n\n// Handle cache's special case and crossDomain\njQuery.ajaxPrefilter( \"script\", function( s ) {\n\tif ( s.cache === undefined ) {\n\t\ts.cache = false;\n\t}\n\tif ( s.crossDomain ) {\n\t\ts.type = \"GET\";\n\t}\n} );\n\n// Bind script tag hack transport\njQuery.ajaxTransport( \"script\", function( s ) {\n\n\t// This transport only deals with cross domain requests\n\tif ( s.crossDomain ) {\n\t\tvar script, callback;\n\t\treturn {\n\t\t\tsend: function( _, complete ) {\n\t\t\t\tscript = jQuery( \"<script>\" ).prop( {\n\t\t\t\t\tcharset: s.scriptCharset,\n\t\t\t\t\tsrc: s.url\n\t\t\t\t} ).on(\n\t\t\t\t\t\"load error\",\n\t\t\t\t\tcallback = function( evt ) {\n\t\t\t\t\t\tscript.remove();\n\t\t\t\t\t\tcallback = null;\n\t\t\t\t\t\tif ( evt ) {\n\t\t\t\t\t\t\tcomplete( evt.type === \"error\" ? 404 : 200, evt.type );\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t);\n\n\t\t\t\t// Use native DOM manipulation to avoid our domManip AJAX trickery\n\t\t\t\tdocument.head.appendChild( script[ 0 ] );\n\t\t\t},\n\t\t\tabort: function() {\n\t\t\t\tif ( callback ) {\n\t\t\t\t\tcallback();\n\t\t\t\t}\n\t\t\t}\n\t\t};\n\t}\n} );\n\n\n\n\nvar oldCallbacks = [],\n\trjsonp = /(=)\\?(?=&|$)|\\?\\?/;\n\n// Default jsonp settings\njQuery.ajaxSetup( {\n\tjsonp: \"callback\",\n\tjsonpCallback: function() {\n\t\tvar callback = oldCallbacks.pop() || ( jQuery.expando + \"_\" + ( nonce++ ) );\n\t\tthis[ callback ] = true;\n\t\treturn callback;\n\t}\n} );\n\n// Detect, normalize options and install callbacks for jsonp requests\njQuery.ajaxPrefilter( \"json jsonp\", function( s, originalSettings, jqXHR ) {\n\n\tvar callbackName, overwritten, responseContainer,\n\t\tjsonProp = s.jsonp !== false && ( rjsonp.test( s.url ) ?\n\t\t\t\"url\" :\n\t\t\ttypeof s.data === \"string\" &&\n\t\t\t\t( s.contentType || \"\" )\n\t\t\t\t\t.indexOf( \"application/x-www-form-urlencoded\" ) === 0 &&\n\t\t\t\trjsonp.test( s.data ) && \"data\"\n\t\t);\n\n\t// Handle iff the expected data type is \"jsonp\" or we have a parameter to set\n\tif ( jsonProp || s.dataTypes[ 0 ] === \"jsonp\" ) {\n\n\t\t// Get callback name, remembering preexisting value associated with it\n\t\tcallbackName = s.jsonpCallback = jQuery.isFunction( s.jsonpCallback ) ?\n\t\t\ts.jsonpCallback() :\n\t\t\ts.jsonpCallback;\n\n\t\t// Insert callback into url or form data\n\t\tif ( jsonProp ) {\n\t\t\ts[ jsonProp ] = s[ jsonProp ].replace( rjsonp, \"$1\" + callbackName );\n\t\t} else if ( s.jsonp !== false ) {\n\t\t\ts.url += ( rquery.test( s.url ) ? \"&\" : \"?\" ) + s.jsonp + \"=\" + callbackName;\n\t\t}\n\n\t\t// Use data converter to retrieve json after script execution\n\t\ts.converters[ \"script json\" ] = function() {\n\t\t\tif ( !responseContainer ) {\n\t\t\t\tjQuery.error( callbackName + \" was not called\" );\n\t\t\t}\n\t\t\treturn responseContainer[ 0 ];\n\t\t};\n\n\t\t// Force json dataType\n\t\ts.dataTypes[ 0 ] = \"json\";\n\n\t\t// Install callback\n\t\toverwritten = window[ callbackName ];\n\t\twindow[ callbackName ] = function() {\n\t\t\tresponseContainer = arguments;\n\t\t};\n\n\t\t// Clean-up function (fires after converters)\n\t\tjqXHR.always( function() {\n\n\t\t\t// If previous value didn't exist - remove it\n\t\t\tif ( overwritten === undefined ) {\n\t\t\t\tjQuery( window ).removeProp( callbackName );\n\n\t\t\t// Otherwise restore preexisting value\n\t\t\t} else {\n\t\t\t\twindow[ callbackName ] = overwritten;\n\t\t\t}\n\n\t\t\t// Save back as free\n\t\t\tif ( s[ callbackName ] ) {\n\n\t\t\t\t// Make sure that re-using the options doesn't screw things around\n\t\t\t\ts.jsonpCallback = originalSettings.jsonpCallback;\n\n\t\t\t\t// Save the callback name for future use\n\t\t\t\toldCallbacks.push( callbackName );\n\t\t\t}\n\n\t\t\t// Call if it was a function and we have a response\n\t\t\tif ( responseContainer && jQuery.isFunction( overwritten ) ) {\n\t\t\t\toverwritten( responseContainer[ 0 ] );\n\t\t\t}\n\n\t\t\tresponseContainer = overwritten = undefined;\n\t\t} );\n\n\t\t// Delegate to script\n\t\treturn \"script\";\n\t}\n} );\n\n\n\n\n// Support: Safari 8 only\n// In Safari 8 documents created via document.implementation.createHTMLDocument\n// collapse sibling forms: the second one becomes a child of the first one.\n// Because of that, this security measure has to be disabled in Safari 8.\n// https://bugs.webkit.org/show_bug.cgi?id=137337\nsupport.createHTMLDocument = ( function() {\n\tvar body = document.implementation.createHTMLDocument( \"\" ).body;\n\tbody.innerHTML = \"<form></form><form></form>\";\n\treturn body.childNodes.length === 2;\n} )();\n\n\n// Argument \"data\" should be string of html\n// context (optional): If specified, the fragment will be created in this context,\n// defaults to document\n// keepScripts (optional): If true, will include scripts passed in the html string\njQuery.parseHTML = function( data, context, keepScripts ) {\n\tif ( typeof data !== \"string\" ) {\n\t\treturn [];\n\t}\n\tif ( typeof context === \"boolean\" ) {\n\t\tkeepScripts = context;\n\t\tcontext = false;\n\t}\n\n\tvar base, parsed, scripts;\n\n\tif ( !context ) {\n\n\t\t// Stop scripts or inline event handlers from being executed immediately\n\t\t// by using document.implementation\n\t\tif ( support.createHTMLDocument ) {\n\t\t\tcontext = document.implementation.createHTMLDocument( \"\" );\n\n\t\t\t// Set the base href for the created document\n\t\t\t// so any parsed elements with URLs\n\t\t\t// are based on the document's URL (gh-2965)\n\t\t\tbase = context.createElement( \"base\" );\n\t\t\tbase.href = document.location.href;\n\t\t\tcontext.head.appendChild( base );\n\t\t} else {\n\t\t\tcontext = document;\n\t\t}\n\t}\n\n\tparsed = rsingleTag.exec( data );\n\tscripts = !keepScripts && [];\n\n\t// Single tag\n\tif ( parsed ) {\n\t\treturn [ context.createElement( parsed[ 1 ] ) ];\n\t}\n\n\tparsed = buildFragment( [ data ], context, scripts );\n\n\tif ( scripts && scripts.length ) {\n\t\tjQuery( scripts ).remove();\n\t}\n\n\treturn jQuery.merge( [], parsed.childNodes );\n};\n\n\n/**\n * Load a url into a page\n */\njQuery.fn.load = function( url, params, callback ) {\n\tvar selector, type, response,\n\t\tself = this,\n\t\toff = url.indexOf( \" \" );\n\n\tif ( off > -1 ) {\n\t\tselector = stripAndCollapse( url.slice( off ) );\n\t\turl = url.slice( 0, off );\n\t}\n\n\t// If it's a function\n\tif ( jQuery.isFunction( params ) ) {\n\n\t\t// We assume that it's the callback\n\t\tcallback = params;\n\t\tparams = undefined;\n\n\t// Otherwise, build a param string\n\t} else if ( params && typeof params === \"object\" ) {\n\t\ttype = \"POST\";\n\t}\n\n\t// If we have elements to modify, make the request\n\tif ( self.length > 0 ) {\n\t\tjQuery.ajax( {\n\t\t\turl: url,\n\n\t\t\t// If \"type\" variable is undefined, then \"GET\" method will be used.\n\t\t\t// Make value of this field explicit since\n\t\t\t// user can override it through ajaxSetup method\n\t\t\ttype: type || \"GET\",\n\t\t\tdataType: \"html\",\n\t\t\tdata: params\n\t\t} ).done( function( responseText ) {\n\n\t\t\t// Save response for use in complete callback\n\t\t\tresponse = arguments;\n\n\t\t\tself.html( selector ?\n\n\t\t\t\t// If a selector was specified, locate the right elements in a dummy div\n\t\t\t\t// Exclude scripts to avoid IE 'Permission Denied' errors\n\t\t\t\tjQuery( \"<div>\" ).append( jQuery.parseHTML( responseText ) ).find( selector ) :\n\n\t\t\t\t// Otherwise use the full result\n\t\t\t\tresponseText );\n\n\t\t// If the request succeeds, this function gets \"data\", \"status\", \"jqXHR\"\n\t\t// but they are ignored because response was set above.\n\t\t// If it fails, this function gets \"jqXHR\", \"status\", \"error\"\n\t\t} ).always( callback && function( jqXHR, status ) {\n\t\t\tself.each( function() {\n\t\t\t\tcallback.apply( this, response || [ jqXHR.responseText, status, jqXHR ] );\n\t\t\t} );\n\t\t} );\n\t}\n\n\treturn this;\n};\n\n\n\n\n// Attach a bunch of functions for handling common AJAX events\njQuery.each( [\n\t\"ajaxStart\",\n\t\"ajaxStop\",\n\t\"ajaxComplete\",\n\t\"ajaxError\",\n\t\"ajaxSuccess\",\n\t\"ajaxSend\"\n], function( i, type ) {\n\tjQuery.fn[ type ] = function( fn ) {\n\t\treturn this.on( type, fn );\n\t};\n} );\n\n\n\n\njQuery.expr.pseudos.animated = function( elem ) {\n\treturn jQuery.grep( jQuery.timers, function( fn ) {\n\t\treturn elem === fn.elem;\n\t} ).length;\n};\n\n\n\n\njQuery.offset = {\n\tsetOffset: function( elem, options, i ) {\n\t\tvar curPosition, curLeft, curCSSTop, curTop, curOffset, curCSSLeft, calculatePosition,\n\t\t\tposition = jQuery.css( elem, \"position\" ),\n\t\t\tcurElem = jQuery( elem ),\n\t\t\tprops = {};\n\n\t\t// Set position first, in-case top/left are set even on static elem\n\t\tif ( position === \"static\" ) {\n\t\t\telem.style.position = \"relative\";\n\t\t}\n\n\t\tcurOffset = curElem.offset();\n\t\tcurCSSTop = jQuery.css( elem, \"top\" );\n\t\tcurCSSLeft = jQuery.css( elem, \"left\" );\n\t\tcalculatePosition = ( position === \"absolute\" || position === \"fixed\" ) &&\n\t\t\t( curCSSTop + curCSSLeft ).indexOf( \"auto\" ) > -1;\n\n\t\t// Need to be able to calculate position if either\n\t\t// top or left is auto and position is either absolute or fixed\n\t\tif ( calculatePosition ) {\n\t\t\tcurPosition = curElem.position();\n\t\t\tcurTop = curPosition.top;\n\t\t\tcurLeft = curPosition.left;\n\n\t\t} else {\n\t\t\tcurTop = parseFloat( curCSSTop ) || 0;\n\t\t\tcurLeft = parseFloat( curCSSLeft ) || 0;\n\t\t}\n\n\t\tif ( jQuery.isFunction( options ) ) {\n\n\t\t\t// Use jQuery.extend here to allow modification of coordinates argument (gh-1848)\n\t\t\toptions = options.call( elem, i, jQuery.extend( {}, curOffset ) );\n\t\t}\n\n\t\tif ( options.top != null ) {\n\t\t\tprops.top = ( options.top - curOffset.top ) + curTop;\n\t\t}\n\t\tif ( options.left != null ) {\n\t\t\tprops.left = ( options.left - curOffset.left ) + curLeft;\n\t\t}\n\n\t\tif ( \"using\" in options ) {\n\t\t\toptions.using.call( elem, props );\n\n\t\t} else {\n\t\t\tcurElem.css( props );\n\t\t}\n\t}\n};\n\njQuery.fn.extend( {\n\toffset: function( options ) {\n\n\t\t// Preserve chaining for setter\n\t\tif ( arguments.length ) {\n\t\t\treturn options === undefined ?\n\t\t\t\tthis :\n\t\t\t\tthis.each( function( i ) {\n\t\t\t\t\tjQuery.offset.setOffset( this, options, i );\n\t\t\t\t} );\n\t\t}\n\n\t\tvar doc, docElem, rect, win,\n\t\t\telem = this[ 0 ];\n\n\t\tif ( !elem ) {\n\t\t\treturn;\n\t\t}\n\n\t\t// Return zeros for disconnected and hidden (display: none) elements (gh-2310)\n\t\t// Support: IE <=11 only\n\t\t// Running getBoundingClientRect on a\n\t\t// disconnected node in IE throws an error\n\t\tif ( !elem.getClientRects().length ) {\n\t\t\treturn { top: 0, left: 0 };\n\t\t}\n\n\t\trect = elem.getBoundingClientRect();\n\n\t\tdoc = elem.ownerDocument;\n\t\tdocElem = doc.documentElement;\n\t\twin = doc.defaultView;\n\n\t\treturn {\n\t\t\ttop: rect.top + win.pageYOffset - docElem.clientTop,\n\t\t\tleft: rect.left + win.pageXOffset - docElem.clientLeft\n\t\t};\n\t},\n\n\tposition: function() {\n\t\tif ( !this[ 0 ] ) {\n\t\t\treturn;\n\t\t}\n\n\t\tvar offsetParent, offset,\n\t\t\telem = this[ 0 ],\n\t\t\tparentOffset = { top: 0, left: 0 };\n\n\t\t// Fixed elements are offset from window (parentOffset = {top:0, left: 0},\n\t\t// because it is its only offset parent\n\t\tif ( jQuery.css( elem, \"position\" ) === \"fixed\" ) {\n\n\t\t\t// Assume getBoundingClientRect is there when computed position is fixed\n\t\t\toffset = elem.getBoundingClientRect();\n\n\t\t} else {\n\n\t\t\t// Get *real* offsetParent\n\t\t\toffsetParent = this.offsetParent();\n\n\t\t\t// Get correct offsets\n\t\t\toffset = this.offset();\n\t\t\tif ( !nodeName( offsetParent[ 0 ], \"html\" ) ) {\n\t\t\t\tparentOffset = offsetParent.offset();\n\t\t\t}\n\n\t\t\t// Add offsetParent borders\n\t\t\tparentOffset = {\n\t\t\t\ttop: parentOffset.top + jQuery.css( offsetParent[ 0 ], \"borderTopWidth\", true ),\n\t\t\t\tleft: parentOffset.left + jQuery.css( offsetParent[ 0 ], \"borderLeftWidth\", true )\n\t\t\t};\n\t\t}\n\n\t\t// Subtract parent offsets and element margins\n\t\treturn {\n\t\t\ttop: offset.top - parentOffset.top - jQuery.css( elem, \"marginTop\", true ),\n\t\t\tleft: offset.left - parentOffset.left - jQuery.css( elem, \"marginLeft\", true )\n\t\t};\n\t},\n\n\t// This method will return documentElement in the following cases:\n\t// 1) For the element inside the iframe without offsetParent, this method will return\n\t// documentElement of the parent window\n\t// 2) For the hidden or detached element\n\t// 3) For body or html element, i.e. in case of the html node - it will return itself\n\t//\n\t// but those exceptions were never presented as a real life use-cases\n\t// and might be considered as more preferable results.\n\t//\n\t// This logic, however, is not guaranteed and can change at any point in the future\n\toffsetParent: function() {\n\t\treturn this.map( function() {\n\t\t\tvar offsetParent = this.offsetParent;\n\n\t\t\twhile ( offsetParent && jQuery.css( offsetParent, \"position\" ) === \"static\" ) {\n\t\t\t\toffsetParent = offsetParent.offsetParent;\n\t\t\t}\n\n\t\t\treturn offsetParent || documentElement;\n\t\t} );\n\t}\n} );\n\n// Create scrollLeft and scrollTop methods\njQuery.each( { scrollLeft: \"pageXOffset\", scrollTop: \"pageYOffset\" }, function( method, prop ) {\n\tvar top = \"pageYOffset\" === prop;\n\n\tjQuery.fn[ method ] = function( val ) {\n\t\treturn access( this, function( elem, method, val ) {\n\n\t\t\t// Coalesce documents and windows\n\t\t\tvar win;\n\t\t\tif ( jQuery.isWindow( elem ) ) {\n\t\t\t\twin = elem;\n\t\t\t} else if ( elem.nodeType === 9 ) {\n\t\t\t\twin = elem.defaultView;\n\t\t\t}\n\n\t\t\tif ( val === undefined ) {\n\t\t\t\treturn win ? win[ prop ] : elem[ method ];\n\t\t\t}\n\n\t\t\tif ( win ) {\n\t\t\t\twin.scrollTo(\n\t\t\t\t\t!top ? val : win.pageXOffset,\n\t\t\t\t\ttop ? val : win.pageYOffset\n\t\t\t\t);\n\n\t\t\t} else {\n\t\t\t\telem[ method ] = val;\n\t\t\t}\n\t\t}, method, val, arguments.length );\n\t};\n} );\n\n// Support: Safari <=7 - 9.1, Chrome <=37 - 49\n// Add the top/left cssHooks using jQuery.fn.position\n// Webkit bug: https://bugs.webkit.org/show_bug.cgi?id=29084\n// Blink bug: https://bugs.chromium.org/p/chromium/issues/detail?id=589347\n// getComputedStyle returns percent when specified for top/left/bottom/right;\n// rather than make the css module depend on the offset module, just check for it here\njQuery.each( [ \"top\", \"left\" ], function( i, prop ) {\n\tjQuery.cssHooks[ prop ] = addGetHookIf( support.pixelPosition,\n\t\tfunction( elem, computed ) {\n\t\t\tif ( computed ) {\n\t\t\t\tcomputed = curCSS( elem, prop );\n\n\t\t\t\t// If curCSS returns percentage, fallback to offset\n\t\t\t\treturn rnumnonpx.test( computed ) ?\n\t\t\t\t\tjQuery( elem ).position()[ prop ] + \"px\" :\n\t\t\t\t\tcomputed;\n\t\t\t}\n\t\t}\n\t);\n} );\n\n\n// Create innerHeight, innerWidth, height, width, outerHeight and outerWidth methods\njQuery.each( { Height: \"height\", Width: \"width\" }, function( name, type ) {\n\tjQuery.each( { padding: \"inner\" + name, content: type, \"\": \"outer\" + name },\n\t\tfunction( defaultExtra, funcName ) {\n\n\t\t// Margin is only for outerHeight, outerWidth\n\t\tjQuery.fn[ funcName ] = function( margin, value ) {\n\t\t\tvar chainable = arguments.length && ( defaultExtra || typeof margin !== \"boolean\" ),\n\t\t\t\textra = defaultExtra || ( margin === true || value === true ? \"margin\" : \"border\" );\n\n\t\t\treturn access( this, function( elem, type, value ) {\n\t\t\t\tvar doc;\n\n\t\t\t\tif ( jQuery.isWindow( elem ) ) {\n\n\t\t\t\t\t// $( window ).outerWidth/Height return w/h including scrollbars (gh-1729)\n\t\t\t\t\treturn funcName.indexOf( \"outer\" ) === 0 ?\n\t\t\t\t\t\telem[ \"inner\" + name ] :\n\t\t\t\t\t\telem.document.documentElement[ \"client\" + name ];\n\t\t\t\t}\n\n\t\t\t\t// Get document width or height\n\t\t\t\tif ( elem.nodeType === 9 ) {\n\t\t\t\t\tdoc = elem.documentElement;\n\n\t\t\t\t\t// Either scroll[Width/Height] or offset[Width/Height] or client[Width/Height],\n\t\t\t\t\t// whichever is greatest\n\t\t\t\t\treturn Math.max(\n\t\t\t\t\t\telem.body[ \"scroll\" + name ], doc[ \"scroll\" + name ],\n\t\t\t\t\t\telem.body[ \"offset\" + name ], doc[ \"offset\" + name ],\n\t\t\t\t\t\tdoc[ \"client\" + name ]\n\t\t\t\t\t);\n\t\t\t\t}\n\n\t\t\t\treturn value === undefined ?\n\n\t\t\t\t\t// Get width or height on the element, requesting but not forcing parseFloat\n\t\t\t\t\tjQuery.css( elem, type, extra ) :\n\n\t\t\t\t\t// Set width or height on the element\n\t\t\t\t\tjQuery.style( elem, type, value, extra );\n\t\t\t}, type, chainable ? margin : undefined, chainable );\n\t\t};\n\t} );\n} );\n\n\njQuery.fn.extend( {\n\n\tbind: function( types, data, fn ) {\n\t\treturn this.on( types, null, data, fn );\n\t},\n\tunbind: function( types, fn ) {\n\t\treturn this.off( types, null, fn );\n\t},\n\n\tdelegate: function( selector, types, data, fn ) {\n\t\treturn this.on( types, selector, data, fn );\n\t},\n\tundelegate: function( selector, types, fn ) {\n\n\t\t// ( namespace ) or ( selector, types [, fn] )\n\t\treturn arguments.length === 1 ?\n\t\t\tthis.off( selector, \"**\" ) :\n\t\t\tthis.off( types, selector || \"**\", fn );\n\t}\n} );\n\njQuery.holdReady = function( hold ) {\n\tif ( hold ) {\n\t\tjQuery.readyWait++;\n\t} else {\n\t\tjQuery.ready( true );\n\t}\n};\njQuery.isArray = Array.isArray;\njQuery.parseJSON = JSON.parse;\njQuery.nodeName = nodeName;\n\n\n\n\n// Register as a named AMD module, since jQuery can be concatenated with other\n// files that may use define, but not via a proper concatenation script that\n// understands anonymous AMD modules. A named AMD is safest and most robust\n// way to register. Lowercase jquery is used because AMD module names are\n// derived from file names, and jQuery is normally delivered in a lowercase\n// file name. Do this after creating the global so that if an AMD module wants\n// to call noConflict to hide this version of jQuery, it will work.\n\n// Note that for maximum portability, libraries that are not jQuery should\n// declare themselves as anonymous modules, and avoid setting a global if an\n// AMD loader is present. jQuery is a special case. For more information, see\n// https://github.com/jrburke/requirejs/wiki/Updating-existing-libraries#wiki-anon\n\nif ( typeof define === \"function\" && define.amd ) {\n\tdefine( \"jquery\", [], function() {\n\t\treturn jQuery;\n\t} );\n}\n\n\n\n\nvar\n\n\t// Map over jQuery in case of overwrite\n\t_jQuery = window.jQuery,\n\n\t// Map over the $ in case of overwrite\n\t_$ = window.$;\n\njQuery.noConflict = function( deep ) {\n\tif ( window.$ === jQuery ) {\n\t\twindow.$ = _$;\n\t}\n\n\tif ( deep && window.jQuery === jQuery ) {\n\t\twindow.jQuery = _jQuery;\n\t}\n\n\treturn jQuery;\n};\n\n// Expose jQuery and $ identifiers, even in AMD\n// (#7102#comment:10, https://github.com/jquery/jquery/pull/557)\n// and CommonJS for browser emulators (#13566)\nif ( !noGlobal ) {\n\twindow.jQuery = window.$ = jQuery;\n}\n\n\n\n\nreturn jQuery;\n} );\n"
},
{
"id": 28,
"identifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/bs-platform/lib/js/caml_utils.js",
"name": "./node_modules/bs-platform/lib/js/caml_utils.js",
"index": 27,
"index2": 19,
"size": 956,
"cacheable": true,
"built": true,
"optional": false,
"prefetched": false,
"chunks": [
0
],
"assets": [],
"issuer": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/bs-platform/lib/js/caml_int64.js",
"issuerId": 25,
"issuerName": "./node_modules/bs-platform/lib/js/caml_int64.js",
"failed": false,
"errors": 0,
"warnings": 0,
"reasons": [
{
"moduleId": 19,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/bs-platform/lib/js/caml_format.js",
"module": "./node_modules/bs-platform/lib/js/caml_format.js",
"moduleName": "./node_modules/bs-platform/lib/js/caml_format.js",
"type": "cjs require",
"userRequest": "./caml_utils.js",
"loc": "6:30-56"
},
{
"moduleId": 25,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/bs-platform/lib/js/caml_int64.js",
"module": "./node_modules/bs-platform/lib/js/caml_int64.js",
"moduleName": "./node_modules/bs-platform/lib/js/caml_int64.js",
"type": "cjs require",
"userRequest": "./caml_utils.js",
"loc": "5:30-56"
}
],
"usedExports": true,
"providedExports": null,
"optimizationBailout": [],
"depth": 5,
"source": "'use strict';\n\n\nvar repeat = ( (String.prototype.repeat && function (count,self){return self.repeat(count)}) ||\n function(count , self) {\n if (self.length == 0 || count == 0) {\n return '';\n }\n // Ensuring count is a 31-bit integer allows us to heavily optimize the\n // main part. But anyway, most current (August 2014) browsers can't handle\n // strings 1 << 28 chars or longer, so:\n if (self.length * count >= 1 << 28) {\n throw new RangeError('repeat count must not overflow maximum string size');\n }\n var rpt = '';\n for (;;) {\n if ((count & 1) == 1) {\n rpt += self;\n }\n count >>>= 1;\n if (count == 0) {\n break;\n }\n self += self;\n }\n return rpt;\n }\n);\n\nexports.repeat = repeat;\n/* repeat Not a pure module */\n"
},
{
"id": 29,
"identifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/bs-platform/lib/js/caml_missing_polyfill.js",
"name": "./node_modules/bs-platform/lib/js/caml_missing_polyfill.js",
"index": 30,
"index2": 24,
"size": 159,
"cacheable": true,
"built": true,
"optional": false,
"prefetched": false,
"chunks": [
0
],
"assets": [],
"issuer": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/bs-platform/lib/js/pervasives.js",
"issuerId": 15,
"issuerName": "./node_modules/bs-platform/lib/js/pervasives.js",
"failed": false,
"errors": 0,
"warnings": 0,
"reasons": [
{
"moduleId": 15,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/bs-platform/lib/js/pervasives.js",
"module": "./node_modules/bs-platform/lib/js/pervasives.js",
"moduleName": "./node_modules/bs-platform/lib/js/pervasives.js",
"type": "cjs require",
"userRequest": "./caml_missing_polyfill.js",
"loc": "10:31-68"
},
{
"moduleId": 65,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/bs-platform/lib/js/digest.js",
"module": "./node_modules/bs-platform/lib/js/digest.js",
"moduleName": "./node_modules/bs-platform/lib/js/digest.js",
"type": "cjs require",
"userRequest": "./caml_missing_polyfill.js",
"loc": "8:30-67"
}
],
"usedExports": true,
"providedExports": null,
"optimizationBailout": [],
"depth": 4,
"source": "'use strict';\n\n\nvar not_implemented = (function (s){ throw new Error(s)});\n\nexports.not_implemented = not_implemented;\n/* not_implemented Not a pure module */\n"
},
{
"id": 30,
"identifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/bs-platform/lib/js/js_exn.js",
"name": "./node_modules/bs-platform/lib/js/js_exn.js",
"index": 43,
"index2": 38,
"size": 1241,
"cacheable": true,
"built": true,
"optional": false,
"prefetched": false,
"chunks": [
0
],
"assets": [],
"issuer": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/bs-platform/lib/js/array.js",
"issuerId": 21,
"issuerName": "./node_modules/bs-platform/lib/js/array.js",
"failed": false,
"errors": 0,
"warnings": 0,
"reasons": [
{
"moduleId": 21,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/bs-platform/lib/js/array.js",
"module": "./node_modules/bs-platform/lib/js/array.js",
"moduleName": "./node_modules/bs-platform/lib/js/array.js",
"type": "cjs require",
"userRequest": "./js_exn.js",
"loc": "4:30-52"
},
{
"moduleId": 52,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/bs-json/lib/js/src/Json_decode.js",
"module": "./node_modules/bs-json/lib/js/src/Json_decode.js",
"moduleName": "./node_modules/bs-json/lib/js/src/Json_decode.js",
"type": "cjs require",
"userRequest": "bs-platform/lib/js/js_exn.js",
"loc": "6:30-69"
}
],
"usedExports": true,
"providedExports": null,
"optimizationBailout": [],
"depth": 4,
"source": "'use strict';\n\nvar Caml_exceptions = require(\"./caml_exceptions.js\");\n\nvar $$Error = Caml_exceptions.create(\"Js_exn.Error\");\n\nfunction internalToOCamlException(e) {\n if (Caml_exceptions.isCamlExceptionOrOpenVariant(e)) {\n return e;\n } else {\n return [\n $$Error,\n e\n ];\n }\n}\n\nfunction raiseError(str) {\n throw new Error(str);\n}\n\nfunction raiseEvalError(str) {\n throw new EvalError(str);\n}\n\nfunction raiseRangeError(str) {\n throw new RangeError(str);\n}\n\nfunction raiseReferenceError(str) {\n throw new ReferenceError(str);\n}\n\nfunction raiseSyntaxError(str) {\n throw new SyntaxError(str);\n}\n\nfunction raiseTypeError(str) {\n throw new TypeError(str);\n}\n\nfunction raiseUriError(str) {\n throw new URIError(str);\n}\n\nexports.$$Error = $$Error;\nexports.internalToOCamlException = internalToOCamlException;\nexports.raiseError = raiseError;\nexports.raiseEvalError = raiseEvalError;\nexports.raiseRangeError = raiseRangeError;\nexports.raiseReferenceError = raiseReferenceError;\nexports.raiseSyntaxError = raiseSyntaxError;\nexports.raiseTypeError = raiseTypeError;\nexports.raiseUriError = raiseUriError;\n/* No side effect */\n"
},
{
"id": 31,
"identifier": "/home/x/zzz/github/douglasduteil/RePeople/lib/js/src/components/personCard.js",
"name": "./lib/js/src/components/personCard.js",
"index": 46,
"index2": 46,
"size": 1880,
"cacheable": true,
"built": true,
"optional": false,
"prefetched": false,
"chunks": [
0
],
"assets": [],
"issuer": "/home/x/zzz/github/douglasduteil/RePeople/lib/js/src/components/listAll.js",
"issuerId": 54,
"issuerName": "./lib/js/src/components/listAll.js",
"failed": false,
"errors": 0,
"warnings": 0,
"reasons": [
{
"moduleId": 54,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/lib/js/src/components/listAll.js",
"module": "./lib/js/src/components/listAll.js",
"moduleName": "./lib/js/src/components/listAll.js",
"type": "cjs require",
"userRequest": "./personCard.js",
"loc": "9:18-44"
},
{
"moduleId": 61,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/lib/js/src/components/discover.js",
"module": "./lib/js/src/components/discover.js",
"moduleName": "./lib/js/src/components/discover.js",
"type": "cjs require",
"userRequest": "./personCard.js",
"loc": "10:18-44"
}
],
"usedExports": true,
"providedExports": null,
"optimizationBailout": [],
"depth": 3,
"source": "// Generated by BUCKLESCRIPT VERSION 1.9.2, PLEASE EDIT WITH CARE\n'use strict';\n\nvar Card = require(\"./card.js\");\nvar React = require(\"react\");\nvar ReasonReact = require(\"reason-react/lib/js/src/reasonReact.js\");\n\nvar component = ReasonReact.statelessComponent(\"PersonCard\");\n\nfunction make(person, _) {\n var newrecord = component.slice();\n newrecord[/* render */9] = (function () {\n var match = person[/* manager */7];\n return ReasonReact.element(/* None */0, /* None */0, Card.make(/* array */[\n ReasonReact.element(/* None */0, /* None */0, Card.Avatar[/* make */1](person[/* photoUrl */3], /* None */0, /* array */[])),\n ReasonReact.element(/* None */0, /* None */0, Card.Title[/* make */1](React.createElement(\"a\", {\n href: \"#\"\n }, person[/* firstname */1] + (\" \" + person[/* lastname */2])), person[/* entity */4], /* array */[])),\n ReasonReact.element(/* None */0, /* None */0, Card.Info[/* make */1](\"email\", /* None */0, /* array */[React.createElement(\"a\", {\n href: \"mailto:\" + person[/* email */5]\n }, person[/* email */5])])),\n ReasonReact.element(/* None */0, /* None */0, Card.Info[/* make */1](\"phone\", /* None */0, /* array */[React.createElement(\"a\", {\n href: \"tel:\" + person[/* phone */6]\n }, person[/* phone */6])])),\n match ? ReasonReact.element(/* None */0, /* None */0, Card.Info[/* make */1](\"supervisor_account\", /* Some */[\"manager\"], /* array */[match[0]])) : null\n ]));\n });\n return newrecord;\n}\n\nexports.component = component;\nexports.make = make;\n/* component Not a pure module */\n"
},
{
"id": 32,
"identifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/bs-platform/lib/js/char.js",
"name": "./node_modules/bs-platform/lib/js/char.js",
"index": 58,
"index2": 53,
"size": 2046,
"cacheable": true,
"built": true,
"optional": false,
"prefetched": false,
"chunks": [
0
],
"assets": [],
"issuer": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/bs-platform/lib/js/digest.js",
"issuerId": 65,
"issuerName": "./node_modules/bs-platform/lib/js/digest.js",
"failed": false,
"errors": 0,
"warnings": 0,
"reasons": [
{
"moduleId": 65,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/bs-platform/lib/js/digest.js",
"module": "./node_modules/bs-platform/lib/js/digest.js",
"moduleName": "./node_modules/bs-platform/lib/js/digest.js",
"type": "cjs require",
"userRequest": "./char.js",
"loc": "3:30-50"
},
{
"moduleId": 67,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/bs-platform/lib/js/bytes.js",
"module": "./node_modules/bs-platform/lib/js/bytes.js",
"moduleName": "./node_modules/bs-platform/lib/js/bytes.js",
"type": "cjs require",
"userRequest": "./char.js",
"loc": "3:30-50"
}
],
"usedExports": true,
"providedExports": null,
"optimizationBailout": [],
"depth": 5,
"source": "'use strict';\n\nvar Caml_string = require(\"./caml_string.js\");\nvar Caml_builtin_exceptions = require(\"./caml_builtin_exceptions.js\");\n\nfunction chr(n) {\n if (n < 0 || n > 255) {\n throw [\n Caml_builtin_exceptions.invalid_argument,\n \"Char.chr\"\n ];\n } else {\n return n;\n }\n}\n\nfunction escaped(c) {\n var exit = 0;\n if (c >= 40) {\n if (c !== 92) {\n exit = c >= 127 ? 1 : 2;\n } else {\n return \"\\\\\\\\\";\n }\n } else if (c >= 32) {\n if (c >= 39) {\n return \"\\\\'\";\n } else {\n exit = 2;\n }\n } else if (c >= 14) {\n exit = 1;\n } else {\n switch (c) {\n case 8 : \n return \"\\\\b\";\n case 9 : \n return \"\\\\t\";\n case 10 : \n return \"\\\\n\";\n case 0 : \n case 1 : \n case 2 : \n case 3 : \n case 4 : \n case 5 : \n case 6 : \n case 7 : \n case 11 : \n case 12 : \n exit = 1;\n break;\n case 13 : \n return \"\\\\r\";\n \n }\n }\n switch (exit) {\n case 1 : \n var s = new Array(4);\n s[0] = /* \"\\\\\" */92;\n s[1] = 48 + (c / 100 | 0) | 0;\n s[2] = 48 + (c / 10 | 0) % 10 | 0;\n s[3] = 48 + c % 10 | 0;\n return Caml_string.bytes_to_string(s);\n case 2 : \n var s$1 = new Array(1);\n s$1[0] = c;\n return Caml_string.bytes_to_string(s$1);\n \n }\n}\n\nfunction lowercase(c) {\n if (c >= /* \"A\" */65 && c <= /* \"Z\" */90 || c >= /* \"\\192\" */192 && c <= /* \"\\214\" */214 || c >= /* \"\\216\" */216 && c <= /* \"\\222\" */222) {\n return c + 32 | 0;\n } else {\n return c;\n }\n}\n\nfunction uppercase(c) {\n if (c >= /* \"a\" */97 && c <= /* \"z\" */122 || c >= /* \"\\224\" */224 && c <= /* \"\\246\" */246 || c >= /* \"\\248\" */248 && c <= /* \"\\254\" */254) {\n return c - 32 | 0;\n } else {\n return c;\n }\n}\n\nfunction compare(c1, c2) {\n return c1 - c2 | 0;\n}\n\nexports.chr = chr;\nexports.escaped = escaped;\nexports.lowercase = lowercase;\nexports.uppercase = uppercase;\nexports.compare = compare;\n/* No side effect */\n"
},
{
"id": 33,
"identifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/fbjs/lib/EventListener.js",
"name": "./node_modules/fbjs/lib/EventListener.js",
"index": 72,
"index2": 68,
"size": 2248,
"cacheable": true,
"built": true,
"optional": false,
"prefetched": false,
"chunks": [
0
],
"assets": [],
"issuer": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/react-dom/cjs/react-dom.production.min.js",
"issuerId": 77,
"issuerName": "./node_modules/react-dom/cjs/react-dom.production.min.js",
"failed": false,
"errors": 0,
"warnings": 0,
"reasons": [
{
"moduleId": 77,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/react-dom/cjs/react-dom.production.min.js",
"module": "./node_modules/react-dom/cjs/react-dom.production.min.js",
"moduleName": "./node_modules/react-dom/cjs/react-dom.production.min.js",
"type": "cjs require",
"userRequest": "fbjs/lib/EventListener",
"loc": "11:144-177"
},
{
"moduleId": 80,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/react-dom/cjs/react-dom.development.js",
"module": "./node_modules/react-dom/cjs/react-dom.development.js",
"moduleName": "./node_modules/react-dom/cjs/react-dom.development.js",
"type": "cjs require",
"userRequest": "fbjs/lib/EventListener",
"loc": "21:20-53"
}
],
"usedExports": true,
"providedExports": null,
"optimizationBailout": [],
"depth": 4,
"source": "'use strict';\n\n/**\n * Copyright (c) 2013-present, Facebook, Inc.\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 * @typechecks\n */\n\nvar emptyFunction = require('./emptyFunction');\n\n/**\n * Upstream version of event listener. Does not take into account specific\n * nature of platform.\n */\nvar EventListener = {\n /**\n * Listen to DOM events during the bubble phase.\n *\n * @param {DOMEventTarget} target DOM element to register listener on.\n * @param {string} eventType Event type, e.g. 'click' or 'mouseover'.\n * @param {function} callback Callback function.\n * @return {object} Object with a `remove` method.\n */\n listen: function listen(target, eventType, callback) {\n if (target.addEventListener) {\n target.addEventListener(eventType, callback, false);\n return {\n remove: function remove() {\n target.removeEventListener(eventType, callback, false);\n }\n };\n } else if (target.attachEvent) {\n target.attachEvent('on' + eventType, callback);\n return {\n remove: function remove() {\n target.detachEvent('on' + eventType, callback);\n }\n };\n }\n },\n\n /**\n * Listen to DOM events during the capture phase.\n *\n * @param {DOMEventTarget} target DOM element to register listener on.\n * @param {string} eventType Event type, e.g. 'click' or 'mouseover'.\n * @param {function} callback Callback function.\n * @return {object} Object with a `remove` method.\n */\n capture: function capture(target, eventType, callback) {\n if (target.addEventListener) {\n target.addEventListener(eventType, callback, true);\n return {\n remove: function remove() {\n target.removeEventListener(eventType, callback, true);\n }\n };\n } else {\n if (process.env.NODE_ENV !== 'production') {\n console.error('Attempted to listen to events during the capture phase on a ' + 'browser that does not support the capture phase. Your application ' + 'will not receive some events.');\n }\n return {\n remove: emptyFunction\n };\n }\n },\n\n registerDefault: function registerDefault() {}\n};\n\nmodule.exports = EventListener;"
},
{
"id": 34,
"identifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/fbjs/lib/shallowEqual.js",
"name": "./node_modules/fbjs/lib/shallowEqual.js",
"index": 73,
"index2": 69,
"size": 1616,
"cacheable": true,
"built": true,
"optional": false,
"prefetched": false,
"chunks": [
0
],
"assets": [],
"issuer": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/react-dom/cjs/react-dom.production.min.js",
"issuerId": 77,
"issuerName": "./node_modules/react-dom/cjs/react-dom.production.min.js",
"failed": false,
"errors": 0,
"warnings": 0,
"reasons": [
{
"moduleId": 77,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/react-dom/cjs/react-dom.production.min.js",
"module": "./node_modules/react-dom/cjs/react-dom.production.min.js",
"moduleName": "./node_modules/react-dom/cjs/react-dom.production.min.js",
"type": "cjs require",
"userRequest": "fbjs/lib/shallowEqual",
"loc": "11:253-285"
},
{
"moduleId": 80,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/react-dom/cjs/react-dom.development.js",
"module": "./node_modules/react-dom/cjs/react-dom.development.js",
"moduleName": "./node_modules/react-dom/cjs/react-dom.development.js",
"type": "cjs require",
"userRequest": "fbjs/lib/shallowEqual",
"loc": "30:19-51"
}
],
"usedExports": true,
"providedExports": null,
"optimizationBailout": [],
"depth": 4,
"source": "/**\n * Copyright (c) 2013-present, Facebook, Inc.\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 * @typechecks\n * \n */\n\n/*eslint-disable no-self-compare */\n\n'use strict';\n\nvar hasOwnProperty = Object.prototype.hasOwnProperty;\n\n/**\n * inlined Object.is polyfill to avoid requiring consumers ship their own\n * https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Object/is\n */\nfunction is(x, y) {\n // SameValue algorithm\n if (x === y) {\n // Steps 1-5, 7-10\n // Steps 6.b-6.e: +0 != -0\n // Added the nonzero y check to make Flow happy, but it is redundant\n return x !== 0 || y !== 0 || 1 / x === 1 / y;\n } else {\n // Step 6.a: NaN == NaN\n return x !== x && y !== y;\n }\n}\n\n/**\n * Performs equality by iterating through keys on an object and returning false\n * when any key has values which are not strictly equal between the arguments.\n * Returns true when the values of all keys are strictly equal.\n */\nfunction shallowEqual(objA, objB) {\n if (is(objA, objB)) {\n return true;\n }\n\n if (typeof objA !== 'object' || objA === null || typeof objB !== 'object' || objB === null) {\n return false;\n }\n\n var keysA = Object.keys(objA);\n var keysB = Object.keys(objB);\n\n if (keysA.length !== keysB.length) {\n return false;\n }\n\n // Test for A's keys different from B.\n for (var i = 0; i < keysA.length; i++) {\n if (!hasOwnProperty.call(objB, keysA[i]) || !is(objA[keysA[i]], objB[keysA[i]])) {\n return false;\n }\n }\n\n return true;\n}\n\nmodule.exports = shallowEqual;"
},
{
"id": 35,
"identifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/fbjs/lib/containsNode.js",
"name": "./node_modules/fbjs/lib/containsNode.js",
"index": 74,
"index2": 72,
"size": 923,
"cacheable": true,
"built": true,
"optional": false,
"prefetched": false,
"chunks": [
0
],
"assets": [],
"issuer": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/react-dom/cjs/react-dom.production.min.js",
"issuerId": 77,
"issuerName": "./node_modules/react-dom/cjs/react-dom.production.min.js",
"failed": false,
"errors": 0,
"warnings": 0,
"reasons": [
{
"moduleId": 77,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/react-dom/cjs/react-dom.production.min.js",
"module": "./node_modules/react-dom/cjs/react-dom.production.min.js",
"moduleName": "./node_modules/react-dom/cjs/react-dom.production.min.js",
"type": "cjs require",
"userRequest": "fbjs/lib/containsNode",
"loc": "11:289-321"
},
{
"moduleId": 80,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/react-dom/cjs/react-dom.development.js",
"module": "./node_modules/react-dom/cjs/react-dom.development.js",
"moduleName": "./node_modules/react-dom/cjs/react-dom.development.js",
"type": "cjs require",
"userRequest": "fbjs/lib/containsNode",
"loc": "31:19-51"
}
],
"usedExports": true,
"providedExports": null,
"optimizationBailout": [],
"depth": 4,
"source": "'use strict';\n\n/**\n * Copyright (c) 2013-present, Facebook, Inc.\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 * \n */\n\nvar isTextNode = require('./isTextNode');\n\n/*eslint-disable no-bitwise */\n\n/**\n * Checks if a given DOM node contains or is another DOM node.\n */\nfunction containsNode(outerNode, innerNode) {\n if (!outerNode || !innerNode) {\n return false;\n } else if (outerNode === innerNode) {\n return true;\n } else if (isTextNode(outerNode)) {\n return false;\n } else if (isTextNode(innerNode)) {\n return containsNode(outerNode, innerNode.parentNode);\n } else if ('contains' in outerNode) {\n return outerNode.contains(innerNode);\n } else if (outerNode.compareDocumentPosition) {\n return !!(outerNode.compareDocumentPosition(innerNode) & 16);\n } else {\n return false;\n }\n}\n\nmodule.exports = containsNode;"
},
{
"id": 36,
"identifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/fbjs/lib/focusNode.js",
"name": "./node_modules/fbjs/lib/focusNode.js",
"index": 77,
"index2": 73,
"size": 578,
"cacheable": true,
"built": true,
"optional": false,
"prefetched": false,
"chunks": [
0
],
"assets": [],
"issuer": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/react-dom/cjs/react-dom.production.min.js",
"issuerId": 77,
"issuerName": "./node_modules/react-dom/cjs/react-dom.production.min.js",
"failed": false,
"errors": 0,
"warnings": 0,
"reasons": [
{
"moduleId": 77,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/react-dom/cjs/react-dom.production.min.js",
"module": "./node_modules/react-dom/cjs/react-dom.production.min.js",
"moduleName": "./node_modules/react-dom/cjs/react-dom.production.min.js",
"type": "cjs require",
"userRequest": "fbjs/lib/focusNode",
"loc": "11:325-354"
},
{
"moduleId": 80,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/react-dom/cjs/react-dom.development.js",
"module": "./node_modules/react-dom/cjs/react-dom.development.js",
"moduleName": "./node_modules/react-dom/cjs/react-dom.development.js",
"type": "cjs require",
"userRequest": "fbjs/lib/focusNode",
"loc": "32:16-45"
}
],
"usedExports": true,
"providedExports": null,
"optimizationBailout": [],
"depth": 4,
"source": "/**\n * Copyright (c) 2013-present, Facebook, Inc.\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 */\n\n'use strict';\n\n/**\n * @param {DOMElement} node input/textarea to focus\n */\n\nfunction focusNode(node) {\n // IE8 can throw \"Can't move focus to the control because it is invisible,\n // not enabled, or of a type that does not accept the focus.\" for all kinds of\n // reasons that are too expensive and fragile to test.\n try {\n node.focus();\n } catch (e) {}\n}\n\nmodule.exports = focusNode;"
},
{
"id": 37,
"identifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/fbjs/lib/getActiveElement.js",
"name": "./node_modules/fbjs/lib/getActiveElement.js",
"index": 78,
"index2": 74,
"size": 912,
"cacheable": true,
"built": true,
"optional": false,
"prefetched": false,
"chunks": [
0
],
"assets": [],
"issuer": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/react-dom/cjs/react-dom.production.min.js",
"issuerId": 77,
"issuerName": "./node_modules/react-dom/cjs/react-dom.production.min.js",
"failed": false,
"errors": 0,
"warnings": 0,
"reasons": [
{
"moduleId": 77,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/react-dom/cjs/react-dom.production.min.js",
"module": "./node_modules/react-dom/cjs/react-dom.production.min.js",
"moduleName": "./node_modules/react-dom/cjs/react-dom.production.min.js",
"type": "cjs require",
"userRequest": "fbjs/lib/getActiveElement",
"loc": "11:358-394"
},
{
"moduleId": 80,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/react-dom/cjs/react-dom.development.js",
"module": "./node_modules/react-dom/cjs/react-dom.development.js",
"moduleName": "./node_modules/react-dom/cjs/react-dom.development.js",
"type": "cjs require",
"userRequest": "fbjs/lib/getActiveElement",
"loc": "33:23-59"
}
],
"usedExports": true,
"providedExports": null,
"optimizationBailout": [],
"depth": 4,
"source": "'use strict';\n\n/**\n * Copyright (c) 2013-present, Facebook, Inc.\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 * @typechecks\n */\n\n/* eslint-disable fb-www/typeof-undefined */\n\n/**\n * Same as document.activeElement but wraps in a try-catch block. In IE it is\n * not safe to call document.activeElement if there is nothing focused.\n *\n * The activeElement will be null only if the document or document body is not\n * yet defined.\n *\n * @param {?DOMDocument} doc Defaults to current document.\n * @return {?DOMElement}\n */\nfunction getActiveElement(doc) /*?DOMElement*/{\n doc = doc || (typeof document !== 'undefined' ? document : undefined);\n if (typeof doc === 'undefined') {\n return null;\n }\n try {\n return doc.activeElement || doc.body;\n } catch (e) {\n return doc.body;\n }\n}\n\nmodule.exports = getActiveElement;"
},
{
"id": 38,
"identifier": "/home/x/zzz/github/douglasduteil/RePeople/lib/js/src/main.js",
"name": "./lib/js/src/main.js",
"index": 0,
"index2": 111,
"size": 455,
"cacheable": true,
"built": true,
"optional": false,
"prefetched": false,
"chunks": [
0
],
"assets": [],
"issuer": null,
"issuerId": null,
"issuerName": null,
"failed": false,
"errors": 0,
"warnings": 0,
"reasons": [],
"usedExports": true,
"providedExports": null,
"optimizationBailout": [],
"depth": 0,
"source": "// Generated by BUCKLESCRIPT VERSION 1.9.2, PLEASE EDIT WITH CARE\n'use strict';\n\nvar App = require(\"./app.js\");\nvar ReactDOMRe = require(\"reason-react/lib/js/src/reactDOMRe.js\");\nvar ReasonReact = require(\"reason-react/lib/js/src/reasonReact.js\");\n\nrequire(\"materialize-css\");\n\nrequire(\"style/main.css\");\n\nReactDOMRe.renderToElementWithId(ReasonReact.element(/* None */0, /* None */0, App.make(/* array */[])), \"main\");\n\n/* Not a pure module */\n"
},
{
"id": 39,
"identifier": "/home/x/zzz/github/douglasduteil/RePeople/lib/js/src/app.js",
"name": "./lib/js/src/app.js",
"index": 1,
"index2": 66,
"size": 2895,
"cacheable": true,
"built": true,
"optional": false,
"prefetched": false,
"chunks": [
0
],
"assets": [],
"issuer": "/home/x/zzz/github/douglasduteil/RePeople/lib/js/src/main.js",
"issuerId": 38,
"issuerName": "./lib/js/src/main.js",
"failed": false,
"errors": 0,
"warnings": 0,
"reasons": [
{
"moduleId": 38,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/lib/js/src/main.js",
"module": "./lib/js/src/main.js",
"moduleName": "./lib/js/src/main.js",
"type": "cjs require",
"userRequest": "./app.js",
"loc": "4:18-37"
}
],
"usedExports": true,
"providedExports": null,
"optimizationBailout": [],
"depth": 1,
"source": "// Generated by BUCKLESCRIPT VERSION 1.9.2, PLEASE EDIT WITH CARE\n'use strict';\n\nvar Block = require(\"bs-platform/lib/js/block.js\");\nvar Curry = require(\"bs-platform/lib/js/curry.js\");\nvar React = require(\"react\");\nvar AppBar = require(\"./components/appBar.js\");\nvar Backend = require(\"./backend.js\");\nvar ListAll = require(\"./components/listAll.js\");\nvar Discover = require(\"./components/discover.js\");\nvar ReasonReact = require(\"reason-react/lib/js/src/reasonReact.js\");\n\nrequire(\"style/app.css\");\n\nfunction initialState() {\n return /* record */[\n /* people : [] */0,\n /* shown : LISTALL */1\n ];\n}\n\nfunction nextRoute(param) {\n if (param !== 0) {\n return /* DISCOVER */0;\n } else {\n return /* LISTALL */1;\n }\n}\n\nfunction routeToString(param) {\n if (param !== 0) {\n return \"Show All\";\n } else {\n return \"Discover\";\n }\n}\n\nfunction reducer(action, state) {\n if (action) {\n return /* Update */Block.__(0, [/* record */[\n /* people */action[0],\n /* shown */state[/* shown */1]\n ]]);\n } else {\n return /* Update */Block.__(0, [/* record */[\n /* people */state[/* people */0],\n /* shown */nextRoute(state[/* shown */1])\n ]]);\n }\n}\n\nvar component = ReasonReact.reducerComponent(\"App\");\n\nfunction peopleReceived(people) {\n return /* PeopleReceived */[people];\n}\n\nfunction toggleShown() {\n return /* ToggleShown */0;\n}\n\nfunction make() {\n var newrecord = component.slice();\n newrecord[/* didMount */4] = (function (param) {\n Backend.getPeople(Curry._1(param[/* reduce */3], peopleReceived));\n return /* NoUpdate */0;\n });\n newrecord[/* render */9] = (function (param) {\n var match = param[/* state */4];\n var shown = match[/* shown */1];\n var people = match[/* people */0];\n return React.createElement(\"div\", {\n className: \"App\"\n }, React.createElement(\"header\", undefined, ReasonReact.element(/* None */0, /* None */0, AppBar.make(routeToString(nextRoute(shown)), Curry._1(param[/* reduce */3], toggleShown), /* array */[]))), React.createElement(\"main\", undefined, people ? (\n shown !== 0 ? ReasonReact.element(/* None */0, /* None */0, ListAll.make(people, /* array */[])) : ReasonReact.element(/* None */0, /* None */0, Discover.make(people, /* array */[]))\n ) : null));\n });\n newrecord[/* initialState */10] = initialState;\n newrecord[/* reducer */12] = reducer;\n return newrecord;\n}\n\nexports.initialState = initialState;\nexports.nextRoute = nextRoute;\nexports.routeToString = routeToString;\nexports.reducer = reducer;\nexports.component = component;\nexports.peopleReceived = peopleReceived;\nexports.toggleShown = toggleShown;\nexports.make = make;\n/* Not a pure module */\n"
},
{
"id": 40,
"identifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/react/cjs/react.production.min.js",
"name": "./node_modules/react/cjs/react.production.min.js",
"index": 8,
"index2": 9,
"size": 5611,
"cacheable": true,
"built": true,
"optional": false,
"prefetched": false,
"chunks": [
0
],
"assets": [],
"issuer": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/react/index.js",
"issuerId": 3,
"issuerName": "./node_modules/react/index.js",
"failed": false,
"errors": 0,
"warnings": 0,
"reasons": [
{
"moduleId": 3,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/react/index.js",
"module": "./node_modules/react/index.js",
"moduleName": "./node_modules/react/index.js",
"type": "cjs require",
"userRequest": "./cjs/react.production.min.js",
"loc": "4:19-59"
}
],
"usedExports": true,
"providedExports": null,
"optimizationBailout": [],
"depth": 3,
"source": "/*\n React v16.0.0\n react.production.min.js\n\n Copyright (c) 2013-present, Facebook, Inc.\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 f=require(\"object-assign\"),p=require(\"fbjs/lib/emptyObject\");require(\"fbjs/lib/invariant\");var r=require(\"fbjs/lib/emptyFunction\");\nfunction t(a){for(var b=arguments.length-1,d=\"Minified React error #\"+a+\"; visit http://facebook.github.io/react/docs/error-decoder.html?invariant\\x3d\"+a,e=0;e<b;e++)d+=\"\\x26args[]\\x3d\"+encodeURIComponent(arguments[e+1]);b=Error(d+\" for the full message or use the non-minified dev environment for full errors and additional helpful warnings.\");b.name=\"Invariant Violation\";b.framesToPop=1;throw b;}\nvar u={isMounted:function(){return!1},enqueueForceUpdate:function(){},enqueueReplaceState:function(){},enqueueSetState:function(){}};function v(a,b,d){this.props=a;this.context=b;this.refs=p;this.updater=d||u}v.prototype.isReactComponent={};v.prototype.setState=function(a,b){\"object\"!==typeof a&&\"function\"!==typeof a&&null!=a?t(\"85\"):void 0;this.updater.enqueueSetState(this,a,b,\"setState\")};v.prototype.forceUpdate=function(a){this.updater.enqueueForceUpdate(this,a,\"forceUpdate\")};\nfunction w(a,b,d){this.props=a;this.context=b;this.refs=p;this.updater=d||u}function x(){}x.prototype=v.prototype;var y=w.prototype=new x;y.constructor=w;f(y,v.prototype);y.isPureReactComponent=!0;function z(a,b,d){this.props=a;this.context=b;this.refs=p;this.updater=d||u}var A=z.prototype=new x;A.constructor=z;f(A,v.prototype);A.unstable_isAsyncReactComponent=!0;A.render=function(){return this.props.children};\nvar B={Component:v,PureComponent:w,AsyncComponent:z},C={current:null},D=Object.prototype.hasOwnProperty,E=\"function\"===typeof Symbol&&Symbol[\"for\"]&&Symbol[\"for\"](\"react.element\")||60103,F={key:!0,ref:!0,__self:!0,__source:!0};function G(a,b,d,e,c,g,k){return{$$typeof:E,type:a,key:b,ref:d,props:k,_owner:g}}\nG.createElement=function(a,b,d){var e,c={},g=null,k=null,m=null,q=null;if(null!=b)for(e in void 0!==b.ref&&(k=b.ref),void 0!==b.key&&(g=\"\"+b.key),m=void 0===b.__self?null:b.__self,q=void 0===b.__source?null:b.__source,b)D.call(b,e)&&!F.hasOwnProperty(e)&&(c[e]=b[e]);var l=arguments.length-2;if(1===l)c.children=d;else if(1<l){for(var h=Array(l),n=0;n<l;n++)h[n]=arguments[n+2];c.children=h}if(a&&a.defaultProps)for(e in l=a.defaultProps,l)void 0===c[e]&&(c[e]=l[e]);return G(a,g,k,m,q,C.current,c)};\nG.createFactory=function(a){var b=G.createElement.bind(null,a);b.type=a;return b};G.cloneAndReplaceKey=function(a,b){return G(a.type,b,a.ref,a._self,a._source,a._owner,a.props)};\nG.cloneElement=function(a,b,d){var e=f({},a.props),c=a.key,g=a.ref,k=a._self,m=a._source,q=a._owner;if(null!=b){void 0!==b.ref&&(g=b.ref,q=C.current);void 0!==b.key&&(c=\"\"+b.key);if(a.type&&a.type.defaultProps)var l=a.type.defaultProps;for(h in b)D.call(b,h)&&!F.hasOwnProperty(h)&&(e[h]=void 0===b[h]&&void 0!==l?l[h]:b[h])}var h=arguments.length-2;if(1===h)e.children=d;else if(1<h){l=Array(h);for(var n=0;n<h;n++)l[n]=arguments[n+2];e.children=l}return G(a.type,c,g,k,m,q,e)};\nG.isValidElement=function(a){return\"object\"===typeof a&&null!==a&&a.$$typeof===E};var H=\"function\"===typeof Symbol&&Symbol.iterator,I=\"function\"===typeof Symbol&&Symbol[\"for\"]&&Symbol[\"for\"](\"react.element\")||60103;function escape(a){var b={\"\\x3d\":\"\\x3d0\",\":\":\"\\x3d2\"};return\"$\"+(\"\"+a).replace(/[=:]/g,function(a){return b[a]})}var J=/\\/+/g,K=[];\nfunction L(a,b,d,e){if(K.length){var c=K.pop();c.result=a;c.keyPrefix=b;c.func=d;c.context=e;c.count=0;return c}return{result:a,keyPrefix:b,func:d,context:e,count:0}}function M(a){a.result=null;a.keyPrefix=null;a.func=null;a.context=null;a.count=0;10>K.length&&K.push(a)}\nfunction N(a,b,d,e){var c=typeof a;if(\"undefined\"===c||\"boolean\"===c)a=null;if(null===a||\"string\"===c||\"number\"===c||\"object\"===c&&a.$$typeof===I)return d(e,a,\"\"===b?\".\"+O(a,0):b),1;var g=0;b=\"\"===b?\".\":b+\":\";if(Array.isArray(a))for(var k=0;k<a.length;k++){c=a[k];var m=b+O(c,k);g+=N(c,m,d,e)}else if(m=H&&a[H]||a[\"@@iterator\"],\"function\"===typeof m)for(a=m.call(a),k=0;!(c=a.next()).done;)c=c.value,m=b+O(c,k++),g+=N(c,m,d,e);else\"object\"===c&&(d=\"\"+a,t(\"31\",\"[object Object]\"===d?\"object with keys {\"+\nObject.keys(a).join(\", \")+\"}\":d,\"\"));return g}function O(a,b){return\"object\"===typeof a&&null!==a&&null!=a.key?escape(a.key):b.toString(36)}function P(a,b){a.func.call(a.context,b,a.count++)}function Q(a,b,d){var e=a.result,c=a.keyPrefix;a=a.func.call(a.context,b,a.count++);Array.isArray(a)?R(a,e,d,r.thatReturnsArgument):null!=a&&(G.isValidElement(a)&&(a=G.cloneAndReplaceKey(a,c+(!a.key||b&&b.key===a.key?\"\":(\"\"+a.key).replace(J,\"$\\x26/\")+\"/\")+d)),e.push(a))}\nfunction R(a,b,d,e,c){var g=\"\";null!=d&&(g=(\"\"+d).replace(J,\"$\\x26/\")+\"/\");b=L(b,g,e,c);null==a||N(a,\"\",Q,b);M(b)}var S={forEach:function(a,b,d){if(null==a)return a;b=L(null,null,b,d);null==a||N(a,\"\",P,b);M(b)},map:function(a,b,d){if(null==a)return a;var e=[];R(a,e,null,b,d);return e},count:function(a){return null==a?0:N(a,\"\",r.thatReturnsNull,null)},toArray:function(a){var b=[];R(a,b,null,r.thatReturnsArgument);return b}};\nmodule.exports={Children:{map:S.map,forEach:S.forEach,count:S.count,toArray:S.toArray,only:function(a){G.isValidElement(a)?void 0:t(\"143\");return a}},Component:B.Component,PureComponent:B.PureComponent,unstable_AsyncComponent:B.AsyncComponent,createElement:G.createElement,cloneElement:G.cloneElement,isValidElement:G.isValidElement,createFactory:G.createFactory,version:\"16.0.0\",__SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED:{ReactCurrentOwner:C,assign:f}};\n"
},
{
"id": 41,
"identifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/react/cjs/react.development.js",
"name": "./node_modules/react/cjs/react.development.js",
"index": 13,
"index2": 13,
"size": 55295,
"cacheable": true,
"built": true,
"optional": false,
"prefetched": false,
"chunks": [
0
],
"assets": [],
"issuer": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/react/index.js",
"issuerId": 3,
"issuerName": "./node_modules/react/index.js",
"failed": false,
"errors": 0,
"warnings": 0,
"reasons": [
{
"moduleId": 3,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/react/index.js",
"module": "./node_modules/react/index.js",
"moduleName": "./node_modules/react/index.js",
"type": "cjs require",
"userRequest": "./cjs/react.development.js",
"loc": "6:19-56"
}
],
"usedExports": true,
"providedExports": null,
"optimizationBailout": [],
"depth": 3,
"source": "/** @license React v16.0.0\n * react.development.js\n *\n * Copyright (c) 2013-present, Facebook, Inc.\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';\n\n\nif (process.env.NODE_ENV !== \"production\") {\n(function() {\n\n'use strict';\n\nvar objectAssign$1 = require('object-assign');\nvar require$$0 = require('fbjs/lib/warning');\nvar emptyObject = require('fbjs/lib/emptyObject');\nvar invariant = require('fbjs/lib/invariant');\nvar emptyFunction = require('fbjs/lib/emptyFunction');\nvar checkPropTypes = require('prop-types/checkPropTypes');\n\n/**\n * Copyright (c) 2013-present, Facebook, Inc.\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 * @providesModule reactProdInvariant\n * \n */\n\n{\n var warning = require$$0;\n}\n\nfunction warnNoop(publicInstance, callerName) {\n {\n var constructor = publicInstance.constructor;\n warning(false, '%s(...): Can only update a mounted or mounting component. ' + 'This usually means you called %s() on an unmounted component. ' + 'This is a no-op.\\n\\nPlease check the code for the %s component.', callerName, callerName, constructor && (constructor.displayName || constructor.name) || 'ReactClass');\n }\n}\n\n/**\n * This is the abstract API for an update queue.\n */\nvar ReactNoopUpdateQueue = {\n /**\n * Checks whether or not this composite component is mounted.\n * @param {ReactClass} publicInstance The instance we want to test.\n * @return {boolean} True if mounted, false otherwise.\n * @protected\n * @final\n */\n isMounted: function (publicInstance) {\n return false;\n },\n\n /**\n * Forces an update. This should only be invoked when it is known with\n * certainty that we are **not** in a DOM transaction.\n *\n * You may want to call this when you know that some deeper aspect of the\n * component's state has changed but `setState` was not called.\n *\n * This will not invoke `shouldComponentUpdate`, but it will invoke\n * `componentWillUpdate` and `componentDidUpdate`.\n *\n * @param {ReactClass} publicInstance The instance that should rerender.\n * @param {?function} callback Called after component is updated.\n * @param {?string} callerName name of the calling function in the public API.\n * @internal\n */\n enqueueForceUpdate: function (publicInstance, callback, callerName) {\n warnNoop(publicInstance, 'forceUpdate');\n },\n\n /**\n * Replaces all of the state. Always use this or `setState` to mutate state.\n * You should treat `this.state` as immutable.\n *\n * There is no guarantee that `this.state` will be immediately updated, so\n * accessing `this.state` after calling this method may return the old value.\n *\n * @param {ReactClass} publicInstance The instance that should rerender.\n * @param {object} completeState Next state.\n * @param {?function} callback Called after component is updated.\n * @param {?string} callerName name of the calling function in the public API.\n * @internal\n */\n enqueueReplaceState: function (publicInstance, completeState, callback, callerName) {\n warnNoop(publicInstance, 'replaceState');\n },\n\n /**\n * Sets a subset of the state. This only exists because _pendingState is\n * internal. This provides a merging strategy that is not available to deep\n * properties which is confusing. TODO: Expose pendingState or don't use it\n * during the merge.\n *\n * @param {ReactClass} publicInstance The instance that should rerender.\n * @param {object} partialState Next partial state to be merged with state.\n * @param {?function} callback Called after component is updated.\n * @param {?string} Name of the calling function in the public API.\n * @internal\n */\n enqueueSetState: function (publicInstance, partialState, callback, callerName) {\n warnNoop(publicInstance, 'setState');\n }\n};\n\nvar ReactNoopUpdateQueue_1 = ReactNoopUpdateQueue;\n\n/**\n * Copyright (c) 2014-present, Facebook, Inc.\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 * @providesModule lowPriorityWarning\n */\n\n/**\n * Forked from fbjs/warning:\n * https://github.com/facebook/fbjs/blob/e66ba20ad5be433eb54423f2b097d829324d9de6/packages/fbjs/src/__forks__/warning.js\n *\n * Only change is we use console.warn instead of console.error,\n * and do nothing when 'console' is not supported.\n * This really simplifies the code.\n * ---\n * Similar to invariant but only logs a warning if the condition is not met.\n * This can be used to log issues in development environments in critical\n * paths. Removing the logging code for production environments will keep the\n * same logic and follow the same code paths.\n */\n\nvar lowPriorityWarning = function () {};\n\n{\n var printWarning = function (format) {\n for (var _len = arguments.length, args = Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) {\n args[_key - 1] = arguments[_key];\n }\n\n var argIndex = 0;\n var message = 'Warning: ' + format.replace(/%s/g, function () {\n return args[argIndex++];\n });\n if (typeof console !== 'undefined') {\n console.warn(message);\n }\n try {\n // --- Welcome to debugging React ---\n // This error was thrown as a convenience so that you can use this stack\n // to find the callsite that caused this warning to fire.\n throw new Error(message);\n } catch (x) {}\n };\n\n lowPriorityWarning = function (condition, format) {\n if (format === undefined) {\n throw new Error('`warning(condition, format, ...args)` requires a warning ' + 'message argument');\n }\n if (!condition) {\n for (var _len2 = arguments.length, args = Array(_len2 > 2 ? _len2 - 2 : 0), _key2 = 2; _key2 < _len2; _key2++) {\n args[_key2 - 2] = arguments[_key2];\n }\n\n printWarning.apply(undefined, [format].concat(args));\n }\n };\n}\n\nvar lowPriorityWarning_1 = lowPriorityWarning;\n\n/**\n * Base class helpers for the updating state of a component.\n */\nfunction ReactComponent(props, context, updater) {\n this.props = props;\n this.context = context;\n this.refs = emptyObject;\n // We initialize the default updater but the real one gets injected by the\n // renderer.\n this.updater = updater || ReactNoopUpdateQueue_1;\n}\n\nReactComponent.prototype.isReactComponent = {};\n\n/**\n * Sets a subset of the state. Always use this to mutate\n * state. You should treat `this.state` as immutable.\n *\n * There is no guarantee that `this.state` will be immediately updated, so\n * accessing `this.state` after calling this method may return the old value.\n *\n * There is no guarantee that calls to `setState` will run synchronously,\n * as they may eventually be batched together. You can provide an optional\n * callback that will be executed when the call to setState is actually\n * completed.\n *\n * When a function is provided to setState, it will be called at some point in\n * the future (not synchronously). It will be called with the up to date\n * component arguments (state, props, context). These values can be different\n * from this.* because your function may be called after receiveProps but before\n * shouldComponentUpdate, and this new state, props, and context will not yet be\n * assigned to this.\n *\n * @param {object|function} partialState Next partial state or function to\n * produce next partial state to be merged with current state.\n * @param {?function} callback Called after state is updated.\n * @final\n * @protected\n */\nReactComponent.prototype.setState = function (partialState, callback) {\n !(typeof partialState === 'object' || typeof partialState === 'function' || partialState == null) ? invariant(false, 'setState(...): takes an object of state variables to update or a function which returns an object of state variables.') : void 0;\n this.updater.enqueueSetState(this, partialState, callback, 'setState');\n};\n\n/**\n * Forces an update. This should only be invoked when it is known with\n * certainty that we are **not** in a DOM transaction.\n *\n * You may want to call this when you know that some deeper aspect of the\n * component's state has changed but `setState` was not called.\n *\n * This will not invoke `shouldComponentUpdate`, but it will invoke\n * `componentWillUpdate` and `componentDidUpdate`.\n *\n * @param {?function} callback Called after update is complete.\n * @final\n * @protected\n */\nReactComponent.prototype.forceUpdate = function (callback) {\n this.updater.enqueueForceUpdate(this, callback, 'forceUpdate');\n};\n\n/**\n * Deprecated APIs. These APIs used to exist on classic React classes but since\n * we would like to deprecate them, we're not going to move them over to this\n * modern base class. Instead, we define a getter that warns if it's accessed.\n */\n{\n var deprecatedAPIs = {\n isMounted: ['isMounted', 'Instead, make sure to clean up subscriptions and pending requests in ' + 'componentWillUnmount to prevent memory leaks.'],\n replaceState: ['replaceState', 'Refactor your code to use setState instead (see ' + 'https://github.com/facebook/react/issues/3236).']\n };\n var defineDeprecationWarning = function (methodName, info) {\n Object.defineProperty(ReactComponent.prototype, methodName, {\n get: function () {\n lowPriorityWarning_1(false, '%s(...) is deprecated in plain JavaScript React classes. %s', info[0], info[1]);\n return undefined;\n }\n });\n };\n for (var fnName in deprecatedAPIs) {\n if (deprecatedAPIs.hasOwnProperty(fnName)) {\n defineDeprecationWarning(fnName, deprecatedAPIs[fnName]);\n }\n }\n}\n\n/**\n * Base class helpers for the updating state of a component.\n */\nfunction ReactPureComponent(props, context, updater) {\n // Duplicated from ReactComponent.\n this.props = props;\n this.context = context;\n this.refs = emptyObject;\n // We initialize the default updater but the real one gets injected by the\n // renderer.\n this.updater = updater || ReactNoopUpdateQueue_1;\n}\n\nfunction ComponentDummy() {}\nComponentDummy.prototype = ReactComponent.prototype;\nvar pureComponentPrototype = ReactPureComponent.prototype = new ComponentDummy();\npureComponentPrototype.constructor = ReactPureComponent;\n// Avoid an extra prototype jump for these methods.\nobjectAssign$1(pureComponentPrototype, ReactComponent.prototype);\npureComponentPrototype.isPureReactComponent = true;\n\nfunction ReactAsyncComponent(props, context, updater) {\n // Duplicated from ReactComponent.\n this.props = props;\n this.context = context;\n this.refs = emptyObject;\n // We initialize the default updater but the real one gets injected by the\n // renderer.\n this.updater = updater || ReactNoopUpdateQueue_1;\n}\n\nvar asyncComponentPrototype = ReactAsyncComponent.prototype = new ComponentDummy();\nasyncComponentPrototype.constructor = ReactAsyncComponent;\n// Avoid an extra prototype jump for these methods.\nobjectAssign$1(asyncComponentPrototype, ReactComponent.prototype);\nasyncComponentPrototype.unstable_isAsyncReactComponent = true;\nasyncComponentPrototype.render = function () {\n return this.props.children;\n};\n\nvar ReactBaseClasses = {\n Component: ReactComponent,\n PureComponent: ReactPureComponent,\n AsyncComponent: ReactAsyncComponent\n};\n\n/**\n * Copyright (c) 2013-present, Facebook, Inc.\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 * @providesModule ReactCurrentOwner\n * \n */\n\n/**\n * Keeps track of the current owner.\n *\n * The current owner is the component who should own any components that are\n * currently being constructed.\n */\nvar ReactCurrentOwner = {\n /**\n * @internal\n * @type {ReactComponent}\n */\n current: null\n};\n\nvar ReactCurrentOwner_1 = ReactCurrentOwner;\n\nvar hasOwnProperty = Object.prototype.hasOwnProperty;\n\n{\n var warning$2 = require$$0;\n}\n\n// The Symbol used to tag the ReactElement type. If there is no native Symbol\n// nor polyfill, then a plain number is used for performance.\nvar REACT_ELEMENT_TYPE$1 = typeof Symbol === 'function' && Symbol['for'] && Symbol['for']('react.element') || 0xeac7;\n\nvar RESERVED_PROPS = {\n key: true,\n ref: true,\n __self: true,\n __source: true\n};\n\nvar specialPropKeyWarningShown;\nvar specialPropRefWarningShown;\n\nfunction hasValidRef(config) {\n {\n if (hasOwnProperty.call(config, 'ref')) {\n var getter = Object.getOwnPropertyDescriptor(config, 'ref').get;\n if (getter && getter.isReactWarning) {\n return false;\n }\n }\n }\n return config.ref !== undefined;\n}\n\nfunction hasValidKey(config) {\n {\n if (hasOwnProperty.call(config, 'key')) {\n var getter = Object.getOwnPropertyDescriptor(config, 'key').get;\n if (getter && getter.isReactWarning) {\n return false;\n }\n }\n }\n return config.key !== undefined;\n}\n\nfunction defineKeyPropWarningGetter(props, displayName) {\n var warnAboutAccessingKey = function () {\n if (!specialPropKeyWarningShown) {\n specialPropKeyWarningShown = true;\n warning$2(false, '%s: `key` is not a prop. Trying to access it will result ' + 'in `undefined` being returned. If you need to access the same ' + 'value within the child component, you should pass it as a different ' + 'prop. (https://fb.me/react-special-props)', displayName);\n }\n };\n warnAboutAccessingKey.isReactWarning = true;\n Object.defineProperty(props, 'key', {\n get: warnAboutAccessingKey,\n configurable: true\n });\n}\n\nfunction defineRefPropWarningGetter(props, displayName) {\n var warnAboutAccessingRef = function () {\n if (!specialPropRefWarningShown) {\n specialPropRefWarningShown = true;\n warning$2(false, '%s: `ref` is not a prop. Trying to access it will result ' + 'in `undefined` being returned. If you need to access the same ' + 'value within the child component, you should pass it as a different ' + 'prop. (https://fb.me/react-special-props)', displayName);\n }\n };\n warnAboutAccessingRef.isReactWarning = true;\n Object.defineProperty(props, 'ref', {\n get: warnAboutAccessingRef,\n configurable: true\n });\n}\n\n/**\n * Factory method to create a new React element. This no longer adheres to\n * the class pattern, so do not use new to call it. Also, no instanceof check\n * will work. Instead test $$typeof field against Symbol.for('react.element') to check\n * if something is a React Element.\n *\n * @param {*} type\n * @param {*} key\n * @param {string|object} ref\n * @param {*} self A *temporary* helper to detect places where `this` is\n * different from the `owner` when React.createElement is called, so that we\n * can warn. We want to get rid of owner and replace string `ref`s with arrow\n * functions, and as long as `this` and owner are the same, there will be no\n * change in behavior.\n * @param {*} source An annotation object (added by a transpiler or otherwise)\n * indicating filename, line number, and/or other information.\n * @param {*} owner\n * @param {*} props\n * @internal\n */\nvar ReactElement = function (type, key, ref, self, source, owner, props) {\n var element = {\n // This tag allow us to uniquely identify this as a React Element\n $$typeof: REACT_ELEMENT_TYPE$1,\n\n // Built-in properties that belong on the element\n type: type,\n key: key,\n ref: ref,\n props: props,\n\n // Record the component responsible for creating this element.\n _owner: owner\n };\n\n {\n // The validation flag is currently mutative. We put it on\n // an external backing store so that we can freeze the whole object.\n // This can be replaced with a WeakMap once they are implemented in\n // commonly used development environments.\n element._store = {};\n\n // To make comparing ReactElements easier for testing purposes, we make\n // the validation flag non-enumerable (where possible, which should\n // include every environment we run tests in), so the test framework\n // ignores it.\n Object.defineProperty(element._store, 'validated', {\n configurable: false,\n enumerable: false,\n writable: true,\n value: false\n });\n // self and source are DEV only properties.\n Object.defineProperty(element, '_self', {\n configurable: false,\n enumerable: false,\n writable: false,\n value: self\n });\n // Two elements created in two different places should be considered\n // equal for testing purposes and therefore we hide it from enumeration.\n Object.defineProperty(element, '_source', {\n configurable: false,\n enumerable: false,\n writable: false,\n value: source\n });\n if (Object.freeze) {\n Object.freeze(element.props);\n Object.freeze(element);\n }\n }\n\n return element;\n};\n\n/**\n * Create and return a new ReactElement of the given type.\n * See https://facebook.github.io/react/docs/react-api.html#createelement\n */\nReactElement.createElement = function (type, config, children) {\n var propName;\n\n // Reserved names are extracted\n var props = {};\n\n var key = null;\n var ref = null;\n var self = null;\n var source = null;\n\n if (config != null) {\n if (hasValidRef(config)) {\n ref = config.ref;\n }\n if (hasValidKey(config)) {\n key = '' + config.key;\n }\n\n self = config.__self === undefined ? null : config.__self;\n source = config.__source === undefined ? null : config.__source;\n // Remaining properties are added to a new props object\n for (propName in config) {\n if (hasOwnProperty.call(config, propName) && !RESERVED_PROPS.hasOwnProperty(propName)) {\n props[propName] = config[propName];\n }\n }\n }\n\n // Children can be more than one argument, and those are transferred onto\n // the newly allocated props object.\n var childrenLength = arguments.length - 2;\n if (childrenLength === 1) {\n props.children = children;\n } else if (childrenLength > 1) {\n var childArray = Array(childrenLength);\n for (var i = 0; i < childrenLength; i++) {\n childArray[i] = arguments[i + 2];\n }\n {\n if (Object.freeze) {\n Object.freeze(childArray);\n }\n }\n props.children = childArray;\n }\n\n // Resolve default props\n if (type && type.defaultProps) {\n var defaultProps = type.defaultProps;\n for (propName in defaultProps) {\n if (props[propName] === undefined) {\n props[propName] = defaultProps[propName];\n }\n }\n }\n {\n if (key || ref) {\n if (typeof props.$$typeof === 'undefined' || props.$$typeof !== REACT_ELEMENT_TYPE$1) {\n var displayName = typeof type === 'function' ? type.displayName || type.name || 'Unknown' : type;\n if (key) {\n defineKeyPropWarningGetter(props, displayName);\n }\n if (ref) {\n defineRefPropWarningGetter(props, displayName);\n }\n }\n }\n }\n return ReactElement(type, key, ref, self, source, ReactCurrentOwner_1.current, props);\n};\n\n/**\n * Return a function that produces ReactElements of a given type.\n * See https://facebook.github.io/react/docs/react-api.html#createfactory\n */\nReactElement.createFactory = function (type) {\n var factory = ReactElement.createElement.bind(null, type);\n // Expose the type on the factory and the prototype so that it can be\n // easily accessed on elements. E.g. `<Foo />.type === Foo`.\n // This should not be named `constructor` since this may not be the function\n // that created the element, and it may not even be a constructor.\n // Legacy hook TODO: Warn if this is accessed\n factory.type = type;\n return factory;\n};\n\nReactElement.cloneAndReplaceKey = function (oldElement, newKey) {\n var newElement = ReactElement(oldElement.type, newKey, oldElement.ref, oldElement._self, oldElement._source, oldElement._owner, oldElement.props);\n\n return newElement;\n};\n\n/**\n * Clone and return a new ReactElement using element as the starting point.\n * See https://facebook.github.io/react/docs/react-api.html#cloneelement\n */\nReactElement.cloneElement = function (element, config, children) {\n var propName;\n\n // Original props are copied\n var props = objectAssign$1({}, element.props);\n\n // Reserved names are extracted\n var key = element.key;\n var ref = element.ref;\n // Self is preserved since the owner is preserved.\n var self = element._self;\n // Source is preserved since cloneElement is unlikely to be targeted by a\n // transpiler, and the original source is probably a better indicator of the\n // true owner.\n var source = element._source;\n\n // Owner will be preserved, unless ref is overridden\n var owner = element._owner;\n\n if (config != null) {\n if (hasValidRef(config)) {\n // Silently steal the ref from the parent.\n ref = config.ref;\n owner = ReactCurrentOwner_1.current;\n }\n if (hasValidKey(config)) {\n key = '' + config.key;\n }\n\n // Remaining properties override existing props\n var defaultProps;\n if (element.type && element.type.defaultProps) {\n defaultProps = element.type.defaultProps;\n }\n for (propName in config) {\n if (hasOwnProperty.call(config, propName) && !RESERVED_PROPS.hasOwnProperty(propName)) {\n if (config[propName] === undefined && defaultProps !== undefined) {\n // Resolve default props\n props[propName] = defaultProps[propName];\n } else {\n props[propName] = config[propName];\n }\n }\n }\n }\n\n // Children can be more than one argument, and those are transferred onto\n // the newly allocated props object.\n var childrenLength = arguments.length - 2;\n if (childrenLength === 1) {\n props.children = children;\n } else if (childrenLength > 1) {\n var childArray = Array(childrenLength);\n for (var i = 0; i < childrenLength; i++) {\n childArray[i] = arguments[i + 2];\n }\n props.children = childArray;\n }\n\n return ReactElement(element.type, key, ref, self, source, owner, props);\n};\n\n/**\n * Verifies the object is a ReactElement.\n * See https://facebook.github.io/react/docs/react-api.html#isvalidelement\n * @param {?object} object\n * @return {boolean} True if `object` is a valid component.\n * @final\n */\nReactElement.isValidElement = function (object) {\n return typeof object === 'object' && object !== null && object.$$typeof === REACT_ELEMENT_TYPE$1;\n};\n\nvar ReactElement_1 = ReactElement;\n\n/**\n * Copyright (c) 2013-present, Facebook, Inc.\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 * @providesModule ReactDebugCurrentFrame\n * \n */\n\nvar ReactDebugCurrentFrame = {};\n\n{\n // Component that is being worked on\n ReactDebugCurrentFrame.getCurrentStack = null;\n\n ReactDebugCurrentFrame.getStackAddendum = function () {\n var impl = ReactDebugCurrentFrame.getCurrentStack;\n if (impl) {\n return impl();\n }\n return null;\n };\n}\n\nvar ReactDebugCurrentFrame_1 = ReactDebugCurrentFrame;\n\n{\n var warning$1 = require$$0;\n\n var _require = ReactDebugCurrentFrame_1,\n getStackAddendum = _require.getStackAddendum;\n}\n\nvar ITERATOR_SYMBOL = typeof Symbol === 'function' && Symbol.iterator;\nvar FAUX_ITERATOR_SYMBOL = '@@iterator'; // Before Symbol spec.\n// The Symbol used to tag the ReactElement type. If there is no native Symbol\n// nor polyfill, then a plain number is used for performance.\nvar REACT_ELEMENT_TYPE = typeof Symbol === 'function' && Symbol['for'] && Symbol['for']('react.element') || 0xeac7;\n\nvar SEPARATOR = '.';\nvar SUBSEPARATOR = ':';\n\n/**\n * Escape and wrap key so it is safe to use as a reactid\n *\n * @param {string} key to be escaped.\n * @return {string} the escaped key.\n */\nfunction escape(key) {\n var escapeRegex = /[=:]/g;\n var escaperLookup = {\n '=': '=0',\n ':': '=2'\n };\n var escapedString = ('' + key).replace(escapeRegex, function (match) {\n return escaperLookup[match];\n });\n\n return '$' + escapedString;\n}\n\n/**\n * TODO: Test that a single child and an array with one item have the same key\n * pattern.\n */\n\nvar didWarnAboutMaps = false;\n\nvar userProvidedKeyEscapeRegex = /\\/+/g;\nfunction escapeUserProvidedKey(text) {\n return ('' + text).replace(userProvidedKeyEscapeRegex, '$&/');\n}\n\nvar POOL_SIZE = 10;\nvar traverseContextPool = [];\nfunction getPooledTraverseContext(mapResult, keyPrefix, mapFunction, mapContext) {\n if (traverseContextPool.length) {\n var traverseContext = traverseContextPool.pop();\n traverseContext.result = mapResult;\n traverseContext.keyPrefix = keyPrefix;\n traverseContext.func = mapFunction;\n traverseContext.context = mapContext;\n traverseContext.count = 0;\n return traverseContext;\n } else {\n return {\n result: mapResult,\n keyPrefix: keyPrefix,\n func: mapFunction,\n context: mapContext,\n count: 0\n };\n }\n}\n\nfunction releaseTraverseContext(traverseContext) {\n traverseContext.result = null;\n traverseContext.keyPrefix = null;\n traverseContext.func = null;\n traverseContext.context = null;\n traverseContext.count = 0;\n if (traverseContextPool.length < POOL_SIZE) {\n traverseContextPool.push(traverseContext);\n }\n}\n\n/**\n * @param {?*} children Children tree container.\n * @param {!string} nameSoFar Name of the key path so far.\n * @param {!function} callback Callback to invoke with each child found.\n * @param {?*} traverseContext Used to pass information throughout the traversal\n * process.\n * @return {!number} The number of children in this subtree.\n */\nfunction traverseAllChildrenImpl(children, nameSoFar, callback, traverseContext) {\n var type = typeof children;\n\n if (type === 'undefined' || type === 'boolean') {\n // All of the above are perceived as null.\n children = null;\n }\n\n if (children === null || type === 'string' || type === 'number' ||\n // The following is inlined from ReactElement. This means we can optimize\n // some checks. React Fiber also inlines this logic for similar purposes.\n type === 'object' && children.$$typeof === REACT_ELEMENT_TYPE) {\n callback(traverseContext, children,\n // If it's the only child, treat the name as if it was wrapped in an array\n // so that it's consistent if the number of children grows.\n nameSoFar === '' ? SEPARATOR + getComponentKey(children, 0) : nameSoFar);\n return 1;\n }\n\n var child;\n var nextName;\n var subtreeCount = 0; // Count of children found in the current subtree.\n var nextNamePrefix = nameSoFar === '' ? SEPARATOR : nameSoFar + SUBSEPARATOR;\n\n if (Array.isArray(children)) {\n for (var i = 0; i < children.length; i++) {\n child = children[i];\n nextName = nextNamePrefix + getComponentKey(child, i);\n subtreeCount += traverseAllChildrenImpl(child, nextName, callback, traverseContext);\n }\n } else {\n var iteratorFn = ITERATOR_SYMBOL && children[ITERATOR_SYMBOL] || children[FAUX_ITERATOR_SYMBOL];\n if (typeof iteratorFn === 'function') {\n {\n // Warn about using Maps as children\n if (iteratorFn === children.entries) {\n warning$1(didWarnAboutMaps, 'Using Maps as children is unsupported and will likely yield ' + 'unexpected results. Convert it to a sequence/iterable of keyed ' + 'ReactElements instead.%s', getStackAddendum());\n didWarnAboutMaps = true;\n }\n }\n\n var iterator = iteratorFn.call(children);\n var step;\n var ii = 0;\n while (!(step = iterator.next()).done) {\n child = step.value;\n nextName = nextNamePrefix + getComponentKey(child, ii++);\n subtreeCount += traverseAllChildrenImpl(child, nextName, callback, traverseContext);\n }\n } else if (type === 'object') {\n var addendum = '';\n {\n addendum = ' If you meant to render a collection of children, use an array ' + 'instead.' + getStackAddendum();\n }\n var childrenString = '' + children;\n invariant(false, 'Objects are not valid as a React child (found: %s).%s', childrenString === '[object Object]' ? 'object with keys {' + Object.keys(children).join(', ') + '}' : childrenString, addendum);\n }\n }\n\n return subtreeCount;\n}\n\n/**\n * Traverses children that are typically specified as `props.children`, but\n * might also be specified through attributes:\n *\n * - `traverseAllChildren(this.props.children, ...)`\n * - `traverseAllChildren(this.props.leftPanelChildren, ...)`\n *\n * The `traverseContext` is an optional argument that is passed through the\n * entire traversal. It can be used to store accumulations or anything else that\n * the callback might find relevant.\n *\n * @param {?*} children Children tree object.\n * @param {!function} callback To invoke upon traversing each child.\n * @param {?*} traverseContext Context for traversal.\n * @return {!number} The number of children in this subtree.\n */\nfunction traverseAllChildren(children, callback, traverseContext) {\n if (children == null) {\n return 0;\n }\n\n return traverseAllChildrenImpl(children, '', callback, traverseContext);\n}\n\n/**\n * Generate a key string that identifies a component within a set.\n *\n * @param {*} component A component that could contain a manual key.\n * @param {number} index Index that is used if a manual key is not provided.\n * @return {string}\n */\nfunction getComponentKey(component, index) {\n // Do some typechecking here since we call this blindly. We want to ensure\n // that we don't block potential future ES APIs.\n if (typeof component === 'object' && component !== null && component.key != null) {\n // Explicit key\n return escape(component.key);\n }\n // Implicit key determined by the index in the set\n return index.toString(36);\n}\n\nfunction forEachSingleChild(bookKeeping, child, name) {\n var func = bookKeeping.func,\n context = bookKeeping.context;\n\n func.call(context, child, bookKeeping.count++);\n}\n\n/**\n * Iterates through children that are typically specified as `props.children`.\n *\n * See https://facebook.github.io/react/docs/react-api.html#react.children.foreach\n *\n * The provided forEachFunc(child, index) will be called for each\n * leaf child.\n *\n * @param {?*} children Children tree container.\n * @param {function(*, int)} forEachFunc\n * @param {*} forEachContext Context for forEachContext.\n */\nfunction forEachChildren(children, forEachFunc, forEachContext) {\n if (children == null) {\n return children;\n }\n var traverseContext = getPooledTraverseContext(null, null, forEachFunc, forEachContext);\n traverseAllChildren(children, forEachSingleChild, traverseContext);\n releaseTraverseContext(traverseContext);\n}\n\nfunction mapSingleChildIntoContext(bookKeeping, child, childKey) {\n var result = bookKeeping.result,\n keyPrefix = bookKeeping.keyPrefix,\n func = bookKeeping.func,\n context = bookKeeping.context;\n\n\n var mappedChild = func.call(context, child, bookKeeping.count++);\n if (Array.isArray(mappedChild)) {\n mapIntoWithKeyPrefixInternal(mappedChild, result, childKey, emptyFunction.thatReturnsArgument);\n } else if (mappedChild != null) {\n if (ReactElement_1.isValidElement(mappedChild)) {\n mappedChild = ReactElement_1.cloneAndReplaceKey(mappedChild,\n // Keep both the (mapped) and old keys if they differ, just as\n // traverseAllChildren used to do for objects as children\n keyPrefix + (mappedChild.key && (!child || child.key !== mappedChild.key) ? escapeUserProvidedKey(mappedChild.key) + '/' : '') + childKey);\n }\n result.push(mappedChild);\n }\n}\n\nfunction mapIntoWithKeyPrefixInternal(children, array, prefix, func, context) {\n var escapedPrefix = '';\n if (prefix != null) {\n escapedPrefix = escapeUserProvidedKey(prefix) + '/';\n }\n var traverseContext = getPooledTraverseContext(array, escapedPrefix, func, context);\n traverseAllChildren(children, mapSingleChildIntoContext, traverseContext);\n releaseTraverseContext(traverseContext);\n}\n\n/**\n * Maps children that are typically specified as `props.children`.\n *\n * See https://facebook.github.io/react/docs/react-api.html#react.children.map\n *\n * The provided mapFunction(child, key, index) will be called for each\n * leaf child.\n *\n * @param {?*} children Children tree container.\n * @param {function(*, int)} func The map function.\n * @param {*} context Context for mapFunction.\n * @return {object} Object containing the ordered map of results.\n */\nfunction mapChildren(children, func, context) {\n if (children == null) {\n return children;\n }\n var result = [];\n mapIntoWithKeyPrefixInternal(children, result, null, func, context);\n return result;\n}\n\n/**\n * Count the number of children that are typically specified as\n * `props.children`.\n *\n * See https://facebook.github.io/react/docs/react-api.html#react.children.count\n *\n * @param {?*} children Children tree container.\n * @return {number} The number of children.\n */\nfunction countChildren(children, context) {\n return traverseAllChildren(children, emptyFunction.thatReturnsNull, null);\n}\n\n/**\n * Flatten a children object (typically specified as `props.children`) and\n * return an array with appropriately re-keyed children.\n *\n * See https://facebook.github.io/react/docs/react-api.html#react.children.toarray\n */\nfunction toArray(children) {\n var result = [];\n mapIntoWithKeyPrefixInternal(children, result, null, emptyFunction.thatReturnsArgument);\n return result;\n}\n\nvar ReactChildren = {\n forEach: forEachChildren,\n map: mapChildren,\n count: countChildren,\n toArray: toArray\n};\n\nvar ReactChildren_1 = ReactChildren;\n\n/**\n * Copyright (c) 2013-present, Facebook, Inc.\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 * @providesModule ReactVersion\n */\n\nvar ReactVersion = '16.0.0';\n\n/**\n * Returns the first child in a collection of children and verifies that there\n * is only one child in the collection.\n *\n * See https://facebook.github.io/react/docs/react-api.html#react.children.only\n *\n * The current implementation of this function assumes that a single child gets\n * passed without a wrapper, but the purpose of this helper function is to\n * abstract away the particular structure of children.\n *\n * @param {?object} children Child collection structure.\n * @return {ReactElement} The first and only `ReactElement` contained in the\n * structure.\n */\nfunction onlyChild(children) {\n !ReactElement_1.isValidElement(children) ? invariant(false, 'React.Children.only expected to receive a single React element child.') : void 0;\n return children;\n}\n\nvar onlyChild_1 = onlyChild;\n\n/**\n * Copyright (c) 2016-present, Facebook, Inc.\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 * \n * @providesModule describeComponentFrame\n */\n\nvar describeComponentFrame$1 = function (name, source, ownerName) {\n return '\\n in ' + (name || 'Unknown') + (source ? ' (at ' + source.fileName.replace(/^.*[\\\\\\/]/, '') + ':' + source.lineNumber + ')' : ownerName ? ' (created by ' + ownerName + ')' : '');\n};\n\n/**\n * Copyright (c) 2013-present, Facebook, Inc.\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 * @providesModule getComponentName\n * \n */\n\nfunction getComponentName$1(instanceOrFiber) {\n if (typeof instanceOrFiber.getName === 'function') {\n // Stack reconciler\n var instance = instanceOrFiber;\n return instance.getName();\n }\n if (typeof instanceOrFiber.tag === 'number') {\n // Fiber reconciler\n var fiber = instanceOrFiber;\n var type = fiber.type;\n\n if (typeof type === 'string') {\n return type;\n }\n if (typeof type === 'function') {\n return type.displayName || type.name;\n }\n }\n return null;\n}\n\nvar getComponentName_1 = getComponentName$1;\n\n{\n var checkPropTypes$1 = checkPropTypes;\n var lowPriorityWarning$1 = lowPriorityWarning_1;\n var ReactDebugCurrentFrame$1 = ReactDebugCurrentFrame_1;\n var warning$3 = require$$0;\n var describeComponentFrame = describeComponentFrame$1;\n var getComponentName = getComponentName_1;\n\n var currentlyValidatingElement = null;\n\n var getDisplayName = function (element) {\n if (element == null) {\n return '#empty';\n } else if (typeof element === 'string' || typeof element === 'number') {\n return '#text';\n } else if (typeof element.type === 'string') {\n return element.type;\n } else {\n return element.type.displayName || element.type.name || 'Unknown';\n }\n };\n\n var getStackAddendum$1 = function () {\n var stack = '';\n if (currentlyValidatingElement) {\n var name = getDisplayName(currentlyValidatingElement);\n var owner = currentlyValidatingElement._owner;\n stack += describeComponentFrame(name, currentlyValidatingElement._source, owner && getComponentName(owner));\n }\n stack += ReactDebugCurrentFrame$1.getStackAddendum() || '';\n return stack;\n };\n}\n\nvar ITERATOR_SYMBOL$1 = typeof Symbol === 'function' && Symbol.iterator;\nvar FAUX_ITERATOR_SYMBOL$1 = '@@iterator'; // Before Symbol spec.\n\nfunction getDeclarationErrorAddendum() {\n if (ReactCurrentOwner_1.current) {\n var name = getComponentName(ReactCurrentOwner_1.current);\n if (name) {\n return '\\n\\nCheck the render method of `' + name + '`.';\n }\n }\n return '';\n}\n\nfunction getSourceInfoErrorAddendum(elementProps) {\n if (elementProps !== null && elementProps !== undefined && elementProps.__source !== undefined) {\n var source = elementProps.__source;\n var fileName = source.fileName.replace(/^.*[\\\\\\/]/, '');\n var lineNumber = source.lineNumber;\n return '\\n\\nCheck your code at ' + fileName + ':' + lineNumber + '.';\n }\n return '';\n}\n\n/**\n * Warn if there's no key explicitly set on dynamic arrays of children or\n * object keys are not valid. This allows us to keep track of children between\n * updates.\n */\nvar ownerHasKeyUseWarning = {};\n\nfunction getCurrentComponentErrorInfo(parentType) {\n var info = getDeclarationErrorAddendum();\n\n if (!info) {\n var parentName = typeof parentType === 'string' ? parentType : parentType.displayName || parentType.name;\n if (parentName) {\n info = '\\n\\nCheck the top-level render call using <' + parentName + '>.';\n }\n }\n return info;\n}\n\n/**\n * Warn if the element doesn't have an explicit key assigned to it.\n * This element is in an array. The array could grow and shrink or be\n * reordered. All children that haven't already been validated are required to\n * have a \"key\" property assigned to it. Error statuses are cached so a warning\n * will only be shown once.\n *\n * @internal\n * @param {ReactElement} element Element that requires a key.\n * @param {*} parentType element's parent's type.\n */\nfunction validateExplicitKey(element, parentType) {\n if (!element._store || element._store.validated || element.key != null) {\n return;\n }\n element._store.validated = true;\n\n var currentComponentErrorInfo = getCurrentComponentErrorInfo(parentType);\n if (ownerHasKeyUseWarning[currentComponentErrorInfo]) {\n return;\n }\n ownerHasKeyUseWarning[currentComponentErrorInfo] = true;\n\n // Usually the current owner is the offender, but if it accepts children as a\n // property, it may be the creator of the child that's responsible for\n // assigning it a key.\n var childOwner = '';\n if (element && element._owner && element._owner !== ReactCurrentOwner_1.current) {\n // Give the component that originally created this child.\n childOwner = ' It was passed a child from ' + getComponentName(element._owner) + '.';\n }\n\n currentlyValidatingElement = element;\n {\n warning$3(false, 'Each child in an array or iterator should have a unique \"key\" prop.' + '%s%s See https://fb.me/react-warning-keys for more information.%s', currentComponentErrorInfo, childOwner, getStackAddendum$1());\n }\n currentlyValidatingElement = null;\n}\n\n/**\n * Ensure that every element either is passed in a static location, in an\n * array with an explicit keys property defined, or in an object literal\n * with valid key property.\n *\n * @internal\n * @param {ReactNode} node Statically passed child of any type.\n * @param {*} parentType node's parent's type.\n */\nfunction validateChildKeys(node, parentType) {\n if (typeof node !== 'object') {\n return;\n }\n if (Array.isArray(node)) {\n for (var i = 0; i < node.length; i++) {\n var child = node[i];\n if (ReactElement_1.isValidElement(child)) {\n validateExplicitKey(child, parentType);\n }\n }\n } else if (ReactElement_1.isValidElement(node)) {\n // This element was passed in a valid location.\n if (node._store) {\n node._store.validated = true;\n }\n } else if (node) {\n var iteratorFn = ITERATOR_SYMBOL$1 && node[ITERATOR_SYMBOL$1] || node[FAUX_ITERATOR_SYMBOL$1];\n if (typeof iteratorFn === 'function') {\n // Entry iterators used to provide implicit keys,\n // but now we print a separate warning for them later.\n if (iteratorFn !== node.entries) {\n var iterator = iteratorFn.call(node);\n var step;\n while (!(step = iterator.next()).done) {\n if (ReactElement_1.isValidElement(step.value)) {\n validateExplicitKey(step.value, parentType);\n }\n }\n }\n }\n }\n}\n\n/**\n * Given an element, validate that its props follow the propTypes definition,\n * provided by the type.\n *\n * @param {ReactElement} element\n */\nfunction validatePropTypes(element) {\n var componentClass = element.type;\n if (typeof componentClass !== 'function') {\n return;\n }\n var name = componentClass.displayName || componentClass.name;\n var propTypes = componentClass.propTypes;\n\n if (propTypes) {\n currentlyValidatingElement = element;\n checkPropTypes$1(propTypes, element.props, 'prop', name, getStackAddendum$1);\n currentlyValidatingElement = null;\n }\n if (typeof componentClass.getDefaultProps === 'function') {\n warning$3(componentClass.getDefaultProps.isReactClassApproved, 'getDefaultProps is only used on classic React.createClass ' + 'definitions. Use a static property named `defaultProps` instead.');\n }\n}\n\nvar ReactElementValidator$1 = {\n createElement: function (type, props, children) {\n var validType = typeof type === 'string' || typeof type === 'function';\n // We warn in this case but don't throw. We expect the element creation to\n // succeed and there will likely be errors in render.\n if (!validType) {\n var info = '';\n if (type === undefined || typeof type === 'object' && type !== null && Object.keys(type).length === 0) {\n info += ' You likely forgot to export your component from the file ' + \"it's defined in.\";\n }\n\n var sourceInfo = getSourceInfoErrorAddendum(props);\n if (sourceInfo) {\n info += sourceInfo;\n } else {\n info += getDeclarationErrorAddendum();\n }\n\n info += ReactDebugCurrentFrame$1.getStackAddendum() || '';\n\n warning$3(false, 'React.createElement: type is invalid -- expected a string (for ' + 'built-in components) or a class/function (for composite ' + 'components) but got: %s.%s', type == null ? type : typeof type, info);\n }\n\n var element = ReactElement_1.createElement.apply(this, arguments);\n\n // The result can be nullish if a mock or a custom function is used.\n // TODO: Drop this when these are no longer allowed as the type argument.\n if (element == null) {\n return element;\n }\n\n // Skip key warning if the type isn't valid since our key validation logic\n // doesn't expect a non-string/function type and can throw confusing errors.\n // We don't want exception behavior to differ between dev and prod.\n // (Rendering will throw with a helpful message and as soon as the type is\n // fixed, the key warnings will appear.)\n if (validType) {\n for (var i = 2; i < arguments.length; i++) {\n validateChildKeys(arguments[i], type);\n }\n }\n\n validatePropTypes(element);\n\n return element;\n },\n\n createFactory: function (type) {\n var validatedFactory = ReactElementValidator$1.createElement.bind(null, type);\n // Legacy hook TODO: Warn if this is accessed\n validatedFactory.type = type;\n\n {\n Object.defineProperty(validatedFactory, 'type', {\n enumerable: false,\n get: function () {\n lowPriorityWarning$1(false, 'Factory.type is deprecated. Access the class directly ' + 'before passing it to createFactory.');\n Object.defineProperty(this, 'type', {\n value: type\n });\n return type;\n }\n });\n }\n\n return validatedFactory;\n },\n\n cloneElement: function (element, props, children) {\n var newElement = ReactElement_1.cloneElement.apply(this, arguments);\n for (var i = 2; i < arguments.length; i++) {\n validateChildKeys(arguments[i], newElement.type);\n }\n validatePropTypes(newElement);\n return newElement;\n }\n};\n\nvar ReactElementValidator_1 = ReactElementValidator$1;\n\n{\n var warning$4 = require$$0;\n}\n\nfunction isNative(fn) {\n // Based on isNative() from Lodash\n var funcToString = Function.prototype.toString;\n var reIsNative = RegExp('^' + funcToString\n // Take an example native function source for comparison\n .call(Object.prototype.hasOwnProperty)\n // Strip regex characters so we can use it for regex\n .replace(/[\\\\^$.*+?()[\\]{}|]/g, '\\\\$&')\n // Remove hasOwnProperty from the template to make it generic\n .replace(/hasOwnProperty|(function).*?(?=\\\\\\()| for .+?(?=\\\\\\])/g, '$1.*?') + '$');\n try {\n var source = funcToString.call(fn);\n return reIsNative.test(source);\n } catch (err) {\n return false;\n }\n}\n\nvar canUseCollections =\n// Array.from\ntypeof Array.from === 'function' &&\n// Map\ntypeof Map === 'function' && isNative(Map) &&\n// Map.prototype.keys\nMap.prototype != null && typeof Map.prototype.keys === 'function' && isNative(Map.prototype.keys) &&\n// Set\ntypeof Set === 'function' && isNative(Set) &&\n// Set.prototype.keys\nSet.prototype != null && typeof Set.prototype.keys === 'function' && isNative(Set.prototype.keys);\n\nvar setItem;\nvar getItem;\nvar removeItem;\nvar getItemIDs;\nvar addRoot;\nvar removeRoot;\nvar getRootIDs;\n\nif (canUseCollections) {\n var itemMap = new Map();\n var rootIDSet = new Set();\n\n setItem = function (id, item) {\n itemMap.set(id, item);\n };\n getItem = function (id) {\n return itemMap.get(id);\n };\n removeItem = function (id) {\n itemMap['delete'](id);\n };\n getItemIDs = function () {\n return Array.from(itemMap.keys());\n };\n\n addRoot = function (id) {\n rootIDSet.add(id);\n };\n removeRoot = function (id) {\n rootIDSet['delete'](id);\n };\n getRootIDs = function () {\n return Array.from(rootIDSet.keys());\n };\n} else {\n var itemByKey = {};\n var rootByKey = {};\n\n // Use non-numeric keys to prevent V8 performance issues:\n // https://github.com/facebook/react/pull/7232\n var getKeyFromID = function (id) {\n return '.' + id;\n };\n var getIDFromKey = function (key) {\n return parseInt(key.substr(1), 10);\n };\n\n setItem = function (id, item) {\n var key = getKeyFromID(id);\n itemByKey[key] = item;\n };\n getItem = function (id) {\n var key = getKeyFromID(id);\n return itemByKey[key];\n };\n removeItem = function (id) {\n var key = getKeyFromID(id);\n delete itemByKey[key];\n };\n getItemIDs = function () {\n return Object.keys(itemByKey).map(getIDFromKey);\n };\n\n addRoot = function (id) {\n var key = getKeyFromID(id);\n rootByKey[key] = true;\n };\n removeRoot = function (id) {\n var key = getKeyFromID(id);\n delete rootByKey[key];\n };\n getRootIDs = function () {\n return Object.keys(rootByKey).map(getIDFromKey);\n };\n}\n\nvar unmountedIDs = [];\n\nfunction purgeDeep(id) {\n var item = getItem(id);\n if (item) {\n var childIDs = item.childIDs;\n\n removeItem(id);\n childIDs.forEach(purgeDeep);\n }\n}\n\nfunction getDisplayName$1(element) {\n if (element == null) {\n return '#empty';\n } else if (typeof element === 'string' || typeof element === 'number') {\n return '#text';\n } else if (typeof element.type === 'string') {\n return element.type;\n } else {\n return element.type.displayName || element.type.name || 'Unknown';\n }\n}\n\nfunction describeID(id) {\n var name = ReactComponentTreeHook.getDisplayName(id);\n var element = ReactComponentTreeHook.getElement(id);\n var ownerID = ReactComponentTreeHook.getOwnerID(id);\n var ownerName = void 0;\n\n if (ownerID) {\n ownerName = ReactComponentTreeHook.getDisplayName(ownerID);\n }\n warning$4(element, 'ReactComponentTreeHook: Missing React element for debugID %s when ' + 'building stack', id);\n return describeComponentFrame$1(name || '', element && element._source, ownerName || '');\n}\n\nvar ReactComponentTreeHook = {\n onSetChildren: function (id, nextChildIDs) {\n var item = getItem(id);\n !item ? invariant(false, 'Item must have been set') : void 0;\n item.childIDs = nextChildIDs;\n\n for (var i = 0; i < nextChildIDs.length; i++) {\n var nextChildID = nextChildIDs[i];\n var nextChild = getItem(nextChildID);\n !nextChild ? invariant(false, 'Expected hook events to fire for the child before its parent includes it in onSetChildren().') : void 0;\n !(nextChild.childIDs != null || typeof nextChild.element !== 'object' || nextChild.element == null) ? invariant(false, 'Expected onSetChildren() to fire for a container child before its parent includes it in onSetChildren().') : void 0;\n !nextChild.isMounted ? invariant(false, 'Expected onMountComponent() to fire for the child before its parent includes it in onSetChildren().') : void 0;\n if (nextChild.parentID == null) {\n nextChild.parentID = id;\n // TODO: This shouldn't be necessary but mounting a new root during in\n // componentWillMount currently causes not-yet-mounted components to\n // be purged from our tree data so their parent id is missing.\n }\n !(nextChild.parentID === id) ? invariant(false, 'Expected onBeforeMountComponent() parent and onSetChildren() to be consistent (%s has parents %s and %s).', nextChildID, nextChild.parentID, id) : void 0;\n }\n },\n onBeforeMountComponent: function (id, element, parentID) {\n var item = {\n element: element,\n parentID: parentID,\n text: null,\n childIDs: [],\n isMounted: false,\n updateCount: 0\n };\n setItem(id, item);\n },\n onBeforeUpdateComponent: function (id, element) {\n var item = getItem(id);\n if (!item || !item.isMounted) {\n // We may end up here as a result of setState() in componentWillUnmount().\n // In this case, ignore the element.\n return;\n }\n item.element = element;\n },\n onMountComponent: function (id) {\n var item = getItem(id);\n !item ? invariant(false, 'Item must have been set') : void 0;\n item.isMounted = true;\n var isRoot = item.parentID === 0;\n if (isRoot) {\n addRoot(id);\n }\n },\n onUpdateComponent: function (id) {\n var item = getItem(id);\n if (!item || !item.isMounted) {\n // We may end up here as a result of setState() in componentWillUnmount().\n // In this case, ignore the element.\n return;\n }\n item.updateCount++;\n },\n onUnmountComponent: function (id) {\n var item = getItem(id);\n if (item) {\n // We need to check if it exists.\n // `item` might not exist if it is inside an error boundary, and a sibling\n // error boundary child threw while mounting. Then this instance never\n // got a chance to mount, but it still gets an unmounting event during\n // the error boundary cleanup.\n item.isMounted = false;\n var isRoot = item.parentID === 0;\n if (isRoot) {\n removeRoot(id);\n }\n }\n unmountedIDs.push(id);\n },\n purgeUnmountedComponents: function () {\n if (ReactComponentTreeHook._preventPurging) {\n // Should only be used for testing.\n return;\n }\n\n for (var i = 0; i < unmountedIDs.length; i++) {\n var id = unmountedIDs[i];\n purgeDeep(id);\n }\n unmountedIDs.length = 0;\n },\n isMounted: function (id) {\n var item = getItem(id);\n return item ? item.isMounted : false;\n },\n getCurrentStackAddendum: function () {\n var info = '';\n var currentOwner = ReactCurrentOwner_1.current;\n if (currentOwner) {\n !(typeof currentOwner.tag !== 'number') ? invariant(false, 'Fiber owners should not show up in Stack stack traces.') : void 0;\n if (typeof currentOwner._debugID === 'number') {\n info += ReactComponentTreeHook.getStackAddendumByID(currentOwner._debugID);\n }\n }\n return info;\n },\n getStackAddendumByID: function (id) {\n var info = '';\n while (id) {\n info += describeID(id);\n id = ReactComponentTreeHook.getParentID(id);\n }\n return info;\n },\n getChildIDs: function (id) {\n var item = getItem(id);\n return item ? item.childIDs : [];\n },\n getDisplayName: function (id) {\n var element = ReactComponentTreeHook.getElement(id);\n if (!element) {\n return null;\n }\n return getDisplayName$1(element);\n },\n getElement: function (id) {\n var item = getItem(id);\n return item ? item.element : null;\n },\n getOwnerID: function (id) {\n var element = ReactComponentTreeHook.getElement(id);\n if (!element || !element._owner) {\n return null;\n }\n return element._owner._debugID;\n },\n getParentID: function (id) {\n var item = getItem(id);\n return item ? item.parentID : null;\n },\n getSource: function (id) {\n var item = getItem(id);\n var element = item ? item.element : null;\n var source = element != null ? element._source : null;\n return source;\n },\n getText: function (id) {\n var element = ReactComponentTreeHook.getElement(id);\n if (typeof element === 'string') {\n return element;\n } else if (typeof element === 'number') {\n return '' + element;\n } else {\n return null;\n }\n },\n getUpdateCount: function (id) {\n var item = getItem(id);\n return item ? item.updateCount : 0;\n },\n\n\n getRootIDs: getRootIDs,\n getRegisteredIDs: getItemIDs\n};\n\nvar ReactComponentTreeHook_1 = ReactComponentTreeHook;\n\nvar createElement = ReactElement_1.createElement;\nvar createFactory = ReactElement_1.createFactory;\nvar cloneElement = ReactElement_1.cloneElement;\n\n{\n var ReactElementValidator = ReactElementValidator_1;\n createElement = ReactElementValidator.createElement;\n createFactory = ReactElementValidator.createFactory;\n cloneElement = ReactElementValidator.cloneElement;\n}\n\nvar React = {\n Children: {\n map: ReactChildren_1.map,\n forEach: ReactChildren_1.forEach,\n count: ReactChildren_1.count,\n toArray: ReactChildren_1.toArray,\n only: onlyChild_1\n },\n\n Component: ReactBaseClasses.Component,\n PureComponent: ReactBaseClasses.PureComponent,\n unstable_AsyncComponent: ReactBaseClasses.AsyncComponent,\n\n createElement: createElement,\n cloneElement: cloneElement,\n isValidElement: ReactElement_1.isValidElement,\n\n createFactory: createFactory,\n\n version: ReactVersion,\n\n __SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED: {\n ReactCurrentOwner: ReactCurrentOwner_1,\n // Used by renderers to avoid bundling object-assign twice in UMD bundles:\n assign: objectAssign$1\n }\n};\n\n{\n objectAssign$1(React.__SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED, {\n // These should not be included in production.\n ReactComponentTreeHook: ReactComponentTreeHook_1,\n ReactDebugCurrentFrame: ReactDebugCurrentFrame_1\n });\n}\n\nvar ReactEntry = React;\n\nmodule.exports = ReactEntry;\n\n})();\n}\n"
},
{
"id": 42,
"identifier": "/home/x/zzz/github/douglasduteil/RePeople/lib/js/src/components/appBar.js",
"name": "./lib/js/src/components/appBar.js",
"index": 17,
"index2": 37,
"size": 983,
"cacheable": true,
"built": true,
"optional": false,
"prefetched": false,
"chunks": [
0
],
"assets": [],
"issuer": "/home/x/zzz/github/douglasduteil/RePeople/lib/js/src/app.js",
"issuerId": 39,
"issuerName": "./lib/js/src/app.js",
"failed": false,
"errors": 0,
"warnings": 0,
"reasons": [
{
"moduleId": 39,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/lib/js/src/app.js",
"module": "./lib/js/src/app.js",
"moduleName": "./lib/js/src/app.js",
"type": "cjs require",
"userRequest": "./components/appBar.js",
"loc": "7:18-51"
}
],
"usedExports": true,
"providedExports": null,
"optimizationBailout": [],
"depth": 2,
"source": "// Generated by BUCKLESCRIPT VERSION 1.9.2, PLEASE EDIT WITH CARE\n'use strict';\n\nvar React = require(\"react\");\nvar ReasonReact = require(\"reason-react/lib/js/src/reasonReact.js\");\n\nrequire(\"style/appBar.css\");\n\nvar logo = require(\"assets/appBar.logo.svg\");\n\nvar component = ReasonReact.statelessComponent(\"AppBar\");\n\nfunction make(shown, onClick, _) {\n var newrecord = component.slice();\n newrecord[/* render */9] = (function () {\n return React.createElement(\"nav\", {\n className: \"AppBar\"\n }, React.createElement(\"img\", {\n className: \"AppBar-logo\",\n alt: \"People\",\n src: logo\n }), React.createElement(\"hr\", undefined), React.createElement(\"a\", {\n onClick: onClick\n }, shown));\n });\n return newrecord;\n}\n\nexports.logo = logo;\nexports.component = component;\nexports.make = make;\n/* Not a pure module */\n"
},
{
"id": 43,
"identifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/bs-platform/lib/js/caml_io.js",
"name": "./node_modules/bs-platform/lib/js/caml_io.js",
"index": 22,
"index2": 16,
"size": 3536,
"cacheable": true,
"built": true,
"optional": false,
"prefetched": false,
"chunks": [
0
],
"assets": [],
"issuer": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/bs-platform/lib/js/pervasives.js",
"issuerId": 15,
"issuerName": "./node_modules/bs-platform/lib/js/pervasives.js",
"failed": false,
"errors": 0,
"warnings": 0,
"reasons": [
{
"moduleId": 15,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/bs-platform/lib/js/pervasives.js",
"module": "./node_modules/bs-platform/lib/js/pervasives.js",
"moduleName": "./node_modules/bs-platform/lib/js/pervasives.js",
"type": "cjs require",
"userRequest": "./caml_io.js",
"loc": "4:31-54"
}
],
"usedExports": true,
"providedExports": null,
"optimizationBailout": [],
"depth": 4,
"source": "'use strict';\n\nvar Curry = require(\"./curry.js\");\nvar Caml_builtin_exceptions = require(\"./caml_builtin_exceptions.js\");\n\nfunction $caret(prim, prim$1) {\n return prim + prim$1;\n}\n\nvar stdin = undefined;\n\nvar stdout = /* record */[\n /* buffer */\"\",\n /* output */(function (_, s) {\n var v = s.length - 1 | 0;\n if (( (typeof process !== \"undefined\") && process.stdout && process.stdout.write)) {\n return ( process.stdout.write )(s);\n } else if (s[v] === \"\\n\") {\n console.log(s.slice(0, v));\n return /* () */0;\n } else {\n console.log(s);\n return /* () */0;\n }\n })\n];\n\nvar stderr = /* record */[\n /* buffer */\"\",\n /* output */(function (_, s) {\n var v = s.length - 1 | 0;\n if (s[v] === \"\\n\") {\n console.log(s.slice(0, v));\n return /* () */0;\n } else {\n console.log(s);\n return /* () */0;\n }\n })\n];\n\nfunction caml_ml_open_descriptor_in() {\n throw [\n Caml_builtin_exceptions.failure,\n \"caml_ml_open_descriptor_in not implemented\"\n ];\n}\n\nfunction caml_ml_open_descriptor_out() {\n throw [\n Caml_builtin_exceptions.failure,\n \"caml_ml_open_descriptor_out not implemented\"\n ];\n}\n\nfunction caml_ml_flush(oc) {\n if (oc[/* buffer */0] !== \"\") {\n Curry._2(oc[/* output */1], oc, oc[/* buffer */0]);\n oc[/* buffer */0] = \"\";\n return /* () */0;\n } else {\n return 0;\n }\n}\n\nvar node_std_output = (function (s){\n return (typeof process !== \"undefined\") && process.stdout && (process.stdout.write(s), true);\n }\n);\n\nfunction caml_ml_output(oc, str, offset, len) {\n var str$1 = offset === 0 && len === str.length ? str : str.slice(offset, len);\n if (( (typeof process !== \"undefined\") && process.stdout && process.stdout.write ) && oc === stdout) {\n return ( process.stdout.write )(str$1);\n } else {\n var id = str$1.lastIndexOf(\"\\n\");\n if (id < 0) {\n oc[/* buffer */0] = oc[/* buffer */0] + str$1;\n return /* () */0;\n } else {\n oc[/* buffer */0] = oc[/* buffer */0] + str$1.slice(0, id + 1 | 0);\n caml_ml_flush(oc);\n oc[/* buffer */0] = oc[/* buffer */0] + str$1.slice(id + 1 | 0);\n return /* () */0;\n }\n }\n}\n\nfunction caml_ml_output_char(oc, $$char) {\n return caml_ml_output(oc, String.fromCharCode($$char), 0, 1);\n}\n\nfunction caml_ml_input(_, _$1, _$2, _$3) {\n throw [\n Caml_builtin_exceptions.failure,\n \"caml_ml_input ic not implemented\"\n ];\n}\n\nfunction caml_ml_input_char() {\n throw [\n Caml_builtin_exceptions.failure,\n \"caml_ml_input_char not implemnted\"\n ];\n}\n\nfunction caml_ml_out_channels_list() {\n return /* :: */[\n stdout,\n /* :: */[\n stderr,\n /* [] */0\n ]\n ];\n}\n\nexports.$caret = $caret;\nexports.stdin = stdin;\nexports.stdout = stdout;\nexports.stderr = stderr;\nexports.caml_ml_open_descriptor_in = caml_ml_open_descriptor_in;\nexports.caml_ml_open_descriptor_out = caml_ml_open_descriptor_out;\nexports.caml_ml_flush = caml_ml_flush;\nexports.node_std_output = node_std_output;\nexports.caml_ml_output = caml_ml_output;\nexports.caml_ml_output_char = caml_ml_output_char;\nexports.caml_ml_input = caml_ml_input;\nexports.caml_ml_input_char = caml_ml_input_char;\nexports.caml_ml_out_channels_list = caml_ml_out_channels_list;\n/* stdin Not a pure module */\n"
},
{
"id": 44,
"identifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/bs-platform/lib/js/camlinternalFormatBasics.js",
"name": "./node_modules/bs-platform/lib/js/camlinternalFormatBasics.js",
"index": 31,
"index2": 25,
"size": 7582,
"cacheable": true,
"built": true,
"optional": false,
"prefetched": false,
"chunks": [
0
],
"assets": [],
"issuer": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/bs-platform/lib/js/pervasives.js",
"issuerId": 15,
"issuerName": "./node_modules/bs-platform/lib/js/pervasives.js",
"failed": false,
"errors": 0,
"warnings": 0,
"reasons": [
{
"moduleId": 15,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/bs-platform/lib/js/pervasives.js",
"module": "./node_modules/bs-platform/lib/js/pervasives.js",
"moduleName": "./node_modules/bs-platform/lib/js/pervasives.js",
"type": "cjs require",
"userRequest": "./camlinternalFormatBasics.js",
"loc": "12:31-71"
}
],
"usedExports": true,
"providedExports": null,
"optimizationBailout": [],
"depth": 4,
"source": "'use strict';\n\nvar Block = require(\"./block.js\");\n\nfunction erase_rel(param) {\n if (typeof param === \"number\") {\n return /* End_of_fmtty */0;\n } else {\n switch (param.tag | 0) {\n case 0 : \n return /* Char_ty */Block.__(0, [erase_rel(param[0])]);\n case 1 : \n return /* String_ty */Block.__(1, [erase_rel(param[0])]);\n case 2 : \n return /* Int_ty */Block.__(2, [erase_rel(param[0])]);\n case 3 : \n return /* Int32_ty */Block.__(3, [erase_rel(param[0])]);\n case 4 : \n return /* Nativeint_ty */Block.__(4, [erase_rel(param[0])]);\n case 5 : \n return /* Int64_ty */Block.__(5, [erase_rel(param[0])]);\n case 6 : \n return /* Float_ty */Block.__(6, [erase_rel(param[0])]);\n case 7 : \n return /* Bool_ty */Block.__(7, [erase_rel(param[0])]);\n case 8 : \n return /* Format_arg_ty */Block.__(8, [\n param[0],\n erase_rel(param[1])\n ]);\n case 9 : \n var ty1 = param[0];\n return /* Format_subst_ty */Block.__(9, [\n ty1,\n ty1,\n erase_rel(param[2])\n ]);\n case 10 : \n return /* Alpha_ty */Block.__(10, [erase_rel(param[0])]);\n case 11 : \n return /* Theta_ty */Block.__(11, [erase_rel(param[0])]);\n case 12 : \n return /* Any_ty */Block.__(12, [erase_rel(param[0])]);\n case 13 : \n return /* Reader_ty */Block.__(13, [erase_rel(param[0])]);\n case 14 : \n return /* Ignored_reader_ty */Block.__(14, [erase_rel(param[0])]);\n \n }\n }\n}\n\nfunction concat_fmtty(fmtty1, fmtty2) {\n if (typeof fmtty1 === \"number\") {\n return fmtty2;\n } else {\n switch (fmtty1.tag | 0) {\n case 0 : \n return /* Char_ty */Block.__(0, [concat_fmtty(fmtty1[0], fmtty2)]);\n case 1 : \n return /* String_ty */Block.__(1, [concat_fmtty(fmtty1[0], fmtty2)]);\n case 2 : \n return /* Int_ty */Block.__(2, [concat_fmtty(fmtty1[0], fmtty2)]);\n case 3 : \n return /* Int32_ty */Block.__(3, [concat_fmtty(fmtty1[0], fmtty2)]);\n case 4 : \n return /* Nativeint_ty */Block.__(4, [concat_fmtty(fmtty1[0], fmtty2)]);\n case 5 : \n return /* Int64_ty */Block.__(5, [concat_fmtty(fmtty1[0], fmtty2)]);\n case 6 : \n return /* Float_ty */Block.__(6, [concat_fmtty(fmtty1[0], fmtty2)]);\n case 7 : \n return /* Bool_ty */Block.__(7, [concat_fmtty(fmtty1[0], fmtty2)]);\n case 8 : \n return /* Format_arg_ty */Block.__(8, [\n fmtty1[0],\n concat_fmtty(fmtty1[1], fmtty2)\n ]);\n case 9 : \n return /* Format_subst_ty */Block.__(9, [\n fmtty1[0],\n fmtty1[1],\n concat_fmtty(fmtty1[2], fmtty2)\n ]);\n case 10 : \n return /* Alpha_ty */Block.__(10, [concat_fmtty(fmtty1[0], fmtty2)]);\n case 11 : \n return /* Theta_ty */Block.__(11, [concat_fmtty(fmtty1[0], fmtty2)]);\n case 12 : \n return /* Any_ty */Block.__(12, [concat_fmtty(fmtty1[0], fmtty2)]);\n case 13 : \n return /* Reader_ty */Block.__(13, [concat_fmtty(fmtty1[0], fmtty2)]);\n case 14 : \n return /* Ignored_reader_ty */Block.__(14, [concat_fmtty(fmtty1[0], fmtty2)]);\n \n }\n }\n}\n\nfunction concat_fmt(fmt1, fmt2) {\n if (typeof fmt1 === \"number\") {\n return fmt2;\n } else {\n switch (fmt1.tag | 0) {\n case 0 : \n return /* Char */Block.__(0, [concat_fmt(fmt1[0], fmt2)]);\n case 1 : \n return /* Caml_char */Block.__(1, [concat_fmt(fmt1[0], fmt2)]);\n case 2 : \n return /* String */Block.__(2, [\n fmt1[0],\n concat_fmt(fmt1[1], fmt2)\n ]);\n case 3 : \n return /* Caml_string */Block.__(3, [\n fmt1[0],\n concat_fmt(fmt1[1], fmt2)\n ]);\n case 4 : \n return /* Int */Block.__(4, [\n fmt1[0],\n fmt1[1],\n fmt1[2],\n concat_fmt(fmt1[3], fmt2)\n ]);\n case 5 : \n return /* Int32 */Block.__(5, [\n fmt1[0],\n fmt1[1],\n fmt1[2],\n concat_fmt(fmt1[3], fmt2)\n ]);\n case 6 : \n return /* Nativeint */Block.__(6, [\n fmt1[0],\n fmt1[1],\n fmt1[2],\n concat_fmt(fmt1[3], fmt2)\n ]);\n case 7 : \n return /* Int64 */Block.__(7, [\n fmt1[0],\n fmt1[1],\n fmt1[2],\n concat_fmt(fmt1[3], fmt2)\n ]);\n case 8 : \n return /* Float */Block.__(8, [\n fmt1[0],\n fmt1[1],\n fmt1[2],\n concat_fmt(fmt1[3], fmt2)\n ]);\n case 9 : \n return /* Bool */Block.__(9, [concat_fmt(fmt1[0], fmt2)]);\n case 10 : \n return /* Flush */Block.__(10, [concat_fmt(fmt1[0], fmt2)]);\n case 11 : \n return /* String_literal */Block.__(11, [\n fmt1[0],\n concat_fmt(fmt1[1], fmt2)\n ]);\n case 12 : \n return /* Char_literal */Block.__(12, [\n fmt1[0],\n concat_fmt(fmt1[1], fmt2)\n ]);\n case 13 : \n return /* Format_arg */Block.__(13, [\n fmt1[0],\n fmt1[1],\n concat_fmt(fmt1[2], fmt2)\n ]);\n case 14 : \n return /* Format_subst */Block.__(14, [\n fmt1[0],\n fmt1[1],\n concat_fmt(fmt1[2], fmt2)\n ]);\n case 15 : \n return /* Alpha */Block.__(15, [concat_fmt(fmt1[0], fmt2)]);\n case 16 : \n return /* Theta */Block.__(16, [concat_fmt(fmt1[0], fmt2)]);\n case 17 : \n return /* Formatting_lit */Block.__(17, [\n fmt1[0],\n concat_fmt(fmt1[1], fmt2)\n ]);\n case 18 : \n return /* Formatting_gen */Block.__(18, [\n fmt1[0],\n concat_fmt(fmt1[1], fmt2)\n ]);\n case 19 : \n return /* Reader */Block.__(19, [concat_fmt(fmt1[0], fmt2)]);\n case 20 : \n return /* Scan_char_set */Block.__(20, [\n fmt1[0],\n fmt1[1],\n concat_fmt(fmt1[2], fmt2)\n ]);\n case 21 : \n return /* Scan_get_counter */Block.__(21, [\n fmt1[0],\n concat_fmt(fmt1[1], fmt2)\n ]);\n case 22 : \n return /* Scan_next_char */Block.__(22, [concat_fmt(fmt1[0], fmt2)]);\n case 23 : \n return /* Ignored_param */Block.__(23, [\n fmt1[0],\n concat_fmt(fmt1[1], fmt2)\n ]);\n case 24 : \n return /* Custom */Block.__(24, [\n fmt1[0],\n fmt1[1],\n concat_fmt(fmt1[2], fmt2)\n ]);\n \n }\n }\n}\n\nexports.concat_fmtty = concat_fmtty;\nexports.erase_rel = erase_rel;\nexports.concat_fmt = concat_fmt;\n/* No side effect */\n"
},
{
"id": 45,
"identifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/reason-react/lib/js/src/reasonReactOptimizedCreateClass.js",
"name": "./node_modules/reason-react/lib/js/src/reasonReactOptimizedCreateClass.js",
"index": 32,
"index2": 28,
"size": 29711,
"cacheable": true,
"built": true,
"optional": false,
"prefetched": false,
"chunks": [
0
],
"assets": [],
"issuer": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/reason-react/lib/js/src/reasonReact.js",
"issuerId": 5,
"issuerName": "./node_modules/reason-react/lib/js/src/reasonReact.js",
"failed": false,
"errors": 0,
"warnings": 0,
"reasons": [
{
"moduleId": 5,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/reason-react/lib/js/src/reasonReact.js",
"module": "./node_modules/reason-react/lib/js/src/reasonReact.js",
"moduleName": "./node_modules/reason-react/lib/js/src/reasonReact.js",
"type": "cjs require",
"userRequest": "./reasonReactOptimizedCreateClass.js",
"loc": "8:38-85"
}
],
"usedExports": true,
"providedExports": null,
"optimizationBailout": [],
"depth": 2,
"source": "// Generated by BUCKLESCRIPT VERSION 1.8.2, PLEASE EDIT WITH CARE\n'use strict';\n\nvar React = require(\"react\");\n\nfunction _assign(prim, prim$1) {\n return Object.assign(prim, prim$1);\n}\n\nvar emptyObject = { };\n\n\n/**\n * Copyright 2013-present, Facebook, Inc.\n * All rights reserved.\n *\n * This source code is licensed under the BSD-style license found in the\n * LICENSE file in the root directory of this source tree. An additional grant\n * of patent rights can be found in the PATENTS file in the same directory.\n *\n */\n\n// 'use strict';\n\n// var _assign = require('object-assign');\n\n// var emptyObject = require('emptyObject');\n// var _invariant = require('invariant');\n\n// if (process.env.NODE_ENV !== 'production') {\n// var warning = require('fbjs/lib/warning');\n// }\n\nvar MIXINS_KEY = 'mixins';\n\n// Helper function to allow the creation of anonymous functions which do not\n// have .name set to the name of the variable being assigned to.\nfunction identity(fn) {\n return fn;\n}\n\nvar ReactPropTypeLocationNames;\n// if (process.env.NODE_ENV !== 'production') {\n// ReactPropTypeLocationNames = {\n// prop: 'prop',\n// context: 'context',\n// childContext: 'child context'\n// };\n// } else {\n ReactPropTypeLocationNames = {};\n// }\n\n;\n\nvar factory = (\nfunction factory(ReactComponent, isValidElement, ReactNoopUpdateQueue) {\n /**\n * Policies that describe methods in `ReactClassInterface`.\n */\n\n var injectedMixins = [];\n\n /**\n * Composite components are higher-level components that compose other composite\n * or host components.\n *\n * To create a new type of `ReactClass`, pass a specification of\n * your new class to `React.createClass`. The only requirement of your class\n * specification is that you implement a `render` method.\n *\n * var MyComponent = React.createClass({\n * render: function() {\n * return <div>Hello World</div>;\n * }\n * });\n *\n * The class specification supports a specific protocol of methods that have\n * special meaning (e.g. `render`). See `ReactClassInterface` for\n * more the comprehensive protocol. Any other properties and methods in the\n * class specification will be available on the prototype.\n *\n * @interface ReactClassInterface\n * @internal\n */\n var ReactClassInterface = {\n /**\n * An array of Mixin objects to include when defining your component.\n *\n * @type {array}\n * @optional\n */\n mixins: 'DEFINE_MANY',\n\n /**\n * An object containing properties and methods that should be defined on\n * the component's constructor instead of its prototype (static methods).\n *\n * @type {object}\n * @optional\n */\n statics: 'DEFINE_MANY',\n\n /**\n * Definition of prop types for this component.\n *\n * @type {object}\n * @optional\n */\n propTypes: 'DEFINE_MANY',\n\n /**\n * Definition of context types for this component.\n *\n * @type {object}\n * @optional\n */\n contextTypes: 'DEFINE_MANY',\n\n /**\n * Definition of context types this component sets for its children.\n *\n * @type {object}\n * @optional\n */\n childContextTypes: 'DEFINE_MANY',\n\n // ==== Definition methods ====\n\n /**\n * Invoked when the component is mounted. Values in the mapping will be set on\n * `this.props` if that prop is not specified (i.e. using an `in` check).\n *\n * This method is invoked before `getInitialState` and therefore cannot rely\n * on `this.state` or use `this.setState`.\n *\n * @return {object}\n * @optional\n */\n getDefaultProps: 'DEFINE_MANY_MERGED',\n\n /**\n * Invoked once before the component is mounted. The return value will be used\n * as the initial value of `this.state`.\n *\n * getInitialState: function() {\n * return {\n * isOn: false,\n * fooBaz: new BazFoo()\n * }\n * }\n *\n * @return {object}\n * @optional\n */\n getInitialState: 'DEFINE_MANY_MERGED',\n\n /**\n * @return {object}\n * @optional\n */\n getChildContext: 'DEFINE_MANY_MERGED',\n\n /**\n * Uses props from `this.props` and state from `this.state` to render the\n * structure of the component.\n *\n * No guarantees are made about when or how often this method is invoked, so\n * it must not have side effects.\n *\n * render: function() {\n * var name = this.props.name;\n * return <div>Hello, {name}!</div>;\n * }\n *\n * @return {ReactComponent}\n * @required\n */\n render: 'DEFINE_ONCE',\n\n // ==== Delegate methods ====\n\n /**\n * Invoked when the component is initially created and about to be mounted.\n * This may have side effects, but any external subscriptions or data created\n * by this method must be cleaned up in `componentWillUnmount`.\n *\n * @optional\n */\n componentWillMount: 'DEFINE_MANY',\n\n /**\n * Invoked when the component has been mounted and has a DOM representation.\n * However, there is no guarantee that the DOM node is in the document.\n *\n * Use this as an opportunity to operate on the DOM when the component has\n * been mounted (initialized and rendered) for the first time.\n *\n * @param {DOMElement} rootNode DOM element representing the component.\n * @optional\n */\n componentDidMount: 'DEFINE_MANY',\n\n /**\n * Invoked before the component receives new props.\n *\n * Use this as an opportunity to react to a prop transition by updating the\n * state using `this.setState`. Current props are accessed via `this.props`.\n *\n * componentWillReceiveProps: function(nextProps, nextContext) {\n * this.setState({\n * likesIncreasing: nextProps.likeCount > this.props.likeCount\n * });\n * }\n *\n * NOTE: There is no equivalent `componentWillReceiveState`. An incoming prop\n * transition may cause a state change, but the opposite is not true. If you\n * need it, you are probably looking for `componentWillUpdate`.\n *\n * @param {object} nextProps\n * @optional\n */\n componentWillReceiveProps: 'DEFINE_MANY',\n\n /**\n * Invoked while deciding if the component should be updated as a result of\n * receiving new props, state and/or context.\n *\n * Use this as an opportunity to `return false` when you're certain that the\n * transition to the new props/state/context will not require a component\n * update.\n *\n * shouldComponentUpdate: function(nextProps, nextState, nextContext) {\n * return !equal(nextProps, this.props) ||\n * !equal(nextState, this.state) ||\n * !equal(nextContext, this.context);\n * }\n *\n * @param {object} nextProps\n * @param {?object} nextState\n * @param {?object} nextContext\n * @return {boolean} True if the component should update.\n * @optional\n */\n shouldComponentUpdate: 'DEFINE_ONCE',\n\n /**\n * Invoked when the component is about to update due to a transition from\n * `this.props`, `this.state` and `this.context` to `nextProps`, `nextState`\n * and `nextContext`.\n *\n * Use this as an opportunity to perform preparation before an update occurs.\n *\n * NOTE: You **cannot** use `this.setState()` in this method.\n *\n * @param {object} nextProps\n * @param {?object} nextState\n * @param {?object} nextContext\n * @param {ReactReconcileTransaction} transaction\n * @optional\n */\n componentWillUpdate: 'DEFINE_MANY',\n\n /**\n * Invoked when the component's DOM representation has been updated.\n *\n * Use this as an opportunity to operate on the DOM when the component has\n * been updated.\n *\n * @param {object} prevProps\n * @param {?object} prevState\n * @param {?object} prevContext\n * @param {DOMElement} rootNode DOM element representing the component.\n * @optional\n */\n componentDidUpdate: 'DEFINE_MANY',\n\n /**\n * Invoked when the component is about to be removed from its parent and have\n * its DOM representation destroyed.\n *\n * Use this as an opportunity to deallocate any external resources.\n *\n * NOTE: There is no `componentDidUnmount` since your component will have been\n * destroyed by that point.\n *\n * @optional\n */\n componentWillUnmount: 'DEFINE_MANY',\n\n // ==== Advanced methods ====\n\n /**\n * Updates the component's currently mounted DOM representation.\n *\n * By default, this implements React's rendering and reconciliation algorithm.\n * Sophisticated clients may wish to override this.\n *\n * @param {ReactReconcileTransaction} transaction\n * @internal\n * @overridable\n */\n updateComponent: 'OVERRIDE_BASE'\n };\n\n /**\n * Mapping from class specification keys to special processing functions.\n *\n * Although these are declared like instance properties in the specification\n * when defining classes using `React.createClass`, they are actually static\n * and are accessible on the constructor instead of the prototype. Despite\n * being static, they must be defined outside of the \"statics\" key under\n * which all other static methods are defined.\n */\n var RESERVED_SPEC_KEYS = {\n displayName: function(Constructor, displayName) {\n Constructor.displayName = displayName;\n },\n mixins: function(Constructor, mixins) {\n if (mixins) {\n for (var i = 0; i < mixins.length; i++) {\n mixSpecIntoComponent(Constructor, mixins[i]);\n }\n }\n },\n childContextTypes: function(Constructor, childContextTypes) {\n // if (process.env.NODE_ENV !== 'production') {\n // validateTypeDef(Constructor, childContextTypes, 'childContext');\n // }\n Constructor.childContextTypes = _assign(\n {},\n Constructor.childContextTypes,\n childContextTypes\n );\n },\n contextTypes: function(Constructor, contextTypes) {\n // if (process.env.NODE_ENV !== 'production') {\n // validateTypeDef(Constructor, contextTypes, 'context');\n // }\n Constructor.contextTypes = _assign(\n {},\n Constructor.contextTypes,\n contextTypes\n );\n },\n /**\n * Special case getDefaultProps which should move into statics but requires\n * automatic merging.\n */\n getDefaultProps: function(Constructor, getDefaultProps) {\n if (Constructor.getDefaultProps) {\n Constructor.getDefaultProps = createMergedResultFunction(\n Constructor.getDefaultProps,\n getDefaultProps\n );\n } else {\n Constructor.getDefaultProps = getDefaultProps;\n }\n },\n propTypes: function(Constructor, propTypes) {\n // if (process.env.NODE_ENV !== 'production') {\n // validateTypeDef(Constructor, propTypes, 'prop');\n // }\n Constructor.propTypes = _assign({}, Constructor.propTypes, propTypes);\n },\n statics: function(Constructor, statics) {\n mixStaticSpecIntoComponent(Constructor, statics);\n },\n autobind: function() {}\n };\n\n function validateTypeDef(Constructor, typeDef, location) {\n for (var propName in typeDef) {\n // if (typeDef.hasOwnProperty(propName)) {\n // // use a warning instead of an _invariant so components\n // // don't show up in prod but only in __DEV__\n // // if (process.env.NODE_ENV !== 'production') {\n // // warning(\n // // typeof typeDef[propName] === 'function',\n // // '%s: %s type `%s` is invalid; it must be a function, usually from ' +\n // // 'React.PropTypes.',\n // // Constructor.displayName || 'ReactClass',\n // // ReactPropTypeLocationNames[location],\n // // propName\n // // );\n // // }\n // }\n }\n }\n\n function validateMethodOverride(isAlreadyDefined, name) {\n var specPolicy = ReactClassInterface.hasOwnProperty(name)\n ? ReactClassInterface[name]\n : null;\n\n // Disallow overriding of base class methods unless explicitly allowed.\n if (ReactClassMixin.hasOwnProperty(name)) {\n // _invariant(\n // specPolicy === 'OVERRIDE_BASE',\n // 'ReactClassInterface: You are attempting to override ' +\n // '`%s` from your class specification. Ensure that your method names ' +\n // 'do not overlap with React methods.',\n // name\n // );\n }\n\n // Disallow defining methods more than once unless explicitly allowed.\n if (isAlreadyDefined) {\n // _invariant(\n // specPolicy === 'DEFINE_MANY' || specPolicy === 'DEFINE_MANY_MERGED',\n // 'ReactClassInterface: You are attempting to define ' +\n // '`%s` on your component more than once. This conflict may be due ' +\n // 'to a mixin.',\n // name\n // );\n }\n }\n\n /**\n * Mixin helper which handles policy validation and reserved\n * specification keys when building React classes.\n */\n function mixSpecIntoComponent(Constructor, spec) {\n if (!spec) {\n // if (process.env.NODE_ENV !== 'production') {\n // var typeofSpec = typeof spec;\n // var isMixinValid = typeofSpec === 'object' && spec !== null;\n //\n // if (process.env.NODE_ENV !== 'production') {\n // warning(\n // isMixinValid,\n // \"%s: You're attempting to include a mixin that is either null \" +\n // 'or not an object. Check the mixins included by the component, ' +\n // 'as well as any mixins they include themselves. ' +\n // 'Expected object but got %s.',\n // Constructor.displayName || 'ReactClass',\n // spec === null ? null : typeofSpec\n // );\n // }\n // }\n\n return;\n }\n\n // _invariant(\n // typeof spec !== 'function',\n // \"ReactClass: You're attempting to \" +\n // 'use a component class or function as a mixin. Instead, just use a ' +\n // 'regular object.'\n // );\n // _invariant(\n // !isValidElement(spec),\n // \"ReactClass: You're attempting to \" +\n // 'use a component as a mixin. Instead, just use a regular object.'\n // );\n\n var proto = Constructor.prototype;\n var autoBindPairs = proto.__reactAutoBindPairs;\n\n // By handling mixins before any other properties, we ensure the same\n // chaining order is applied to methods with DEFINE_MANY policy, whether\n // mixins are listed before or after these methods in the spec.\n if (spec.hasOwnProperty(MIXINS_KEY)) {\n RESERVED_SPEC_KEYS.mixins(Constructor, spec.mixins);\n }\n\n for (var name in spec) {\n if (!spec.hasOwnProperty(name)) {\n continue;\n }\n\n if (name === MIXINS_KEY) {\n // We have already handled mixins in a special case above.\n continue;\n }\n\n var property = spec[name];\n var isAlreadyDefined = proto.hasOwnProperty(name);\n validateMethodOverride(isAlreadyDefined, name);\n\n if (RESERVED_SPEC_KEYS.hasOwnProperty(name)) {\n RESERVED_SPEC_KEYS[name](Constructor, property);\n } else {\n // Setup methods on prototype:\n // The following member methods should not be automatically bound:\n // 1. Expected ReactClass methods (in the \"interface\").\n // 2. Overridden methods (that were mixed in).\n var isReactClassMethod = ReactClassInterface.hasOwnProperty(name);\n var isFunction = typeof property === 'function';\n var shouldAutoBind =\n isFunction &&\n !isReactClassMethod &&\n !isAlreadyDefined &&\n spec.autobind !== false;\n\n if (shouldAutoBind) {\n autoBindPairs.push(name, property);\n proto[name] = property;\n } else {\n if (isAlreadyDefined) {\n var specPolicy = ReactClassInterface[name];\n\n // These cases should already be caught by validateMethodOverride.\n // _invariant(\n // isReactClassMethod &&\n // (specPolicy === 'DEFINE_MANY_MERGED' ||\n // specPolicy === 'DEFINE_MANY'),\n // 'ReactClass: Unexpected spec policy %s for key %s ' +\n // 'when mixing in component specs.',\n // specPolicy,\n // name\n // );\n\n // For methods which are defined more than once, call the existing\n // methods before calling the new property, merging if appropriate.\n if (specPolicy === 'DEFINE_MANY_MERGED') {\n proto[name] = createMergedResultFunction(proto[name], property);\n } else if (specPolicy === 'DEFINE_MANY') {\n proto[name] = createChainedFunction(proto[name], property);\n }\n } else {\n proto[name] = property;\n // if (process.env.NODE_ENV !== 'production') {\n // // Add verbose displayName to the function, which helps when looking\n // // at profiling tools.\n // if (typeof property === 'function' && spec.displayName) {\n // proto[name].displayName = spec.displayName + '_' + name;\n // }\n // }\n }\n }\n }\n }\n }\n\n function mixStaticSpecIntoComponent(Constructor, statics) {\n if (!statics) {\n return;\n }\n for (var name in statics) {\n var property = statics[name];\n if (!statics.hasOwnProperty(name)) {\n continue;\n }\n\n var isReserved = name in RESERVED_SPEC_KEYS;\n // _invariant(\n // !isReserved,\n // 'ReactClass: You are attempting to define a reserved ' +\n // 'property, `%s`, that shouldn\\'t be on the \"statics\" key. Define it ' +\n // 'as an instance property instead; it will still be accessible on the ' +\n // 'constructor.',\n // name\n // );\n\n var isInherited = name in Constructor;\n // _invariant(\n // !isInherited,\n // 'ReactClass: You are attempting to define ' +\n // '`%s` on your component more than once. This conflict may be ' +\n // 'due to a mixin.',\n // name\n // );\n Constructor[name] = property;\n }\n }\n\n /**\n * Merge two objects, but throw if both contain the same key.\n *\n * @param {object} one The first object, which is mutated.\n * @param {object} two The second object\n * @return {object} one after it has been mutated to contain everything in two.\n */\n function mergeIntoWithNoDuplicateKeys(one, two) {\n // _invariant(\n // one && two && typeof one === 'object' && typeof two === 'object',\n // 'mergeIntoWithNoDuplicateKeys(): Cannot merge non-objects.'\n // );\n\n for (var key in two) {\n if (two.hasOwnProperty(key)) {\n // _invariant(\n // one[key] === undefined,\n // 'mergeIntoWithNoDuplicateKeys(): ' +\n // 'Tried to merge two objects with the same key: `%s`. This conflict ' +\n // 'may be due to a mixin; in particular, this may be caused by two ' +\n // 'getInitialState() or getDefaultProps() methods returning objects ' +\n // 'with clashing keys.',\n // key\n // );\n one[key] = two[key];\n }\n }\n return one;\n }\n\n /**\n * Creates a function that invokes two functions and merges their return values.\n *\n * @param {function} one Function to invoke first.\n * @param {function} two Function to invoke second.\n * @return {function} Function that invokes the two argument functions.\n * @private\n */\n function createMergedResultFunction(one, two) {\n return function mergedResult() {\n var a = one.apply(this, arguments);\n var b = two.apply(this, arguments);\n if (a == null) {\n return b;\n } else if (b == null) {\n return a;\n }\n var c = {};\n mergeIntoWithNoDuplicateKeys(c, a);\n mergeIntoWithNoDuplicateKeys(c, b);\n return c;\n };\n }\n\n /**\n * Creates a function that invokes two functions and ignores their return vales.\n *\n * @param {function} one Function to invoke first.\n * @param {function} two Function to invoke second.\n * @return {function} Function that invokes the two argument functions.\n * @private\n */\n function createChainedFunction(one, two) {\n return function chainedFunction() {\n one.apply(this, arguments);\n two.apply(this, arguments);\n };\n }\n\n /**\n * Binds a method to the component.\n *\n * @param {object} component Component whose method is going to be bound.\n * @param {function} method Method to be bound.\n * @return {function} The bound method.\n */\n function bindAutoBindMethod(component, method) {\n var boundMethod = method.bind(component);\n // if (process.env.NODE_ENV !== 'production') {\n // boundMethod.__reactBoundContext = component;\n // boundMethod.__reactBoundMethod = method;\n // boundMethod.__reactBoundArguments = null;\n // var componentName = component.constructor.displayName;\n // var _bind = boundMethod.bind;\n // boundMethod.bind = function(newThis) {\n // for (\n // var _len = arguments.length,\n // args = Array(_len > 1 ? _len - 1 : 0),\n // _key = 1;\n // _key < _len;\n // _key++\n // ) {\n // args[_key - 1] = arguments[_key];\n // }\n //\n // // User is trying to bind() an autobound method; we effectively will\n // // ignore the value of \"this\" that the user is trying to use, so\n // // let's warn.\n // if (newThis !== component && newThis !== null) {\n // if (process.env.NODE_ENV !== 'production') {\n // warning(\n // false,\n // 'bind(): React component methods may only be bound to the ' +\n // 'component instance. See %s',\n // componentName\n // );\n // }\n // } else if (!args.length) {\n // if (process.env.NODE_ENV !== 'production') {\n // warning(\n // false,\n // 'bind(): You are binding a component method to the component. ' +\n // 'React does this for you automatically in a high-performance ' +\n // 'way, so you can safely remove this call. See %s',\n // componentName\n // );\n // }\n // return boundMethod;\n // }\n // var reboundMethod = _bind.apply(boundMethod, arguments);\n // reboundMethod.__reactBoundContext = component;\n // reboundMethod.__reactBoundMethod = method;\n // reboundMethod.__reactBoundArguments = args;\n // return reboundMethod;\n // };\n // }\n return boundMethod;\n }\n\n /**\n * Binds all auto-bound methods in a component.\n *\n * @param {object} component Component whose method is going to be bound.\n */\n function bindAutoBindMethods(component) {\n var pairs = component.__reactAutoBindPairs;\n for (var i = 0; i < pairs.length; i += 2) {\n var autoBindKey = pairs[i];\n var method = pairs[i + 1];\n component[autoBindKey] = bindAutoBindMethod(component, method);\n }\n }\n\n var IsMountedPreMixin = {\n componentDidMount: function() {\n this.__isMounted = true;\n }\n };\n\n var IsMountedPostMixin = {\n componentWillUnmount: function() {\n this.__isMounted = false;\n }\n };\n\n /**\n * Add more to the ReactClass base class. These are all legacy features and\n * therefore not already part of the modern ReactComponent.\n */\n var ReactClassMixin = {\n /**\n * TODO: This will be deprecated because state should always keep a consistent\n * type signature and the only use case for this, is to avoid that.\n */\n replaceState: function(newState, callback) {\n this.updater.enqueueReplaceState(this, newState, callback);\n },\n\n /**\n * Checks whether or not this composite component is mounted.\n * @return {boolean} True if mounted, false otherwise.\n * @protected\n * @final\n */\n isMounted: function() {\n // if (process.env.NODE_ENV !== 'production') {\n // warning(\n // this.__didWarnIsMounted,\n // '%s: isMounted is deprecated. Instead, make sure to clean up ' +\n // 'subscriptions and pending requests in componentWillUnmount to ' +\n // 'prevent memory leaks.',\n // (this.constructor && this.constructor.displayName) ||\n // this.name ||\n // 'Component'\n // );\n // this.__didWarnIsMounted = true;\n // }\n return !!this.__isMounted;\n }\n };\n\n var ReactClassComponent = function() {};\n _assign(\n ReactClassComponent.prototype,\n ReactComponent.prototype,\n ReactClassMixin\n );\n\n /**\n * Creates a composite component class given a class specification.\n * See https://facebook.github.io/react/docs/top-level-api.html#react.createclass\n *\n * @param {object} spec Class specification (which must define `render`).\n * @return {function} Component constructor function.\n * @public\n */\n function createClass(spec) {\n // To keep our warnings more understandable, we'll use a little hack here to\n // ensure that Constructor.name !== 'Constructor'. This makes sure we don't\n // unnecessarily identify a class without displayName as 'Constructor'.\n var Constructor = identity(function(props, context, updater) {\n // This constructor gets overridden by mocks. The argument is used\n // by mocks to assert on what gets mounted.\n\n // if (process.env.NODE_ENV !== 'production') {\n // warning(\n // this instanceof Constructor,\n // 'Something is calling a React component directly. Use a factory or ' +\n // 'JSX instead. See: https://fb.me/react-legacyfactory'\n // );\n // }\n\n // Wire up auto-binding\n if (this.__reactAutoBindPairs.length) {\n bindAutoBindMethods(this);\n }\n\n this.props = props;\n this.context = context;\n this.refs = emptyObject;\n this.updater = updater || ReactNoopUpdateQueue;\n\n this.state = null;\n\n // ReactClasses doesn't have constructors. Instead, they use the\n // getInitialState and componentWillMount methods for initialization.\n\n var initialState = this.getInitialState ? this.getInitialState() : null;\n // if (process.env.NODE_ENV !== 'production') {\n // // We allow auto-mocks to proceed as if they're returning null.\n // if (\n // initialState === undefined &&\n // this.getInitialState._isMockFunction\n // ) {\n // // This is probably bad practice. Consider warning here and\n // // deprecating this convenience.\n // initialState = null;\n // }\n // }\n // _invariant(\n // typeof initialState === 'object' && !Array.isArray(initialState),\n // '%s.getInitialState(): must return an object or null',\n // Constructor.displayName || 'ReactCompositeComponent'\n // );\n\n this.state = initialState;\n });\n Constructor.prototype = new ReactClassComponent();\n Constructor.prototype.constructor = Constructor;\n Constructor.prototype.__reactAutoBindPairs = [];\n\n injectedMixins.forEach(mixSpecIntoComponent.bind(null, Constructor));\n\n mixSpecIntoComponent(Constructor, IsMountedPreMixin);\n mixSpecIntoComponent(Constructor, spec);\n mixSpecIntoComponent(Constructor, IsMountedPostMixin);\n\n // Initialize the defaultProps property after all mixins have been merged.\n if (Constructor.getDefaultProps) {\n Constructor.defaultProps = Constructor.getDefaultProps();\n }\n\n // if (process.env.NODE_ENV !== 'production') {\n // // This is a tag to indicate that the use of these method names is ok,\n // // since it's used with createClass. If it's not, then it's likely a\n // // mistake so we'll warn you to use the static property, property\n // // initializer or constructor respectively.\n // if (Constructor.getDefaultProps) {\n // Constructor.getDefaultProps.isReactClassApproved = {};\n // }\n // if (Constructor.prototype.getInitialState) {\n // Constructor.prototype.getInitialState.isReactClassApproved = {};\n // }\n // }\n\n // _invariant(\n // Constructor.prototype.render,\n // 'createClass(...): Class specification must implement a `render` method.'\n // );\n\n // if (process.env.NODE_ENV !== 'production') {\n // warning(\n // !Constructor.prototype.componentShouldUpdate,\n // '%s has a method called ' +\n // 'componentShouldUpdate(). Did you mean shouldComponentUpdate()? ' +\n // 'The name is phrased as a question because the function is ' +\n // 'expected to return a value.',\n // spec.displayName || 'A component'\n // );\n // warning(\n // !Constructor.prototype.componentWillRecieveProps,\n // '%s has a method called ' +\n // 'componentWillRecieveProps(). Did you mean componentWillReceiveProps()?',\n // spec.displayName || 'A component'\n // );\n // }\n\n // Reduce time spent doing lookups by setting these on the prototype.\n for (var methodName in ReactClassInterface) {\n if (!Constructor.prototype[methodName]) {\n Constructor.prototype[methodName] = null;\n }\n }\n\n return Constructor;\n }\n\n return createClass;\n}\n);\n\nvar reactNoopUpdateQueue = new React.Component().updater;\n\nvar createClass = factory(React.Component, React.isValidElement, reactNoopUpdateQueue);\n\nexports._assign = _assign;\nexports.emptyObject = emptyObject;\nexports.factory = factory;\nexports.reactNoopUpdateQueue = reactNoopUpdateQueue;\nexports.createClass = createClass;\n/* Not a pure module */\n"
},
{
"id": 46,
"identifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/style-loader/index.js!/home/x/zzz/github/douglasduteil/RePeople/node_modules/css-loader/index.js!/home/x/zzz/github/douglasduteil/RePeople/src/style/appBar.css",
"name": "./src/style/appBar.css",
"index": 33,
"index2": 35,
"size": 1015,
"cacheable": true,
"built": true,
"optional": false,
"prefetched": false,
"chunks": [
0
],
"assets": [],
"issuer": "/home/x/zzz/github/douglasduteil/RePeople/lib/js/src/components/appBar.js",
"issuerId": 42,
"issuerName": "./lib/js/src/components/appBar.js",
"failed": false,
"errors": 0,
"warnings": 0,
"reasons": [
{
"moduleId": 42,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/lib/js/src/components/appBar.js",
"module": "./lib/js/src/components/appBar.js",
"moduleName": "./lib/js/src/components/appBar.js",
"type": "cjs require",
"userRequest": "style/appBar.css",
"loc": "7:0-27"
}
],
"usedExports": true,
"providedExports": null,
"optimizationBailout": [],
"depth": 3,
"source": "// style-loader: Adds some css to the DOM by adding a <style> tag\n\n// load the styles\nvar content = require(\"!!../../node_modules/css-loader/index.js!./appBar.css\");\nif(typeof content === 'string') content = [[module.id, content, '']];\n// Prepare cssTransformation\nvar transform;\n\nvar options = {}\noptions.transform = transform\n// add the styles to the DOM\nvar update = require(\"!../../node_modules/style-loader/lib/addStyles.js\")(content, options);\nif(content.locals) module.exports = content.locals;\n// Hot Module Replacement\nif(module.hot) {\n\t// When the styles change, update the <style> tags\n\tif(!content.locals) {\n\t\tmodule.hot.accept(\"!!../../node_modules/css-loader/index.js!./appBar.css\", function() {\n\t\t\tvar newContent = require(\"!!../../node_modules/css-loader/index.js!./appBar.css\");\n\t\t\tif(typeof newContent === 'string') newContent = [[module.id, newContent, '']];\n\t\t\tupdate(newContent);\n\t\t});\n\t}\n\t// When the module is disposed, remove the <style> tags\n\tmodule.hot.dispose(function() { update(); });\n}"
},
{
"id": 47,
"identifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/css-loader/index.js!/home/x/zzz/github/douglasduteil/RePeople/src/style/appBar.css",
"name": "./node_modules/css-loader!./src/style/appBar.css",
"index": 34,
"index2": 32,
"size": 694,
"cacheable": true,
"built": true,
"optional": false,
"prefetched": false,
"chunks": [
0
],
"assets": [],
"issuer": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/style-loader/index.js!/home/x/zzz/github/douglasduteil/RePeople/node_modules/css-loader/index.js!/home/x/zzz/github/douglasduteil/RePeople/src/style/appBar.css",
"issuerId": 46,
"issuerName": "./src/style/appBar.css",
"failed": false,
"errors": 0,
"warnings": 0,
"reasons": [
{
"moduleId": 46,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/style-loader/index.js!/home/x/zzz/github/douglasduteil/RePeople/node_modules/css-loader/index.js!/home/x/zzz/github/douglasduteil/RePeople/src/style/appBar.css",
"module": "./src/style/appBar.css",
"moduleName": "./src/style/appBar.css",
"type": "cjs require",
"userRequest": "!!../../node_modules/css-loader/index.js!./appBar.css",
"loc": "4:14-78"
}
],
"usedExports": true,
"providedExports": null,
"optimizationBailout": [],
"depth": 4,
"source": "exports = module.exports = require(\"../../node_modules/css-loader/lib/css-base.js\")(undefined);\n// imports\n\n\n// module\nexports.push([module.id, \".AppBar {\\n background-color: #0168AB;\\n background-image: url(\" + require(\"./AppBar.background.png\") + \");\\n background-repeat: no-repeat;\\n background-position: right;\\n color: white;\\n margin-bottom: 10px;\\n padding: 0 15px; \\n display: flex;\\n align-items: center;\\n}\\n\\n.AppBar-logo {\\n height: 40px;\\n}\\n\\n.AppBar a {\\n line-height: 1.5;\\n border: 2px solid transparent;\\n cursor: pointer;\\n}\\n\\n.AppBar a:hover {\\n border-bottom-color: white;\\n}\\n\\n.AppBar hr {\\n flex-grow: 1;\\n visibility: hidden;\\n}\\n\", \"\"]);\n\n// exports\n"
},
{
"id": 48,
"identifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/url-loader/index.js!/home/x/zzz/github/douglasduteil/RePeople/src/style/AppBar.background.png",
"name": "./src/style/AppBar.background.png",
"index": 36,
"index2": 31,
"size": 21877,
"cacheable": true,
"built": true,
"optional": false,
"prefetched": false,
"chunks": [
0
],
"assets": [],
"issuer": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/css-loader/index.js!/home/x/zzz/github/douglasduteil/RePeople/src/style/appBar.css",
"issuerId": 47,
"issuerName": "./node_modules/css-loader!./src/style/appBar.css",
"failed": false,
"errors": 0,
"warnings": 0,
"reasons": [
{
"moduleId": 47,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/css-loader/index.js!/home/x/zzz/github/douglasduteil/RePeople/src/style/appBar.css",
"module": "./node_modules/css-loader!./src/style/appBar.css",
"moduleName": "./node_modules/css-loader!./src/style/appBar.css",
"type": "cjs require",
"userRequest": "./AppBar.background.png",
"loc": "6:95-129"
}
],
"usedExports": true,
"providedExports": null,
"optimizationBailout": [],
"depth": 5,
"source": "module.exports = \"data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAlMAAAFcCAIAAABjnaz3AAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAAAyZpVFh0WE1MOmNvbS5hZG9iZS54bXAAAAAAADw/eHBhY2tldCBiZWdpbj0i77u/IiBpZD0iVzVNME1wQ2VoaUh6cmVTek5UY3prYzlkIj8+IDx4OnhtcG1ldGEgeG1sbnM6eD0iYWRvYmU6bnM6bWV0YS8iIHg6eG1wdGs9IkFkb2JlIFhNUCBDb3JlIDUuNi1jMTExIDc5LjE1ODMyNSwgMjAxNS8wOS8xMC0wMToxMDoyMCAgICAgICAgIj4gPHJkZjpSREYgeG1sbnM6cmRmPSJodHRwOi8vd3d3LnczLm9yZy8xOTk5LzAyLzIyLXJkZi1zeW50YXgtbnMjIj4gPHJkZjpEZXNjcmlwdGlvbiByZGY6YWJvdXQ9IiIgeG1sbnM6eG1wPSJodHRwOi8vbnMuYWRvYmUuY29tL3hhcC8xLjAvIiB4bWxuczp4bXBNTT0iaHR0cDovL25zLmFkb2JlLmNvbS94YXAvMS4wL21tLyIgeG1sbnM6c3RSZWY9Imh0dHA6Ly9ucy5hZG9iZS5jb20veGFwLzEuMC9zVHlwZS9SZXNvdXJjZVJlZiMiIHhtcDpDcmVhdG9yVG9vbD0iQWRvYmUgUGhvdG9zaG9wIENDIDIwMTUgKFdpbmRvd3MpIiB4bXBNTTpJbnN0YW5jZUlEPSJ4bXAuaWlkOjM2NzE1RThCREIxNjExRTU4RDYzQ0JFOENCOTVFOTBBIiB4bXBNTTpEb2N1bWVudElEPSJ4bXAuZGlkOjM2NzE1RThDREIxNjExRTU4RDYzQ0JFOENCOTVFOTBBIj4gPHhtcE1NOkRlcml2ZWRGcm9tIHN0UmVmOmluc3RhbmNlSUQ9InhtcC5paWQ6MzY3MTVFODlEQjE2MTFFNThENjNDQkU4Q0I5NUU5MEEiIHN0UmVmOmRvY3VtZW50SUQ9InhtcC5kaWQ6MzY3MTVFOEFEQjE2MTFFNThENjNDQkU4Q0I5NUU5MEEiLz4gPC9yZGY6RGVzY3JpcHRpb24+IDwvcmRmOlJERj4gPC94OnhtcG1ldGE+IDw/eHBhY2tldCBlbmQ9InIiPz6+a8LkAAA8aUlEQVR42uydiZbjurFlAWrIuerafu63+g/73/q/evKzr6ty0Ex0BEFRnEkpNYDU3itvXg1MlURCODhAIMLa//E/DQBcgSgyr29muzXrlf5uwlrj5PfhfuH/k6l5eTG/fhk9aI8r/A++y3/8p3Gx+ec/eh384w8znZp//RenbUBMOQUAF0fETPrHzcZ8fpjdrsfxzY/IS+3i/UOucADCd66LJbIXxzpSieNeAxr/u8/BgPIBjJ/JxDw9GxuZX3/27HdrDF9eCCM5wJV1Lr2L+p0DOb3yM52Zn38xX59ms26UtIdHvbjiwuW0I3soHwBo1zmfm2hiPt+1J+1rOLoeiaZmu96rXU7q/GEI31n495/m6ck8vZgfP9WpL77Malm+uC+vZjbT23KACOTVnWlNUzH5NkBTQPkArurzpubxSWfMpLvsM7fZZPisrdHAaWSWNXbv8CeOLu/bxDudl16vVd5E5N5+mvmD+UpmqqPIvLzpXX/iZVizXFxb8FzX4MntV4vRP5QPrvLFtIXRaNYL30l3LB//7YeaAOkNd9sTurWGO7nb0vO6kuohfpdhsza/f6lxf3o2j49mNjfbjfo8G+mw5muhT5W84KVbl2uYGGhqSFm0FCqI8sEFiSY1/bZ8406QgYFpXhK3Gcfm/V27xRMHDQ2yl81k2uQM6+vvH0L8Lm3+ZBAj8vb4bB4e1OoJ66X5/NQmvZmp//v4fSWrV695tuL/XfmZdCKBVoHywSWYTPRLVprfk15YOmt56rh5v9uZtmN7h8lU+0T5jO+/vueVi32ZzXV5vufyj0xnOWW1qfiZ4pof4nde5EwuPs1qofq3XessqGe7NQ9OG8BlB3a28cH6VWGbqp1vD9bQKlA+uKTpkS9ZtQvQSLkkQDzwb528PRGVh0f9CNK19enL5PjZXP9w8XWiz+uUvVJ3Zvcjf5tNI+fNH+J3Uf8X61JfqW1vkvnPCypfVeGaYluKMU421za+ObZD+QAaiaLG3l+6DNFFOSBY26cxKY/J+k0yhH+a6hrPetXYR8hneXpJNHL13V6v3e1VH99uDm6v8IeI3y2Qqz9/vNhmvpLstd/NB7aYxsmAmsaD8gGcbvhM25dfnppEaWhAaIItPk/UzodiagjDXFNyzB90LL9catdWEg+NYdmqz4u/L+QNsneQQ3voqVwS2Olc8Sm3H9ZnM59FtUP8Lsp2ax6T+fxLKF+j1cvNgVePt62TAQ7hQ/ngjPrR/s0XXZGvn9q+YJRPJMHLm0ui+NbrVJXFxsmPPP7wpEF98rnWS53Ukt7t8Ul7jfdzRTTUyl6D1csW+dRA77uwgtvLjeUt4ndFlgudAPjOKm+fyYD6bHa1856uqH9F8TvsebjrJoHywTkQzThMs7R09MF82fyWOz9mF52ryrZI3XanYeuijtKvTTcq25/vZx7P21JvVunsXOVPsoSftiJ+Jj+6Lw7z4aK2T5jNdfx0xubhGiI5bXMLOQyAcvrnKpMBlmtmIk4BnAFvRKxtG8DKk+Gs8z08pqN1+Wlyq37+8+tDDxALeE7Zy8VqlmxdNaSz8FdRZdTfMPa3xcMsvd0lkbbx/HzB5mErNwoXN/eArQ2PqrOF990kUD44n/hFzc1pMglrdsXnZuyzUCdq7WNYojN+WfL+uBqq17R5y+kCpEa4VBJVW1OYL63t6eCijX+7S5OZXap52IKkFRSuJH2mIpC2GBuM7UP54Ixa0iQP/sGgAjvtUUsd9vABzz6iz/drtqtPmk1r3kZh2rPYOWL7rsZmpROe5zd8dU3RNh1XFb/q0IpmgPLB2Ue+NgljsVG6jcEm2/hsSIEtJanudWScrJRcosuwFfXqPMmu5shSN2dNfcg7XI7tVlvIZHKZBmIP0U+2j4BVRLG2SdyxCqJ8cFYtccnUW5T8qPjZNJ9ZaJsZ3D4Gsn8PdDblqHsp19Q37fczpD8ufefZI0eJK1x02Cc/09lZm0dl1tsdcy1tq8Ld90gI5YOzf/93ydpYsjzmf8e7sy6SnW80fcQEpjtnV1E71dn0z2ZP+Tw47f2XrXn13LOo3yVZLjQfwvfbhq1tJ3XruLbrtWy/dojyAVzGYNng3tIRspf0RucSb9vkxhoyMbqcbq03HRrsmsSVYf5VGtUuTrNan83wtaXtNK6H+DU9eN+jIJQPrtMpxMHZPl2A7Pft9+/87LJxXNeTpD89qLUrb9ezpnkRCKt3LT5+m+eXsxo+m27RKwVAubpZAdujsjGgfHBd2xfYbJu8I60v2vWWZrM0bMFe4A0c9bq+SkP7tGtnzVImPC/NepUmSfiW4auzd99qZkc2lbFDDhe4ovhp3s4w9jZst2aaFGcQVfOVGaqTn5MkXVk00a5HM1Of6Z23zFDZ1t5Lq+HsOl7k0Esm9RwcKRqvzmaTjqiO3QZTG3XZs6k0XmfX9uAdNw2UD66pfC6UpNXbjaqd+LnpXPO5+OScma5ItyWaJ0pjk7pLLXlezobt7sYmkQpwp1Gs3fPgGOlfC2kwNsmBnlbV6Hn9a9OVNQezuOYV3Nrmw3VH+eBmaMWGiQlkR7sosbq9XVqc4ek5yeG5VjnUqnvJzrnF5zU24Nd3eZXOTN5kdVukbdW56qPU5r5CI5ef+fwI5SvLnq2UU+8KZqmfEXWFikWueIw199wMWOeDK/cLLqxQFxG2NHun08nP55c0E8dyqckYLyF79TEIrutgm3hQVw5jKYQC2l7/KKp3aWTA9PTStzVUZa//gCn/23XOBHDhUT64mdOKQ4w2E7cnvdVqqVsPN2vVvHPm3W9XI9dLIaV/jONKcb6G+bHqilHJQBLncunphMWXeX3rIXumr+zVthZnmu82lWVwjH5QPriR+EWT8N6VU7X7SvTvOrNArjPQwBYmvuJtYe9CnzRU1a3QeSmFy7Fc6BSCtW1Wr3rpCjlbbEHwXLN1q05yHmJYkn2rriJ4lhwuANfXmEulwRzExz/2qf1eLk2C2lCz7QiL2dD/wtmHdzKQqt/VXluCan8tbFOTKIlfU9CmOzzpcut8NYbvrqUP5YMbiV90x22vI9KyLjozX+bJtsyPNc9lNcV8In6XmkLYpOHBJatdW4LKHrPxzuX8nNn/zmterezl2w+znTRRuE2/4Lf3Yfr6iJZJNvNttpWVvS7ZKy3v1RewxfxdBvF800nuxO6DWWqdt2swcIVLmUteXho8uaI7rI6tyg/cu/ShfHAjtJLtvfa21ZKznR1RYX+YrQtucd362rEtGv079/Buvdbdoi1WL4s/aozMdcV5zpK8VX7ypTwKsucO/xB7WlA+uLX43XkLdA2mrdI3iXuo2U1fNAGuOKKvju6d6RE9iP6dD63e8KyN3DUPQ2zPdrIXNuc65kXzC4Fuv6x+kD2uCsoHNx8U27vsZ93xSVUmE91xWP8SdeHsJ09q5fUPCfyuubdm+aV7++o3cTYZwR4NyNX9lMo2lmyfZVff4dtEDhe4te0LJ5nnbcXQ2f2W9rqkHZqrOq4RM1d3p0P2eoz8C/k/mR87RfTS07xampc3tX0Fy27bNp67Rn/YNlqypvHqM8mZ5y//IZcD5YOb2z53SnrfURlAW6OC2pe5g3XIFCgbvNtSUEPlbmd/2tf/oX/HW7283myTHNbLReG02lx5qfZxTK9rZxu3+llkb8/jk/njr+Yf/9fstsx2QgC27+5W+1xdf+dqlCz7EWccu3LCqvzs1mGk77oE73tToNBh9WxZ0nY7beHWHlITdMieO/4aNVx3e2wR5rFelsj87e+aW+D//i9NKU7GagjF+ZWng+7V/zmby1OVC4iPd/W65RoetKYmc8d5rCn+r4fVy7NJIjyjiUqgLSZSKZ9b13EJGk15Ue0MPi/H84ue//ffh1InKB+EYvsmk3v6wLatwN5hPjOb7XRJlYbaCL2G5ZzLVZBH/+qtXsvmBKvbG56fzft7o1y1xJ44c1wgDBclQ3qV1x96Qv78Z+kZlA+CET8ZFMf3Eepi67Yz2H23lU2XZQ/O5knt3Hxf6er7O3fFj4D+VWWv6UxtVublOakzta2z0a2aR0zmaTw+mbefqnl15aJY54Mw8L3n/Swj2bpu7nAqiss2NtJUWMbVLOy5bM/WDT/F3a7/NSSePjxkDxf3/bdOu3VavfxSri1uyIP+/Lf/rqt6//g/TVUS8XwQju3bJXVrx277bMNUZ21BGd/jyWlZLQ4moCYipkFE214c/3d5q5c399udnhy5lNtd83XKr9Lh807i7YdmD/h//7v9KJQPAnN+ur1vxKEu9ggdygb+kdlvY+9Su0btsTXBhOjfNzXPdJXOKAWzaPWGudkuamQvv1nFMIF8ErOZ+fkX9dby0wXKB0HZviTUZcSur8UllHrSgpIl9Ynihl16tuIRa4cUpjn4EP27nNXLX9PN1jw+JOvZ20bZw+qdNo/y+kN///nPnpNGKB+EJ35jDXWxtlt1DvqXW8zzBdmb7F3/fjJf0h39O+0KNg4d6qyeyWfDMUl4y4OZRCauDFzcnedz+AZio59fNVfO4qv/H6F8EBi6t2+sdq9nXdmKdfPTvz3t3RESeOEp0FHpX9e+BVMXsmtLQujMcmmennXa01S3XSJ7xw9EXl418vnf/zr27BHbCUHavvFt7+tMltkU4C5f72hyUKwzRvr5l7In5QxpLqvTrH+DDQG1PWY4W6xeesultk8833RWuARwAtJF/Md/6kbJP/95wqAB5YMgbd/IaoU3znPaQ629pryLUbKl4XJd5In6507RP7eXQDOUi1uXjawk/7Z1lFO9rO/v6lRYz/sOf/mbeX3TTQu5tCxHwWwnhGn7xrTDoUc8Z0u6YTF8m801RhuZQpv+RePy4ud6nonD4mXg83sdAUENwSyuOVbFPy5te50EeZ7aa981j8+6LfLXv77ZOeD5IGDnN4ZM1rZ5ntPmlKBB9vwOsN32euf8aP/nGgL8W0vg2pz/C9Hc97N6pSSc7VbP5Xamb1aHCU/oK1YT3bQQWfPnf31/TIzng2Bt3yhW+6xpm+fskL2c87jymON0/+cKH7zT/6Uf1h7+3eFaPdNq9fJhPrvYzMxd5G04m9V70kpPX59pcNC3QfkgbPEb9A6Hzm0MTYs9+Q5Uc/wvb+O5j9a/nAi4qiy0SqDLSc7NFsD6BXCaBtlrt3r5x2Ofz2WK8vWwepGW9pWu4Pe/z/iqKB8EjN/hMNR9Ti3Le7ZDDuXZ6TSd7JUbYg7Su1ZnPqW7vNpo4Gj9c63i1kf/TGOd1T6n2rX/465D805b1atU0CgeU/f4aqF5trKlvtcfen2XiySaiXJdOav3lKzqnbuEGcoHYbMbaKhLexx8s7Pxf/LXvxfqof/8S6GrlU7z4/2qo4G+KWDaE4Yeo38HuXUdJ9mUSxm2elFbfhfZ3c5NC00znIUk061WrzSfsdlq3Tjh7Wf64GyuGZa/Pq4R0xQ+f/u7+fzQVb0LgPJB+M5vgLave/tXs+y9vOnt5TItZOqnfL3/k/Pw8KDd5XqtSSuub8FN/xRoLRUITYcElvTPNGiV6VK7FhUuvU3b5SZd8Q0UrJ45wuoVbN9So/M9iy+9O3/Qfe4//jCLhfq/+F7nQuUrMJ2af/7jcv8CygfBozscpteLbzyD7NluA9H0pJ2osLnYfDRk3d086yyZ9I9iDm5ihY9Igea6XFgP/TvuWdvXjHaLZXM2Mle2dUdYvQzx8fN5ckE35tef6VmVa7peqgWU6ytDHM3ItbivyU9xvc8vGsny+X7Rfwflg0GIX6ymJx5EF2B79MvNhu+PP/TWr+bF/OWXeXrStPTiD45JVHgxCeypf6bVAvbeC9j+RMsxrlUIa1+wduXuOzOcqaF51TyTckzsNO1WaUi33Woox+xBr/LTi17lZeL/Ro+MF+Xzyu/3X1f4pqN8MARk2DtJQjwKvWhuSlF8YRC62LW81y57MuCVb/563WFwxQ7+8Vdd/N+staO88aXpqX/tFrDHFOjRglfU1Pwxrt/0aNuqXt3lMz1mOKUZq+wZ8/tX43y1WPndl5o/cT8Pjzr1N0Tls5HaVl3OXHeflulMbe56dbU5fJQPhkC2pd3aGqUxSWbLEJTvO8t78vs1WeH76Jrn2WySJCAPms/i8z2IFdCz6J/Na5Lr9n22hxC6UiYBVzmgx4XqI3tHBaP26eKlPX99mocnHdUNa51b3q2M4UTJ/NdWPsjiqy1hjQwFJhO1elcE5YOBjB/9WLg0rPZCKONon9b5thEB7ct7ti2iXp96edVb0iH2WdeRbuJvf09CXVYBJcHypXaMOVH/XLPINT7c5fxsaURS2TLYEQtqysefZvUOPe60bgDXLH4+k9GAZE8+4NOL/vaCJ9/cx0dt2+LqxMWWpijkm/vzD13mvPqKNcoHwSPjQZukvah+//0jPgRGDnPx7fqIrt17We+p+bqipMyQ06Gx5qlJduk9POiDnx99+8T3d/P2pnOe201AK6DOlXcO9AmBsV37AHsJXnv0kCvKlS0bwdq3Zs5q9apzGJ1jKWsGs6VHhp7SGqUZSxtYrXRB2jdLads+YGc+14Hdcj+2+/GHCuG//usmbxblg+BnTnwn1eKE5AtmkxCYaHKzENBs3dG7z0mUdsTp8mSc+iG5K8dsd/qIN6nx/in9FPaIea2NWL03DXUJLvAnqx1oC2m92o63jcpo62Y1bbMNbMmSWpLAw8Rqe5SNa3xXJwyz0rFa3PfgODneLw1K2/ajnNAsoG62eVTZM8lUvGhe3tutV/q2peU/Pekx0mLlWbGAX5/6+K2sKV0rhD2QjNLvfIcH2mkqW612fdYVkXw+SZW0KO0yxahpzTyXCnOU/PbdWZS8Afluu51mhI836dtzLt2cV2savObJ0Fj6uKb9DCVkyCx/+/474IvnDpvHO/TP1Ti5ktWztmM6tPNfcaXXcaZJM12X7H0zxVr/XKw2meoXq6SLZzMzf9QGJo9MolQXpUVJ68oU8Sai+PyisxfyTzet5+mbXOub9Ok3RSZ//XnbERvKB+Ebvh5fZt8LRImp6hxIZr7K2kPFcJt1KHvFlbt2XwzWd1W73d6f7dKINT3GplOXtf1Woeh2bU+7r8e9WiVd21yHw50fQVOaJZ90AJVuXDl5Spv+2erN9GS55onNxgQupcOKbi+zeo2Wryvx9Cknw6UNqWf7lwam+eqSkZ9vFaXs3tJQRXU0KjhpitH+K+PLbkgr1Vx3rpBR+0Lq2LkbwUujN4i3BuWD4A1fz7gVHwLnnVkpCsbu4xyiTMxMOnZ2Lv26qhzG+6xRxQ6iZQbS9y8t1RhceydfzGK8XJrXmY6gO5Pz/vyr/paB82DoqX+1T+RnOPvs3msxUPk3U7F6nbL3/Wzatvf+xXQ8t0saba4FlpqitN7aMFE/te510ecA8i1cW7tN1dQP43zhpO+skR9XVCSIolQoHwRr+JKlsv4JLLyGTSf6hfdi6SNCD19pv8Dmen+VTX1fU/VtLUWI2mbMKo/LoF4G6dJVyaC4Jerdb/iV4fPwEnn30T93iMC0Dee53vy5fjqavQHX+Ec9r9fJnm86V9feuRfTrxmfNoepU+4NMwdeCH1QWME+Jv+WV8T8T+fQ02te39lL1/GdQvngrnHxoXJpz++J3+qua2z+S3jhoLjGbQz5VJMtRYiqtjXWPcvTma72rVf1n1r+0ZcX/fuvj+Fe2i79c+VyFvk9Cba3dXB+htN2jXCK16NW5M7VU/tluUlSZPXrS8OUmvTv9YfuB3Dm/BPa8S5dGqyONTVMzKY3MkmLJuUQU18tJIu1SVe4o36zuDb9t9wtY1ZRPggYn6y5p/Kls5ruWnkObVv321mEqGm+S/pBcXuPT5q5Q8VvL/9Z5/uyzwAyyMpN/fXPpZvQjz2/zhzj/Fy35ztvvUBxVP/+UzOvyvjm9c3EL3q5ZRCTN0xPz2nWchGSj1/Xq9sgjW0X1wwX/XKjzQ1D5be8f+8d5a9mc9P/JKVG88YBySgfhNw3Jqto+q1zvfJCeeW4Di3znKY55UfnvJmGuiy1K5nPNQrO1M3sSS85gMCW4/XPVYoauf6rQs1Tl9Z0FVVokL6Okn7fEL9ff6apmX2uk9ksTc4pcuIrUokwfH7q9oBAvoZN/sxHgclv+QhHnSg8H0C37eucSEnjMK+11al9nrMpFMJ11ydPR/qLr0NVwmygrSE8yfLMbDbsUvVN+lc6q1lIrTkhKsIVRiHt4tdk+OzFlqPkZWXsslnrku3Do675iZV/fE78kNNAp4/fA7lucXrhTO8IlzDmKlA+CN72ybfLJnsMWmZI/BTKlQxf1zxnx/Jej29+m6WTHnNqXl91wnOEFr8kfpXzbDv1yhTTjtmSDtb/aZ84l0t83q8PvdbzpDKDtOHtRsN646GVJUojXHovxhtz83EbygdDsH2TZOG9aZd6tE9vdh3Z6zXPaeoN31k6VBF4OSfSXY5nzrN4mo5b8ytplStKpusYqRQGJVcxfOWrudGf1VIlQVzgUIcsSb51n0W26bxpnYqXdJB66xzcKB8MZFIljTcr5fLfT7O4a40ibf90zBXZO+NX/fNDF4RGqHxmnxmnwfQ1jjlcQb2Oc4quTQKvg26wG+wVW3zqVK3mqn5OykZ+pjkfDmc1Sp5KinCtViGEJaN8MBTbVwoBzO0T77Pl6Dyy16fY+qnLe8eOskX2Hp/GWbM0PznpTI/kL6fby9y/mIuRcXzljpLtnVbLEjP38KjK9/pDzau0TL9QrWmsH3XYut3q+iXrfADH9VM3L0JkTiq2bs8dGe/5+tTg+M3mZkm6L3uxK7EttksGjz3B1ThS952XQ/922ibF0mm0arJVf7lUIZQbonbvv25fRRnlg4HRHt5ylXfQ46mWEm6X6UYXC93snA2uR3XFc+7W1u54aPgTVzfp6fqHt7jcYAVO0L+tTmZqjfUnlUAdon2ZVXAzEygfDIHIXiuApbkjdn1KzdXJ3uWmd7YbHVDL+DpeDn9je93ptPU+sGt/nj1i3FJaIITv4/ebisN7ftFZ0CBbZsRlguCH//bGcd5tu/dak4lcoUv1MYG6j3hkuIZBhetlym01yadtfX3X6d7hSP3bXS8+FuWDMRq+6JbfnxbZs/nQ+QabeOlO1CWVaKazNFh8VCOekkp1plax5Q0MNsv2acsnzdRtAiS85cxzEttgmyXKBxi+E2TPmF51vK/SiW422sU8PI3Q9bla7XNdgln66dTU7EFXuAHf/fpEeD6AoX152mSvtTiOM9ee59EyuXGa53PMuKIouu+/0uEOYnd+z7fB8wGcpj03MXy2W/bc95JznlkRkpLuAZS6PrPO5c1Z1fbVnn/bsfyaK0tbEjxXNprw/e+vtWG+NZQPMHxFwWvPkmwrRVPr/cTVu894pwF1z69j83iuVbeqZq0pjUuj7LnKXyF952qTcVodGuUDCMnw2Zza2cLDLUbQNcubu2nXuVrqJofJmLYq1dm+2ht9hbRJ9jB8l/l6RSgfwNHK5y71jcy8XTkOsMnn2e4O1gWwA/rjtyYOHq3tcxWn52qmnV2zWayqXf66YvjOfu1CrTuB8sFdyV5x4cG2esH8kpHts4B0o3nOPNLR7HZpjezxdJ/Fk+r24ub6n3nXuEBYeBFk77ytcUeEC8Btla91Ac/a4sxnUf5aeuSS4QvBMXy+a+KoaExfbVcweWW3VhRAV7dNr032mOe8R1A+CLOvO2s/VK95e6nLu7q85rUYwtoHXTCnbrnUBPkjE7+aTXiuLG+H8Ud1xrNV9oxB+s7PbkdsJ0D/VnnWkM6aGgve2x3qHZmyy+uxG7rG/gXTdWrdPqtznqH2O98eDOWDXCoLeNUfZO8mWHvuylIoH4z423I22atuJ9prXknq/FfUVuoB2Lo7LmDDl7H80jjP6bjyebrKxGb7DodaaUT2rnm9rAlz+IXyQXDSdybls3VCWBmNFpxfbqmvdha06YUD7D3jWFOaqe0b13e8Zhkv5wKdP6A421nKrYrsXfl6UasBoM935VwCWnBsB6tXK2m2efkuf3DdemGwPed6pfrna6SNWPxc5Va24dIZ3N6tR2DORCGGd6J8EJTfO5Phs7be6hVum8Z9C7aqi62eMsz+U8s4rHTRdD4fWzupX/MzdXsVHLJ30290oOcZ5YMxfttcq+xZUyN4ZS0sxcUUq725YFfui+x2ZvFlnl7GOTXgmsTPNexmZ8f69T1fHGZSIZQPxmf4msvp5dWrXvAqL9S5h8GGrYK7rS74jVD8XPG0u/aN7Iemxda9qyoMO9kBriOfNWpXt8hXMHOt3WH+RawZiN3L8fVhHh+D7YPOZPsKpq5jYIT0XXPghfIBXNzwVRXL2pKCNS/guRbd6/lwkArhzMe7eXsbXaOp2D5Tv6/hOGmE87Y9djUAXFo/Cyt8WWdnaxXLHvXCldcflPpt1mZ3D6Vr6+StZPIQv2tCxmqAixs+W45EKc5zmsLttBesS/PYMvlZO+E5iM508amla0dVw6hZ9FzDFbZ82a6sfDvNqIDyAVzJ/HU/1ZLsqvvvjvkXw2C3U+cnti8a2d724hDK9KjJDtcc1AZp+1A+GIvha+vT8obP1VeoqXkdV3+wbb4ROMuF/h73nCeuLrTxVpAp9FA+uNdesNcOsN6vOZQOd71UzzeyfJ4Q7lcwMg7PB3A5w2fqSs52pxlzjbrYdLzrtJhhj8G323sJdWlpdXAdRPZE/MI74SgfjPuLl5PAFhWszfH4PUsZLhrnudMCfgDX+A6SvQzgUobvMoLpRiN3xZ5ovdIgz5HHeUIYxHGAQVUoH8AdDsNjzef5/MyZgIszmQQ4wEX54Kbm4xJGrfaR4/4pe+I/OKSR+E4H4zNCXeDC7HYBzpSgfHAjzr/oXVc2yPaTNtuQs7pW7ga3maGJr0+t3ndv4R6Et1z7hBsiXAAuZPhqLZjtYct6FVyv/3eGnhBSLsFyaR4IdYELe77wBhsoH4xo3G1LQuTalLGpJl/t7ohyBizXoblDQUNdIl2JAbjcACu8/aMoH4zD8LU7QNfL7/V51h25LzB8xPbNH8eW0gzCIY4DTGBGc4exGL4mWWqfk7TNPzV/1VLje7DsthrqKaNyFsDgIt/KGM8HcFHDV1W5yqKcO/klXS6fZ3M1gCGyIqUZXPL77vB8gOG77OtXRcuVk7P0F6qS2+so1zDkvmmz0dW+iAU/ODdxHOBCMsoHozF82QCzxQS6vkbN1U1yujoTaUehhLut9lDz+ehGWnzlAhjsxsF9QUhfBNf9DlwhtqUQ4WkLN/T/rlCuvdo5lmq4F+Y2XY2CjobtRjNZy4+OHtxhwK5bGO1+1GJNZNO7u12wFbchrMGubzMhZXJB+WBEhu/wr9hDNT5nc7bM1itefeSKKwph05LhWNRPZEzE7Pkl7aRK89L+kexBubtaago0gM7xrgkuQy+znXDNL8A1VTZ3y1XW/FLf5hqUy1Uyn2UF3F3RXI5rxc9n8qzKXnb5so8vd+dzgmKg73g3sG0zeD4Yl+E7iJUt2jVbeOpg/FzTXxc0z9QVMHLjkr2nl/Rjb7daycg7PDGCPjDPV1mLJnqIfG6RPbn98Kg2MZDIPXZl8PVH+SA4w3ftpl8RP2eLRi2vf52aZ8aTt6XpAmXhLZ/vfY+fzfT3akkDhza2m6Q4+y6cd8RsJ4x4xFeazHTlmc/sJ7/3z7nCRGij7I3M8D0fIXvCaqHVHoTZ/MYTWTi9QYyrAnPkKB9cuLnfuNHX5nTJr/ZljtDVLe8V1G//V25ssicXSFfsnE5dbre9/kSOXG+SlIxTDQcFaGstW5QP7snnZT+3FT9XjWSpGLvyj+uRDG0svLyln6yn4fOsl0nptcT2Ud4dOqQmLK1B+eBaKhjIG3DVx2t/KmI3PqvnyaYrN+vjLlMca6kHl2ToeHgkwASaPR/Zy+BuuX3P6Ar657oPD0i5L8fTU/oBT9icJ2K52erfzqY32OGA1g5o4BvYBhiUD67Y+oPoqlzZvbX4PedGa/U8j09ptM5pe9L9fnbN5GLVO4YpRYPTxyhKz2R2Poeu8daGdhWYnYf7leJGRXP3cQKkh50lOxlip3Hnp7HbpmnPxPbtHtjhcCJyAt9+HAZbfvekjzmSuzK2+HgPsOJBX+KdfiI8HwDcnmwnw3LxrddZrZKI0GSHH6EupyGyJ1LnU6Fm4dB+mmQyUV18GHIArW7mC0u2aaYA94r0sz62RfrWkz1fOqJPeupoomrq4nT+M8sJEO/SSWPvYGySYUAOu9rqqbVBr9S+/tDTJa7OO+b8W5ULJGf15x+aYWezUYc9UM9HDhe4UwLvfe6Q9Vp7VV+TVpRvd2qKDd3VEOnFlRfR9cKknkOme17q/L8yTdYCU2lMrID27FZvyN/GcZoszadJ8xVNd3Gh3/QrRvGIGpJPAieftNZ5+3OyWOiQQg5bfA7yS+QbAMoHAEGMxDfrdEPC/OH0wgvq85Ib8gqpt6vzl5tNTYeYu5P2jz6+w0ujqMIsqZrkH0wHTyKHLu1JfR6Z/M5Rv3yblk9yA9CJHz/1969/tx0jJ/bxUX/Wy76pBoJCrsIuDmrsi/IBhu+O2Sal2MWN6e/pKb3q49PeQa6OvsSuWDjY7ZWsvf3Y5D8RRTGaJlc1Se7Kp7DJB/FrZmmuba+pVvVSq8+vEyOVzPRq2IXbe01XcJbXaa6zma6Myptpn8aUDyLi9/yqc54DDXUJrCw7ygfXGvRBmNdFxW+a2r7d8esxaeoy990wmaPaj3qIrYmLkfI7Wy+Z3ll6FyifVCRQpXG2r0QhDyaPa9e8T1geZ/OxyX+qTLt09lWfcnvBtd9drXzzhu/P7iNF+cSdz+dDTREeWNJqlA/gvtFcnZskk8tEf4t1649GhyZq8fkRrrSnuetc2v82DcWqBQj9hKr89gGrcsMlCU61VJNNfYwv52vcIUWt6KJfmNwkK5d+ITN2h9XNvF0WMZAT3rO0vbi9n3/oX3nbOiyyTYooHwAEoQ2bZM5TlW+mE55xv4F5lEyT+inK3W4M56FsK3fpyGDTGvhqfZDOXjjVRCYbJZ+e0m15XhrNfhVTTrUa1jixy8fkEBDZlqsjhnU2QNsn71w+ezDNBOUDuHvipHOfR2nVvZ7zls8v6Y2vj7s+exqAWnc+azRyn5nFq+zDRpfu5DS+/+o1Zap7+5Iee5DpAlxQ4Z3sZAeAXJilOJI+wQhZrrJj81zfub32CVn8DRGw9Sqp7ttvl7rudjfm97+H2cCSbS3BTHji+QDunofH1Ek8PGjfJHd3+90C6fY7d9iWniTVSragJQ9eNLDlrF3voShVIN2vFz8x2Y9PureyPWJzkqzCdk69BohYvZdXnRs3ST2s7UY/9a1HSygfwH3jDYd0RiJy22TpTofn0UEvKrcO3HLabRSFGkQGxPbJMOLpuWPS+Mcfqtm/hmb4nl/2uWGTUKDpRGVebO5ioYudt9M/lA/gjvGBgpnDEz/hozAOGVjMPg9Ztt0tF80hTuUGVqlTCG3boUEpphaHWuhoQ8RPJLAph5zookaBLoe0k08+UbbXU0ZI3uf5zTPyuLhAaWzLRd9wKpQPAM6D9KfrdSEsU7qhw+ylTXez+b3exq8FZrIXB1BtuChjbr/9rqBywa9BivWRcy7e6PnZ/P6Ve++5pNVPL/pBPt6H0a6mU43cSZeBN2a1OLQxP8G73WrbE+cnR4re99/XgfIBwOmIq2tKV3bQM1dfvz4QKSmIWkv5N5u+Z/1//m9CEkXp+udzdX4//7I33HuHnfnvr69hNC0RvJe3RNGTUVStixWx//pQ2RPzJz+Tqfm8tqijfAB3hp9xGnYhPWvy7s42PJ4JnnWtwnlrxPGsVmn28DQ9d25KOU5KFy2/hnRp5A2LmLXMCsgB67VGTr283mRXPsoHcE/IQFuG2IMJyGw1fLake0XZy25nIldWu8BsX34sUkocOqCa7HY/PdBnMjzNVnqDq8B+PoD7kb0k89bQy6bbvMLZiv7t1yONPTzoH3Glw0L6UNUMMi13w786/Q++kaijfAD3gd+Bd1RazqE4jLLm5VUv/0gWs2OH56UGRj+pdjcrI4XyAdwB84ek9ux28B/E13PPdM/lBNDWzXbWOMKSXiJ+Z8Uv2vUtHezTfN9AhljnAxg1PidLAFkzziZ71XnOwmYGWzYfhXU+e9ik6B8dwsaHQV2jKDVzPS27DxjG8wHAOaXC5/UfQ2rN2njOnOzZyuxlNrdpc47QVpYGmfM8I1k14F4Hu1vZbjwfwEjR3NPT8Szs5eM5rc31mDYncqXN7Jnhy/9xrdXD+t2CtGgfng8AziV7UTSieJZiPGfx4QbZyxm+gzs0NWJpWOw7Hz4N7GxmHp87in48PJrXH8nBc/2r69YwwvMBjI5ZUjB2cEn9u4SveHs/z9koe7k/sFkCUpdubPcLfoXELti+b4rJTDPRxLF5/63J2B4etB2uljV1rCZT8/qW7llcLjW9mTwiQijiJ3evEoeF8gGMTPaS3mcEYZytule2cbWyd9CykqrZXL2l6sFwJNFEdU7O4OIrFbmP36pk4uSenlUOVyvN1emXAMXneS8oj8hhHi03v0kK2T+rUq5Xl16ZRvkARoT0NaJ5u92oPlRhha+oea605udv7m+7fGCnj+rMZTLD6Z3h0iSZ8MSxrSpezbs9rUk0N89TbZNyQFaDV3xhtUqDHJ/q34u+sujf5lLFQFA+gNHI3lzH0fFuhB8tE7yaXQ0lH1g1iK4soc4VbR8TnqfOLsiPaFVTZcE4Nl+fZrbRaU850ls98YUty88+2YII3iTJZy1N+jLznygfwCiG3tKzjCw/S6MEVmJVGjfzFSXPdOkdwtcTkSVxby7uqKabd3KbjS4ELj57vb7on/zJx0bTzIr4mXnyIufUP5QPYPhIn7JZj/SzdWXarH0wv0+sJm4+i3mBI/H1rTQUZXFEjQUterw+pYluk6l7EdqnZ71q8o+eqZ2jfAAD74mkXxit7O1lrLYCQ01ZPh+0mT/e9atVi93rN68gY6yW2vEXufre/23TMiOzF9XCb2ddZz8fwJBlz0Yjlz1b6+ds8xGuWfZaXgS6JhV81MnXx1Vlr+AaN+r55GcyMW8/9C3h+QDuDhn/Sv89qt0L39bIQ6hnRfMwdSc2s0kSkGl7LeldgTRqJgmZkd9yVxTx+KgulA9gmLLn4psUsw7eILqKHXQ13g8h7D6ZkUaX+DrGoQUMb5KQGXmHj4/mx0+NFz1y/hPlAxgaMtTVfcH30XO7WnnLPWvbbxd375VezjY8DvNkx8J6bVYfAbeNONkjsdZ99M/J+p9GxPSaBUH5AAbFdDqqtGR9nVxFD9M96bageNmm9bzs5TcwuHZRhaSBzR90OuHzYxhvWKTua6sXXd656F+c7LXoGheifABDEQCrU0/bO5O9krDZyhKe3nWV1J0uJ4Q5Y+dvu6IRpGiDJ9uxkCUhG1IzSUJgtr/Ny6vqn98OsWucGkH5AAbSK4ny3Z3stVpAVymw7ky5FG1J2KpaaCp/fp+DKp+QZbkYdsyU6NzHe/pxnpMtgIvP2jkSlA8gfNmbaGe9293vGXBZ9Mo+91g21VnewNekee7wWq5WD++V6UzXyUQePt/H0lqSFGjyMxf9e00yiCbxnzn/h/IBhM1kYmJ312Gcmnja1vm83Gqf79T8Ya4qmyX9c4fb7r6b1vxRT8FQlvSOZb02m2QL/FNSLPDzsBkR5QMIuW+aquY5di9UtLBQriGvkaZmqa9G9iq6eFdTnemS3kQnA8cdJCzfHZ84TQvhvun6X5IRG+UDCFj22KhuSvLmcrv0coYvE7xGASvJ3r0aPo2BTKY3lwuzXdzRB18tVfNmc5XAp2eUDyBIptO7Xthrlr5c9Epe/Mw+b1ldurN8PIur3Lgfw+dLn8tw6uP9LhvRfv1vNkP5AMIblUeT89ZkGUm3lc9MVop58ZqX7nCoOL122RsBWvr8QdvM8qt+wBRFqnnhJCG7LZsNygcQnuwxydlh/HLi54qer5CKurST3VXkcPiGLw3fT6I55jNdytpszGp1aEI2SrNcLj5Jd5eB8gGEJHvSTyF7LdLnSvlZbC5Xp93/v6Jw+SCOks4NV/YmEw3Zj2xaxEBUbTXRTdzTmc5q+mk9P725Xo5nxwLKBzAqoqRkWMzaXn/xM8X9fA2WrkXkhit78wfz+KQTm1+5vefSeL4+VPnkWRE8n98VzUP5AMKVPfEljkySPcXPHHb4Hdbt9o+Us7rU6eHQE1VroMquJkGlOD/v9l5eddp8uaC5oHwAQaJ71WNk70j5c5Wa7F2ebzSy5z9+MSlJGRvRotqGmpwCgJt+BSc6eKeTOtH8ueP0y2UznMM/4e3hKvmkNoDnAwjL7bFp7wz6l9ocU/x/0d7Zwfs8L2OzJIClU9LSRG6MqFA+gKB6MflB9s4rgaZF3YapARr3ZFO1i3faZnw5Hrnbrmr5ZKeA8gGEIntsroLatqGWLimhoAkNkgzL260m3yrw1MPzYfhQPoBwRvHOIXtwkKjZXEXOxWk5KrF00kJE6loaiTwlfyVs1mXzJy/49KL7/JYrzi7KBxCM7LH6cud236ud9/020mlMFbD4iLax+NSNDfMHtYbLr4NG+gflBT/eGV2hfABhyB6d0X2qnZq5ZLlOPJ3feL5efytrgQjkcmEma/PwpJlctlsTb5Nie4kokvQV5QNA9galE5HO+A36XGWWLnX5JlmuS7TqvHbfb2YXkyf/nMiq38POjALKBxBEP0g8S0+k+xblE5GInXqjQXTimcJNZ4dHxHX52csrXHcttbpJdzcCygeA7A2GydRMfGKNpPuO5LzN9LzFQW7zV2NqE7Wbpotzvvbbrd6qo4GhfAABuQFkrwvRj8k0lTybzODJ/6JkxDCZ6LPeP4XwJtP4lCQmxSecIzEmygcARdljMN51irIZQn+utnuHF+9lT9fMpon5i683hvAbxuUNqCTv879ks68MZVA+AGiWPdZdWvqeaaHewra4queSR0R7xGBFybyi3/G2vdjinzfok8TbeW3TbClrLiLKBwB9+tCIcIM2vJnLNG+3a3RR8pQVqxclEuhSj6jHnyPrm6pplK7Y+bVYH5NSzpYCKB8AdMoeM5xtXc7M613yO+7OXKrBI8kU6DTZEmcTs+gm6saOtXR+AlO9o1MfGSeFfkycVG7gkqF8ANDUezb1zsjecSfQHVebSc7qJk7CTJL8XnavZH3+uWiSps7x2wSPlUxA+QDuvOeuZAHe174hnuUo4pNmg/2k6LS514qiQ/ilhonGe9UkpwmgfAAn+pVqf+3SrtYQz3IU7mx/6pfrnMlNYKrocTkA5QP4vuzZZktncXv9RCsrhv7t0nFaoC5OIlNcmqZydw5ZBZQPALq1zS8g9Vl2gjMylNxmECQRpwCgh+Hrqn9tDCWwe53J1PWdKlqoHaB8AGH5QkC3YAgw2wlwtn6dU8B5BjwfwIicSstkZhr/Qo8MgPIBjEz8mqWP2M6rWj7GGIDyAVyJWtvXGf8CAIHBOh9Ab9uXbVrH8H3LshEKBHg+gMF35XCUaXZpQfNj94HoX004i4DnA7iu7YPTBM/v5LN762z2YUEm7ntWo32tBkYbgPIBQKDeLp/ONK31mlm3ZLbJ+uoWLv1pfDVfSC83/ohJywkoHwCEpXbJf3Fzvrc4Piyapo6w7vhUI/ei5wvpxayqAsoHACEIXt7bdZKZvGy1z6/hudzkp5/ezEjrMACgfABwK7XLahP2F7wq3vwVJj/Nvt5hroxtHDO9CSgfABwrVN+O0CnZu3Pt5XBJfXZdzLN7PUXzAOUDgNO1KjdhaI8Xv9LGA+cupUO6gGcLOyZV81jSA5QPAE6RPbffS2AbKss3qV2Pg88pfvv3GUXqAgFQPgA4UfMyXbF7PavVv7y9S5+6xTSjc0xvAsoHAN/TvKqepf6v9tlAPgUAygcAx/imDhnL+78A19LwfHBhyNsJcGeyV/J/ACgfAAwZ5gkBUD6AezN8fAgAlA8AAADlA4CwTR/hnYDyAQAAoHwAAAAoHwAAQBfsZAcYHfli6C0HAKB8ADB4vNqVygk1aR6pUuBeYbYTYKT653Uuk7r8bWQP8HwAMHLzV6uLIb955mMB5QOA7+ofPg8A5QO4L/0DgD2s8wFAgDDbCSgfANyZUeUUAMoHAACA8gEAAKB8AAAAKB8AAADKBwAAKB8AAADKBwAAgPIBAACgfAAAACgfAMA3oFwDoHwAAAAoHwCMFOpLAMoHAACA8gEAAKB8AAAAKB8AAADKBwAAKB8AAADKBwAAgPIBAACgfAAAACgfAAAAygcAAIDyAQAAoHwAAAAoHwAAAMoHAACA8gHASKBEH6B8AAAAKB8AAADKBwCjwVrOAaB8AAAAKB8AAADKBwAAgPIBAACgfAAAgPIBAABoYO10Ntbw2inXFwBC7HbzN8jncmUmU/PwYGykZ363NaslygcAcBXZk27X35bfiN91iCIzf1Dl227M+svM5mY+1wdF/OIY5QMAuKTm5W/I45i/KyCaJ1K325nFZ6pz65VKoDz+/KqPb9Z6dwT6zrUGgCA0ryp7GfJISQLh/D5oZmYz9XbLr4K9k9vLhf7IiX98Gomz5XIDQEBWr8XVZU8hfhe6CnKCmyydPL7dGjMSz43yAUAY9JnJZLbzgsrXZ0gxkjEHygcAAF2Ge38QygcAAHekjaP5JCgfAAAk3M0CKsoHAACqezrbOZs3Pj+ZjkYa2c8HAHD3iKrJT7zT1C1RpNv48mt+05l5etboluVIkrmgfAAA983jU7Jp70st3WZiHh7N80yTlm3Wqn9PL6qFcnexMG4kaVxQPgCAO7Z6onNfH+ldn6VT7vpkLj5jtYiiPLLbjelzo3wAEAZ9knOyh/2MZ1s0z6talfVKDZ+In1wRuTE6UD4AuDV9knPmNS87no3tJ1u9+dys1+rwWi6K6N9IQfkAIHj9q03pmVVyQP+OwpdiWHze8zlA+QAgMP3LKhPVSmPtI0hgH6LIPD6b9XLEZg7lA4ABks1hVqc3O/US/Wvh4VHPj1g9zg/KBwAhyt4JAob/a7F684dkl8KGk4HyAUBgnEWu8pYR/ZtMk6p7q9FsxUP5AGCkhu+8+ne3Evj4pPvwlgsaF8oHAGOXvbz+ZfEydyV+qdVb4npRPgC4J9krub078X/yMWfzJBsZVg/lA4BguY4U5fcLjlX8oomZTs12q7mnAeUDgHs0fC36Nz7/N3/Q4rF3v1cP5QMAZK9B/1T8rImSNzB0/dN9C49mtWBVD+UDAGSv3fyJ5pnBb4EXq+drDAHKBwDQWwIT/RPnNCz/p6t6E7PdqPIBygcAGL5T9E/fWOTvhy6Bvnjeek1TQvkAANn7pvhlKUBtoHlP5L3NH7RsHlYP5QMAZO9sEqghMFHi/wIzf7O5/l4taUcoHwDA2fUvTnVa1//M7f2fvI3pTLNOk4ET5QMADN81/J+PfzG3CAGVkzaZ6OzrZs2+BZQPAJC9a/m/bP+Dve4WQM1GNtPE07stLQjlAwBk7yb+bx//ctoS4FHnYTrVrQukZUH5AABC0b8oMrE7YuFNlMxGmlQzjjv0Lwvg3GL1UD4AwPCFpX+RsZNkOrT1A04m6t5M4hX9bdG/3a5RIOU4AjhRPgBA9oLUv0S9RP8mDf5Pnprue1rv9nzEyiTn//LnSh6XF2FVD+UDAAhbAmMTJ5OfZpIqmXeEKm82PSCbt5Sn5Bh5SsQymppdrPonD3ovuN0QwInyAQCGbyD+b7c7xH9mibCNU82rngRxdS5SqZskPyb58w3ZyFA+AED2Bqd//iP7Gc7dri3HmDyl5i+Z+TS2cdkPzk3EKQAAZO8Snz/Vtk4QPJQPAGAc7i+V//4HA8oHABi+gXs+TgLKBwDI3r3Zvp6ej7OF8gEAsjcS28epQPkAAO7L8wHKBwAYvnuSPXv02QOUDwCQveGeDv01mRyheZy9a8FOdgA4l8mh484R79LkLKJqu7ixnsNkmu555+yhfACA4Ru48iXVG3xa6lmkd3e7wimKIjOdpbc361573gHlAwBkL3QTvN0ktRqSVNQidT45tTCbpdOhFFtH+QAA2Rud/sVmE6d1GCaJ/mWreuSnRvkAYKjOBjrxqau9+JlkepPzhvIBAIZv/EOE3VbP2HbDybgt7GoAAGTvmp0um/ZQPgBA9u7L+XEKUD4AgPsaMXAKbg/rfADQ5e0OfsVh+L5LzHnD8wFAyJpXyiTp7yJ7gPIBwEitnj1YvVTqrO7LhnN5aLgRzHYCQJPmuYK309sufVZ/O5zfKXDSUD4ACFL2mlVNHk9Ni00OpB8/ksgyXYzyAcBwZC/vWqxJD4ZjPR+yd/PhB6cAAGqEDS47wgCUDwDol+/l9EaMLVA+AAAAlA8AYKw4h6tG+QBgsNCBn3LSCOxE+QAA7svzxZwDlA8ABu5ggDOG8gHAkPvl/t13cigTd0d7Pk7B7WEnOwBknbLLqZprFLYskzWd+Gmej6U+lA8AghM/k5uUy/fR+eoN5CI5Wfk4bygfAIQrfnn/5xN1onnfPb1EuKB8ABCs/vmdZ4VyRXTcZzB9nAKUDwDC178o1T2sHqB8AHAf+ofPO+fZZKnv5rCrAQDgilDUHuUDALg7A43huzX/X4ABAF14ctp5X9naAAAAAElFTkSuQmCC\""
},
{
"id": 49,
"identifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/style-loader/lib/urls.js",
"name": "./node_modules/style-loader/lib/urls.js",
"index": 38,
"index2": 33,
"size": 3008,
"cacheable": true,
"built": true,
"optional": false,
"prefetched": false,
"chunks": [
0
],
"assets": [],
"issuer": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/style-loader/lib/addStyles.js",
"issuerId": 10,
"issuerName": "./node_modules/style-loader/lib/addStyles.js",
"failed": false,
"errors": 0,
"warnings": 0,
"reasons": [
{
"moduleId": 10,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/style-loader/lib/addStyles.js",
"module": "./node_modules/style-loader/lib/addStyles.js",
"moduleName": "./node_modules/style-loader/lib/addStyles.js",
"type": "cjs require",
"userRequest": "./urls",
"loc": "44:14-31"
}
],
"usedExports": true,
"providedExports": null,
"optimizationBailout": [],
"depth": 3,
"source": "\n/**\n * When source maps are enabled, `style-loader` uses a link element with a data-uri to\n * embed the css on the page. This breaks all relative urls because now they are relative to a\n * bundle instead of the current page.\n *\n * One solution is to only use full urls, but that may be impossible.\n *\n * Instead, this function \"fixes\" the relative urls to be absolute according to the current page location.\n *\n * A rudimentary test suite is located at `test/fixUrls.js` and can be run via the `npm test` command.\n *\n */\n\nmodule.exports = function (css) {\n // get current location\n var location = typeof window !== \"undefined\" && window.location;\n\n if (!location) {\n throw new Error(\"fixUrls requires window.location\");\n }\n\n\t// blank or null?\n\tif (!css || typeof css !== \"string\") {\n\t return css;\n }\n\n var baseUrl = location.protocol + \"//\" + location.host;\n var currentDir = baseUrl + location.pathname.replace(/\\/[^\\/]*$/, \"/\");\n\n\t// convert each url(...)\n\t/*\n\tThis regular expression is just a way to recursively match brackets within\n\ta string.\n\n\t /url\\s*\\( = Match on the word \"url\" with any whitespace after it and then a parens\n\t ( = Start a capturing group\n\t (?: = Start a non-capturing group\n\t [^)(] = Match anything that isn't a parentheses\n\t | = OR\n\t \\( = Match a start parentheses\n\t (?: = Start another non-capturing groups\n\t [^)(]+ = Match anything that isn't a parentheses\n\t | = OR\n\t \\( = Match a start parentheses\n\t [^)(]* = Match anything that isn't a parentheses\n\t \\) = Match a end parentheses\n\t ) = End Group\n *\\) = Match anything and then a close parens\n ) = Close non-capturing group\n * = Match anything\n ) = Close capturing group\n\t \\) = Match a close parens\n\n\t /gi = Get all matches, not the first. Be case insensitive.\n\t */\n\tvar fixedCss = css.replace(/url\\s*\\(((?:[^)(]|\\((?:[^)(]+|\\([^)(]*\\))*\\))*)\\)/gi, function(fullMatch, origUrl) {\n\t\t// strip quotes (if they exist)\n\t\tvar unquotedOrigUrl = origUrl\n\t\t\t.trim()\n\t\t\t.replace(/^\"(.*)\"$/, function(o, $1){ return $1; })\n\t\t\t.replace(/^'(.*)'$/, function(o, $1){ return $1; });\n\n\t\t// already a full url? no change\n\t\tif (/^(#|data:|http:\\/\\/|https:\\/\\/|file:\\/\\/\\/)/i.test(unquotedOrigUrl)) {\n\t\t return fullMatch;\n\t\t}\n\n\t\t// convert the url to a full url\n\t\tvar newUrl;\n\n\t\tif (unquotedOrigUrl.indexOf(\"//\") === 0) {\n\t\t \t//TODO: should we add protocol?\n\t\t\tnewUrl = unquotedOrigUrl;\n\t\t} else if (unquotedOrigUrl.indexOf(\"/\") === 0) {\n\t\t\t// path should be relative to the base url\n\t\t\tnewUrl = baseUrl + unquotedOrigUrl; // already starts with '/'\n\t\t} else {\n\t\t\t// path should be relative to current directory\n\t\t\tnewUrl = currentDir + unquotedOrigUrl.replace(/^\\.\\//, \"\"); // Strip leading './'\n\t\t}\n\n\t\t// send back the fixed url(...)\n\t\treturn \"url(\" + JSON.stringify(newUrl) + \")\";\n\t});\n\n\t// send back the fixed css\n\treturn fixedCss;\n};\n"
},
{
"id": 50,
"identifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/file-loader/index.js!/home/x/zzz/github/douglasduteil/RePeople/src/assets/appBar.logo.svg",
"name": "./src/assets/appBar.logo.svg",
"index": 39,
"index2": 36,
"size": 82,
"cacheable": true,
"built": true,
"optional": false,
"prefetched": false,
"chunks": [
0
],
"assets": [
"6dc3d87ca4e7a3c134aab663f0a17a10.svg"
],
"issuer": "/home/x/zzz/github/douglasduteil/RePeople/lib/js/src/components/appBar.js",
"issuerId": 42,
"issuerName": "./lib/js/src/components/appBar.js",
"failed": false,
"errors": 0,
"warnings": 0,
"reasons": [
{
"moduleId": 42,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/lib/js/src/components/appBar.js",
"module": "./lib/js/src/components/appBar.js",
"moduleName": "./lib/js/src/components/appBar.js",
"type": "cjs require",
"userRequest": "assets/appBar.logo.svg",
"loc": "9:11-44"
}
],
"usedExports": true,
"providedExports": null,
"optimizationBailout": [],
"depth": 3,
"source": "module.exports = __webpack_public_path__ + \"6dc3d87ca4e7a3c134aab663f0a17a10.svg\";"
},
{
"id": 51,
"identifier": "/home/x/zzz/github/douglasduteil/RePeople/lib/js/src/backend.js",
"name": "./lib/js/src/backend.js",
"index": 40,
"index2": 42,
"size": 1475,
"cacheable": true,
"built": true,
"optional": false,
"prefetched": false,
"chunks": [
0
],
"assets": [],
"issuer": "/home/x/zzz/github/douglasduteil/RePeople/lib/js/src/app.js",
"issuerId": 39,
"issuerName": "./lib/js/src/app.js",
"failed": false,
"errors": 0,
"warnings": 0,
"reasons": [
{
"moduleId": 39,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/lib/js/src/app.js",
"module": "./lib/js/src/app.js",
"moduleName": "./lib/js/src/app.js",
"type": "cjs require",
"userRequest": "./backend.js",
"loc": "8:18-41"
}
],
"usedExports": true,
"providedExports": null,
"optimizationBailout": [],
"depth": 2,
"source": "// Generated by BUCKLESCRIPT VERSION 1.9.2, PLEASE EDIT WITH CARE\n'use strict';\n\nvar Curry = require(\"bs-platform/lib/js/curry.js\");\nvar Json_decode = require(\"bs-json/lib/js/src/Json_decode.js\");\n\nfunction person(json) {\n return /* record */[\n /* id */Json_decode.field(\"id\", Json_decode.string, json),\n /* firstname */Json_decode.field(\"firstname\", Json_decode.string, json),\n /* lastname */Json_decode.field(\"lastname\", Json_decode.string, json),\n /* photo */Json_decode.field(\"photo\", Json_decode.string, json),\n /* entity */Json_decode.field(\"entity\", Json_decode.string, json),\n /* email */Json_decode.field(\"email\", Json_decode.string, json),\n /* phone */Json_decode.field(\"phone\", Json_decode.string, json),\n /* manager */Json_decode.optional((function (param) {\n return Json_decode.field(\"entity\", Json_decode.string, param);\n }), json)\n ];\n}\n\nfunction people(json) {\n return Json_decode.list(person, json);\n}\n\nvar Decode = /* module */[\n /* person */person,\n /* people */people\n];\n\nfunction getPeople(callback) {\n fetch(\"people.json\").then((function (prim) {\n return prim.json();\n })).then((function (jsonPeople) {\n return Promise.resolve(Curry._1(callback, Json_decode.list(person, jsonPeople)));\n }));\n return /* () */0;\n}\n\nexports.Decode = Decode;\nexports.getPeople = getPeople;\n/* No side effect */\n"
},
{
"id": 52,
"identifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/bs-json/lib/js/src/Json_decode.js",
"name": "./node_modules/bs-json/lib/js/src/Json_decode.js",
"index": 41,
"index2": 41,
"size": 6345,
"cacheable": true,
"built": true,
"optional": false,
"prefetched": false,
"chunks": [
0
],
"assets": [],
"issuer": "/home/x/zzz/github/douglasduteil/RePeople/lib/js/src/backend.js",
"issuerId": 51,
"issuerName": "./lib/js/src/backend.js",
"failed": false,
"errors": 0,
"warnings": 0,
"reasons": [
{
"moduleId": 51,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/lib/js/src/backend.js",
"module": "./lib/js/src/backend.js",
"moduleName": "./lib/js/src/backend.js",
"type": "cjs require",
"userRequest": "bs-json/lib/js/src/Json_decode.js",
"loc": "5:18-62"
}
],
"usedExports": true,
"providedExports": null,
"optimizationBailout": [],
"depth": 3,
"source": "'use strict';\n\nvar List = require(\"bs-platform/lib/js/list.js\");\nvar $$Array = require(\"bs-platform/lib/js/array.js\");\nvar Curry = require(\"bs-platform/lib/js/curry.js\");\nvar Js_exn = require(\"bs-platform/lib/js/js_exn.js\");\nvar Js_math = require(\"bs-platform/lib/js/js_math.js\");\nvar Caml_exceptions = require(\"bs-platform/lib/js/caml_exceptions.js\");\nvar Caml_builtin_exceptions = require(\"bs-platform/lib/js/caml_builtin_exceptions.js\");\n\nfunction _isInteger(value) {\n if (isFinite(value)) {\n return +(Js_math.floor(value) === value);\n } else {\n return /* false */0;\n }\n}\n\nvar DecodeError = Caml_exceptions.create(\"Json_decode.DecodeError\");\n\nfunction $$boolean(json) {\n if (typeof json === \"boolean\") {\n return json;\n } else {\n throw [\n DecodeError,\n \"Expected boolean, got \" + JSON.stringify(json)\n ];\n }\n}\n\nfunction bool(json) {\n return +$$boolean(json);\n}\n\nfunction $$float(json) {\n if (typeof json === \"number\") {\n return json;\n } else {\n throw [\n DecodeError,\n \"Expected number, got \" + JSON.stringify(json)\n ];\n }\n}\n\nfunction $$int(json) {\n var f = $$float(json);\n if (_isInteger(f)) {\n return f;\n } else {\n throw [\n DecodeError,\n \"Expected integer, got \" + JSON.stringify(json)\n ];\n }\n}\n\nfunction string(json) {\n if (typeof json === \"string\") {\n return json;\n } else {\n throw [\n DecodeError,\n \"Expected string, got \" + JSON.stringify(json)\n ];\n }\n}\n\nfunction nullable(decode, json) {\n if (json === null) {\n return null;\n } else {\n return Curry._1(decode, json);\n }\n}\n\nfunction nullAs(value, json) {\n if (json === null) {\n return value;\n } else {\n throw [\n DecodeError,\n \"Expected null, got \" + JSON.stringify(json)\n ];\n }\n}\n\nfunction array(decode, json) {\n if (Array.isArray(json)) {\n var length = json.length;\n var target = new Array(length);\n for(var i = 0 ,i_finish = length - 1 | 0; i <= i_finish; ++i){\n var value = Curry._1(decode, json[i]);\n target[i] = value;\n }\n return target;\n } else {\n throw [\n DecodeError,\n \"Expected array, got \" + JSON.stringify(json)\n ];\n }\n}\n\nfunction list(decode, json) {\n return $$Array.to_list(array(decode, json));\n}\n\nfunction pair(left, right, json) {\n if (Array.isArray(json)) {\n var length = json.length;\n if (length === 2) {\n return /* tuple */[\n Curry._1(left, json[0]),\n Curry._1(right, json[1])\n ];\n } else {\n throw [\n DecodeError,\n \"Expected array of length 2, got array of length \" + (String(length) + \"\")\n ];\n }\n } else {\n throw [\n DecodeError,\n \"Expected array, got \" + JSON.stringify(json)\n ];\n }\n}\n\nfunction dict(decode, json) {\n if (typeof json === \"object\" && !Array.isArray(json) && json !== null) {\n var keys = Object.keys(json);\n var l = keys.length;\n var target = { };\n for(var i = 0 ,i_finish = l - 1 | 0; i <= i_finish; ++i){\n var key = keys[i];\n var value = Curry._1(decode, json[key]);\n target[key] = value;\n }\n return target;\n } else {\n throw [\n DecodeError,\n \"Expected object, got \" + JSON.stringify(json)\n ];\n }\n}\n\nfunction field(key, decode, json) {\n if (typeof json === \"object\" && !Array.isArray(json) && json !== null) {\n var match = json[key];\n if (match !== undefined) {\n return Curry._1(decode, match);\n } else {\n throw [\n DecodeError,\n \"Expected field \\'\" + (String(key) + \"\\'\")\n ];\n }\n } else {\n throw [\n DecodeError,\n \"Expected object, got \" + JSON.stringify(json)\n ];\n }\n}\n\nfunction at(key_path, decoder) {\n if (key_path) {\n var rest = key_path[1];\n var key = key_path[0];\n if (rest) {\n var partial_arg = at(rest, decoder);\n return (function (param) {\n return field(key, partial_arg, param);\n });\n } else {\n return (function (param) {\n return field(key, decoder, param);\n });\n }\n } else {\n throw [\n Caml_builtin_exceptions.invalid_argument,\n \"Expected key_path to contain at least one element\"\n ];\n }\n}\n\nfunction optional(decode, json) {\n var exit = 0;\n var v;\n try {\n v = Curry._1(decode, json);\n exit = 1;\n }\n catch (raw_exn){\n var exn = Js_exn.internalToOCamlException(raw_exn);\n if (exn[0] === DecodeError) {\n return /* None */0;\n } else {\n throw exn;\n }\n }\n if (exit === 1) {\n return /* Some */[v];\n }\n \n}\n\nfunction oneOf(_decoders, json) {\n while(true) {\n var decoders = _decoders;\n if (decoders) {\n try {\n return Curry._1(decoders[0], json);\n }\n catch (exn){\n _decoders = decoders[1];\n continue ;\n \n }\n } else {\n var length = List.length(decoders);\n throw [\n DecodeError,\n \"Expected oneOf \" + (String(length) + \", got \") + JSON.stringify(json)\n ];\n }\n };\n}\n\nfunction either(a, b) {\n var partial_arg_001 = /* :: */[\n b,\n /* [] */0\n ];\n var partial_arg = /* :: */[\n a,\n partial_arg_001\n ];\n return (function (param) {\n return oneOf(partial_arg, param);\n });\n}\n\nfunction withDefault($$default, decode, json) {\n try {\n return Curry._1(decode, json);\n }\n catch (exn){\n return $$default;\n }\n}\n\nfunction map(f, decode, json) {\n return Curry._1(f, Curry._1(decode, json));\n}\n\nfunction andThen(b, a, json) {\n return Curry._2(b, Curry._1(a, json), json);\n}\n\nexports.DecodeError = DecodeError;\nexports.$$boolean = $$boolean;\nexports.bool = bool;\nexports.$$float = $$float;\nexports.$$int = $$int;\nexports.string = string;\nexports.nullable = nullable;\nexports.nullAs = nullAs;\nexports.array = array;\nexports.list = list;\nexports.pair = pair;\nexports.dict = dict;\nexports.field = field;\nexports.at = at;\nexports.optional = optional;\nexports.oneOf = oneOf;\nexports.either = either;\nexports.withDefault = withDefault;\nexports.map = map;\nexports.andThen = andThen;\n/* No side effect */\n"
},
{
"id": 53,
"identifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/bs-platform/lib/js/js_math.js",
"name": "./node_modules/bs-platform/lib/js/js_math.js",
"index": 44,
"index2": 40,
"size": 978,
"cacheable": true,
"built": true,
"optional": false,
"prefetched": false,
"chunks": [
0
],
"assets": [],
"issuer": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/bs-json/lib/js/src/Json_decode.js",
"issuerId": 52,
"issuerName": "./node_modules/bs-json/lib/js/src/Json_decode.js",
"failed": false,
"errors": 0,
"warnings": 0,
"reasons": [
{
"moduleId": 52,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/bs-json/lib/js/src/Json_decode.js",
"module": "./node_modules/bs-json/lib/js/src/Json_decode.js",
"moduleName": "./node_modules/bs-json/lib/js/src/Json_decode.js",
"type": "cjs require",
"userRequest": "bs-platform/lib/js/js_math.js",
"loc": "7:30-70"
}
],
"usedExports": true,
"providedExports": null,
"optimizationBailout": [],
"depth": 4,
"source": "'use strict';\n\nvar Pervasives = require(\"./pervasives.js\");\n\nfunction unsafe_ceil(prim) {\n return Math.ceil(prim);\n}\n\nfunction ceil_int(f) {\n if (f > Pervasives.max_int) {\n return Pervasives.max_int;\n } else if (f < Pervasives.min_int) {\n return Pervasives.min_int;\n } else {\n return Math.ceil(f);\n }\n}\n\nfunction unsafe_floor(prim) {\n return Math.floor(prim);\n}\n\nfunction floor_int(f) {\n if (f > Pervasives.max_int) {\n return Pervasives.max_int;\n } else if (f < Pervasives.min_int) {\n return Pervasives.min_int;\n } else {\n return Math.floor(f);\n }\n}\n\nfunction random_int(min, max) {\n return floor_int(Math.random() * (max - min | 0)) + min | 0;\n}\n\nvar ceil = ceil_int;\n\nvar floor = floor_int;\n\nexports.unsafe_ceil = unsafe_ceil;\nexports.ceil_int = ceil_int;\nexports.ceil = ceil;\nexports.unsafe_floor = unsafe_floor;\nexports.floor_int = floor_int;\nexports.floor = floor;\nexports.random_int = random_int;\n/* No side effect */\n"
},
{
"id": 54,
"identifier": "/home/x/zzz/github/douglasduteil/RePeople/lib/js/src/components/listAll.js",
"name": "./lib/js/src/components/listAll.js",
"index": 45,
"index2": 50,
"size": 2411,
"cacheable": true,
"built": true,
"optional": false,
"prefetched": false,
"chunks": [
0
],
"assets": [],
"issuer": "/home/x/zzz/github/douglasduteil/RePeople/lib/js/src/app.js",
"issuerId": 39,
"issuerName": "./lib/js/src/app.js",
"failed": false,
"errors": 0,
"warnings": 0,
"reasons": [
{
"moduleId": 39,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/lib/js/src/app.js",
"module": "./lib/js/src/app.js",
"moduleName": "./lib/js/src/app.js",
"type": "cjs require",
"userRequest": "./components/listAll.js",
"loc": "9:18-52"
}
],
"usedExports": true,
"providedExports": null,
"optimizationBailout": [],
"depth": 2,
"source": "// Generated by BUCKLESCRIPT VERSION 1.9.2, PLEASE EDIT WITH CARE\n'use strict';\n\nvar List = require(\"bs-platform/lib/js/list.js\");\nvar $$Array = require(\"bs-platform/lib/js/array.js\");\nvar Block = require(\"bs-platform/lib/js/block.js\");\nvar Curry = require(\"bs-platform/lib/js/curry.js\");\nvar React = require(\"react\");\nvar PersonCard = require(\"./personCard.js\");\nvar ReasonReact = require(\"reason-react/lib/js/src/reasonReact.js\");\nvar SearchInput = require(\"./searchInput.js\");\n\nfunction initialState() {\n return /* record */[/* filterPattern */\"\"];\n}\n\nfunction reducer(action, _) {\n return /* Update */Block.__(0, [/* record */[/* filterPattern */action[0]]]);\n}\n\nvar component = ReasonReact.reducerComponent(\"ListAll\");\n\nfunction filterPerson(pattern) {\n var re = new RegExp(pattern, \"i\");\n return (function (person) {\n if (re.test(person[/* firstname */1])) {\n return /* true */1;\n } else {\n return +re.test(person[/* lastname */2]);\n }\n });\n}\n\nfunction personCards(pattern, people) {\n return List.map((function (person) {\n return ReasonReact.element(/* Some */[person[/* id */0]], /* None */0, PersonCard.make(person, /* array */[]));\n }), List.filter(filterPerson(pattern))(people));\n}\n\nfunction search($$event) {\n return /* Search */[$$event.target.value];\n}\n\nfunction make(people, _) {\n var newrecord = component.slice();\n newrecord[/* render */9] = (function (param) {\n var filterPattern = param[/* state */4][/* filterPattern */0];\n return React.createElement(\"div\", undefined, React.createElement(\"div\", {\n className: \"card-container\"\n }, $$Array.of_list(personCards(filterPattern, people))), React.createElement(\"div\", {\n className: \"control-container\"\n }, ReasonReact.element(/* None */0, /* None */0, SearchInput.make(\"searchInput\", \"Search\", filterPattern, Curry._1(param[/* reduce */3], search), /* array */[]))));\n });\n newrecord[/* initialState */10] = initialState;\n newrecord[/* reducer */12] = reducer;\n return newrecord;\n}\n\nexports.initialState = initialState;\nexports.reducer = reducer;\nexports.component = component;\nexports.filterPerson = filterPerson;\nexports.personCards = personCards;\nexports.search = search;\nexports.make = make;\n/* component Not a pure module */\n"
},
{
"id": 55,
"identifier": "/home/x/zzz/github/douglasduteil/RePeople/lib/js/src/components/card.js",
"name": "./lib/js/src/components/card.js",
"index": 47,
"index2": 45,
"size": 2517,
"cacheable": true,
"built": true,
"optional": false,
"prefetched": false,
"chunks": [
0
],
"assets": [],
"issuer": "/home/x/zzz/github/douglasduteil/RePeople/lib/js/src/components/personCard.js",
"issuerId": 31,
"issuerName": "./lib/js/src/components/personCard.js",
"failed": false,
"errors": 0,
"warnings": 0,
"reasons": [
{
"moduleId": 31,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/lib/js/src/components/personCard.js",
"module": "./lib/js/src/components/personCard.js",
"moduleName": "./lib/js/src/components/personCard.js",
"type": "cjs require",
"userRequest": "./card.js",
"loc": "4:18-38"
}
],
"usedExports": true,
"providedExports": null,
"optimizationBailout": [],
"depth": 4,
"source": "// Generated by BUCKLESCRIPT VERSION 1.9.2, PLEASE EDIT WITH CARE\n'use strict';\n\nvar React = require(\"react\");\nvar ReasonReact = require(\"reason-react/lib/js/src/reasonReact.js\");\n\nrequire(\"style/card.css\");\n\nvar component = ReasonReact.statelessComponent(\"Card\");\n\nfunction make(children) {\n var newrecord = component.slice();\n newrecord[/* render */9] = (function () {\n return React.createElement(\"div\", {\n className: \"Card card\"\n }, ReasonReact.createDomElement(\"div\", {\n className: \"card-content\"\n }, children));\n });\n return newrecord;\n}\n\nvar component$1 = ReasonReact.statelessComponent(\"Card.Title\");\n\nfunction make$1(main, sub, _) {\n var newrecord = component$1.slice();\n newrecord[/* render */9] = (function () {\n return React.createElement(\"div\", {\n className: \"card-title\"\n }, React.createElement(\"div\", undefined, main), React.createElement(\"div\", {\n className: \"card-subtitle\"\n }, sub));\n });\n return newrecord;\n}\n\nvar Title = /* module */[\n /* component */component$1,\n /* make */make$1\n];\n\nvar component$2 = ReasonReact.statelessComponent(\"Card.Avatar\");\n\nfunction make$2(photoUrl, $staropt$star, _) {\n var altText = $staropt$star ? $staropt$star[0] : \"persons face\";\n var newrecord = component$2.slice();\n newrecord[/* render */9] = (function () {\n return React.createElement(\"img\", {\n className: \"card-avatar\",\n alt: altText,\n src: photoUrl\n });\n });\n return newrecord;\n}\n\nvar Avatar = /* module */[\n /* component */component$2,\n /* make */make$2\n];\n\nvar component$3 = ReasonReact.statelessComponent(\"Card.Info\");\n\nfunction make$3(icon, desc, children) {\n var title = desc ? desc[0] : icon;\n var newrecord = component$3.slice();\n newrecord[/* render */9] = (function () {\n return React.createElement(\"div\", {\n className: \"card-info\"\n }, React.createElement(\"i\", {\n className: \"material-icons\",\n title: title\n }, icon), ReasonReact.createDomElement(\"span\", { }, children));\n });\n return newrecord;\n}\n\nvar Info = /* module */[\n /* component */component$3,\n /* make */make$3\n];\n\nexports.component = component;\nexports.make = make;\nexports.Title = Title;\nexports.Avatar = Avatar;\nexports.Info = Info;\n/* Not a pure module */\n"
},
{
"id": 56,
"identifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/style-loader/index.js!/home/x/zzz/github/douglasduteil/RePeople/node_modules/css-loader/index.js!/home/x/zzz/github/douglasduteil/RePeople/src/style/card.css",
"name": "./src/style/card.css",
"index": 48,
"index2": 44,
"size": 1009,
"cacheable": true,
"built": true,
"optional": false,
"prefetched": false,
"chunks": [
0
],
"assets": [],
"issuer": "/home/x/zzz/github/douglasduteil/RePeople/lib/js/src/components/card.js",
"issuerId": 55,
"issuerName": "./lib/js/src/components/card.js",
"failed": false,
"errors": 0,
"warnings": 0,
"reasons": [
{
"moduleId": 55,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/lib/js/src/components/card.js",
"module": "./lib/js/src/components/card.js",
"moduleName": "./lib/js/src/components/card.js",
"type": "cjs require",
"userRequest": "style/card.css",
"loc": "7:0-25"
}
],
"usedExports": true,
"providedExports": null,
"optimizationBailout": [],
"depth": 5,
"source": "// style-loader: Adds some css to the DOM by adding a <style> tag\n\n// load the styles\nvar content = require(\"!!../../node_modules/css-loader/index.js!./card.css\");\nif(typeof content === 'string') content = [[module.id, content, '']];\n// Prepare cssTransformation\nvar transform;\n\nvar options = {}\noptions.transform = transform\n// add the styles to the DOM\nvar update = require(\"!../../node_modules/style-loader/lib/addStyles.js\")(content, options);\nif(content.locals) module.exports = content.locals;\n// Hot Module Replacement\nif(module.hot) {\n\t// When the styles change, update the <style> tags\n\tif(!content.locals) {\n\t\tmodule.hot.accept(\"!!../../node_modules/css-loader/index.js!./card.css\", function() {\n\t\t\tvar newContent = require(\"!!../../node_modules/css-loader/index.js!./card.css\");\n\t\t\tif(typeof newContent === 'string') newContent = [[module.id, newContent, '']];\n\t\t\tupdate(newContent);\n\t\t});\n\t}\n\t// When the module is disposed, remove the <style> tags\n\tmodule.hot.dispose(function() { update(); });\n}"
},
{
"id": 57,
"identifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/css-loader/index.js!/home/x/zzz/github/douglasduteil/RePeople/src/style/card.css",
"name": "./node_modules/css-loader!./src/style/card.css",
"index": 49,
"index2": 43,
"size": 966,
"cacheable": true,
"built": true,
"optional": false,
"prefetched": false,
"chunks": [
0
],
"assets": [],
"issuer": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/style-loader/index.js!/home/x/zzz/github/douglasduteil/RePeople/node_modules/css-loader/index.js!/home/x/zzz/github/douglasduteil/RePeople/src/style/card.css",
"issuerId": 56,
"issuerName": "./src/style/card.css",
"failed": false,
"errors": 0,
"warnings": 0,
"reasons": [
{
"moduleId": 56,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/style-loader/index.js!/home/x/zzz/github/douglasduteil/RePeople/node_modules/css-loader/index.js!/home/x/zzz/github/douglasduteil/RePeople/src/style/card.css",
"module": "./src/style/card.css",
"moduleName": "./src/style/card.css",
"type": "cjs require",
"userRequest": "!!../../node_modules/css-loader/index.js!./card.css",
"loc": "4:14-76"
}
],
"usedExports": true,
"providedExports": null,
"optimizationBailout": [],
"depth": 6,
"source": "exports = module.exports = require(\"../../node_modules/css-loader/lib/css-base.js\")(undefined);\n// imports\n\n\n// module\nexports.push([module.id, \".Card.card {\\n width: 460px;\\n min-height: 180px;\\n margin: 10px;\\n}\\n\\n.Card.card:hover {\\n box-shadow: 0 16px 24px 2px rgba(0, 0, 0, 0.14),\\n 0 6px 30px 5px rgba(0, 0, 0, 0.12),\\n 0 8px 10px -5px rgba(0, 0, 0, 0.3);\\n}\\n\\n.Card .card-avatar {\\n float: right;\\n border-radius: 50%;\\n width: 128px;\\n height: 128px;\\n}\\n\\n.Card .card-title {\\n margin-bottom: 15px;\\n}\\n\\n.Card .card-subtitle {\\n font-size: 14px;\\n line-height: initial;\\n text-transform: uppercase;\\n color: #777;\\n}\\n\\n.Card .card-info {\\n display: flex;\\n align-items: center;\\n margin-bottom: 2px; \\n}\\n\\n.Card .card-info > span {\\n overflow: hidden;\\n text-overflow: ellipsis;\\n font-weight: 300;\\n}\\n\\n.Card .card-info > i.material-icons {\\n color: #777;\\n margin-right: 5px;\\n}\\n\", \"\"]);\n\n// exports\n"
},
{
"id": 58,
"identifier": "/home/x/zzz/github/douglasduteil/RePeople/lib/js/src/components/searchInput.js",
"name": "./lib/js/src/components/searchInput.js",
"index": 50,
"index2": 49,
"size": 1056,
"cacheable": true,
"built": true,
"optional": false,
"prefetched": false,
"chunks": [
0
],
"assets": [],
"issuer": "/home/x/zzz/github/douglasduteil/RePeople/lib/js/src/components/listAll.js",
"issuerId": 54,
"issuerName": "./lib/js/src/components/listAll.js",
"failed": false,
"errors": 0,
"warnings": 0,
"reasons": [
{
"moduleId": 54,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/lib/js/src/components/listAll.js",
"module": "./lib/js/src/components/listAll.js",
"moduleName": "./lib/js/src/components/listAll.js",
"type": "cjs require",
"userRequest": "./searchInput.js",
"loc": "11:18-45"
}
],
"usedExports": true,
"providedExports": null,
"optimizationBailout": [],
"depth": 3,
"source": "// Generated by BUCKLESCRIPT VERSION 1.9.2, PLEASE EDIT WITH CARE\n'use strict';\n\nvar React = require(\"react\");\nvar ReasonReact = require(\"reason-react/lib/js/src/reasonReact.js\");\n\nrequire(\"style/searchInput.css\");\n\nvar component = ReasonReact.statelessComponent(\"SearchInput\");\n\nfunction make(id, label, value, onChange, _) {\n var newrecord = component.slice();\n newrecord[/* render */9] = (function () {\n return React.createElement(\"div\", {\n className: \"SearchInput input-field\"\n }, React.createElement(\"i\", {\n className: \"material-icons prefix\"\n }, \"search\"), React.createElement(\"input\", {\n id: id,\n type: \"text\",\n value: value,\n onChange: onChange\n }), React.createElement(\"label\", {\n htmlFor: id\n }, label));\n });\n return newrecord;\n}\n\nexports.component = component;\nexports.make = make;\n/* Not a pure module */\n"
},
{
"id": 59,
"identifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/style-loader/index.js!/home/x/zzz/github/douglasduteil/RePeople/node_modules/css-loader/index.js!/home/x/zzz/github/douglasduteil/RePeople/src/style/searchInput.css",
"name": "./src/style/searchInput.css",
"index": 51,
"index2": 48,
"size": 1030,
"cacheable": true,
"built": true,
"optional": false,
"prefetched": false,
"chunks": [
0
],
"assets": [],
"issuer": "/home/x/zzz/github/douglasduteil/RePeople/lib/js/src/components/searchInput.js",
"issuerId": 58,
"issuerName": "./lib/js/src/components/searchInput.js",
"failed": false,
"errors": 0,
"warnings": 0,
"reasons": [
{
"moduleId": 58,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/lib/js/src/components/searchInput.js",
"module": "./lib/js/src/components/searchInput.js",
"moduleName": "./lib/js/src/components/searchInput.js",
"type": "cjs require",
"userRequest": "style/searchInput.css",
"loc": "7:0-32"
}
],
"usedExports": true,
"providedExports": null,
"optimizationBailout": [],
"depth": 4,
"source": "// style-loader: Adds some css to the DOM by adding a <style> tag\n\n// load the styles\nvar content = require(\"!!../../node_modules/css-loader/index.js!./searchInput.css\");\nif(typeof content === 'string') content = [[module.id, content, '']];\n// Prepare cssTransformation\nvar transform;\n\nvar options = {}\noptions.transform = transform\n// add the styles to the DOM\nvar update = require(\"!../../node_modules/style-loader/lib/addStyles.js\")(content, options);\nif(content.locals) module.exports = content.locals;\n// Hot Module Replacement\nif(module.hot) {\n\t// When the styles change, update the <style> tags\n\tif(!content.locals) {\n\t\tmodule.hot.accept(\"!!../../node_modules/css-loader/index.js!./searchInput.css\", function() {\n\t\t\tvar newContent = require(\"!!../../node_modules/css-loader/index.js!./searchInput.css\");\n\t\t\tif(typeof newContent === 'string') newContent = [[module.id, newContent, '']];\n\t\t\tupdate(newContent);\n\t\t});\n\t}\n\t// When the module is disposed, remove the <style> tags\n\tmodule.hot.dispose(function() { update(); });\n}"
},
{
"id": 60,
"identifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/css-loader/index.js!/home/x/zzz/github/douglasduteil/RePeople/src/style/searchInput.css",
"name": "./node_modules/css-loader!./src/style/searchInput.css",
"index": 52,
"index2": 47,
"size": 660,
"cacheable": true,
"built": true,
"optional": false,
"prefetched": false,
"chunks": [
0
],
"assets": [],
"issuer": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/style-loader/index.js!/home/x/zzz/github/douglasduteil/RePeople/node_modules/css-loader/index.js!/home/x/zzz/github/douglasduteil/RePeople/src/style/searchInput.css",
"issuerId": 59,
"issuerName": "./src/style/searchInput.css",
"failed": false,
"errors": 0,
"warnings": 0,
"reasons": [
{
"moduleId": 59,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/style-loader/index.js!/home/x/zzz/github/douglasduteil/RePeople/node_modules/css-loader/index.js!/home/x/zzz/github/douglasduteil/RePeople/src/style/searchInput.css",
"module": "./src/style/searchInput.css",
"moduleName": "./src/style/searchInput.css",
"type": "cjs require",
"userRequest": "!!../../node_modules/css-loader/index.js!./searchInput.css",
"loc": "4:14-83"
}
],
"usedExports": true,
"providedExports": null,
"optimizationBailout": [],
"depth": 5,
"source": "exports = module.exports = require(\"../../node_modules/css-loader/lib/css-base.js\")(undefined);\n// imports\n\n\n// module\nexports.push([module.id, \".SearchInput {\\n width: 460px;\\n}\\n\\n.SearchInput .material-icons.prefix {\\n top: calc(1.5rem - 12px);\\n color: #9e9e9e;\\n}\\n\\n.SearchInput.input-field input[type=text] {\\n font-size: 20px;\\n font-weight: 300;\\n}\\n\\n.SearchInput.input-field input[type=text]:focus + label {\\n color: #0168AB;\\n}\\n\\n.SearchInput.input-field .prefix.active {\\n color: #0168AB;\\n}\\n\\n.SearchInput.input-field input[type=text]:focus {\\n border-bottom: 1px solid #0168AB;\\n box-shadow: 0 1px 0 0 #0168AB;\\n}\", \"\"]);\n\n// exports\n"
},
{
"id": 61,
"identifier": "/home/x/zzz/github/douglasduteil/RePeople/lib/js/src/components/discover.js",
"name": "./lib/js/src/components/discover.js",
"index": 53,
"index2": 63,
"size": 5872,
"cacheable": true,
"built": true,
"optional": false,
"prefetched": false,
"chunks": [
0
],
"assets": [],
"issuer": "/home/x/zzz/github/douglasduteil/RePeople/lib/js/src/app.js",
"issuerId": 39,
"issuerName": "./lib/js/src/app.js",
"failed": false,
"errors": 0,
"warnings": 0,
"reasons": [
{
"moduleId": 39,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/lib/js/src/app.js",
"module": "./lib/js/src/app.js",
"moduleName": "./lib/js/src/app.js",
"type": "cjs require",
"userRequest": "./components/discover.js",
"loc": "10:18-53"
}
],
"usedExports": true,
"providedExports": null,
"optimizationBailout": [],
"depth": 2,
"source": "// Generated by BUCKLESCRIPT VERSION 1.9.2, PLEASE EDIT WITH CARE\n'use strict';\n\nvar $$Array = require(\"bs-platform/lib/js/array.js\");\nvar Block = require(\"bs-platform/lib/js/block.js\");\nvar Curry = require(\"bs-platform/lib/js/curry.js\");\nvar React = require(\"react\");\nvar Random = require(\"bs-platform/lib/js/random.js\");\nvar Caml_array = require(\"bs-platform/lib/js/caml_array.js\");\nvar PersonCard = require(\"./personCard.js\");\nvar ReasonReact = require(\"reason-react/lib/js/src/reasonReact.js\");\n\nrequire(\"style/discover.css\");\n\nRandom.self_init(/* () */0);\n\nvar component = ReasonReact.statelessComponent(\"Fab\");\n\nfunction make(kind, size, onClick, _) {\n var sizeClass = size ? \" btn-\" + size[0] : \"\";\n var newrecord = component.slice();\n newrecord[/* render */9] = (function () {\n return React.createElement(\"a\", {\n className: \"btn-default btn-floating waves-effect waves-light\" + sizeClass,\n onClick: onClick\n }, React.createElement(\"i\", {\n className: \"material-icons\"\n }, kind));\n });\n return newrecord;\n}\n\nvar Fab = /* module */[\n /* component */component,\n /* make */make\n];\n\nfunction initialState(nbPeople, _) {\n return /* record */[\n /* currentPersonId */Random.$$int(nbPeople) + 1 | 0,\n /* isPlaying : false */0,\n /* intervalId */[/* None */0]\n ];\n}\n\nfunction showNext() {\n return /* ShowNext */0;\n}\n\nfunction showPrev() {\n return /* ShowPrev */1;\n}\n\nfunction play() {\n return /* Play */2;\n}\n\nfunction pause() {\n return /* Pause */3;\n}\n\nfunction succ(max, n) {\n var match = +(n >= max);\n if (match !== 0) {\n return 1;\n } else {\n return n + 1 | 0;\n }\n}\n\nfunction pred(max, n) {\n var match = +(n <= 1);\n if (match !== 0) {\n return max;\n } else {\n return n - 1 | 0;\n }\n}\n\nfunction setNext(nbPeople, state) {\n return /* record */[\n /* currentPersonId */succ(nbPeople, state[/* currentPersonId */0]),\n /* isPlaying */state[/* isPlaying */1],\n /* intervalId */state[/* intervalId */2]\n ];\n}\n\nfunction setPrev(nbPeople, state) {\n return /* record */[\n /* currentPersonId */pred(nbPeople, state[/* currentPersonId */0]),\n /* isPlaying */state[/* isPlaying */1],\n /* intervalId */state[/* intervalId */2]\n ];\n}\n\nfunction setPlaying(isPlaying, state) {\n return /* record */[\n /* currentPersonId */state[/* currentPersonId */0],\n /* isPlaying */isPlaying,\n /* intervalId */state[/* intervalId */2]\n ];\n}\n\nfunction stopInterval(self) {\n var state = self[/* state */4];\n var match = state[/* intervalId */2][0];\n if (match) {\n clearInterval(match[0]);\n state[/* intervalId */2][0] = /* None */0;\n return /* () */0;\n } else {\n return /* () */0;\n }\n}\n\nfunction startInterval(self) {\n stopInterval(self);\n self[/* state */4][/* intervalId */2][0] = /* Some */[setInterval(Curry._1(self[/* reduce */3], showNext), 2000)];\n return /* () */0;\n}\n\nfunction reducer(nbPeople, action, state) {\n switch (action) {\n case 0 : \n return /* Update */Block.__(0, [setNext(nbPeople, state)]);\n case 1 : \n return /* Update */Block.__(0, [setPrev(nbPeople, state)]);\n case 2 : \n return /* UpdateWithSideEffects */Block.__(3, [\n setPlaying(/* true */1, setNext(nbPeople, state)),\n startInterval\n ]);\n case 3 : \n return /* UpdateWithSideEffects */Block.__(3, [\n setPlaying(/* false */0, state),\n stopInterval\n ]);\n \n }\n}\n\nvar component$1 = ReasonReact.reducerComponent(\"Discover\");\n\nfunction make$1(people, _) {\n var aPeople = $$Array.of_list(people);\n var nbPeople = aPeople.length;\n var newrecord = component$1.slice();\n newrecord[/* willUnmount */6] = stopInterval;\n newrecord[/* render */9] = (function (param) {\n var state = param[/* state */4];\n var reduce = param[/* reduce */3];\n var match = state[/* isPlaying */1];\n return React.createElement(\"div\", {\n className: \"Discover\"\n }, React.createElement(\"div\", {\n className: \"card-container\"\n }, ReasonReact.element(/* None */0, /* None */0, PersonCard.make(Caml_array.caml_array_get(aPeople, state[/* currentPersonId */0] - 1 | 0), /* array */[]))), React.createElement(\"div\", {\n className: \"fab-container\"\n }, ReasonReact.element(/* None */0, /* None */0, make(\"skip_previous\", /* None */0, Curry._1(reduce, showPrev), /* array */[])), match !== 0 ? ReasonReact.element(/* None */0, /* None */0, make(\"pause\", /* Some */[\"large\"], Curry._1(reduce, pause), /* array */[])) : ReasonReact.element(/* None */0, /* None */0, make(\"play_arrow\", /* Some */[\"large\"], Curry._1(reduce, play), /* array */[])), ReasonReact.element(/* None */0, /* None */0, make(\"skip_next\", /* None */0, Curry._1(reduce, showNext), /* array */[]))));\n });\n newrecord[/* initialState */10] = (function (param) {\n return initialState(nbPeople, param);\n });\n newrecord[/* reducer */12] = (function (param, param$1) {\n return reducer(nbPeople, param, param$1);\n });\n return newrecord;\n}\n\nexports.Fab = Fab;\nexports.initialState = initialState;\nexports.showNext = showNext;\nexports.showPrev = showPrev;\nexports.play = play;\nexports.pause = pause;\nexports.succ = succ;\nexports.pred = pred;\nexports.setNext = setNext;\nexports.setPrev = setPrev;\nexports.setPlaying = setPlaying;\nexports.stopInterval = stopInterval;\nexports.startInterval = startInterval;\nexports.reducer = reducer;\nexports.component = component$1;\nexports.make = make$1;\n/* Not a pure module */\n"
},
{
"id": 62,
"identifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/bs-platform/lib/js/random.js",
"name": "./node_modules/bs-platform/lib/js/random.js",
"index": 54,
"index2": 60,
"size": 6863,
"cacheable": true,
"built": true,
"optional": false,
"prefetched": false,
"chunks": [
0
],
"assets": [],
"issuer": "/home/x/zzz/github/douglasduteil/RePeople/lib/js/src/components/discover.js",
"issuerId": 61,
"issuerName": "./lib/js/src/components/discover.js",
"failed": false,
"errors": 0,
"warnings": 0,
"reasons": [
{
"moduleId": 61,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/lib/js/src/components/discover.js",
"module": "./lib/js/src/components/discover.js",
"moduleName": "./lib/js/src/components/discover.js",
"type": "cjs require",
"userRequest": "bs-platform/lib/js/random.js",
"loc": "8:18-57"
}
],
"usedExports": true,
"providedExports": null,
"optimizationBailout": [],
"depth": 3,
"source": "'use strict';\n\nvar $$Array = require(\"./array.js\");\nvar Curry = require(\"./curry.js\");\nvar Int32 = require(\"./int32.js\");\nvar Int64 = require(\"./int64.js\");\nvar Digest = require(\"./digest.js\");\nvar Caml_sys = require(\"./caml_sys.js\");\nvar Nativeint = require(\"./nativeint.js\");\nvar Caml_array = require(\"./caml_array.js\");\nvar Caml_int64 = require(\"./caml_int64.js\");\nvar Pervasives = require(\"./pervasives.js\");\nvar Caml_string = require(\"./caml_string.js\");\nvar Caml_builtin_exceptions = require(\"./caml_builtin_exceptions.js\");\n\nfunction assign(st1, st2) {\n $$Array.blit(st2[/* st */0], 0, st1[/* st */0], 0, 55);\n st1[/* idx */1] = st2[/* idx */1];\n return /* () */0;\n}\n\nfunction full_init(s, seed) {\n var combine = function (accu, x) {\n return Digest.string(accu + x);\n };\n var extract = function (d) {\n return ((Caml_string.get(d, 0) + (Caml_string.get(d, 1) << 8) | 0) + (Caml_string.get(d, 2) << 16) | 0) + (Caml_string.get(d, 3) << 24) | 0;\n };\n var seed$1 = seed.length ? seed : /* int array */[0];\n var l = seed$1.length;\n for(var i = 0; i <= 54; ++i){\n Caml_array.caml_array_set(s[/* st */0], i, i);\n }\n var accu = \"x\";\n for(var i$1 = 0 ,i_finish = 54 + Pervasives.max(55, l) | 0; i$1 <= i_finish; ++i$1){\n var j = i$1 % 55;\n var k = i$1 % l;\n accu = combine(accu, Caml_array.caml_array_get(seed$1, k));\n Caml_array.caml_array_set(s[/* st */0], j, (Caml_array.caml_array_get(s[/* st */0], j) ^ extract(accu)) & 1073741823);\n }\n s[/* idx */1] = 0;\n return /* () */0;\n}\n\nfunction make(seed) {\n var result = /* record */[\n /* st */Caml_array.caml_make_vect(55, 0),\n /* idx */0\n ];\n full_init(result, seed);\n return result;\n}\n\nfunction make_self_init() {\n return make(Caml_sys.caml_sys_random_seed(/* () */0));\n}\n\nfunction copy(s) {\n var result = /* record */[\n /* st */Caml_array.caml_make_vect(55, 0),\n /* idx */0\n ];\n assign(result, s);\n return result;\n}\n\nfunction bits(s) {\n s[/* idx */1] = (s[/* idx */1] + 1 | 0) % 55;\n var curval = Caml_array.caml_array_get(s[/* st */0], s[/* idx */1]);\n var newval = Caml_array.caml_array_get(s[/* st */0], (s[/* idx */1] + 24 | 0) % 55) + (curval ^ (curval >>> 25) & 31) | 0;\n var newval30 = newval & 1073741823;\n Caml_array.caml_array_set(s[/* st */0], s[/* idx */1], newval30);\n return newval30;\n}\n\nfunction $$int(s, bound) {\n if (bound > 1073741823 || bound <= 0) {\n throw [\n Caml_builtin_exceptions.invalid_argument,\n \"Random.int\"\n ];\n } else {\n var s$1 = s;\n var n = bound;\n while(true) {\n var r = bits(s$1);\n var v = r % n;\n if ((r - v | 0) > ((1073741823 - n | 0) + 1 | 0)) {\n continue ;\n \n } else {\n return v;\n }\n };\n }\n}\n\nfunction int32(s, bound) {\n if (bound <= 0) {\n throw [\n Caml_builtin_exceptions.invalid_argument,\n \"Random.int32\"\n ];\n } else {\n var s$1 = s;\n var n = bound;\n while(true) {\n var b1 = bits(s$1);\n var b2 = ((bits(s$1) & 1) << 30);\n var r = b1 | b2;\n var v = r % n;\n if ((r - v | 0) > ((Int32.max_int - n | 0) + 1 | 0)) {\n continue ;\n \n } else {\n return v;\n }\n };\n }\n}\n\nfunction int64(s, bound) {\n if (Caml_int64.le(bound, /* int64 */[\n /* hi */0,\n /* lo */0\n ])) {\n throw [\n Caml_builtin_exceptions.invalid_argument,\n \"Random.int64\"\n ];\n } else {\n var s$1 = s;\n var n = bound;\n while(true) {\n var b1 = Caml_int64.of_int32(bits(s$1));\n var b2 = Caml_int64.lsl_(Caml_int64.of_int32(bits(s$1)), 30);\n var b3 = Caml_int64.lsl_(Caml_int64.of_int32(bits(s$1) & 7), 60);\n var r = Caml_int64.or_(b1, /* int64 */[\n /* hi */b2[0] | b3[0],\n /* lo */((b2[1] | b3[1]) >>> 0)\n ]);\n var v = Caml_int64.mod_(r, n);\n if (Caml_int64.gt(Caml_int64.sub(r, v), Caml_int64.add(Caml_int64.sub(Int64.max_int, n), /* int64 */[\n /* hi */0,\n /* lo */1\n ]))) {\n continue ;\n \n } else {\n return v;\n }\n };\n }\n}\n\nvar nativeint = Nativeint.size === 32 ? int32 : (function (s, bound) {\n return int64(s, Caml_int64.of_int32(bound))[1] | 0;\n });\n\nfunction rawfloat(s) {\n var r1 = bits(s);\n var r2 = bits(s);\n return (r1 / 1073741824.0 + r2) / 1073741824.0;\n}\n\nfunction $$float(s, bound) {\n return rawfloat(s) * bound;\n}\n\nfunction bool(s) {\n return +((bits(s) & 1) === 0);\n}\n\nvar $$default = /* record */[\n /* st : array */[\n 987910699,\n 495797812,\n 364182224,\n 414272206,\n 318284740,\n 990407751,\n 383018966,\n 270373319,\n 840823159,\n 24560019,\n 536292337,\n 512266505,\n 189156120,\n 730249596,\n 143776328,\n 51606627,\n 140166561,\n 366354223,\n 1003410265,\n 700563762,\n 981890670,\n 913149062,\n 526082594,\n 1021425055,\n 784300257,\n 667753350,\n 630144451,\n 949649812,\n 48546892,\n 415514493,\n 258888527,\n 511570777,\n 89983870,\n 283659902,\n 308386020,\n 242688715,\n 482270760,\n 865188196,\n 1027664170,\n 207196989,\n 193777847,\n 619708188,\n 671350186,\n 149669678,\n 257044018,\n 87658204,\n 558145612,\n 183450813,\n 28133145,\n 901332182,\n 710253903,\n 510646120,\n 652377910,\n 409934019,\n 801085050\n ],\n /* idx */0\n];\n\nfunction bits$1() {\n return bits($$default);\n}\n\nfunction $$int$1(bound) {\n return $$int($$default, bound);\n}\n\nfunction int32$1(bound) {\n return int32($$default, bound);\n}\n\nfunction nativeint$1(bound) {\n return Curry._2(nativeint, $$default, bound);\n}\n\nfunction int64$1(bound) {\n return int64($$default, bound);\n}\n\nfunction $$float$1(scale) {\n return rawfloat($$default) * scale;\n}\n\nfunction bool$1() {\n return bool($$default);\n}\n\nfunction full_init$1(seed) {\n return full_init($$default, seed);\n}\n\nfunction init(seed) {\n return full_init($$default, /* int array */[seed]);\n}\n\nfunction self_init() {\n return full_init$1(Caml_sys.caml_sys_random_seed(/* () */0));\n}\n\nfunction get_state() {\n return copy($$default);\n}\n\nfunction set_state(s) {\n return assign($$default, s);\n}\n\nvar State = [\n make,\n make_self_init,\n copy,\n bits,\n $$int,\n int32,\n nativeint,\n int64,\n $$float,\n bool\n];\n\nexports.init = init;\nexports.full_init = full_init$1;\nexports.self_init = self_init;\nexports.bits = bits$1;\nexports.$$int = $$int$1;\nexports.int32 = int32$1;\nexports.nativeint = nativeint$1;\nexports.int64 = int64$1;\nexports.$$float = $$float$1;\nexports.bool = bool$1;\nexports.State = State;\nexports.get_state = get_state;\nexports.set_state = set_state;\n/* No side effect */\n"
},
{
"id": 63,
"identifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/bs-platform/lib/js/int32.js",
"name": "./node_modules/bs-platform/lib/js/int32.js",
"index": 55,
"index2": 51,
"size": 868,
"cacheable": true,
"built": true,
"optional": false,
"prefetched": false,
"chunks": [
0
],
"assets": [],
"issuer": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/bs-platform/lib/js/random.js",
"issuerId": 62,
"issuerName": "./node_modules/bs-platform/lib/js/random.js",
"failed": false,
"errors": 0,
"warnings": 0,
"reasons": [
{
"moduleId": 62,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/bs-platform/lib/js/random.js",
"module": "./node_modules/bs-platform/lib/js/random.js",
"moduleName": "./node_modules/bs-platform/lib/js/random.js",
"type": "cjs require",
"userRequest": "./int32.js",
"loc": "5:30-51"
}
],
"usedExports": true,
"providedExports": null,
"optimizationBailout": [],
"depth": 4,
"source": "'use strict';\n\nvar Caml_obj = require(\"./caml_obj.js\");\nvar Caml_format = require(\"./caml_format.js\");\n\nfunction succ(n) {\n return n + 1 | 0;\n}\n\nfunction pred(n) {\n return n - 1 | 0;\n}\n\nfunction abs(n) {\n if (n >= 0) {\n return n;\n } else {\n return -n | 0;\n }\n}\n\nfunction lognot(n) {\n return n ^ -1;\n}\n\nfunction to_string(n) {\n return Caml_format.caml_int32_format(\"%d\", n);\n}\n\nvar compare = Caml_obj.caml_int32_compare;\n\nvar zero = 0;\n\nvar one = 1;\n\nvar minus_one = -1;\n\nvar max_int = 2147483647;\n\nvar min_int = -2147483648;\n\nexports.zero = zero;\nexports.one = one;\nexports.minus_one = minus_one;\nexports.succ = succ;\nexports.pred = pred;\nexports.abs = abs;\nexports.max_int = max_int;\nexports.min_int = min_int;\nexports.lognot = lognot;\nexports.to_string = to_string;\nexports.compare = compare;\n/* No side effect */\n"
},
{
"id": 64,
"identifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/bs-platform/lib/js/int64.js",
"name": "./node_modules/bs-platform/lib/js/int64.js",
"index": 56,
"index2": 52,
"size": 1423,
"cacheable": true,
"built": true,
"optional": false,
"prefetched": false,
"chunks": [
0
],
"assets": [],
"issuer": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/bs-platform/lib/js/random.js",
"issuerId": 62,
"issuerName": "./node_modules/bs-platform/lib/js/random.js",
"failed": false,
"errors": 0,
"warnings": 0,
"reasons": [
{
"moduleId": 62,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/bs-platform/lib/js/random.js",
"module": "./node_modules/bs-platform/lib/js/random.js",
"moduleName": "./node_modules/bs-platform/lib/js/random.js",
"type": "cjs require",
"userRequest": "./int64.js",
"loc": "6:30-51"
}
],
"usedExports": true,
"providedExports": null,
"optimizationBailout": [],
"depth": 4,
"source": "'use strict';\n\nvar Caml_int64 = require(\"./caml_int64.js\");\nvar Caml_format = require(\"./caml_format.js\");\n\nfunction succ(n) {\n return Caml_int64.add(n, /* int64 */[\n /* hi */0,\n /* lo */1\n ]);\n}\n\nfunction pred(n) {\n return Caml_int64.sub(n, /* int64 */[\n /* hi */0,\n /* lo */1\n ]);\n}\n\nfunction abs(n) {\n if (Caml_int64.ge(n, /* int64 */[\n /* hi */0,\n /* lo */0\n ])) {\n return n;\n } else {\n return Caml_int64.neg(n);\n }\n}\n\nfunction lognot(n) {\n return Caml_int64.xor(n, /* int64 */[\n /* hi */-1,\n /* lo */4294967295\n ]);\n}\n\nfunction to_string(n) {\n return Caml_format.caml_int64_format(\"%d\", n);\n}\n\nvar compare = Caml_int64.compare;\n\nvar zero = /* int64 */[\n /* hi */0,\n /* lo */0\n];\n\nvar one = /* int64 */[\n /* hi */0,\n /* lo */1\n];\n\nvar minus_one = /* int64 */[\n /* hi */-1,\n /* lo */4294967295\n];\n\nvar max_int = /* int64 */[\n /* hi */2147483647,\n /* lo */4294967295\n];\n\nvar min_int = /* int64 */[\n /* hi */-2147483648,\n /* lo */0\n];\n\nexports.zero = zero;\nexports.one = one;\nexports.minus_one = minus_one;\nexports.succ = succ;\nexports.pred = pred;\nexports.abs = abs;\nexports.max_int = max_int;\nexports.min_int = min_int;\nexports.lognot = lognot;\nexports.to_string = to_string;\nexports.compare = compare;\n/* No side effect */\n"
},
{
"id": 65,
"identifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/bs-platform/lib/js/digest.js",
"name": "./node_modules/bs-platform/lib/js/digest.js",
"index": 57,
"index2": 57,
"size": 3425,
"cacheable": true,
"built": true,
"optional": false,
"prefetched": false,
"chunks": [
0
],
"assets": [],
"issuer": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/bs-platform/lib/js/random.js",
"issuerId": 62,
"issuerName": "./node_modules/bs-platform/lib/js/random.js",
"failed": false,
"errors": 0,
"warnings": 0,
"reasons": [
{
"moduleId": 62,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/bs-platform/lib/js/random.js",
"module": "./node_modules/bs-platform/lib/js/random.js",
"moduleName": "./node_modules/bs-platform/lib/js/random.js",
"type": "cjs require",
"userRequest": "./digest.js",
"loc": "7:30-52"
}
],
"usedExports": true,
"providedExports": null,
"optimizationBailout": [],
"depth": 4,
"source": "'use strict';\n\nvar Char = require(\"./char.js\");\nvar $$String = require(\"./string.js\");\nvar Caml_md5 = require(\"./caml_md5.js\");\nvar Pervasives = require(\"./pervasives.js\");\nvar Caml_string = require(\"./caml_string.js\");\nvar Caml_missing_polyfill = require(\"./caml_missing_polyfill.js\");\nvar Caml_builtin_exceptions = require(\"./caml_builtin_exceptions.js\");\n\nfunction string(str) {\n return Caml_md5.caml_md5_string(str, 0, str.length);\n}\n\nfunction bytes(b) {\n return string(Caml_string.bytes_to_string(b));\n}\n\nfunction substring(str, ofs, len) {\n if (ofs < 0 || len < 0 || ofs > (str.length - len | 0)) {\n throw [\n Caml_builtin_exceptions.invalid_argument,\n \"Digest.substring\"\n ];\n } else {\n return Caml_md5.caml_md5_string(str, ofs, len);\n }\n}\n\nfunction subbytes(b, ofs, len) {\n return substring(Caml_string.bytes_to_string(b), ofs, len);\n}\n\nfunction file(filename) {\n Pervasives.open_in_bin(filename);\n var exit = 0;\n var d;\n try {\n d = Caml_missing_polyfill.not_implemented(\"caml_md5_chan not implemented by bucklescript yet\\n\");\n exit = 1;\n }\n catch (e){\n Caml_missing_polyfill.not_implemented(\"caml_ml_close_channel not implemented by bucklescript yet\\n\");\n throw e;\n }\n if (exit === 1) {\n Caml_missing_polyfill.not_implemented(\"caml_ml_close_channel not implemented by bucklescript yet\\n\");\n return d;\n }\n \n}\n\nvar output = Pervasives.output_string;\n\nfunction input(chan) {\n return Pervasives.really_input_string(chan, 16);\n}\n\nfunction char_hex(n) {\n return n + (\n n < 10 ? /* \"0\" */48 : 87\n ) | 0;\n}\n\nfunction to_hex(d) {\n var result = new Array(32);\n for(var i = 0; i <= 15; ++i){\n var x = Caml_string.get(d, i);\n result[(i << 1)] = char_hex((x >>> 4));\n result[(i << 1) + 1 | 0] = char_hex(x & 15);\n }\n return Caml_string.bytes_to_string(result);\n}\n\nfunction from_hex(s) {\n if (s.length !== 32) {\n throw [\n Caml_builtin_exceptions.invalid_argument,\n \"Digest.from_hex\"\n ];\n }\n var digit = function (c) {\n if (c >= 65) {\n if (c >= 97) {\n if (c >= 103) {\n throw [\n Caml_builtin_exceptions.invalid_argument,\n \"Digest.from_hex\"\n ];\n } else {\n return (c - /* \"a\" */97 | 0) + 10 | 0;\n }\n } else if (c >= 71) {\n throw [\n Caml_builtin_exceptions.invalid_argument,\n \"Digest.from_hex\"\n ];\n } else {\n return (c - /* \"A\" */65 | 0) + 10 | 0;\n }\n } else if (c > 57 || c < 48) {\n throw [\n Caml_builtin_exceptions.invalid_argument,\n \"Digest.from_hex\"\n ];\n } else {\n return c - /* \"0\" */48 | 0;\n }\n };\n var $$byte = function (i) {\n return (digit(Caml_string.get(s, i)) << 4) + digit(Caml_string.get(s, i + 1 | 0)) | 0;\n };\n var result = new Array(16);\n for(var i = 0; i <= 15; ++i){\n result[i] = Char.chr($$byte((i << 1)));\n }\n return Caml_string.bytes_to_string(result);\n}\n\nvar compare = $$String.compare;\n\nexports.compare = compare;\nexports.string = string;\nexports.bytes = bytes;\nexports.substring = substring;\nexports.subbytes = subbytes;\nexports.file = file;\nexports.output = output;\nexports.input = input;\nexports.to_hex = to_hex;\nexports.from_hex = from_hex;\n/* No side effect */\n"
},
{
"id": 66,
"identifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/bs-platform/lib/js/string.js",
"name": "./node_modules/bs-platform/lib/js/string.js",
"index": 59,
"index2": 55,
"size": 5307,
"cacheable": true,
"built": true,
"optional": false,
"prefetched": false,
"chunks": [
0
],
"assets": [],
"issuer": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/bs-platform/lib/js/digest.js",
"issuerId": 65,
"issuerName": "./node_modules/bs-platform/lib/js/digest.js",
"failed": false,
"errors": 0,
"warnings": 0,
"reasons": [
{
"moduleId": 65,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/bs-platform/lib/js/digest.js",
"module": "./node_modules/bs-platform/lib/js/digest.js",
"moduleName": "./node_modules/bs-platform/lib/js/digest.js",
"type": "cjs require",
"userRequest": "./string.js",
"loc": "4:30-52"
}
],
"usedExports": true,
"providedExports": null,
"optimizationBailout": [],
"depth": 5,
"source": "'use strict';\n\nvar List = require(\"./list.js\");\nvar Bytes = require(\"./bytes.js\");\nvar Caml_int32 = require(\"./caml_int32.js\");\nvar Caml_string = require(\"./caml_string.js\");\n\nfunction make(n, c) {\n return Caml_string.bytes_to_string(Bytes.make(n, c));\n}\n\nfunction init(n, f) {\n return Caml_string.bytes_to_string(Bytes.init(n, f));\n}\n\nfunction copy(s) {\n return Caml_string.bytes_to_string(Bytes.copy(Caml_string.bytes_of_string(s)));\n}\n\nfunction sub(s, ofs, len) {\n return Caml_string.bytes_to_string(Bytes.sub(Caml_string.bytes_of_string(s), ofs, len));\n}\n\nfunction concat(sep, l) {\n if (l) {\n var hd = l[0];\n var num = [0];\n var len = [0];\n List.iter((function (s) {\n num[0] = num[0] + 1 | 0;\n len[0] = len[0] + s.length | 0;\n return /* () */0;\n }), l);\n var r = Caml_string.caml_create_string(len[0] + Caml_int32.imul(sep.length, num[0] - 1 | 0) | 0);\n Caml_string.caml_blit_string(hd, 0, r, 0, hd.length);\n var pos = [hd.length];\n List.iter((function (s) {\n Caml_string.caml_blit_string(sep, 0, r, pos[0], sep.length);\n pos[0] = pos[0] + sep.length | 0;\n Caml_string.caml_blit_string(s, 0, r, pos[0], s.length);\n pos[0] = pos[0] + s.length | 0;\n return /* () */0;\n }), l[1]);\n return Caml_string.bytes_to_string(r);\n } else {\n return \"\";\n }\n}\n\nfunction iter(f, s) {\n return Bytes.iter(f, Caml_string.bytes_of_string(s));\n}\n\nfunction iteri(f, s) {\n return Bytes.iteri(f, Caml_string.bytes_of_string(s));\n}\n\nfunction map(f, s) {\n return Caml_string.bytes_to_string(Bytes.map(f, Caml_string.bytes_of_string(s)));\n}\n\nfunction mapi(f, s) {\n return Caml_string.bytes_to_string(Bytes.mapi(f, Caml_string.bytes_of_string(s)));\n}\n\nfunction is_space(param) {\n var switcher = param - 9 | 0;\n if (switcher > 4 || switcher < 0) {\n if (switcher !== 23) {\n return /* false */0;\n } else {\n return /* true */1;\n }\n } else if (switcher !== 2) {\n return /* true */1;\n } else {\n return /* false */0;\n }\n}\n\nfunction trim(s) {\n if (s === \"\" || !(is_space(s.charCodeAt(0)) || is_space(s.charCodeAt(s.length - 1 | 0)))) {\n return s;\n } else {\n return Caml_string.bytes_to_string(Bytes.trim(Caml_string.bytes_of_string(s)));\n }\n}\n\nfunction escaped(s) {\n var needs_escape = function (_i) {\n while(true) {\n var i = _i;\n if (i >= s.length) {\n return /* false */0;\n } else {\n var match = s.charCodeAt(i);\n if (match >= 32) {\n var switcher = match - 34 | 0;\n if (switcher > 58 || switcher < 0) {\n if (switcher >= 93) {\n return /* true */1;\n } else {\n _i = i + 1 | 0;\n continue ;\n \n }\n } else if (switcher > 57 || switcher < 1) {\n return /* true */1;\n } else {\n _i = i + 1 | 0;\n continue ;\n \n }\n } else {\n return /* true */1;\n }\n }\n };\n };\n if (needs_escape(0)) {\n return Caml_string.bytes_to_string(Bytes.escaped(Caml_string.bytes_of_string(s)));\n } else {\n return s;\n }\n}\n\nfunction index(s, c) {\n return Bytes.index(Caml_string.bytes_of_string(s), c);\n}\n\nfunction rindex(s, c) {\n return Bytes.rindex(Caml_string.bytes_of_string(s), c);\n}\n\nfunction index_from(s, i, c) {\n return Bytes.index_from(Caml_string.bytes_of_string(s), i, c);\n}\n\nfunction rindex_from(s, i, c) {\n return Bytes.rindex_from(Caml_string.bytes_of_string(s), i, c);\n}\n\nfunction contains(s, c) {\n return Bytes.contains(Caml_string.bytes_of_string(s), c);\n}\n\nfunction contains_from(s, i, c) {\n return Bytes.contains_from(Caml_string.bytes_of_string(s), i, c);\n}\n\nfunction rcontains_from(s, i, c) {\n return Bytes.rcontains_from(Caml_string.bytes_of_string(s), i, c);\n}\n\nfunction uppercase(s) {\n return Caml_string.bytes_to_string(Bytes.uppercase(Caml_string.bytes_of_string(s)));\n}\n\nfunction lowercase(s) {\n return Caml_string.bytes_to_string(Bytes.lowercase(Caml_string.bytes_of_string(s)));\n}\n\nfunction capitalize(s) {\n return Caml_string.bytes_to_string(Bytes.capitalize(Caml_string.bytes_of_string(s)));\n}\n\nfunction uncapitalize(s) {\n return Caml_string.bytes_to_string(Bytes.uncapitalize(Caml_string.bytes_of_string(s)));\n}\n\nvar compare = Caml_string.caml_string_compare;\n\nvar fill = Bytes.fill;\n\nvar blit = Bytes.blit_string;\n\nexports.make = make;\nexports.init = init;\nexports.copy = copy;\nexports.sub = sub;\nexports.fill = fill;\nexports.blit = blit;\nexports.concat = concat;\nexports.iter = iter;\nexports.iteri = iteri;\nexports.map = map;\nexports.mapi = mapi;\nexports.trim = trim;\nexports.escaped = escaped;\nexports.index = index;\nexports.rindex = rindex;\nexports.index_from = index_from;\nexports.rindex_from = rindex_from;\nexports.contains = contains;\nexports.contains_from = contains_from;\nexports.rcontains_from = rcontains_from;\nexports.uppercase = uppercase;\nexports.lowercase = lowercase;\nexports.capitalize = capitalize;\nexports.uncapitalize = uncapitalize;\nexports.compare = compare;\n/* No side effect */\n"
},
{
"id": 67,
"identifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/bs-platform/lib/js/bytes.js",
"name": "./node_modules/bs-platform/lib/js/bytes.js",
"index": 60,
"index2": 54,
"size": 11572,
"cacheable": true,
"built": true,
"optional": false,
"prefetched": false,
"chunks": [
0
],
"assets": [],
"issuer": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/bs-platform/lib/js/string.js",
"issuerId": 66,
"issuerName": "./node_modules/bs-platform/lib/js/string.js",
"failed": false,
"errors": 0,
"warnings": 0,
"reasons": [
{
"moduleId": 66,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/bs-platform/lib/js/string.js",
"module": "./node_modules/bs-platform/lib/js/string.js",
"moduleName": "./node_modules/bs-platform/lib/js/string.js",
"type": "cjs require",
"userRequest": "./bytes.js",
"loc": "4:18-39"
}
],
"usedExports": true,
"providedExports": null,
"optimizationBailout": [],
"depth": 6,
"source": "'use strict';\n\nvar Char = require(\"./char.js\");\nvar List = require(\"./list.js\");\nvar Curry = require(\"./curry.js\");\nvar Caml_obj = require(\"./caml_obj.js\");\nvar Caml_int32 = require(\"./caml_int32.js\");\nvar Pervasives = require(\"./pervasives.js\");\nvar Caml_string = require(\"./caml_string.js\");\nvar Caml_builtin_exceptions = require(\"./caml_builtin_exceptions.js\");\n\nfunction make(n, c) {\n var s = Caml_string.caml_create_string(n);\n Caml_string.caml_fill_string(s, 0, n, c);\n return s;\n}\n\nfunction init(n, f) {\n var s = Caml_string.caml_create_string(n);\n for(var i = 0 ,i_finish = n - 1 | 0; i <= i_finish; ++i){\n s[i] = Curry._1(f, i);\n }\n return s;\n}\n\nvar empty = [];\n\nfunction copy(s) {\n var len = s.length;\n var r = Caml_string.caml_create_string(len);\n Caml_string.caml_blit_bytes(s, 0, r, 0, len);\n return r;\n}\n\nfunction to_string(b) {\n return Caml_string.bytes_to_string(copy(b));\n}\n\nfunction of_string(s) {\n return copy(Caml_string.bytes_of_string(s));\n}\n\nfunction sub(s, ofs, len) {\n if (ofs < 0 || len < 0 || ofs > (s.length - len | 0)) {\n throw [\n Caml_builtin_exceptions.invalid_argument,\n \"String.sub / Bytes.sub\"\n ];\n } else {\n var r = Caml_string.caml_create_string(len);\n Caml_string.caml_blit_bytes(s, ofs, r, 0, len);\n return r;\n }\n}\n\nfunction sub_string(b, ofs, len) {\n return Caml_string.bytes_to_string(sub(b, ofs, len));\n}\n\nfunction extend(s, left, right) {\n var len = (s.length + left | 0) + right | 0;\n var r = Caml_string.caml_create_string(len);\n var match = left < 0 ? /* tuple */[\n -left | 0,\n 0\n ] : /* tuple */[\n 0,\n left\n ];\n var dstoff = match[1];\n var srcoff = match[0];\n var cpylen = Pervasives.min(s.length - srcoff | 0, len - dstoff | 0);\n if (cpylen > 0) {\n Caml_string.caml_blit_bytes(s, srcoff, r, dstoff, cpylen);\n }\n return r;\n}\n\nfunction fill(s, ofs, len, c) {\n if (ofs < 0 || len < 0 || ofs > (s.length - len | 0)) {\n throw [\n Caml_builtin_exceptions.invalid_argument,\n \"String.fill / Bytes.fill\"\n ];\n } else {\n return Caml_string.caml_fill_string(s, ofs, len, c);\n }\n}\n\nfunction blit(s1, ofs1, s2, ofs2, len) {\n if (len < 0 || ofs1 < 0 || ofs1 > (s1.length - len | 0) || ofs2 < 0 || ofs2 > (s2.length - len | 0)) {\n throw [\n Caml_builtin_exceptions.invalid_argument,\n \"Bytes.blit\"\n ];\n } else {\n return Caml_string.caml_blit_bytes(s1, ofs1, s2, ofs2, len);\n }\n}\n\nfunction blit_string(s1, ofs1, s2, ofs2, len) {\n if (len < 0 || ofs1 < 0 || ofs1 > (s1.length - len | 0) || ofs2 < 0 || ofs2 > (s2.length - len | 0)) {\n throw [\n Caml_builtin_exceptions.invalid_argument,\n \"String.blit / Bytes.blit_string\"\n ];\n } else {\n return Caml_string.caml_blit_string(s1, ofs1, s2, ofs2, len);\n }\n}\n\nfunction iter(f, a) {\n for(var i = 0 ,i_finish = a.length - 1 | 0; i <= i_finish; ++i){\n Curry._1(f, a[i]);\n }\n return /* () */0;\n}\n\nfunction iteri(f, a) {\n for(var i = 0 ,i_finish = a.length - 1 | 0; i <= i_finish; ++i){\n Curry._2(f, i, a[i]);\n }\n return /* () */0;\n}\n\nfunction concat(sep, l) {\n if (l) {\n var hd = l[0];\n var num = [0];\n var len = [0];\n List.iter((function (s) {\n num[0] = num[0] + 1 | 0;\n len[0] = len[0] + s.length | 0;\n return /* () */0;\n }), l);\n var r = Caml_string.caml_create_string(len[0] + Caml_int32.imul(sep.length, num[0] - 1 | 0) | 0);\n Caml_string.caml_blit_bytes(hd, 0, r, 0, hd.length);\n var pos = [hd.length];\n List.iter((function (s) {\n Caml_string.caml_blit_bytes(sep, 0, r, pos[0], sep.length);\n pos[0] = pos[0] + sep.length | 0;\n Caml_string.caml_blit_bytes(s, 0, r, pos[0], s.length);\n pos[0] = pos[0] + s.length | 0;\n return /* () */0;\n }), l[1]);\n return r;\n } else {\n return empty;\n }\n}\n\nfunction cat(a, b) {\n return a.concat(b);\n}\n\nfunction is_space(param) {\n var switcher = param - 9 | 0;\n if (switcher > 4 || switcher < 0) {\n if (switcher !== 23) {\n return /* false */0;\n } else {\n return /* true */1;\n }\n } else if (switcher !== 2) {\n return /* true */1;\n } else {\n return /* false */0;\n }\n}\n\nfunction trim(s) {\n var len = s.length;\n var i = 0;\n while(i < len && is_space(s[i])) {\n i = i + 1 | 0;\n };\n var j = len - 1 | 0;\n while(j >= i && is_space(s[j])) {\n j = j - 1 | 0;\n };\n if (j >= i) {\n return sub(s, i, (j - i | 0) + 1 | 0);\n } else {\n return empty;\n }\n}\n\nfunction escaped(s) {\n var n = 0;\n for(var i = 0 ,i_finish = s.length - 1 | 0; i <= i_finish; ++i){\n var match = s[i];\n var tmp;\n if (match >= 32) {\n var switcher = match - 34 | 0;\n tmp = switcher > 58 || switcher < 0 ? (\n switcher >= 93 ? 4 : 1\n ) : (\n switcher > 57 || switcher < 1 ? 2 : 1\n );\n } else {\n tmp = match >= 11 ? (\n match !== 13 ? 4 : 2\n ) : (\n match >= 8 ? 2 : 4\n );\n }\n n = n + tmp | 0;\n }\n if (n === s.length) {\n return copy(s);\n } else {\n var s$prime = Caml_string.caml_create_string(n);\n n = 0;\n for(var i$1 = 0 ,i_finish$1 = s.length - 1 | 0; i$1 <= i_finish$1; ++i$1){\n var c = s[i$1];\n var exit = 0;\n if (c >= 35) {\n if (c !== 92) {\n if (c >= 127) {\n exit = 1;\n } else {\n s$prime[n] = c;\n }\n } else {\n exit = 2;\n }\n } else if (c >= 32) {\n if (c >= 34) {\n exit = 2;\n } else {\n s$prime[n] = c;\n }\n } else if (c >= 14) {\n exit = 1;\n } else {\n switch (c) {\n case 8 : \n s$prime[n] = /* \"\\\\\" */92;\n n = n + 1 | 0;\n s$prime[n] = /* \"b\" */98;\n break;\n case 9 : \n s$prime[n] = /* \"\\\\\" */92;\n n = n + 1 | 0;\n s$prime[n] = /* \"t\" */116;\n break;\n case 10 : \n s$prime[n] = /* \"\\\\\" */92;\n n = n + 1 | 0;\n s$prime[n] = /* \"n\" */110;\n break;\n case 0 : \n case 1 : \n case 2 : \n case 3 : \n case 4 : \n case 5 : \n case 6 : \n case 7 : \n case 11 : \n case 12 : \n exit = 1;\n break;\n case 13 : \n s$prime[n] = /* \"\\\\\" */92;\n n = n + 1 | 0;\n s$prime[n] = /* \"r\" */114;\n break;\n \n }\n }\n switch (exit) {\n case 1 : \n s$prime[n] = /* \"\\\\\" */92;\n n = n + 1 | 0;\n s$prime[n] = 48 + (c / 100 | 0) | 0;\n n = n + 1 | 0;\n s$prime[n] = 48 + (c / 10 | 0) % 10 | 0;\n n = n + 1 | 0;\n s$prime[n] = 48 + c % 10 | 0;\n break;\n case 2 : \n s$prime[n] = /* \"\\\\\" */92;\n n = n + 1 | 0;\n s$prime[n] = c;\n break;\n \n }\n n = n + 1 | 0;\n }\n return s$prime;\n }\n}\n\nfunction map(f, s) {\n var l = s.length;\n if (l) {\n var r = Caml_string.caml_create_string(l);\n for(var i = 0 ,i_finish = l - 1 | 0; i <= i_finish; ++i){\n r[i] = Curry._1(f, s[i]);\n }\n return r;\n } else {\n return s;\n }\n}\n\nfunction mapi(f, s) {\n var l = s.length;\n if (l) {\n var r = Caml_string.caml_create_string(l);\n for(var i = 0 ,i_finish = l - 1 | 0; i <= i_finish; ++i){\n r[i] = Curry._2(f, i, s[i]);\n }\n return r;\n } else {\n return s;\n }\n}\n\nfunction uppercase(s) {\n return map(Char.uppercase, s);\n}\n\nfunction lowercase(s) {\n return map(Char.lowercase, s);\n}\n\nfunction apply1(f, s) {\n if (s.length) {\n var r = copy(s);\n r[0] = Curry._1(f, s[0]);\n return r;\n } else {\n return s;\n }\n}\n\nfunction capitalize(s) {\n return apply1(Char.uppercase, s);\n}\n\nfunction uncapitalize(s) {\n return apply1(Char.lowercase, s);\n}\n\nfunction index_rec(s, lim, _i, c) {\n while(true) {\n var i = _i;\n if (i >= lim) {\n throw Caml_builtin_exceptions.not_found;\n } else if (s[i] === c) {\n return i;\n } else {\n _i = i + 1 | 0;\n continue ;\n \n }\n };\n}\n\nfunction index(s, c) {\n return index_rec(s, s.length, 0, c);\n}\n\nfunction index_from(s, i, c) {\n var l = s.length;\n if (i < 0 || i > l) {\n throw [\n Caml_builtin_exceptions.invalid_argument,\n \"String.index_from / Bytes.index_from\"\n ];\n } else {\n return index_rec(s, l, i, c);\n }\n}\n\nfunction rindex_rec(s, _i, c) {\n while(true) {\n var i = _i;\n if (i < 0) {\n throw Caml_builtin_exceptions.not_found;\n } else if (s[i] === c) {\n return i;\n } else {\n _i = i - 1 | 0;\n continue ;\n \n }\n };\n}\n\nfunction rindex(s, c) {\n return rindex_rec(s, s.length - 1 | 0, c);\n}\n\nfunction rindex_from(s, i, c) {\n if (i < -1 || i >= s.length) {\n throw [\n Caml_builtin_exceptions.invalid_argument,\n \"String.rindex_from / Bytes.rindex_from\"\n ];\n } else {\n return rindex_rec(s, i, c);\n }\n}\n\nfunction contains_from(s, i, c) {\n var l = s.length;\n if (i < 0 || i > l) {\n throw [\n Caml_builtin_exceptions.invalid_argument,\n \"String.contains_from / Bytes.contains_from\"\n ];\n } else {\n try {\n index_rec(s, l, i, c);\n return /* true */1;\n }\n catch (exn){\n if (exn === Caml_builtin_exceptions.not_found) {\n return /* false */0;\n } else {\n throw exn;\n }\n }\n }\n}\n\nfunction contains(s, c) {\n return contains_from(s, 0, c);\n}\n\nfunction rcontains_from(s, i, c) {\n if (i < 0 || i >= s.length) {\n throw [\n Caml_builtin_exceptions.invalid_argument,\n \"String.rcontains_from / Bytes.rcontains_from\"\n ];\n } else {\n try {\n rindex_rec(s, i, c);\n return /* true */1;\n }\n catch (exn){\n if (exn === Caml_builtin_exceptions.not_found) {\n return /* false */0;\n } else {\n throw exn;\n }\n }\n }\n}\n\nvar compare = Caml_obj.caml_compare;\n\nvar unsafe_to_string = Caml_string.bytes_to_string;\n\nvar unsafe_of_string = Caml_string.bytes_of_string;\n\nexports.make = make;\nexports.init = init;\nexports.empty = empty;\nexports.copy = copy;\nexports.of_string = of_string;\nexports.to_string = to_string;\nexports.sub = sub;\nexports.sub_string = sub_string;\nexports.extend = extend;\nexports.fill = fill;\nexports.blit = blit;\nexports.blit_string = blit_string;\nexports.concat = concat;\nexports.cat = cat;\nexports.iter = iter;\nexports.iteri = iteri;\nexports.map = map;\nexports.mapi = mapi;\nexports.trim = trim;\nexports.escaped = escaped;\nexports.index = index;\nexports.rindex = rindex;\nexports.index_from = index_from;\nexports.rindex_from = rindex_from;\nexports.contains = contains;\nexports.contains_from = contains_from;\nexports.rcontains_from = rcontains_from;\nexports.uppercase = uppercase;\nexports.lowercase = lowercase;\nexports.capitalize = capitalize;\nexports.uncapitalize = uncapitalize;\nexports.compare = compare;\nexports.unsafe_to_string = unsafe_to_string;\nexports.unsafe_of_string = unsafe_of_string;\n/* No side effect */\n"
},
{
"id": 68,
"identifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/bs-platform/lib/js/caml_md5.js",
"name": "./node_modules/bs-platform/lib/js/caml_md5.js",
"index": 61,
"index2": 56,
"size": 5224,
"cacheable": true,
"built": true,
"optional": false,
"prefetched": false,
"chunks": [
0
],
"assets": [],
"issuer": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/bs-platform/lib/js/digest.js",
"issuerId": 65,
"issuerName": "./node_modules/bs-platform/lib/js/digest.js",
"failed": false,
"errors": 0,
"warnings": 0,
"reasons": [
{
"moduleId": 65,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/bs-platform/lib/js/digest.js",
"module": "./node_modules/bs-platform/lib/js/digest.js",
"moduleName": "./node_modules/bs-platform/lib/js/digest.js",
"type": "cjs require",
"userRequest": "./caml_md5.js",
"loc": "5:30-54"
}
],
"usedExports": true,
"providedExports": null,
"optimizationBailout": [],
"depth": 5,
"source": "'use strict';\n\n\nfunction cmn(q, a, b, x, s, t) {\n var a$1 = ((a + q | 0) + x | 0) + t | 0;\n return ((a$1 << s) | (a$1 >>> (32 - s | 0)) | 0) + b | 0;\n}\n\nfunction f(a, b, c, d, x, s, t) {\n return cmn(b & c | (b ^ -1) & d, a, b, x, s, t);\n}\n\nfunction g(a, b, c, d, x, s, t) {\n return cmn(b & d | c & (d ^ -1), a, b, x, s, t);\n}\n\nfunction h(a, b, c, d, x, s, t) {\n return cmn(b ^ c ^ d, a, b, x, s, t);\n}\n\nfunction i(a, b, c, d, x, s, t) {\n return cmn(c ^ (b | d ^ -1), a, b, x, s, t);\n}\n\nfunction cycle(x, k) {\n var a = x[0];\n var b = x[1];\n var c = x[2];\n var d = x[3];\n a = f(a, b, c, d, k[0], 7, -680876936);\n d = f(d, a, b, c, k[1], 12, -389564586);\n c = f(c, d, a, b, k[2], 17, 606105819);\n b = f(b, c, d, a, k[3], 22, -1044525330);\n a = f(a, b, c, d, k[4], 7, -176418897);\n d = f(d, a, b, c, k[5], 12, 1200080426);\n c = f(c, d, a, b, k[6], 17, -1473231341);\n b = f(b, c, d, a, k[7], 22, -45705983);\n a = f(a, b, c, d, k[8], 7, 1770035416);\n d = f(d, a, b, c, k[9], 12, -1958414417);\n c = f(c, d, a, b, k[10], 17, -42063);\n b = f(b, c, d, a, k[11], 22, -1990404162);\n a = f(a, b, c, d, k[12], 7, 1804603682);\n d = f(d, a, b, c, k[13], 12, -40341101);\n c = f(c, d, a, b, k[14], 17, -1502002290);\n b = f(b, c, d, a, k[15], 22, 1236535329);\n a = g(a, b, c, d, k[1], 5, -165796510);\n d = g(d, a, b, c, k[6], 9, -1069501632);\n c = g(c, d, a, b, k[11], 14, 643717713);\n b = g(b, c, d, a, k[0], 20, -373897302);\n a = g(a, b, c, d, k[5], 5, -701558691);\n d = g(d, a, b, c, k[10], 9, 38016083);\n c = g(c, d, a, b, k[15], 14, -660478335);\n b = g(b, c, d, a, k[4], 20, -405537848);\n a = g(a, b, c, d, k[9], 5, 568446438);\n d = g(d, a, b, c, k[14], 9, -1019803690);\n c = g(c, d, a, b, k[3], 14, -187363961);\n b = g(b, c, d, a, k[8], 20, 1163531501);\n a = g(a, b, c, d, k[13], 5, -1444681467);\n d = g(d, a, b, c, k[2], 9, -51403784);\n c = g(c, d, a, b, k[7], 14, 1735328473);\n b = g(b, c, d, a, k[12], 20, -1926607734);\n a = h(a, b, c, d, k[5], 4, -378558);\n d = h(d, a, b, c, k[8], 11, -2022574463);\n c = h(c, d, a, b, k[11], 16, 1839030562);\n b = h(b, c, d, a, k[14], 23, -35309556);\n a = h(a, b, c, d, k[1], 4, -1530992060);\n d = h(d, a, b, c, k[4], 11, 1272893353);\n c = h(c, d, a, b, k[7], 16, -155497632);\n b = h(b, c, d, a, k[10], 23, -1094730640);\n a = h(a, b, c, d, k[13], 4, 681279174);\n d = h(d, a, b, c, k[0], 11, -358537222);\n c = h(c, d, a, b, k[3], 16, -722521979);\n b = h(b, c, d, a, k[6], 23, 76029189);\n a = h(a, b, c, d, k[9], 4, -640364487);\n d = h(d, a, b, c, k[12], 11, -421815835);\n c = h(c, d, a, b, k[15], 16, 530742520);\n b = h(b, c, d, a, k[2], 23, -995338651);\n a = i(a, b, c, d, k[0], 6, -198630844);\n d = i(d, a, b, c, k[7], 10, 1126891415);\n c = i(c, d, a, b, k[14], 15, -1416354905);\n b = i(b, c, d, a, k[5], 21, -57434055);\n a = i(a, b, c, d, k[12], 6, 1700485571);\n d = i(d, a, b, c, k[3], 10, -1894986606);\n c = i(c, d, a, b, k[10], 15, -1051523);\n b = i(b, c, d, a, k[1], 21, -2054922799);\n a = i(a, b, c, d, k[8], 6, 1873313359);\n d = i(d, a, b, c, k[15], 10, -30611744);\n c = i(c, d, a, b, k[6], 15, -1560198380);\n b = i(b, c, d, a, k[13], 21, 1309151649);\n a = i(a, b, c, d, k[4], 6, -145523070);\n d = i(d, a, b, c, k[11], 10, -1120210379);\n c = i(c, d, a, b, k[2], 15, 718787259);\n b = i(b, c, d, a, k[9], 21, -343485551);\n x[0] = a + x[0] | 0;\n x[1] = b + x[1] | 0;\n x[2] = c + x[2] | 0;\n x[3] = d + x[3] | 0;\n return /* () */0;\n}\n\nvar state = /* array */[\n 1732584193,\n -271733879,\n -1732584194,\n 271733878\n];\n\nvar md5blk = /* array */[\n 0,\n 0,\n 0,\n 0,\n 0,\n 0,\n 0,\n 0,\n 0,\n 0,\n 0,\n 0,\n 0,\n 0,\n 0,\n 0\n];\n\nfunction caml_md5_string(s, start, len) {\n var s$1 = s.slice(start, len);\n var n = s$1.length;\n state[0] = 1732584193;\n state[1] = -271733879;\n state[2] = -1732584194;\n state[3] = 271733878;\n for(var i = 0; i <= 15; ++i){\n md5blk[i] = 0;\n }\n var i_end = n / 64 | 0;\n for(var i$1 = 1; i$1 <= i_end; ++i$1){\n for(var j = 0; j <= 15; ++j){\n var k = ((i$1 << 6) - 64 | 0) + (j << 2) | 0;\n md5blk[j] = ((s$1.charCodeAt(k) + (s$1.charCodeAt(k + 1 | 0) << 8) | 0) + (s$1.charCodeAt(k + 2 | 0) << 16) | 0) + (s$1.charCodeAt(k + 3 | 0) << 24) | 0;\n }\n cycle(state, md5blk);\n }\n var s_tail = s$1.slice((i_end << 6));\n for(var kk = 0; kk <= 15; ++kk){\n md5blk[kk] = 0;\n }\n var i_end$1 = s_tail.length - 1 | 0;\n for(var i$2 = 0; i$2 <= i_end$1; ++i$2){\n md5blk[i$2 / 4 | 0] = md5blk[i$2 / 4 | 0] | (s_tail.charCodeAt(i$2) << (i$2 % 4 << 3));\n }\n var i$3 = i_end$1 + 1 | 0;\n md5blk[i$3 / 4 | 0] = md5blk[i$3 / 4 | 0] | (128 << (i$3 % 4 << 3));\n if (i$3 > 55) {\n cycle(state, md5blk);\n for(var i$4 = 0; i$4 <= 15; ++i$4){\n md5blk[i$4] = 0;\n }\n }\n md5blk[14] = (n << 3);\n cycle(state, md5blk);\n return String.fromCharCode(state[0] & 255, (state[0] >> 8) & 255, (state[0] >> 16) & 255, (state[0] >> 24) & 255, state[1] & 255, (state[1] >> 8) & 255, (state[1] >> 16) & 255, (state[1] >> 24) & 255, state[2] & 255, (state[2] >> 8) & 255, (state[2] >> 16) & 255, (state[2] >> 24) & 255, state[3] & 255, (state[3] >> 8) & 255, (state[3] >> 16) & 255, (state[3] >> 24) & 255);\n}\n\nexports.caml_md5_string = caml_md5_string;\n/* No side effect */\n"
},
{
"id": 69,
"identifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/bs-platform/lib/js/nativeint.js",
"name": "./node_modules/bs-platform/lib/js/nativeint.js",
"index": 62,
"index2": 59,
"size": 968,
"cacheable": true,
"built": true,
"optional": false,
"prefetched": false,
"chunks": [
0
],
"assets": [],
"issuer": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/bs-platform/lib/js/random.js",
"issuerId": 62,
"issuerName": "./node_modules/bs-platform/lib/js/random.js",
"failed": false,
"errors": 0,
"warnings": 0,
"reasons": [
{
"moduleId": 62,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/bs-platform/lib/js/random.js",
"module": "./node_modules/bs-platform/lib/js/random.js",
"moduleName": "./node_modules/bs-platform/lib/js/random.js",
"type": "cjs require",
"userRequest": "./nativeint.js",
"loc": "9:30-55"
}
],
"usedExports": true,
"providedExports": null,
"optimizationBailout": [],
"depth": 4,
"source": "'use strict';\n\nvar Sys = require(\"./sys.js\");\nvar Caml_obj = require(\"./caml_obj.js\");\nvar Caml_format = require(\"./caml_format.js\");\n\nfunction succ(n) {\n return n + 1;\n}\n\nfunction pred(n) {\n return n - 1;\n}\n\nfunction abs(n) {\n if (n >= 0) {\n return n;\n } else {\n return -n;\n }\n}\n\nvar min_int = -9007199254740991;\n\nvar max_int = 9007199254740991;\n\nfunction lognot(n) {\n return n ^ -1;\n}\n\nfunction to_string(n) {\n return Caml_format.caml_nativeint_format(\"%d\", n);\n}\n\nvar compare = Caml_obj.caml_nativeint_compare;\n\nvar zero = 0;\n\nvar one = 1;\n\nvar minus_one = -1;\n\nvar size = Sys.word_size;\n\nexports.zero = zero;\nexports.one = one;\nexports.minus_one = minus_one;\nexports.succ = succ;\nexports.pred = pred;\nexports.abs = abs;\nexports.size = size;\nexports.max_int = max_int;\nexports.min_int = min_int;\nexports.lognot = lognot;\nexports.to_string = to_string;\nexports.compare = compare;\n/* No side effect */\n"
},
{
"id": 70,
"identifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/bs-platform/lib/js/sys.js",
"name": "./node_modules/bs-platform/lib/js/sys.js",
"index": 63,
"index2": 58,
"size": 2547,
"cacheable": true,
"built": true,
"optional": false,
"prefetched": false,
"chunks": [
0
],
"assets": [],
"issuer": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/bs-platform/lib/js/nativeint.js",
"issuerId": 69,
"issuerName": "./node_modules/bs-platform/lib/js/nativeint.js",
"failed": false,
"errors": 0,
"warnings": 0,
"reasons": [
{
"moduleId": 69,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/bs-platform/lib/js/nativeint.js",
"module": "./node_modules/bs-platform/lib/js/nativeint.js",
"moduleName": "./node_modules/bs-platform/lib/js/nativeint.js",
"type": "cjs require",
"userRequest": "./sys.js",
"loc": "3:18-37"
}
],
"usedExports": true,
"providedExports": null,
"optimizationBailout": [],
"depth": 5,
"source": "'use strict';\n\nvar Caml_sys = require(\"./caml_sys.js\");\nvar Caml_exceptions = require(\"./caml_exceptions.js\");\n\nvar is_js = /* true */1;\n\nvar match = Caml_sys.caml_sys_get_argv(/* () */0);\n\nvar big_endian = /* false */0;\n\nvar unix = /* true */1;\n\nvar win32 = /* false */0;\n\nvar cygwin = /* false */0;\n\nvar max_array_length = 2147483647;\n\nvar max_string_length = 2147483647;\n\nvar interactive = [/* false */0];\n\nfunction set_signal(_, _$1) {\n return /* () */0;\n}\n\nvar Break = Caml_exceptions.create(\"Sys.Break\");\n\nfunction catch_break() {\n return /* () */0;\n}\n\nvar argv = match[1];\n\nvar executable_name = match[0];\n\nvar os_type = \"Unix\";\n\nvar word_size = 32;\n\nvar sigabrt = -1;\n\nvar sigalrm = -2;\n\nvar sigfpe = -3;\n\nvar sighup = -4;\n\nvar sigill = -5;\n\nvar sigint = -6;\n\nvar sigkill = -7;\n\nvar sigpipe = -8;\n\nvar sigquit = -9;\n\nvar sigsegv = -10;\n\nvar sigterm = -11;\n\nvar sigusr1 = -12;\n\nvar sigusr2 = -13;\n\nvar sigchld = -14;\n\nvar sigcont = -15;\n\nvar sigstop = -16;\n\nvar sigtstp = -17;\n\nvar sigttin = -18;\n\nvar sigttou = -19;\n\nvar sigvtalrm = -20;\n\nvar sigprof = -21;\n\nvar ocaml_version = \"4.02.3+dev1-2015-07-10\";\n\nexports.argv = argv;\nexports.executable_name = executable_name;\nexports.interactive = interactive;\nexports.os_type = os_type;\nexports.unix = unix;\nexports.win32 = win32;\nexports.cygwin = cygwin;\nexports.word_size = word_size;\nexports.big_endian = big_endian;\nexports.is_js = is_js;\nexports.max_string_length = max_string_length;\nexports.max_array_length = max_array_length;\nexports.set_signal = set_signal;\nexports.sigabrt = sigabrt;\nexports.sigalrm = sigalrm;\nexports.sigfpe = sigfpe;\nexports.sighup = sighup;\nexports.sigill = sigill;\nexports.sigint = sigint;\nexports.sigkill = sigkill;\nexports.sigpipe = sigpipe;\nexports.sigquit = sigquit;\nexports.sigsegv = sigsegv;\nexports.sigterm = sigterm;\nexports.sigusr1 = sigusr1;\nexports.sigusr2 = sigusr2;\nexports.sigchld = sigchld;\nexports.sigcont = sigcont;\nexports.sigstop = sigstop;\nexports.sigtstp = sigtstp;\nexports.sigttin = sigttin;\nexports.sigttou = sigttou;\nexports.sigvtalrm = sigvtalrm;\nexports.sigprof = sigprof;\nexports.Break = Break;\nexports.catch_break = catch_break;\nexports.ocaml_version = ocaml_version;\n/* No side effect */\n"
},
{
"id": 71,
"identifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/style-loader/index.js!/home/x/zzz/github/douglasduteil/RePeople/node_modules/css-loader/index.js!/home/x/zzz/github/douglasduteil/RePeople/src/style/discover.css",
"name": "./src/style/discover.css",
"index": 64,
"index2": 62,
"size": 1021,
"cacheable": true,
"built": true,
"optional": false,
"prefetched": false,
"chunks": [
0
],
"assets": [],
"issuer": "/home/x/zzz/github/douglasduteil/RePeople/lib/js/src/components/discover.js",
"issuerId": 61,
"issuerName": "./lib/js/src/components/discover.js",
"failed": false,
"errors": 0,
"warnings": 0,
"reasons": [
{
"moduleId": 61,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/lib/js/src/components/discover.js",
"module": "./lib/js/src/components/discover.js",
"moduleName": "./lib/js/src/components/discover.js",
"type": "cjs require",
"userRequest": "style/discover.css",
"loc": "13:0-29"
}
],
"usedExports": true,
"providedExports": null,
"optimizationBailout": [],
"depth": 3,
"source": "// style-loader: Adds some css to the DOM by adding a <style> tag\n\n// load the styles\nvar content = require(\"!!../../node_modules/css-loader/index.js!./discover.css\");\nif(typeof content === 'string') content = [[module.id, content, '']];\n// Prepare cssTransformation\nvar transform;\n\nvar options = {}\noptions.transform = transform\n// add the styles to the DOM\nvar update = require(\"!../../node_modules/style-loader/lib/addStyles.js\")(content, options);\nif(content.locals) module.exports = content.locals;\n// Hot Module Replacement\nif(module.hot) {\n\t// When the styles change, update the <style> tags\n\tif(!content.locals) {\n\t\tmodule.hot.accept(\"!!../../node_modules/css-loader/index.js!./discover.css\", function() {\n\t\t\tvar newContent = require(\"!!../../node_modules/css-loader/index.js!./discover.css\");\n\t\t\tif(typeof newContent === 'string') newContent = [[module.id, newContent, '']];\n\t\t\tupdate(newContent);\n\t\t});\n\t}\n\t// When the module is disposed, remove the <style> tags\n\tmodule.hot.dispose(function() { update(); });\n}"
},
{
"id": 72,
"identifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/css-loader/index.js!/home/x/zzz/github/douglasduteil/RePeople/src/style/discover.css",
"name": "./node_modules/css-loader!./src/style/discover.css",
"index": 65,
"index2": 61,
"size": 630,
"cacheable": true,
"built": true,
"optional": false,
"prefetched": false,
"chunks": [
0
],
"assets": [],
"issuer": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/style-loader/index.js!/home/x/zzz/github/douglasduteil/RePeople/node_modules/css-loader/index.js!/home/x/zzz/github/douglasduteil/RePeople/src/style/discover.css",
"issuerId": 71,
"issuerName": "./src/style/discover.css",
"failed": false,
"errors": 0,
"warnings": 0,
"reasons": [
{
"moduleId": 71,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/style-loader/index.js!/home/x/zzz/github/douglasduteil/RePeople/node_modules/css-loader/index.js!/home/x/zzz/github/douglasduteil/RePeople/src/style/discover.css",
"module": "./src/style/discover.css",
"moduleName": "./src/style/discover.css",
"type": "cjs require",
"userRequest": "!!../../node_modules/css-loader/index.js!./discover.css",
"loc": "4:14-80"
}
],
"usedExports": true,
"providedExports": null,
"optimizationBailout": [],
"depth": 4,
"source": "exports = module.exports = require(\"../../node_modules/css-loader/lib/css-base.js\")(undefined);\n// imports\n\n\n// module\nexports.push([module.id, \".Discover .fab-container {\\n position: fixed;\\n bottom: 20px;\\n right: 20px;\\n left: 20px;\\n display: flex;\\n align-items: center;\\n justify-content: center;\\n}\\n\\n.Discover .btn-default.btn-floating {\\n background-color: #0168AB;\\n margin: 0 10px;\\n}\\n\\n.Discover .btn-default.btn-floating:hover {\\n background-color: #0168AB;\\n box-shadow: 0 8px 10px 1px rgba(0, 0, 0, 0.14), 0 3px 14px 2px rgba(0, 0, 0, 0.12), 0 5px 5px -3px rgba(0, 0, 0, 0.3);\\n}\\n\", \"\"]);\n\n// exports\n"
},
{
"id": 73,
"identifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/style-loader/index.js!/home/x/zzz/github/douglasduteil/RePeople/node_modules/css-loader/index.js!/home/x/zzz/github/douglasduteil/RePeople/src/style/app.css",
"name": "./src/style/app.css",
"index": 66,
"index2": 65,
"size": 1006,
"cacheable": true,
"built": true,
"optional": false,
"prefetched": false,
"chunks": [
0
],
"assets": [],
"issuer": "/home/x/zzz/github/douglasduteil/RePeople/lib/js/src/app.js",
"issuerId": 39,
"issuerName": "./lib/js/src/app.js",
"failed": false,
"errors": 0,
"warnings": 0,
"reasons": [
{
"moduleId": 39,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/lib/js/src/app.js",
"module": "./lib/js/src/app.js",
"moduleName": "./lib/js/src/app.js",
"type": "cjs require",
"userRequest": "style/app.css",
"loc": "13:0-24"
}
],
"usedExports": true,
"providedExports": null,
"optimizationBailout": [],
"depth": 2,
"source": "// style-loader: Adds some css to the DOM by adding a <style> tag\n\n// load the styles\nvar content = require(\"!!../../node_modules/css-loader/index.js!./app.css\");\nif(typeof content === 'string') content = [[module.id, content, '']];\n// Prepare cssTransformation\nvar transform;\n\nvar options = {}\noptions.transform = transform\n// add the styles to the DOM\nvar update = require(\"!../../node_modules/style-loader/lib/addStyles.js\")(content, options);\nif(content.locals) module.exports = content.locals;\n// Hot Module Replacement\nif(module.hot) {\n\t// When the styles change, update the <style> tags\n\tif(!content.locals) {\n\t\tmodule.hot.accept(\"!!../../node_modules/css-loader/index.js!./app.css\", function() {\n\t\t\tvar newContent = require(\"!!../../node_modules/css-loader/index.js!./app.css\");\n\t\t\tif(typeof newContent === 'string') newContent = [[module.id, newContent, '']];\n\t\t\tupdate(newContent);\n\t\t});\n\t}\n\t// When the module is disposed, remove the <style> tags\n\tmodule.hot.dispose(function() { update(); });\n}"
},
{
"id": 74,
"identifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/css-loader/index.js!/home/x/zzz/github/douglasduteil/RePeople/src/style/app.css",
"name": "./node_modules/css-loader!./src/style/app.css",
"index": 67,
"index2": 64,
"size": 692,
"cacheable": true,
"built": true,
"optional": false,
"prefetched": false,
"chunks": [
0
],
"assets": [],
"issuer": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/style-loader/index.js!/home/x/zzz/github/douglasduteil/RePeople/node_modules/css-loader/index.js!/home/x/zzz/github/douglasduteil/RePeople/src/style/app.css",
"issuerId": 73,
"issuerName": "./src/style/app.css",
"failed": false,
"errors": 0,
"warnings": 0,
"reasons": [
{
"moduleId": 73,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/style-loader/index.js!/home/x/zzz/github/douglasduteil/RePeople/node_modules/css-loader/index.js!/home/x/zzz/github/douglasduteil/RePeople/src/style/app.css",
"module": "./src/style/app.css",
"moduleName": "./src/style/app.css",
"type": "cjs require",
"userRequest": "!!../../node_modules/css-loader/index.js!./app.css",
"loc": "4:14-75"
}
],
"usedExports": true,
"providedExports": null,
"optimizationBailout": [],
"depth": 3,
"source": "exports = module.exports = require(\"../../node_modules/css-loader/lib/css-base.js\")(undefined);\n// imports\n\n\n// module\nexports.push([module.id, \".App header {\\n position: fixed;\\n top: 0;\\n left: 0;\\n right: 0;\\n z-index: 100;\\n}\\n\\n.App main {\\n position: relative;\\n min-height: 100vh;\\n padding-top: 80px;\\n padding-bottom: 100px;\\n}\\n\\n.App .card-container {\\n display: flex;\\n justify-content: center;\\n flex-wrap: wrap;\\n}\\n\\n.App .control-container {\\n position: fixed;\\n bottom: 0;\\n right: 0;\\n left: 0;\\n padding: 10px;\\n background-color: rgba(250, 250, 250, 0.95);\\n display: flex;\\n align-items: center;\\n justify-content: center; \\n}\\n\", \"\"]);\n\n// exports\n"
},
{
"id": 75,
"identifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/reason-react/lib/js/src/reactDOMRe.js",
"name": "./node_modules/reason-react/lib/js/src/reactDOMRe.js",
"index": 68,
"index2": 87,
"size": 1626,
"cacheable": true,
"built": true,
"optional": false,
"prefetched": false,
"chunks": [
0
],
"assets": [],
"issuer": "/home/x/zzz/github/douglasduteil/RePeople/lib/js/src/main.js",
"issuerId": 38,
"issuerName": "./lib/js/src/main.js",
"failed": false,
"errors": 0,
"warnings": 0,
"reasons": [
{
"moduleId": 38,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/lib/js/src/main.js",
"module": "./lib/js/src/main.js",
"moduleName": "./lib/js/src/main.js",
"type": "cjs require",
"userRequest": "reason-react/lib/js/src/reactDOMRe.js",
"loc": "5:18-66"
}
],
"usedExports": true,
"providedExports": null,
"optimizationBailout": [],
"depth": 1,
"source": "// Generated by BUCKLESCRIPT VERSION 1.8.2, PLEASE EDIT WITH CARE\n'use strict';\n\nvar ReactDom = require(\"react-dom\");\nvar Caml_array = require(\"bs-platform/lib/js/caml_array.js\");\nvar Caml_builtin_exceptions = require(\"bs-platform/lib/js/caml_builtin_exceptions.js\");\n\nfunction renderToElementWithClassName(reactElement, className) {\n var elements = document.getElementsByClassName(className);\n if (elements.length) {\n ReactDom.render(reactElement, Caml_array.caml_array_get(elements, 0));\n return /* () */0;\n } else {\n throw [\n Caml_builtin_exceptions.invalid_argument,\n \"ReactDOMRE.renderToElementWithClassName: no element of class \" + (className + \" found in the HTML.\")\n ];\n }\n}\n\nfunction renderToElementWithId(reactElement, id) {\n var match = document.getElementById(id);\n if (match !== null) {\n ReactDom.render(reactElement, match);\n return /* () */0;\n } else {\n throw [\n Caml_builtin_exceptions.invalid_argument,\n \"ReactDOMRE.renderToElementWithId : no element of id \" + (id + \" found in the HTML.\")\n ];\n }\n}\n\nfunction combine(a, b) {\n return Object.assign(Object.assign({ }, a), b);\n}\n\nfunction unsafeAddProp(style, property, value) {\n var dict = { };\n dict[property] = value;\n return combine(style, dict);\n}\n\nvar Style = /* module */[\n /* combine */combine,\n /* unsafeAddProp */unsafeAddProp\n];\n\nexports.renderToElementWithClassName = renderToElementWithClassName;\nexports.renderToElementWithId = renderToElementWithId;\nexports.Style = Style;\n/* react-dom Not a pure module */\n"
},
{
"id": 76,
"identifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/react-dom/index.js",
"name": "./node_modules/react-dom/index.js",
"index": 69,
"index2": 86,
"size": 1363,
"cacheable": true,
"built": true,
"optional": false,
"prefetched": false,
"chunks": [
0
],
"assets": [],
"issuer": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/reason-react/lib/js/src/reactDOMRe.js",
"issuerId": 75,
"issuerName": "./node_modules/reason-react/lib/js/src/reactDOMRe.js",
"failed": false,
"errors": 0,
"warnings": 0,
"reasons": [
{
"moduleId": 75,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/reason-react/lib/js/src/reactDOMRe.js",
"module": "./node_modules/reason-react/lib/js/src/reactDOMRe.js",
"moduleName": "./node_modules/reason-react/lib/js/src/reactDOMRe.js",
"type": "cjs require",
"userRequest": "react-dom",
"loc": "4:30-50"
}
],
"usedExports": true,
"providedExports": null,
"optimizationBailout": [],
"depth": 2,
"source": "'use strict';\n\nfunction checkDCE() {\n /* global __REACT_DEVTOOLS_GLOBAL_HOOK__ */\n if (\n typeof __REACT_DEVTOOLS_GLOBAL_HOOK__ === 'undefined' ||\n typeof __REACT_DEVTOOLS_GLOBAL_HOOK__.checkDCE !== 'function'\n ) {\n return;\n }\n if (process.env.NODE_ENV !== 'production') {\n // This branch is unreachable because this function is only called\n // in production, but the condition is true only in development.\n // Therefore if the branch is still here, dead code elimination wasn't\n // properly applied.\n // Don't change the message. React DevTools relies on it. Also make sure\n // this message doesn't occur elsewhere in this function, or it will cause\n // a false positive.\n throw new Error('^_^');\n }\n try {\n // Verify that the code above has been dead code eliminated (DCE'd).\n __REACT_DEVTOOLS_GLOBAL_HOOK__.checkDCE(checkDCE);\n } catch (err) {\n // DevTools shouldn't crash React, no matter what.\n // We should still report in case we break this code.\n console.error(err);\n }\n}\n\nif (process.env.NODE_ENV === 'production') {\n // DCE check should happen before ReactDOM bundle executes so that\n // DevTools can report bad minification during injection.\n checkDCE();\n module.exports = require('./cjs/react-dom.production.min.js');\n} else {\n module.exports = require('./cjs/react-dom.development.js');\n}\n"
},
{
"id": 77,
"identifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/react-dom/cjs/react-dom.production.min.js",
"name": "./node_modules/react-dom/cjs/react-dom.production.min.js",
"index": 70,
"index2": 75,
"size": 108200,
"cacheable": true,
"built": true,
"optional": false,
"prefetched": false,
"chunks": [
0
],
"assets": [],
"issuer": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/react-dom/index.js",
"issuerId": 76,
"issuerName": "./node_modules/react-dom/index.js",
"failed": false,
"errors": 0,
"warnings": 0,
"reasons": [
{
"moduleId": 76,
"moduleIdentifier": "/home/x/zzz/github/douglasduteil/RePeople/node_modules/react-dom/index.js",
"module": "./node_modules/react-dom/index.js",
"moduleName": "./node_modules/react-dom/index.js",
"type": "cjs require",
"userRequest": "./cjs/react-dom.production.min.js",
"loc": "35:19-63"
}
],
"usedExports": true,
"providedExports": null,
"optimizationBailout": [],
"depth": 3,
"source": "/*\n React v16.0.0\n react-dom.production.min.js\n\n Copyright (c) 2013-present, Facebook, Inc.\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 Modernizr 3.0.0pre (Custom Build) | MIT\n*/\n'use strict';var aa=require(\"react\");require(\"fbjs/lib/invariant\");var l=require(\"fbjs/lib/ExecutionEnvironment\"),n=require(\"object-assign\"),ba=require(\"fbjs/lib/EventListener\"),ca=require(\"fbjs/lib/emptyFunction\"),da=require(\"fbjs/lib/emptyObject\"),ea=require(\"fbjs/lib/shallowEqual\"),fa=require(\"fbjs/lib/containsNode\"),ha=require(\"fbjs/lib/focusNode\"),ia=require(\"fbjs/lib/getActiveElement\");\nfunction w(a){for(var b=arguments.length-1,c=\"Minified React error #\"+a+\"; visit http://facebook.github.io/react/docs/error-decoder.html?invariant\\x3d\"+a,d=0;d<b;d++)c+=\"\\x26args[]\\x3d\"+encodeURIComponent(arguments[d+1]);b=Error(c+\" for the full message or use the non-minified dev environment for full errors and additional helpful warnings.\");b.name=\"Invariant Violation\";b.framesToPop=1;throw b;}aa?void 0:w(\"227\");\nfunction ja(a){switch(a){case \"svg\":return\"http://www.w3.org/2000/svg\";case \"math\":return\"http://www.w3.org/1998/Math/MathML\";default:return\"http://www.w3.org/1999/xhtml\"}}\nvar ka={Namespaces:{html:\"http://www.w3.org/1999/xhtml\",mathml:\"http://www.w3.org/1998/Math/MathML\",svg:\"http://www.w3.org/2000/svg\"},getIntrinsicNamespace:ja,getChildNamespace:function(a,b){return null==a||\"http://www.w3.org/1999/xhtml\"===a?ja(b):\"http://www.w3.org/2000/svg\"===a&&\"foreignObject\"===b?\"http://www.w3.org/1999/xhtml\":a}},la=null,oa={};\nfunction pa(){if(la)for(var a in oa){var b=oa[a],c=la.indexOf(a);-1<c?void 0:w(\"96\",a);if(!qa.plugins[c]){b.extractEvents?void 0:w(\"97\",a);qa.plugins[c]=b;c=b.eventTypes;for(var d in c){var e=void 0;var f=c[d],g=b,h=d;qa.eventNameDispatchConfigs.hasOwnProperty(h)?w(\"99\",h):void 0;qa.eventNameDispatchConfigs[h]=f;var k=f.phasedRegistrationNames;if(k){for(e in k)k.hasOwnProperty(e)&&ra(k[e],g,h);e=!0}else f.registrationName?(ra(f.registrationName,g,h),e=!0):e=!1;e?void 0:w(\"98\",d,a)}}}}\nfunction ra(a,b,c){qa.registrationNameModules[a]?w(\"100\",a):void 0;qa.registrationNameModules[a]=b;qa.registrationNameDependencies[a]=b.eventTypes[c].dependencies}\nvar qa={plugins:[],eventNameDispatchConfigs:{},registrationNameModules:{},registrationNameDependencies:{},possibleRegistrationNames:null,injectEventPluginOrder:function(a){la?w(\"101\"):void 0;la=Array.prototype.slice.call(a);pa()},injectEventPluginsByName:function(a){var b=!1,c;for(c in a)if(a.hasOwnProperty(c)){var d=a[c];oa.hasOwnProperty(c)&&oa[c]===d||(oa[c]?w(\"102\",c):void 0,oa[c]=d,b=!0)}b&&pa()}},sa=qa,ta={children:!0,dangerouslySetInnerHTML:!0,autoFocus:!0,defaultValue:!0,defaultChecked:!0,\ninnerHTML:!0,suppressContentEditableWarning:!0,style:!0};function ua(a,b){return(a&b)===b}\nvar wa={MUST_USE_PROPERTY:1,HAS_BOOLEAN_VALUE:4,HAS_NUMERIC_VALUE:8,HAS_POSITIVE_NUMERIC_VALUE:24,HAS_OVERLOADED_BOOLEAN_VALUE:32,HAS_STRING_BOOLEAN_VALUE:64,injectDOMPropertyConfig:function(a){var b=wa,c=a.Properties||{},d=a.DOMAttributeNamespaces||{},e=a.DOMAttributeNames||{};a=a.DOMMutationMethods||{};for(var f in c){xa.properties.hasOwnProperty(f)?w(\"48\",f):void 0;var g=f.toLowerCase(),h=c[f];g={attributeName:g,attributeNamespace:null,propertyName:f,mutationMethod:null,mustUseProperty:ua(h,b.MUST_USE_PROPERTY),\nhasBooleanValue:ua(h,b.HAS_BOOLEAN_VALUE),hasNumericValue:ua(h,b.HAS_NUMERIC_VALUE),hasPositiveNumericValue:ua(h,b.HAS_POSITIVE_NUMERIC_VALUE),hasOverloadedBooleanValue:ua(h,b.HAS_OVERLOADED_BOOLEAN_VALUE),hasStringBooleanValue:ua(h,b.HAS_STRING_BOOLEAN_VALUE)};1>=g.hasBooleanValue+g.hasNumericValue+g.hasOverloadedBooleanValue?void 0:w(\"50\",f);e.hasOwnProperty(f)&&(g.attributeName=e[f]);d.hasOwnProperty(f)&&(g.attributeNamespace=d[f]);a.hasOwnProperty(f)&&(g.mutationMethod=a[f]);xa.properties[f]=\ng}}},xa={ID_ATTRIBUTE_NAME:\"data-reactid\",ROOT_ATTRIBUTE_NAME:\"data-reactroot\",ATTRIBUTE_NAME_START_CHAR:\":A-Z_a-z\\\\u00C0-\\\\u00D6\\\\u00D8-\\\\u00F6\\\\u00F8-\\\\u02FF\\\\u0370-\\\\u037D\\\\u037F-\\\\u1FFF\\\\u200C-\\\\u200D\\\\u2070-\\\\u218F\\\\u2C00-\\\\u2FEF\\\\u3001-\\\\uD7FF\\\\uF900-\\\\uFDCF\\\\uFDF0-\\\\uFFFD\",ATTRIBUTE_NAME_CHAR:\":A-Z_a-z\\\\u00C0-\\\\u00D6\\\\u00D8-\\\\u00F6\\\\u00F8-\\\\u02FF\\\\u0370-\\\\u037D\\\\u037F-\\\\u1FFF\\\\u200C-\\\\u200D\\\\u2070-\\\\u218F\\\\u2C00-\\\\u2FEF\\\\u3001-\\\\uD7FF\\\\uF900-\\\\uFDCF\\\\uFDF0-\\\\uFFFD\\\\-.0-9\\\\u00B7\\\\u0300-\\\\u036F\\\\u203F-\\\\u2040\",\nproperties:{},shouldSetAttribute:function(a,b){if(xa.isReservedProp(a)||!(\"o\"!==a[0]&&\"O\"!==a[0]||\"n\"!==a[1]&&\"N\"!==a[1]))return!1;if(null===b)return!0;switch(typeof b){case \"boolean\":return xa.shouldAttributeAcceptBooleanValue(a);case \"undefined\":case \"number\":case \"string\":case \"object\":return!0;default:return!1}},getPropertyInfo:function(a){return xa.properties.hasOwnProperty(a)?xa.properties[a]:null},shouldAttributeAcceptBooleanValue:function(a){if(xa.isReservedProp(a))return!0;var b=xa.getPropertyInfo(a);\nif(b)return b.hasBooleanValue||b.hasStringBooleanValue||b.hasOverloadedBooleanValue;a=a.toLowerCase().slice(0,5);return\"data-\"===a||\"aria-\"===a},isReservedProp:function(a){return ta.hasOwnProperty(a)},injection:wa},A=xa,E={IndeterminateComponent:0,FunctionalComponent:1,ClassComponent:2,HostRoot:3,HostPortal:4,HostComponent:5,HostText:6,CoroutineComponent:7,CoroutineHandlerPhase:8,YieldComponent:9,Fragment:10},F={ELEMENT_NODE:1,TEXT_NODE:3,COMMENT_NODE:8,DOCUMENT_NODE:9,DOCUMENT_FRAGMENT_NODE:11},\nya=E.HostComponent,za=E.HostText,Aa=F.ELEMENT_NODE,Ba=F.COMMENT_NODE,Ea=A.ID_ATTRIBUTE_NAME,Fa={hasCachedChildNodes:1},Ga=Math.random().toString(36).slice(2),Ha=\"__reactInternalInstance$\"+Ga,Ia=\"__reactEventHandlers$\"+Ga;function La(a){for(var b;b=a._renderedComponent;)a=b;return a}function Ma(a,b){a=La(a);a._hostNode=b;b[Ha]=a}\nfunction Na(a,b){if(!(a._flags&Fa.hasCachedChildNodes)){var c=a._renderedChildren;b=b.firstChild;var d;a:for(d in c)if(c.hasOwnProperty(d)){var e=c[d],f=La(e)._domID;if(0!==f){for(;null!==b;b=b.nextSibling){var g=b,h=f;if(g.nodeType===Aa&&g.getAttribute(Ea)===\"\"+h||g.nodeType===Ba&&g.nodeValue===\" react-text: \"+h+\" \"||g.nodeType===Ba&&g.nodeValue===\" react-empty: \"+h+\" \"){Ma(e,b);continue a}}w(\"32\",f)}}a._flags|=Fa.hasCachedChildNodes}}\nfunction Oa(a){if(a[Ha])return a[Ha];for(var b=[];!a[Ha];)if(b.push(a),a.parentNode)a=a.parentNode;else return null;var c=a[Ha];if(c.tag===ya||c.tag===za)return c;for(;a&&(c=a[Ha]);a=b.pop()){var d=c;b.length&&Na(c,a)}return d}\nvar G={getClosestInstanceFromNode:Oa,getInstanceFromNode:function(a){var b=a[Ha];if(b)return b.tag===ya||b.tag===za?b:b._hostNode===a?b:null;b=Oa(a);return null!=b&&b._hostNode===a?b:null},getNodeFromInstance:function(a){if(a.tag===ya||a.tag===za)return a.stateNode;void 0===a._hostNode?w(\"33\"):void 0;if(a._hostNode)return a._hostNode;for(var b=[];!a._hostNode;)b.push(a),a._hostParent?void 0:w(\"34\"),a=a._hostParent;for(;b.length;a=b.pop())Na(a,a._hostNode);return a._hostNode},precacheChildNodes:Na,\nprecacheNode:Ma,uncacheNode:function(a){var b=a._hostNode;b&&(delete b[Ha],a._hostNode=null)},precacheFiberNode:function(a,b){b[Ha]=a},getFiberCurrentPropsFromNode:function(a){return a[Ia]||null},updateFiberProps:function(a,b){a[Ia]=b}},Pa={remove:function(a){a._reactInternalFiber=void 0},get:function(a){return a._reactInternalFiber},has:function(a){return void 0!==a._reactInternalFiber},set:function(a,b){a._reactInternalFiber=b}},Qa={ReactCurrentOwner:aa.__SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED.ReactCurrentOwner};\nfunction Ra(a){if(\"function\"===typeof a.getName)return a.getName();if(\"number\"===typeof a.tag){a=a.type;if(\"string\"===typeof a)return a;if(\"function\"===typeof a)return a.displayName||a.name}return null}var J={NoEffect:0,PerformedWork:1,Placement:2,Update:4,PlacementAndUpdate:6,Deletion:8,ContentReset:16,Callback:32,Err:64,Ref:128},Sa=E.HostComponent,Ta=E.HostRoot,Ua=E.HostPortal,Va=E.HostText,Wa=J.NoEffect,Xa=J.Placement;\nfunction Za(a){var b=a;if(a.alternate)for(;b[\"return\"];)b=b[\"return\"];else{if((b.effectTag&Xa)!==Wa)return 1;for(;b[\"return\"];)if(b=b[\"return\"],(b.effectTag&Xa)!==Wa)return 1}return b.tag===Ta?2:3}function $a(a){2!==Za(a)?w(\"188\"):void 0}\nfunction ab(a){var b=a.alternate;if(!b)return b=Za(a),3===b?w(\"188\"):void 0,1===b?null:a;for(var c=a,d=b;;){var e=c[\"return\"],f=e?e.alternate:null;if(!e||!f)break;if(e.child===f.child){for(var g=e.child;g;){if(g===c)return $a(e),a;if(g===d)return $a(e),b;g=g.sibling}w(\"188\")}if(c[\"return\"]!==d[\"return\"])c=e,d=f;else{g=!1;for(var h=e.child;h;){if(h===c){g=!0;c=e;d=f;break}if(h===d){g=!0;d=e;c=f;break}h=h.sibling}if(!g){for(h=f.child;h;){if(h===c){g=!0;c=f;d=e;break}if(h===d){g=!0;d=f;c=e;break}h=h.sibling}g?\nvoid 0:w(\"189\")}}c.alternate!==d?w(\"190\"):void 0}c.tag!==Ta?w(\"188\"):void 0;return c.stateNode.current===c?a:b}\nvar bb={isFiberMounted:function(a){return 2===Za(a)},isMounted:function(a){return(a=Pa.get(a))?2===Za(a):!1},findCurrentFiberUsingSlowPath:ab,findCurrentHostFiber:function(a){a=ab(a);if(!a)return null;for(var b=a;;){if(b.tag===Sa||b.tag===Va)return b;if(b.child)b.child[\"return\"]=b,b=b.child;else{if(b===a)break;for(;!b.sibling;){if(!b[\"return\"]||b[\"return\"]===a)return null;b=b[\"return\"]}b.sibling[\"return\"]=b[\"return\"];b=b.sibling}}return null},findCurrentHostFiberWithNoPortals:function(a){a=ab(a);\nif(!a)return null;for(var b=a;;){if(b.tag===Sa||b.tag===Va)return b;if(b.child&&b.tag!==Ua)b.child[\"return\"]=b,b=b.child;else{if(b===a)break;for(;!b.sibling;){if(!b[\"return\"]||b[\"return\"]===a)return null;b=b[\"return\"]}b.sibling[\"return\"]=b[\"return\"];b=b.sibling}}return null}},K={_caughtError:null,_hasCaughtError:!1,_rethrowError:null,_hasRethrowError:!1,injection:{injectErrorUtils:function(a){\"function\"!==typeof a.invokeGuardedCallback?w(\"197\"):void 0;cb=a.invokeGuardedCallback}},invokeGuardedCallback:function(a,\nb,c,d,e,f,g,h,k){cb.apply(K,arguments)},invokeGuardedCallbackAndCatchFirstError:function(a,b,c,d,e,f,g,h,k){K.invokeGuardedCallback.apply(this,arguments);if(K.hasCaughtError()){var p=K.clearCaughtError();K._hasRethrowError||(K._hasRethrowError=!0,K._rethrowError=p)}},rethrowCaughtError:function(){return db.apply(K,arguments)},hasCaughtError:function(){return K._hasCaughtError},clearCaughtError:function(){if(K._hasCaughtError){var a=K._caughtError;K._caughtError=null;K._hasCaughtError=!1;return a}w(\"198\")}};\nfunction cb(a,b,c,d,e,f,g,h,k){K._hasCaughtError=!1;K._caughtError=null;var p=Array.prototype.slice.call(arguments,3);try{b.apply(c,p)}catch(x){K._caughtError=x,K._hasCaughtError=!0}}function db(){if(K._hasRethrowError){var a=K._rethrowError;K._rethrowError=null;K._hasRethrowError=!1;throw a;}}var eb=K,fb;function gb(a,b,c,d){b=a.type||\"unknown-event\";a.currentTarget=hb.getNodeFromInstance(d);eb.invokeGuardedCallbackAndCatchFirstError(b,c,void 0,a);a.currentTarget=null}\nvar hb={isEndish:function(a){return\"topMouseUp\"===a||\"topTouchEnd\"===a||\"topTouchCancel\"===a},isMoveish:function(a){return\"topMouseMove\"===a||\"topTouchMove\"===a},isStartish:function(a){return\"topMouseDown\"===a||\"topTouchStart\"===a},executeDirectDispatch:function(a){var b=a._dispatchListeners,c=a._dispatchInstances;Array.isArray(b)?w(\"103\"):void 0;a.currentTarget=b?hb.getNodeFromInstance(c):null;b=b?b(a):null;a.currentTarget=null;a._dispatchListeners=null;a._dispatchInstances=null;return b},executeDispatchesInOrder:function(a,\nb){var c=a._dispatchListeners,d=a._dispatchInstances;if(Array.isArray(c))for(var e=0;e<c.length&&!a.isPropagationStopped();e++)gb(a,b,c[e],d[e]);else c&&gb(a,b,c,d);a._dispatchListeners=null;a._dispatchInstances=null},executeDispatchesInOrderStopAtTrue:function(a){a:{var b=a._dispatchListeners;var c=a._dispatchInstances;if(Array.isArray(b))for(var d=0;d<b.length&&!a.isPropagationStopped();d++){if(b[d](a,c[d])){b=c[d];break a}}else if(b&&b(a,c)){b=c;break a}b=null}a._dispatchInstances=null;a._dispatchListeners=\nnull;return b},hasDispatches:function(a){return!!a._dispatchListeners},getFiberCurrentPropsFromNode:function(a){return fb.getFiberCurrentPropsFromNode(a)},getInstanceFromNode:function(a){return fb.getInstanceFromNode(a)},getNodeFromInstance:function(a){return fb.getNodeFromInstance(a)},injection:{injectComponentTree:function(a){fb=a}}},ib=hb,jb=null,kb=null,lb=null;\nfunction mb(a){if(a=ib.getInstanceFromNode(a))if(\"number\"===typeof a.tag){jb&&\"function\"===typeof jb.restoreControlledState?void 0:w(\"194\");var b=ib.getFiberCurrentPropsFromNode(a.stateNode);jb.restoreControlledState(a.stateNode,a.type,b)}else\"function\"!==typeof a.restoreControlledState?w(\"195\"):void 0,a.restoreControlledState()}\nvar nb={injection:{injectFiberControlledHostComponent:function(a){jb=a}},enqueueStateRestore:function(a){kb?lb?lb.push(a):lb=[a]:kb=a},restoreStateIfNeeded:function(){if(kb){var a=kb,b=lb;lb=kb=null;mb(a);if(b)for(a=0;a<b.length;a++)mb(b[a])}}};function ob(a,b,c,d,e,f){return a(b,c,d,e,f)}function pb(a,b){return a(b)}function qb(a,b){return pb(a,b)}\nvar rb=!1,sb={batchedUpdates:function(a,b){if(rb)return ob(qb,a,b);rb=!0;try{return ob(qb,a,b)}finally{rb=!1,nb.restoreStateIfNeeded()}},injection:{injectStackBatchedUpdates:function(a){ob=a},injec
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment