From 0da2c37e63b7022b5a9a767c9658e6dc056bc515 Mon Sep 17 00:00:00 2001 From: Philipp Fehr Date: Tue, 18 Feb 2020 17:47:01 +0100 Subject: [PATCH 1/3] Remove webpack builds, make webpack public path runtime --- .gitignore | 4 +- formwidgets/GraphQLSchemaEditor.php | 3 +- .../assets/0.graphqlschemaeditor.js | 15 - .../assets/0b4894564ab0a74ae4e3.worker.js | 1 - .../assets/1.graphqlschemaeditor.js | 519 - .../assets/10.graphqlschemaeditor.js | 15 - .../assets/11.graphqlschemaeditor.js | 15 - .../assets/12.graphqlschemaeditor.js | 15 - .../assets/13.graphqlschemaeditor.js | 15 - .../assets/14.graphqlschemaeditor.js | 15 - .../assets/15.graphqlschemaeditor.js | 15 - .../assets/16.graphqlschemaeditor.js | 15 - .../assets/17.graphqlschemaeditor.js | 15 - .../assets/18.graphqlschemaeditor.js | 15 - .../assets/188fd4683e6467540b46.worker.js | 1 - .../assets/19.graphqlschemaeditor.js | 15 - .../assets/2.graphqlschemaeditor.js | 399 - .../assets/20.graphqlschemaeditor.js | 15 - .../assets/21.graphqlschemaeditor.js | 15 - .../assets/22.graphqlschemaeditor.js | 15 - .../assets/23.graphqlschemaeditor.js | 15 - .../assets/24.graphqlschemaeditor.js | 15 - .../assets/25.graphqlschemaeditor.js | 15 - .../assets/26.graphqlschemaeditor.js | 15 - .../assets/27.graphqlschemaeditor.js | 15 - .../assets/28.graphqlschemaeditor.js | 15 - .../assets/29.graphqlschemaeditor.js | 15 - .../assets/3.graphqlschemaeditor.js | 339 - .../assets/30.graphqlschemaeditor.js | 15 - .../assets/31.graphqlschemaeditor.js | 15 - .../assets/32.graphqlschemaeditor.js | 15 - .../assets/33.graphqlschemaeditor.js | 15 - .../assets/34.graphqlschemaeditor.js | 15 - .../assets/35.graphqlschemaeditor.js | 15 - .../assets/36.graphqlschemaeditor.js | 15 - .../assets/37.graphqlschemaeditor.js | 15 - .../assets/38.graphqlschemaeditor.js | 15 - .../assets/39.graphqlschemaeditor.js | 15 - .../assets/4.graphqlschemaeditor.js | 39 - .../assets/40.graphqlschemaeditor.js | 15 - .../assets/41.graphqlschemaeditor.js | 15 - .../assets/42.graphqlschemaeditor.js | 15 - .../assets/43.graphqlschemaeditor.js | 15 - .../assets/44.graphqlschemaeditor.js | 15 - .../assets/45.graphqlschemaeditor.js | 15 - .../assets/46.graphqlschemaeditor.js | 15 - .../assets/47.graphqlschemaeditor.js | 15 - .../assets/48.graphqlschemaeditor.js | 15 - .../assets/49.graphqlschemaeditor.js | 15 - .../assets/5.graphqlschemaeditor.js | 27 - .../assets/50.graphqlschemaeditor.js | 15 - .../assets/51.graphqlschemaeditor.js | 15 - .../assets/52.graphqlschemaeditor.js | 15 - .../assets/53.graphqlschemaeditor.js | 15 - .../assets/54.graphqlschemaeditor.js | 15 - .../assets/55.graphqlschemaeditor.js | 15 - .../assets/56.graphqlschemaeditor.js | 15 - .../assets/57.graphqlschemaeditor.js | 15 - .../assets/58.graphqlschemaeditor.js | 15 - .../assets/59.graphqlschemaeditor.js | 15 - .../assets/6.graphqlschemaeditor.js | 15 - .../assets/60.graphqlschemaeditor.js | 15 - .../assets/61.graphqlschemaeditor.js | 15 - .../assets/62.graphqlschemaeditor.js | 15 - .../assets/63.graphqlschemaeditor.js | 15 - .../assets/64.graphqlschemaeditor.js | 1 - .../assets/64e0cd421fa4a53b03c1.worker.js | 1 - .../assets/7.graphqlschemaeditor.js | 15 - .../assets/7539664022d133e935bd.worker.js | 1637 --- .../assets/8.graphqlschemaeditor.js | 15 - .../assets/8125ddbdbde74fdf4b94.worker.js | 112 - .../assets/9.graphqlschemaeditor.js | 15 - .../a609dc0f334a7d4e64205247c4e8b97c.ttf | Bin 56484 -> 0 bytes .../assets/ac6fec3f622f555129e8.worker.js | 112 - .../assets/de1c1049509be01f1022.worker.js | 540 - .../assets/editor.worker.js | 112 - .../assets/graphqlschemaeditor.js | 11699 ---------------- .../assets/graphqlschemaeditor.js.map | 1 - .../graphqlschemaeditor/assets/packloader.js | 3 - .../partials/_graphqlschemaeditor.htm | 2 + formwidgets/graphqlschemaeditor/src/index.tsx | 2 + .../graphqlschemaeditor/webpack.config.js | 3 +- 82 files changed, 10 insertions(+), 16432 deletions(-) delete mode 100644 formwidgets/graphqlschemaeditor/assets/0.graphqlschemaeditor.js delete mode 100644 formwidgets/graphqlschemaeditor/assets/0b4894564ab0a74ae4e3.worker.js delete mode 100644 formwidgets/graphqlschemaeditor/assets/1.graphqlschemaeditor.js delete mode 100644 formwidgets/graphqlschemaeditor/assets/10.graphqlschemaeditor.js delete mode 100644 formwidgets/graphqlschemaeditor/assets/11.graphqlschemaeditor.js delete mode 100644 formwidgets/graphqlschemaeditor/assets/12.graphqlschemaeditor.js delete mode 100644 formwidgets/graphqlschemaeditor/assets/13.graphqlschemaeditor.js delete mode 100644 formwidgets/graphqlschemaeditor/assets/14.graphqlschemaeditor.js delete mode 100644 formwidgets/graphqlschemaeditor/assets/15.graphqlschemaeditor.js delete mode 100644 formwidgets/graphqlschemaeditor/assets/16.graphqlschemaeditor.js delete mode 100644 formwidgets/graphqlschemaeditor/assets/17.graphqlschemaeditor.js delete mode 100644 formwidgets/graphqlschemaeditor/assets/18.graphqlschemaeditor.js delete mode 100644 formwidgets/graphqlschemaeditor/assets/188fd4683e6467540b46.worker.js delete mode 100644 formwidgets/graphqlschemaeditor/assets/19.graphqlschemaeditor.js delete mode 100644 formwidgets/graphqlschemaeditor/assets/2.graphqlschemaeditor.js delete mode 100644 formwidgets/graphqlschemaeditor/assets/20.graphqlschemaeditor.js delete mode 100644 formwidgets/graphqlschemaeditor/assets/21.graphqlschemaeditor.js delete mode 100644 formwidgets/graphqlschemaeditor/assets/22.graphqlschemaeditor.js delete mode 100644 formwidgets/graphqlschemaeditor/assets/23.graphqlschemaeditor.js delete mode 100644 formwidgets/graphqlschemaeditor/assets/24.graphqlschemaeditor.js delete mode 100644 formwidgets/graphqlschemaeditor/assets/25.graphqlschemaeditor.js delete mode 100644 formwidgets/graphqlschemaeditor/assets/26.graphqlschemaeditor.js delete mode 100644 formwidgets/graphqlschemaeditor/assets/27.graphqlschemaeditor.js delete mode 100644 formwidgets/graphqlschemaeditor/assets/28.graphqlschemaeditor.js delete mode 100644 formwidgets/graphqlschemaeditor/assets/29.graphqlschemaeditor.js delete mode 100644 formwidgets/graphqlschemaeditor/assets/3.graphqlschemaeditor.js delete mode 100644 formwidgets/graphqlschemaeditor/assets/30.graphqlschemaeditor.js delete mode 100644 formwidgets/graphqlschemaeditor/assets/31.graphqlschemaeditor.js delete mode 100644 formwidgets/graphqlschemaeditor/assets/32.graphqlschemaeditor.js delete mode 100644 formwidgets/graphqlschemaeditor/assets/33.graphqlschemaeditor.js delete mode 100644 formwidgets/graphqlschemaeditor/assets/34.graphqlschemaeditor.js delete mode 100644 formwidgets/graphqlschemaeditor/assets/35.graphqlschemaeditor.js delete mode 100644 formwidgets/graphqlschemaeditor/assets/36.graphqlschemaeditor.js delete mode 100644 formwidgets/graphqlschemaeditor/assets/37.graphqlschemaeditor.js delete mode 100644 formwidgets/graphqlschemaeditor/assets/38.graphqlschemaeditor.js delete mode 100644 formwidgets/graphqlschemaeditor/assets/39.graphqlschemaeditor.js delete mode 100644 formwidgets/graphqlschemaeditor/assets/4.graphqlschemaeditor.js delete mode 100644 formwidgets/graphqlschemaeditor/assets/40.graphqlschemaeditor.js delete mode 100644 formwidgets/graphqlschemaeditor/assets/41.graphqlschemaeditor.js delete mode 100644 formwidgets/graphqlschemaeditor/assets/42.graphqlschemaeditor.js delete mode 100644 formwidgets/graphqlschemaeditor/assets/43.graphqlschemaeditor.js delete mode 100644 formwidgets/graphqlschemaeditor/assets/44.graphqlschemaeditor.js delete mode 100644 formwidgets/graphqlschemaeditor/assets/45.graphqlschemaeditor.js delete mode 100644 formwidgets/graphqlschemaeditor/assets/46.graphqlschemaeditor.js delete mode 100644 formwidgets/graphqlschemaeditor/assets/47.graphqlschemaeditor.js delete mode 100644 formwidgets/graphqlschemaeditor/assets/48.graphqlschemaeditor.js delete mode 100644 formwidgets/graphqlschemaeditor/assets/49.graphqlschemaeditor.js delete mode 100644 formwidgets/graphqlschemaeditor/assets/5.graphqlschemaeditor.js delete mode 100644 formwidgets/graphqlschemaeditor/assets/50.graphqlschemaeditor.js delete mode 100644 formwidgets/graphqlschemaeditor/assets/51.graphqlschemaeditor.js delete mode 100644 formwidgets/graphqlschemaeditor/assets/52.graphqlschemaeditor.js delete mode 100644 formwidgets/graphqlschemaeditor/assets/53.graphqlschemaeditor.js delete mode 100644 formwidgets/graphqlschemaeditor/assets/54.graphqlschemaeditor.js delete mode 100644 formwidgets/graphqlschemaeditor/assets/55.graphqlschemaeditor.js delete mode 100644 formwidgets/graphqlschemaeditor/assets/56.graphqlschemaeditor.js delete mode 100644 formwidgets/graphqlschemaeditor/assets/57.graphqlschemaeditor.js delete mode 100644 formwidgets/graphqlschemaeditor/assets/58.graphqlschemaeditor.js delete mode 100644 formwidgets/graphqlschemaeditor/assets/59.graphqlschemaeditor.js delete mode 100644 formwidgets/graphqlschemaeditor/assets/6.graphqlschemaeditor.js delete mode 100644 formwidgets/graphqlschemaeditor/assets/60.graphqlschemaeditor.js delete mode 100644 formwidgets/graphqlschemaeditor/assets/61.graphqlschemaeditor.js delete mode 100644 formwidgets/graphqlschemaeditor/assets/62.graphqlschemaeditor.js delete mode 100644 formwidgets/graphqlschemaeditor/assets/63.graphqlschemaeditor.js delete mode 100644 formwidgets/graphqlschemaeditor/assets/64.graphqlschemaeditor.js delete mode 100644 formwidgets/graphqlschemaeditor/assets/64e0cd421fa4a53b03c1.worker.js delete mode 100644 formwidgets/graphqlschemaeditor/assets/7.graphqlschemaeditor.js delete mode 100644 formwidgets/graphqlschemaeditor/assets/7539664022d133e935bd.worker.js delete mode 100644 formwidgets/graphqlschemaeditor/assets/8.graphqlschemaeditor.js delete mode 100644 formwidgets/graphqlschemaeditor/assets/8125ddbdbde74fdf4b94.worker.js delete mode 100644 formwidgets/graphqlschemaeditor/assets/9.graphqlschemaeditor.js delete mode 100644 formwidgets/graphqlschemaeditor/assets/a609dc0f334a7d4e64205247c4e8b97c.ttf delete mode 100644 formwidgets/graphqlschemaeditor/assets/ac6fec3f622f555129e8.worker.js delete mode 100644 formwidgets/graphqlschemaeditor/assets/de1c1049509be01f1022.worker.js delete mode 100644 formwidgets/graphqlschemaeditor/assets/editor.worker.js delete mode 100644 formwidgets/graphqlschemaeditor/assets/graphqlschemaeditor.js delete mode 100644 formwidgets/graphqlschemaeditor/assets/graphqlschemaeditor.js.map delete mode 100644 formwidgets/graphqlschemaeditor/assets/packloader.js diff --git a/.gitignore b/.gitignore index 0eb087d..057d2cc 100644 --- a/.gitignore +++ b/.gitignore @@ -2,4 +2,6 @@ graphql/*.graphql graphql/schema.graphql.valid -node_modules/ \ No newline at end of file +node_modules/ +formwidgets/graphqlschemaeditor/assets/ +!formwidgets/graphqlschemaeditor/assets/.gitkeep \ No newline at end of file diff --git a/formwidgets/GraphQLSchemaEditor.php b/formwidgets/GraphQLSchemaEditor.php index c6ce4a7..f2a2ded 100644 --- a/formwidgets/GraphQLSchemaEditor.php +++ b/formwidgets/GraphQLSchemaEditor.php @@ -38,6 +38,8 @@ public function prepareVars() $this->vars['name'] = $this->formField->getName(); $this->vars['value'] = $this->getLoadValue(); $this->vars['model'] = $this->model; + $this->vars['webpackAssetsUrl'] = asset('plugins/thefehr/lighthouse/formwidgets/graphqlschemaeditor/assets/'); + $this->vars['webpackUrl'] = asset('plugins/thefehr/lighthouse/formwidgets/graphqlschemaeditor/assets/graphqlschemaeditor.js'); } /** @@ -45,7 +47,6 @@ public function prepareVars() */ public function loadAssets() { - $this->addJs('packloader.js', 'TheFehr.Lighthouse'); $this->addCss('https://code.cdn.mozilla.net/fonts/fira.css'); } diff --git a/formwidgets/graphqlschemaeditor/assets/0.graphqlschemaeditor.js b/formwidgets/graphqlschemaeditor/assets/0.graphqlschemaeditor.js deleted file mode 100644 index 2f9faa0..0000000 --- a/formwidgets/graphqlschemaeditor/assets/0.graphqlschemaeditor.js +++ /dev/null @@ -1,15 +0,0 @@ -(window["webpackJsonp"] = window["webpackJsonp"] || []).push([[0],{ - -/***/ "./node_modules/monaco-editor/esm/vs/basic-languages/cpp/cpp.js": -/*!**********************************************************************!*\ - !*** ./node_modules/monaco-editor/esm/vs/basic-languages/cpp/cpp.js ***! - \**********************************************************************/ -/*! exports provided: conf, language */ -/***/ (function(module, __webpack_exports__, __webpack_require__) { - -"use strict"; -eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"conf\", function() { return conf; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"language\", function() { return language; });\n/*---------------------------------------------------------------------------------------------\r\n * Copyright (c) Microsoft Corporation. All rights reserved.\r\n * Licensed under the MIT License. See License.txt in the project root for license information.\r\n *--------------------------------------------------------------------------------------------*/\r\n\r\nvar conf = {\r\n comments: {\r\n lineComment: '//',\r\n blockComment: ['/*', '*/'],\r\n },\r\n brackets: [\r\n ['{', '}'],\r\n ['[', ']'],\r\n ['(', ')']\r\n ],\r\n autoClosingPairs: [\r\n { open: '[', close: ']' },\r\n { open: '{', close: '}' },\r\n { open: '(', close: ')' },\r\n { open: '\\'', close: '\\'', notIn: ['string', 'comment'] },\r\n { open: '\"', close: '\"', notIn: ['string'] },\r\n ],\r\n surroundingPairs: [\r\n { open: '{', close: '}' },\r\n { open: '[', close: ']' },\r\n { open: '(', close: ')' },\r\n { open: '\"', close: '\"' },\r\n { open: '\\'', close: '\\'' },\r\n ],\r\n folding: {\r\n markers: {\r\n start: new RegExp(\"^\\\\s*#pragma\\\\s+region\\\\b\"),\r\n end: new RegExp(\"^\\\\s*#pragma\\\\s+endregion\\\\b\")\r\n }\r\n }\r\n};\r\nvar language = {\r\n defaultToken: '',\r\n tokenPostfix: '.cpp',\r\n brackets: [\r\n { token: 'delimiter.curly', open: '{', close: '}' },\r\n { token: 'delimiter.parenthesis', open: '(', close: ')' },\r\n { token: 'delimiter.square', open: '[', close: ']' },\r\n { token: 'delimiter.angle', open: '<', close: '>' }\r\n ],\r\n keywords: [\r\n 'abstract',\r\n 'amp',\r\n 'array',\r\n 'auto',\r\n 'bool',\r\n 'break',\r\n 'case',\r\n 'catch',\r\n 'char',\r\n 'class',\r\n 'const',\r\n 'constexpr',\r\n 'const_cast',\r\n 'continue',\r\n 'cpu',\r\n 'decltype',\r\n 'default',\r\n 'delegate',\r\n 'delete',\r\n 'do',\r\n 'double',\r\n 'dynamic_cast',\r\n 'each',\r\n 'else',\r\n 'enum',\r\n 'event',\r\n 'explicit',\r\n 'export',\r\n 'extern',\r\n 'false',\r\n 'final',\r\n 'finally',\r\n 'float',\r\n 'for',\r\n 'friend',\r\n 'gcnew',\r\n 'generic',\r\n 'goto',\r\n 'if',\r\n 'in',\r\n 'initonly',\r\n 'inline',\r\n 'int',\r\n 'interface',\r\n 'interior_ptr',\r\n 'internal',\r\n 'literal',\r\n 'long',\r\n 'mutable',\r\n 'namespace',\r\n 'new',\r\n 'noexcept',\r\n 'nullptr',\r\n '__nullptr',\r\n 'operator',\r\n 'override',\r\n 'partial',\r\n 'pascal',\r\n 'pin_ptr',\r\n 'private',\r\n 'property',\r\n 'protected',\r\n 'public',\r\n 'ref',\r\n 'register',\r\n 'reinterpret_cast',\r\n 'restrict',\r\n 'return',\r\n 'safe_cast',\r\n 'sealed',\r\n 'short',\r\n 'signed',\r\n 'sizeof',\r\n 'static',\r\n 'static_assert',\r\n 'static_cast',\r\n 'struct',\r\n 'switch',\r\n 'template',\r\n 'this',\r\n 'thread_local',\r\n 'throw',\r\n 'tile_static',\r\n 'true',\r\n 'try',\r\n 'typedef',\r\n 'typeid',\r\n 'typename',\r\n 'union',\r\n 'unsigned',\r\n 'using',\r\n 'virtual',\r\n 'void',\r\n 'volatile',\r\n 'wchar_t',\r\n 'where',\r\n 'while',\r\n '_asm',\r\n '_based',\r\n '_cdecl',\r\n '_declspec',\r\n '_fastcall',\r\n '_if_exists',\r\n '_if_not_exists',\r\n '_inline',\r\n '_multiple_inheritance',\r\n '_pascal',\r\n '_single_inheritance',\r\n '_stdcall',\r\n '_virtual_inheritance',\r\n '_w64',\r\n '__abstract',\r\n '__alignof',\r\n '__asm',\r\n '__assume',\r\n '__based',\r\n '__box',\r\n '__builtin_alignof',\r\n '__cdecl',\r\n '__clrcall',\r\n '__declspec',\r\n '__delegate',\r\n '__event',\r\n '__except',\r\n '__fastcall',\r\n '__finally',\r\n '__forceinline',\r\n '__gc',\r\n '__hook',\r\n '__identifier',\r\n '__if_exists',\r\n '__if_not_exists',\r\n '__inline',\r\n '__int128',\r\n '__int16',\r\n '__int32',\r\n '__int64',\r\n '__int8',\r\n '__interface',\r\n '__leave',\r\n '__m128',\r\n '__m128d',\r\n '__m128i',\r\n '__m256',\r\n '__m256d',\r\n '__m256i',\r\n '__m64',\r\n '__multiple_inheritance',\r\n '__newslot',\r\n '__nogc',\r\n '__noop',\r\n '__nounwind',\r\n '__novtordisp',\r\n '__pascal',\r\n '__pin',\r\n '__pragma',\r\n '__property',\r\n '__ptr32',\r\n '__ptr64',\r\n '__raise',\r\n '__restrict',\r\n '__resume',\r\n '__sealed',\r\n '__single_inheritance',\r\n '__stdcall',\r\n '__super',\r\n '__thiscall',\r\n '__try',\r\n '__try_cast',\r\n '__typeof',\r\n '__unaligned',\r\n '__unhook',\r\n '__uuidof',\r\n '__value',\r\n '__virtual_inheritance',\r\n '__w64',\r\n '__wchar_t'\r\n ],\r\n operators: [\r\n '=', '>', '<', '!', '~', '?', ':',\r\n '==', '<=', '>=', '!=', '&&', '||', '++', '--',\r\n '+', '-', '*', '/', '&', '|', '^', '%', '<<',\r\n '>>', '>>>', '+=', '-=', '*=', '/=', '&=', '|=',\r\n '^=', '%=', '<<=', '>>=', '>>>='\r\n ],\r\n // we include these common regular expressions\r\n symbols: /[=>](?!@symbols)/, '@brackets'],\r\n [/@symbols/, {\r\n cases: {\r\n '@operators': 'delimiter',\r\n '@default': ''\r\n }\r\n }],\r\n // numbers\r\n [/\\d*\\d+[eE]([\\-+]?\\d+)?(@floatsuffix)/, 'number.float'],\r\n [/\\d*\\.\\d+([eE][\\-+]?\\d+)?(@floatsuffix)/, 'number.float'],\r\n [/0[xX][0-9a-fA-F']*[0-9a-fA-F](@integersuffix)/, 'number.hex'],\r\n [/0[0-7']*[0-7](@integersuffix)/, 'number.octal'],\r\n [/0[bB][0-1']*[0-1](@integersuffix)/, 'number.binary'],\r\n [/\\d[\\d']*\\d(@integersuffix)/, 'number'],\r\n [/\\d(@integersuffix)/, 'number'],\r\n // delimiter: after number because of .\\d floats\r\n [/[;,.]/, 'delimiter'],\r\n // strings\r\n [/\"([^\"\\\\]|\\\\.)*$/, 'string.invalid'],\r\n [/\"/, 'string', '@string'],\r\n // characters\r\n [/'[^\\\\']'/, 'string'],\r\n [/(')(@escapes)(')/, ['string', 'string.escape', 'string']],\r\n [/'/, 'string.invalid']\r\n ],\r\n whitespace: [\r\n [/[ \\t\\r\\n]+/, ''],\r\n [/\\/\\*\\*(?!\\/)/, 'comment.doc', '@doccomment'],\r\n [/\\/\\*/, 'comment', '@comment'],\r\n [/\\/\\/.*$/, 'comment'],\r\n ],\r\n comment: [\r\n [/[^\\/*]+/, 'comment'],\r\n [/\\*\\//, 'comment', '@pop'],\r\n [/[\\/*]/, 'comment']\r\n ],\r\n //Identical copy of comment above, except for the addition of .doc\r\n doccomment: [\r\n [/[^\\/*]+/, 'comment.doc'],\r\n [/\\*\\//, 'comment.doc', '@pop'],\r\n [/[\\/*]/, 'comment.doc']\r\n ],\r\n string: [\r\n [/[^\\\\\"]+/, 'string'],\r\n [/@escapes/, 'string.escape'],\r\n [/\\\\./, 'string.escape.invalid'],\r\n [/\"/, 'string', '@pop']\r\n ],\r\n raw: [\r\n [/(.*)(\\))(?:([^ ()\\\\\\t]*))(\\\")/, {\r\n cases: {\r\n '$3==$S2': ['string.raw', 'string.raw.end', 'string.raw.end', { token: 'string.raw.end', next: '@pop' }],\r\n '@default': ['string.raw', 'string.raw', 'string.raw', 'string.raw']\r\n }\r\n }\r\n ],\r\n [/.*/, 'string.raw']\r\n ],\r\n include: [\r\n [/(\\s*)(<)([^<>]*)(>)/, ['', 'keyword.directive.include.begin', 'string.include.identifier', { token: 'keyword.directive.include.end', next: '@pop' }]],\r\n [/(\\s*)(\")([^\"]*)(\")/, ['', 'keyword.directive.include.begin', 'string.include.identifier', { token: 'keyword.directive.include.end', next: '@pop' }]]\r\n ]\r\n },\r\n};\r\n\n\n//# sourceURL=webpack:///./node_modules/monaco-editor/esm/vs/basic-languages/cpp/cpp.js?"); - -/***/ }) - -}]); \ No newline at end of file diff --git a/formwidgets/graphqlschemaeditor/assets/0b4894564ab0a74ae4e3.worker.js b/formwidgets/graphqlschemaeditor/assets/0b4894564ab0a74ae4e3.worker.js deleted file mode 100644 index 171ba8a..0000000 --- a/formwidgets/graphqlschemaeditor/assets/0b4894564ab0a74ae4e3.worker.js +++ /dev/null @@ -1 +0,0 @@ -!function(e){var t={};function n(r){if(t[r])return t[r].exports;var i=t[r]={i:r,l:!1,exports:{}};return e[r].call(i.exports,i,i.exports,n),i.l=!0,i.exports}n.m=e,n.c=t,n.d=function(e,t,r){n.o(e,t)||Object.defineProperty(e,t,{enumerable:!0,get:r})},n.r=function(e){"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(e,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(e,"__esModule",{value:!0})},n.t=function(e,t){if(1&t&&(e=n(e)),8&t)return e;if(4&t&&"object"==typeof e&&e&&e.__esModule)return e;var r=Object.create(null);if(n.r(r),Object.defineProperty(r,"default",{enumerable:!0,value:e}),2&t&&"string"!=typeof e)for(var i in e)n.d(r,i,function(t){return e[t]}.bind(null,i));return r},n.n=function(e){var t=e&&e.__esModule?function(){return e.default}:function(){return e};return n.d(t,"a",t),t},n.o=function(e,t){return Object.prototype.hasOwnProperty.call(e,t)},n.p="http://localhost:8080/plugins/thefehr/lighthouse/formwidgets/graphqlschemaeditor/assets/",n(n.s=0)}([function(e,t,n){e.exports=function(){return n(1)('!function(e){var t={};function n(r){if(t[r])return t[r].exports;var i=t[r]={i:r,l:!1,exports:{}};return e[r].call(i.exports,i,i.exports,n),i.l=!0,i.exports}n.m=e,n.c=t,n.d=function(e,t,r){n.o(e,t)||Object.defineProperty(e,t,{enumerable:!0,get:r})},n.r=function(e){"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(e,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(e,"__esModule",{value:!0})},n.t=function(e,t){if(1&t&&(e=n(e)),8&t)return e;if(4&t&&"object"==typeof e&&e&&e.__esModule)return e;var r=Object.create(null);if(n.r(r),Object.defineProperty(r,"default",{enumerable:!0,value:e}),2&t&&"string"!=typeof e)for(var i in e)n.d(r,i,function(t){return e[t]}.bind(null,i));return r},n.n=function(e){var t=e&&e.__esModule?function(){return e.default}:function(){return e};return n.d(t,"a",t),t},n.o=function(e,t){return Object.prototype.hasOwnProperty.call(e,t)},n.p="http://localhost:8080/plugins/thefehr/lighthouse/formwidgets/graphqlschemaeditor/assets/",n(n.s=104)}([function(e,t,n){"use strict";Object.defineProperty(t,"__esModule",{value:!0}),Object.defineProperty(t,"isSchema",{enumerable:!0,get:function(){return r.isSchema}}),Object.defineProperty(t,"assertSchema",{enumerable:!0,get:function(){return r.assertSchema}}),Object.defineProperty(t,"GraphQLSchema",{enumerable:!0,get:function(){return r.GraphQLSchema}}),Object.defineProperty(t,"isType",{enumerable:!0,get:function(){return i.isType}}),Object.defineProperty(t,"isScalarType",{enumerable:!0,get:function(){return i.isScalarType}}),Object.defineProperty(t,"isObjectType",{enumerable:!0,get:function(){return i.isObjectType}}),Object.defineProperty(t,"isInterfaceType",{enumerable:!0,get:function(){return i.isInterfaceType}}),Object.defineProperty(t,"isUnionType",{enumerable:!0,get:function(){return i.isUnionType}}),Object.defineProperty(t,"isEnumType",{enumerable:!0,get:function(){return i.isEnumType}}),Object.defineProperty(t,"isInputObjectType",{enumerable:!0,get:function(){return i.isInputObjectType}}),Object.defineProperty(t,"isListType",{enumerable:!0,get:function(){return i.isListType}}),Object.defineProperty(t,"isNonNullType",{enumerable:!0,get:function(){return i.isNonNullType}}),Object.defineProperty(t,"isInputType",{enumerable:!0,get:function(){return i.isInputType}}),Object.defineProperty(t,"isOutputType",{enumerable:!0,get:function(){return i.isOutputType}}),Object.defineProperty(t,"isLeafType",{enumerable:!0,get:function(){return i.isLeafType}}),Object.defineProperty(t,"isCompositeType",{enumerable:!0,get:function(){return i.isCompositeType}}),Object.defineProperty(t,"isAbstractType",{enumerable:!0,get:function(){return i.isAbstractType}}),Object.defineProperty(t,"isWrappingType",{enumerable:!0,get:function(){return i.isWrappingType}}),Object.defineProperty(t,"isNullableType",{enumerable:!0,get:function(){return i.isNullableType}}),Object.defineProperty(t,"isNamedType",{enumerable:!0,get:function(){return i.isNamedType}}),Object.defineProperty(t,"isRequiredArgument",{enumerable:!0,get:function(){return i.isRequiredArgument}}),Object.defineProperty(t,"isRequiredInputField",{enumerable:!0,get:function(){return i.isRequiredInputField}}),Object.defineProperty(t,"assertType",{enumerable:!0,get:function(){return i.assertType}}),Object.defineProperty(t,"assertScalarType",{enumerable:!0,get:function(){return i.assertScalarType}}),Object.defineProperty(t,"assertObjectType",{enumerable:!0,get:function(){return i.assertObjectType}}),Object.defineProperty(t,"assertInterfaceType",{enumerable:!0,get:function(){return i.assertInterfaceType}}),Object.defineProperty(t,"assertUnionType",{enumerable:!0,get:function(){return i.assertUnionType}}),Object.defineProperty(t,"assertEnumType",{enumerable:!0,get:function(){return i.assertEnumType}}),Object.defineProperty(t,"assertInputObjectType",{enumerable:!0,get:function(){return i.assertInputObjectType}}),Object.defineProperty(t,"assertListType",{enumerable:!0,get:function(){return i.assertListType}}),Object.defineProperty(t,"assertNonNullType",{enumerable:!0,get:function(){return i.assertNonNullType}}),Object.defineProperty(t,"assertInputType",{enumerable:!0,get:function(){return i.assertInputType}}),Object.defineProperty(t,"assertOutputType",{enumerable:!0,get:function(){return i.assertOutputType}}),Object.defineProperty(t,"assertLeafType",{enumerable:!0,get:function(){return i.assertLeafType}}),Object.defineProperty(t,"assertCompositeType",{enumerable:!0,get:function(){return i.assertCompositeType}}),Object.defineProperty(t,"assertAbstractType",{enumerable:!0,get:function(){return i.assertAbstractType}}),Object.defineProperty(t,"assertWrappingType",{enumerable:!0,get:function(){return i.assertWrappingType}}),Object.defineProperty(t,"assertNullableType",{enumerable:!0,get:function(){return i.assertNullableType}}),Object.defineProperty(t,"assertNamedType",{enumerable:!0,get:function(){return i.assertNamedType}}),Object.defineProperty(t,"getNullableType",{enumerable:!0,get:function(){return i.getNullableType}}),Object.defineProperty(t,"getNamedType",{enumerable:!0,get:function(){return i.getNamedType}}),Object.defineProperty(t,"GraphQLScalarType",{enumerable:!0,get:function(){return i.GraphQLScalarType}}),Object.defineProperty(t,"GraphQLObjectType",{enumerable:!0,get:function(){return i.GraphQLObjectType}}),Object.defineProperty(t,"GraphQLInterfaceType",{enumerable:!0,get:function(){return i.GraphQLInterfaceType}}),Object.defineProperty(t,"GraphQLUnionType",{enumerable:!0,get:function(){return i.GraphQLUnionType}}),Object.defineProperty(t,"GraphQLEnumType",{enumerable:!0,get:function(){return i.GraphQLEnumType}}),Object.defineProperty(t,"GraphQLInputObjectType",{enumerable:!0,get:function(){return i.GraphQLInputObjectType}}),Object.defineProperty(t,"GraphQLList",{enumerable:!0,get:function(){return i.GraphQLList}}),Object.defineProperty(t,"GraphQLNonNull",{enumerable:!0,get:function(){return i.GraphQLNonNull}}),Object.defineProperty(t,"isDirective",{enumerable:!0,get:function(){return a.isDirective}}),Object.defineProperty(t,"assertDirective",{enumerable:!0,get:function(){return a.assertDirective}}),Object.defineProperty(t,"GraphQLDirective",{enumerable:!0,get:function(){return a.GraphQLDirective}}),Object.defineProperty(t,"isSpecifiedDirective",{enumerable:!0,get:function(){return a.isSpecifiedDirective}}),Object.defineProperty(t,"specifiedDirectives",{enumerable:!0,get:function(){return a.specifiedDirectives}}),Object.defineProperty(t,"GraphQLIncludeDirective",{enumerable:!0,get:function(){return a.GraphQLIncludeDirective}}),Object.defineProperty(t,"GraphQLSkipDirective",{enumerable:!0,get:function(){return a.GraphQLSkipDirective}}),Object.defineProperty(t,"GraphQLDeprecatedDirective",{enumerable:!0,get:function(){return a.GraphQLDeprecatedDirective}}),Object.defineProperty(t,"DEFAULT_DEPRECATION_REASON",{enumerable:!0,get:function(){return a.DEFAULT_DEPRECATION_REASON}}),Object.defineProperty(t,"isSpecifiedScalarType",{enumerable:!0,get:function(){return o.isSpecifiedScalarType}}),Object.defineProperty(t,"specifiedScalarTypes",{enumerable:!0,get:function(){return o.specifiedScalarTypes}}),Object.defineProperty(t,"GraphQLInt",{enumerable:!0,get:function(){return o.GraphQLInt}}),Object.defineProperty(t,"GraphQLFloat",{enumerable:!0,get:function(){return o.GraphQLFloat}}),Object.defineProperty(t,"GraphQLString",{enumerable:!0,get:function(){return o.GraphQLString}}),Object.defineProperty(t,"GraphQLBoolean",{enumerable:!0,get:function(){return o.GraphQLBoolean}}),Object.defineProperty(t,"GraphQLID",{enumerable:!0,get:function(){return o.GraphQLID}}),Object.defineProperty(t,"isIntrospectionType",{enumerable:!0,get:function(){return u.isIntrospectionType}}),Object.defineProperty(t,"introspectionTypes",{enumerable:!0,get:function(){return u.introspectionTypes}}),Object.defineProperty(t,"__Schema",{enumerable:!0,get:function(){return u.__Schema}}),Object.defineProperty(t,"__Directive",{enumerable:!0,get:function(){return u.__Directive}}),Object.defineProperty(t,"__DirectiveLocation",{enumerable:!0,get:function(){return u.__DirectiveLocation}}),Object.defineProperty(t,"__Type",{enumerable:!0,get:function(){return u.__Type}}),Object.defineProperty(t,"__Field",{enumerable:!0,get:function(){return u.__Field}}),Object.defineProperty(t,"__InputValue",{enumerable:!0,get:function(){return u.__InputValue}}),Object.defineProperty(t,"__EnumValue",{enumerable:!0,get:function(){return u.__EnumValue}}),Object.defineProperty(t,"__TypeKind",{enumerable:!0,get:function(){return u.__TypeKind}}),Object.defineProperty(t,"TypeKind",{enumerable:!0,get:function(){return u.TypeKind}}),Object.defineProperty(t,"SchemaMetaFieldDef",{enumerable:!0,get:function(){return u.SchemaMetaFieldDef}}),Object.defineProperty(t,"TypeMetaFieldDef",{enumerable:!0,get:function(){return u.TypeMetaFieldDef}}),Object.defineProperty(t,"TypeNameMetaFieldDef",{enumerable:!0,get:function(){return u.TypeNameMetaFieldDef}}),Object.defineProperty(t,"validateSchema",{enumerable:!0,get:function(){return c.validateSchema}}),Object.defineProperty(t,"assertValidSchema",{enumerable:!0,get:function(){return c.assertValidSchema}});var r=n(19),i=n(4),a=n(10),o=n(15),u=n(12),c=n(40)},function(e,t,n){"use strict";Object.defineProperty(t,"__esModule",{value:!0}),t.GraphQLError=u,t.printError=c;var r,i=(r=n(14))&&r.__esModule?r:{default:r},a=n(49),o=n(63);function u(e,t,n,r,o,c,s){var p=Array.isArray(t)?0!==t.length?t:void 0:t?[t]:void 0,l=n;if(!l&&p){var f=p[0];l=f&&f.loc&&f.loc.source}var d,y=r;!y&&p&&(y=p.reduce((function(e,t){return t.loc&&e.push(t.loc.start),e}),[])),y&&0===y.length&&(y=void 0),r&&n?d=r.map((function(e){return(0,a.getLocation)(n,e)})):p&&(d=p.reduce((function(e,t){return t.loc&&e.push((0,a.getLocation)(t.loc.source,t.loc.start)),e}),[]));var v=s;if(null==v&&null!=c){var h=c.extensions;(0,i.default)(h)&&(v=h)}Object.defineProperties(this,{message:{value:e,enumerable:!0,writable:!0},locations:{value:d||void 0,enumerable:Boolean(d)},path:{value:o||void 0,enumerable:Boolean(o)},nodes:{value:p||void 0},source:{value:l||void 0},positions:{value:y||void 0},originalError:{value:c},extensions:{value:v||void 0,enumerable:Boolean(v)}}),c&&c.stack?Object.defineProperty(this,"stack",{value:c.stack,writable:!0,configurable:!0}):Error.captureStackTrace?Error.captureStackTrace(this,u):Object.defineProperty(this,"stack",{value:Error().stack,writable:!0,configurable:!0})}function c(e){var t=e.message;if(e.nodes)for(var n=0,r=e.nodes;n0?e:void 0}x.prototype.toString=function(){return"["+String(this.ofType)+"]"},(0,y.default)(x),(0,d.default)(x),M.prototype.toString=function(){return String(this.ofType)+"!"},(0,y.default)(M),(0,d.default)(M);var B=function(){function e(e){var t=e.parseValue||f.default;this.name=e.name,this.description=e.description,this.serialize=e.serialize||f.default,this.parseValue=t,this.parseLiteral=e.parseLiteral||function(e){return t((0,h.valueFromASTUntyped)(e))},this.extensions=e.extensions&&(0,u.default)(e.extensions),this.astNode=e.astNode,this.extensionASTNodes=U(e.extensionASTNodes),"string"==typeof e.name||(0,c.default)(0,"Must provide name."),null==e.serialize||"function"==typeof e.serialize||(0,c.default)(0,"".concat(this.name,\' must provide "serialize" function. If this custom Scalar is also used as an input type, ensure "parseValue" and "parseLiteral" functions are also provided.\')),e.parseLiteral&&("function"==typeof e.parseValue&&"function"==typeof e.parseLiteral||(0,c.default)(0,"".concat(this.name,\' must provide both "parseValue" and "parseLiteral" functions.\')))}var t=e.prototype;return t.toConfig=function(){return{name:this.name,description:this.description,serialize:this.serialize,parseValue:this.parseValue,parseLiteral:this.parseLiteral,extensions:this.extensions,astNode:this.astNode,extensionASTNodes:this.extensionASTNodes||[]}},t.toString=function(){return this.name},e}();t.GraphQLScalarType=B,(0,y.default)(B),(0,d.default)(B);var q=function(){function e(e){this.name=e.name,this.description=e.description,this.isTypeOf=e.isTypeOf,this.extensions=e.extensions&&(0,u.default)(e.extensions),this.astNode=e.astNode,this.extensionASTNodes=U(e.extensionASTNodes),this._fields=J.bind(void 0,e),this._interfaces=Y.bind(void 0,e),"string"==typeof e.name||(0,c.default)(0,"Must provide name."),null==e.isTypeOf||"function"==typeof e.isTypeOf||(0,c.default)(0,"".concat(this.name,\' must provide "isTypeOf" as a function, \')+"but got: ".concat((0,i.default)(e.isTypeOf),"."))}var t=e.prototype;return t.getFields=function(){return"function"==typeof this._fields&&(this._fields=this._fields()),this._fields},t.getInterfaces=function(){return"function"==typeof this._interfaces&&(this._interfaces=this._interfaces()),this._interfaces},t.toConfig=function(){return{name:this.name,description:this.description,interfaces:this.getInterfaces(),fields:z(this.getFields()),isTypeOf:this.isTypeOf,extensions:this.extensions,astNode:this.astNode,extensionASTNodes:this.extensionASTNodes||[]}},t.toString=function(){return this.name},e}();function Y(e){var t=Q(e.interfaces)||[];return Array.isArray(t)||(0,c.default)(0,"".concat(e.name," interfaces must be an Array or a function which returns an Array.")),t}function J(e){var t=Q(e.fields)||{};return X(t)||(0,c.default)(0,"".concat(e.name," fields must be an object with field names as keys or a function which returns such an object.")),(0,o.default)(t,(function(t,n){X(t)||(0,c.default)(0,"".concat(e.name,".").concat(n," field config must be an object")),!("isDeprecated"in t)||(0,c.default)(0,"".concat(e.name,".").concat(n,\' should provide "deprecationReason" instead of "isDeprecated".\')),null==t.resolve||"function"==typeof t.resolve||(0,c.default)(0,"".concat(e.name,".").concat(n," field resolver must be a function if ")+"provided, but got: ".concat((0,i.default)(t.resolve),"."));var a=t.args||{};X(a)||(0,c.default)(0,"".concat(e.name,".").concat(n," args must be an object with argument names as keys."));var o=(0,r.default)(a).map((function(e){var t=e[0],n=e[1];return{name:t,description:void 0===n.description?null:n.description,type:n.type,defaultValue:n.defaultValue,extensions:n.extensions&&(0,u.default)(n.extensions),astNode:n.astNode}}));return g({},t,{name:n,description:t.description,type:t.type,args:o,resolve:t.resolve,subscribe:t.subscribe,isDeprecated:Boolean(t.deprecationReason),deprecationReason:t.deprecationReason,extensions:t.extensions&&(0,u.default)(t.extensions),astNode:t.astNode})}))}function X(e){return(0,l.default)(e)&&!Array.isArray(e)}function z(e){return(0,o.default)(e,(function(e){return{description:e.description,type:e.type,args:H(e.args),resolve:e.resolve,subscribe:e.subscribe,deprecationReason:e.deprecationReason,extensions:e.extensions,astNode:e.astNode}}))}function H(e){return(0,s.default)(e,(function(e){return e.name}),(function(e){return{description:e.description,type:e.type,defaultValue:e.defaultValue,extensions:e.extensions,astNode:e.astNode}}))}t.GraphQLObjectType=q,(0,y.default)(q),(0,d.default)(q);var W=function(){function e(e){this.name=e.name,this.description=e.description,this.resolveType=e.resolveType,this.extensions=e.extensions&&(0,u.default)(e.extensions),this.astNode=e.astNode,this.extensionASTNodes=U(e.extensionASTNodes),this._fields=J.bind(void 0,e),"string"==typeof e.name||(0,c.default)(0,"Must provide name."),null==e.resolveType||"function"==typeof e.resolveType||(0,c.default)(0,"".concat(this.name,\' must provide "resolveType" as a function, \')+"but got: ".concat((0,i.default)(e.resolveType),"."))}var t=e.prototype;return t.getFields=function(){return"function"==typeof this._fields&&(this._fields=this._fields()),this._fields},t.toConfig=function(){return{name:this.name,description:this.description,fields:z(this.getFields()),resolveType:this.resolveType,extensions:this.extensions,astNode:this.astNode,extensionASTNodes:this.extensionASTNodes||[]}},t.toString=function(){return this.name},e}();t.GraphQLInterfaceType=W,(0,y.default)(W),(0,d.default)(W);var $=function(){function e(e){this.name=e.name,this.description=e.description,this.resolveType=e.resolveType,this.extensions=e.extensions&&(0,u.default)(e.extensions),this.astNode=e.astNode,this.extensionASTNodes=U(e.extensionASTNodes),this._types=Z.bind(void 0,e),"string"==typeof e.name||(0,c.default)(0,"Must provide name."),null==e.resolveType||"function"==typeof e.resolveType||(0,c.default)(0,"".concat(this.name,\' must provide "resolveType" as a function, \')+"but got: ".concat((0,i.default)(e.resolveType),"."))}var t=e.prototype;return t.getTypes=function(){return"function"==typeof this._types&&(this._types=this._types()),this._types},t.toConfig=function(){return{name:this.name,description:this.description,types:this.getTypes(),resolveType:this.resolveType,extensions:this.extensions,astNode:this.astNode,extensionASTNodes:this.extensionASTNodes||[]}},t.toString=function(){return this.name},e}();function Z(e){var t=Q(e.types)||[];return Array.isArray(t)||(0,c.default)(0,"Must provide Array of types or a function which returns such an array for Union ".concat(e.name,".")),t}t.GraphQLUnionType=$,(0,y.default)($),(0,d.default)($);var ee=function(){function e(e){var t,n;this.name=e.name,this.description=e.description,this.extensions=e.extensions&&(0,u.default)(e.extensions),this.astNode=e.astNode,this.extensionASTNodes=U(e.extensionASTNodes),this._values=(t=this.name,X(n=e.values)||(0,c.default)(0,"".concat(t," values must be an object with value names as keys.")),(0,r.default)(n).map((function(e){var n=e[0],r=e[1];return X(r)||(0,c.default)(0,"".concat(t,".").concat(n,\' must refer to an object with a "value" key \')+"representing an internal value but got: ".concat((0,i.default)(r),".")),!("isDeprecated"in r)||(0,c.default)(0,"".concat(t,".").concat(n,\' should provide "deprecationReason" instead of "isDeprecated".\')),{name:n,description:r.description,value:"value"in r?r.value:n,isDeprecated:Boolean(r.deprecationReason),deprecationReason:r.deprecationReason,extensions:r.extensions&&(0,u.default)(r.extensions),astNode:r.astNode}}))),this._valueLookup=new Map(this._values.map((function(e){return[e.value,e]}))),this._nameLookup=(0,a.default)(this._values,(function(e){return e.name})),"string"==typeof e.name||(0,c.default)(0,"Must provide name.")}var t=e.prototype;return t.getValues=function(){return this._values},t.getValue=function(e){return this._nameLookup[e]},t.serialize=function(e){var t=this._valueLookup.get(e);if(t)return t.name},t.parseValue=function(e){if("string"==typeof e){var t=this.getValue(e);if(t)return t.value}},t.parseLiteral=function(e,t){if(e.kind===v.Kind.ENUM){var n=this.getValue(e.value);if(n)return n.value}},t.toConfig=function(){var e=(0,s.default)(this.getValues(),(function(e){return e.name}),(function(e){return{description:e.description,value:e.value,deprecationReason:e.deprecationReason,extensions:e.extensions,astNode:e.astNode}}));return{name:this.name,description:this.description,values:e,extensions:this.extensions,astNode:this.astNode,extensionASTNodes:this.extensionASTNodes||[]}},t.toString=function(){return this.name},e}();t.GraphQLEnumType=ee,(0,y.default)(ee),(0,d.default)(ee);var te=function(){function e(e){this.name=e.name,this.description=e.description,this.extensions=e.extensions&&(0,u.default)(e.extensions),this.astNode=e.astNode,this.extensionASTNodes=U(e.extensionASTNodes),this._fields=ne.bind(void 0,e),"string"==typeof e.name||(0,c.default)(0,"Must provide name.")}var t=e.prototype;return t.getFields=function(){return"function"==typeof this._fields&&(this._fields=this._fields()),this._fields},t.toConfig=function(){var e=(0,o.default)(this.getFields(),(function(e){return{description:e.description,type:e.type,defaultValue:e.defaultValue,extensions:e.extensions,astNode:e.astNode}}));return{name:this.name,description:this.description,fields:e,extensions:this.extensions,astNode:this.astNode,extensionASTNodes:this.extensionASTNodes||[]}},t.toString=function(){return this.name},e}();function ne(e){var t=Q(e.fields)||{};return X(t)||(0,c.default)(0,"".concat(e.name," fields must be an object with field names as keys or a function which returns such an object.")),(0,o.default)(t,(function(t,n){return!("resolve"in t)||(0,c.default)(0,"".concat(e.name,".").concat(n," field has a resolve property, but Input Types cannot define resolvers.")),g({},t,{name:n,description:t.description,type:t.type,defaultValue:t.defaultValue,extensions:t.extensions&&(0,u.default)(t.extensions),astNode:t.astNode})}))}t.GraphQLInputObjectType=te,(0,y.default)(te),(0,d.default)(te)},function(e,t,n){"use strict";Object.defineProperty(t,"__esModule",{value:!0}),t.default=function(e){return o(e,[])};var r,i=(r=n(62))&&r.__esModule?r:{default:r};function a(e){return(a="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(e){return typeof e}:function(e){return e&&"function"==typeof Symbol&&e.constructor===Symbol&&e!==Symbol.prototype?"symbol":typeof e})(e)}function o(e,t){switch(a(e)){case"string":return JSON.stringify(e);case"function":return e.name?"[function ".concat(e.name,"]"):"[function]";case"object":return null===e?"null":function(e,t){if(-1!==t.indexOf(e))return"[Circular]";var n=[].concat(t,[e]),r=function(e){var t=e[String(i.default)];if("function"==typeof t)return t;if("function"==typeof e.inspect)return e.inspect}(e);if(void 0!==r){var a=r.call(e);if(a!==e)return"string"==typeof a?a:o(a,n)}else if(Array.isArray(e))return function(e,t){if(0===e.length)return"[]";if(t.length>2)return"[Array]";for(var n=Math.min(10,e.length),r=e.length-n,i=[],a=0;a1&&i.push("... ".concat(r," more items"));return"["+i.join(", ")+"]"}(e,n);return function(e,t){var n=Object.keys(e);if(0===n.length)return"{}";if(t.length>2)return"["+function(e){var t=Object.prototype.toString.call(e).replace(/^\\[object /,"").replace(/]$/,"");if("Object"===t&&"function"==typeof e.constructor){var n=e.constructor.name;if("string"==typeof n&&""!==n)return n}return t}(e)+"]";return"{ "+n.map((function(n){return n+": "+o(e[n],t)})).join(", ")+" }"}(e,n)}(e,t);default:return String(e)}}},function(e,t,n){"use strict";Object.defineProperty(t,"__esModule",{value:!0}),Object.defineProperty(t,"Source",{enumerable:!0,get:function(){return r.Source}}),Object.defineProperty(t,"getLocation",{enumerable:!0,get:function(){return i.getLocation}}),Object.defineProperty(t,"printLocation",{enumerable:!0,get:function(){return a.printLocation}}),Object.defineProperty(t,"printSourceLocation",{enumerable:!0,get:function(){return a.printSourceLocation}}),Object.defineProperty(t,"Kind",{enumerable:!0,get:function(){return o.Kind}}),Object.defineProperty(t,"TokenKind",{enumerable:!0,get:function(){return u.TokenKind}}),Object.defineProperty(t,"createLexer",{enumerable:!0,get:function(){return c.createLexer}}),Object.defineProperty(t,"parse",{enumerable:!0,get:function(){return s.parse}}),Object.defineProperty(t,"parseValue",{enumerable:!0,get:function(){return s.parseValue}}),Object.defineProperty(t,"parseType",{enumerable:!0,get:function(){return s.parseType}}),Object.defineProperty(t,"print",{enumerable:!0,get:function(){return p.print}}),Object.defineProperty(t,"visit",{enumerable:!0,get:function(){return l.visit}}),Object.defineProperty(t,"visitInParallel",{enumerable:!0,get:function(){return l.visitInParallel}}),Object.defineProperty(t,"visitWithTypeInfo",{enumerable:!0,get:function(){return l.visitWithTypeInfo}}),Object.defineProperty(t,"getVisitFn",{enumerable:!0,get:function(){return l.getVisitFn}}),Object.defineProperty(t,"BREAK",{enumerable:!0,get:function(){return l.BREAK}}),Object.defineProperty(t,"isDefinitionNode",{enumerable:!0,get:function(){return f.isDefinitionNode}}),Object.defineProperty(t,"isExecutableDefinitionNode",{enumerable:!0,get:function(){return f.isExecutableDefinitionNode}}),Object.defineProperty(t,"isSelectionNode",{enumerable:!0,get:function(){return f.isSelectionNode}}),Object.defineProperty(t,"isValueNode",{enumerable:!0,get:function(){return f.isValueNode}}),Object.defineProperty(t,"isTypeNode",{enumerable:!0,get:function(){return f.isTypeNode}}),Object.defineProperty(t,"isTypeSystemDefinitionNode",{enumerable:!0,get:function(){return f.isTypeSystemDefinitionNode}}),Object.defineProperty(t,"isTypeDefinitionNode",{enumerable:!0,get:function(){return f.isTypeDefinitionNode}}),Object.defineProperty(t,"isTypeSystemExtensionNode",{enumerable:!0,get:function(){return f.isTypeSystemExtensionNode}}),Object.defineProperty(t,"isTypeExtensionNode",{enumerable:!0,get:function(){return f.isTypeExtensionNode}}),Object.defineProperty(t,"DirectiveLocation",{enumerable:!0,get:function(){return d.DirectiveLocation}});var r=n(50),i=n(49),a=n(63),o=n(7),u=n(29),c=n(51),s=n(27),p=n(13),l=n(17),f=n(22),d=n(30)},function(e,t,n){"use strict";Object.defineProperty(t,"__esModule",{value:!0}),t.Kind=void 0;var r=Object.freeze({NAME:"Name",DOCUMENT:"Document",OPERATION_DEFINITION:"OperationDefinition",VARIABLE_DEFINITION:"VariableDefinition",SELECTION_SET:"SelectionSet",FIELD:"Field",ARGUMENT:"Argument",FRAGMENT_SPREAD:"FragmentSpread",INLINE_FRAGMENT:"InlineFragment",FRAGMENT_DEFINITION:"FragmentDefinition",VARIABLE:"Variable",INT:"IntValue",FLOAT:"FloatValue",STRING:"StringValue",BOOLEAN:"BooleanValue",NULL:"NullValue",ENUM:"EnumValue",LIST:"ListValue",OBJECT:"ObjectValue",OBJECT_FIELD:"ObjectField",DIRECTIVE:"Directive",NAMED_TYPE:"NamedType",LIST_TYPE:"ListType",NON_NULL_TYPE:"NonNullType",SCHEMA_DEFINITION:"SchemaDefinition",OPERATION_TYPE_DEFINITION:"OperationTypeDefinition",SCALAR_TYPE_DEFINITION:"ScalarTypeDefinition",OBJECT_TYPE_DEFINITION:"ObjectTypeDefinition",FIELD_DEFINITION:"FieldDefinition",INPUT_VALUE_DEFINITION:"InputValueDefinition",INTERFACE_TYPE_DEFINITION:"InterfaceTypeDefinition",UNION_TYPE_DEFINITION:"UnionTypeDefinition",ENUM_TYPE_DEFINITION:"EnumTypeDefinition",ENUM_VALUE_DEFINITION:"EnumValueDefinition",INPUT_OBJECT_TYPE_DEFINITION:"InputObjectTypeDefinition",DIRECTIVE_DEFINITION:"DirectiveDefinition",SCHEMA_EXTENSION:"SchemaExtension",SCALAR_TYPE_EXTENSION:"ScalarTypeExtension",OBJECT_TYPE_EXTENSION:"ObjectTypeExtension",INTERFACE_TYPE_EXTENSION:"InterfaceTypeExtension",UNION_TYPE_EXTENSION:"UnionTypeExtension",ENUM_TYPE_EXTENSION:"EnumTypeExtension",INPUT_OBJECT_TYPE_EXTENSION:"InputObjectTypeExtension"});t.Kind=r},function(e,t,n){"use strict";Object.defineProperty(t,"__esModule",{value:!0}),t.default=void 0;var r=Object.values||function(e){return Object.keys(e).map((function(t){return e[t]}))};t.default=r},function(e,t,n){"use strict";Object.defineProperty(t,"__esModule",{value:!0}),t.default=function(e,t){if(!Boolean(e))throw new Error(t||"Unexpected invariant triggered")}},function(e,t,n){"use strict";Object.defineProperty(t,"__esModule",{value:!0}),t.isDirective=v,t.assertDirective=function(e){if(!v(e))throw new Error("Expected ".concat((0,i.default)(e)," to be a GraphQL directive."));return e},t.isSpecifiedDirective=function(e){return v(e)&&E.some((function(t){return t.name===e.name}))},t.specifiedDirectives=t.GraphQLDeprecatedDirective=t.DEFAULT_DEPRECATION_REASON=t.GraphQLSkipDirective=t.GraphQLIncludeDirective=t.GraphQLDirective=void 0;var r=y(n(20)),i=y(n(5)),a=y(n(52)),o=y(n(11)),u=y(n(53)),c=y(n(38)),s=y(n(14)),p=y(n(39)),l=n(30),f=n(15),d=n(4);function y(e){return e&&e.__esModule?e:{default:e}}function v(e){return(0,u.default)(e,h)}var h=function(){function e(e){this.name=e.name,this.description=e.description,this.locations=e.locations,this.isRepeatable=null!=e.isRepeatable&&e.isRepeatable,this.extensions=e.extensions&&(0,a.default)(e.extensions),this.astNode=e.astNode,e.name||(0,o.default)(0,"Directive must be named."),Array.isArray(e.locations)||(0,o.default)(0,"@".concat(e.name," locations must be an Array."));var t=e.args||{};(0,s.default)(t)&&!Array.isArray(t)||(0,o.default)(0,"@".concat(e.name," args must be an object with argument names as keys.")),this.args=(0,r.default)(t).map((function(e){var t=e[0],n=e[1];return{name:t,description:void 0===n.description?null:n.description,type:n.type,defaultValue:n.defaultValue,extensions:n.extensions&&(0,a.default)(n.extensions),astNode:n.astNode}}))}var t=e.prototype;return t.toString=function(){return"@"+this.name},t.toConfig=function(){return{name:this.name,description:this.description,locations:this.locations,args:(0,d.argsToArgsConfig)(this.args),isRepeatable:this.isRepeatable,extensions:this.extensions,astNode:this.astNode}},e}();t.GraphQLDirective=h,(0,p.default)(h),(0,c.default)(h);var m=new h({name:"include",description:"Directs the executor to include this field or fragment only when the `if` argument is true.",locations:[l.DirectiveLocation.FIELD,l.DirectiveLocation.FRAGMENT_SPREAD,l.DirectiveLocation.INLINE_FRAGMENT],args:{if:{type:(0,d.GraphQLNonNull)(f.GraphQLBoolean),description:"Included when true."}}});t.GraphQLIncludeDirective=m;var T=new h({name:"skip",description:"Directs the executor to skip this field or fragment when the `if` argument is true.",locations:[l.DirectiveLocation.FIELD,l.DirectiveLocation.FRAGMENT_SPREAD,l.DirectiveLocation.INLINE_FRAGMENT],args:{if:{type:(0,d.GraphQLNonNull)(f.GraphQLBoolean),description:"Skipped when true."}}});t.GraphQLSkipDirective=T;t.DEFAULT_DEPRECATION_REASON="No longer supported";var g=new h({name:"deprecated",description:"Marks an element of a GraphQL schema as no longer supported.",locations:[l.DirectiveLocation.FIELD_DEFINITION,l.DirectiveLocation.ENUM_VALUE],args:{reason:{type:f.GraphQLString,description:"Explains why this element was deprecated, usually also including a suggestion for how to access supported similar data. Formatted using the Markdown syntax (as specified by [CommonMark](https://commonmark.org/).",defaultValue:"No longer supported"}}});t.GraphQLDeprecatedDirective=g;var E=Object.freeze([m,T,g]);t.specifiedDirectives=E},function(e,t,n){"use strict";Object.defineProperty(t,"__esModule",{value:!0}),t.default=function(e,t){if(!Boolean(e))throw new Error(t)}},function(e,t,n){"use strict";Object.defineProperty(t,"__esModule",{value:!0}),t.isIntrospectionType=function(e){return(0,p.isNamedType)(e)&&_.some((function(t){var n=t.name;return e.name===n}))},t.introspectionTypes=t.TypeNameMetaFieldDef=t.TypeMetaFieldDef=t.SchemaMetaFieldDef=t.__TypeKind=t.TypeKind=t.__EnumValue=t.__InputValue=t.__Field=t.__Type=t.__DirectiveLocation=t.__Directive=t.__Schema=void 0;var r=l(n(8)),i=l(n(5)),a=l(n(9)),o=n(13),u=n(30),c=n(43),s=n(15),p=n(4);function l(e){return e&&e.__esModule?e:{default:e}}var f=new p.GraphQLObjectType({name:"__Schema",description:"A GraphQL Schema defines the capabilities of a GraphQL server. It exposes all available types and directives on the server, as well as the entry points for query, mutation, and subscription operations.",fields:function(){return{types:{description:"A list of all types supported by this server.",type:(0,p.GraphQLNonNull)((0,p.GraphQLList)((0,p.GraphQLNonNull)(v))),resolve:function(e){return(0,r.default)(e.getTypeMap())}},queryType:{description:"The type that query operations will be rooted at.",type:(0,p.GraphQLNonNull)(v),resolve:function(e){return e.getQueryType()}},mutationType:{description:"If this server supports mutation, the type that mutation operations will be rooted at.",type:v,resolve:function(e){return e.getMutationType()}},subscriptionType:{description:"If this server support subscription, the type that subscription operations will be rooted at.",type:v,resolve:function(e){return e.getSubscriptionType()}},directives:{description:"A list of all directives supported by this server.",type:(0,p.GraphQLNonNull)((0,p.GraphQLList)((0,p.GraphQLNonNull)(d))),resolve:function(e){return e.getDirectives()}}}}});t.__Schema=f;var d=new p.GraphQLObjectType({name:"__Directive",description:"A Directive provides a way to describe alternate runtime execution and type validation behavior in a GraphQL document.\\n\\nIn some cases, you need to provide options to alter GraphQL\'s execution behavior in ways field arguments will not suffice, such as conditionally including or skipping a field. Directives provide this by describing additional information to the executor.",fields:function(){return{name:{type:(0,p.GraphQLNonNull)(s.GraphQLString),resolve:function(e){return e.name}},description:{type:s.GraphQLString,resolve:function(e){return e.description}},locations:{type:(0,p.GraphQLNonNull)((0,p.GraphQLList)((0,p.GraphQLNonNull)(y))),resolve:function(e){return e.locations}},args:{type:(0,p.GraphQLNonNull)((0,p.GraphQLList)((0,p.GraphQLNonNull)(m))),resolve:function(e){return e.args}}}}});t.__Directive=d;var y=new p.GraphQLEnumType({name:"__DirectiveLocation",description:"A Directive can be adjacent to many parts of the GraphQL language, a __DirectiveLocation describes one such possible adjacencies.",values:{QUERY:{value:u.DirectiveLocation.QUERY,description:"Location adjacent to a query operation."},MUTATION:{value:u.DirectiveLocation.MUTATION,description:"Location adjacent to a mutation operation."},SUBSCRIPTION:{value:u.DirectiveLocation.SUBSCRIPTION,description:"Location adjacent to a subscription operation."},FIELD:{value:u.DirectiveLocation.FIELD,description:"Location adjacent to a field."},FRAGMENT_DEFINITION:{value:u.DirectiveLocation.FRAGMENT_DEFINITION,description:"Location adjacent to a fragment definition."},FRAGMENT_SPREAD:{value:u.DirectiveLocation.FRAGMENT_SPREAD,description:"Location adjacent to a fragment spread."},INLINE_FRAGMENT:{value:u.DirectiveLocation.INLINE_FRAGMENT,description:"Location adjacent to an inline fragment."},VARIABLE_DEFINITION:{value:u.DirectiveLocation.VARIABLE_DEFINITION,description:"Location adjacent to a variable definition."},SCHEMA:{value:u.DirectiveLocation.SCHEMA,description:"Location adjacent to a schema definition."},SCALAR:{value:u.DirectiveLocation.SCALAR,description:"Location adjacent to a scalar definition."},OBJECT:{value:u.DirectiveLocation.OBJECT,description:"Location adjacent to an object type definition."},FIELD_DEFINITION:{value:u.DirectiveLocation.FIELD_DEFINITION,description:"Location adjacent to a field definition."},ARGUMENT_DEFINITION:{value:u.DirectiveLocation.ARGUMENT_DEFINITION,description:"Location adjacent to an argument definition."},INTERFACE:{value:u.DirectiveLocation.INTERFACE,description:"Location adjacent to an interface definition."},UNION:{value:u.DirectiveLocation.UNION,description:"Location adjacent to a union definition."},ENUM:{value:u.DirectiveLocation.ENUM,description:"Location adjacent to an enum definition."},ENUM_VALUE:{value:u.DirectiveLocation.ENUM_VALUE,description:"Location adjacent to an enum value definition."},INPUT_OBJECT:{value:u.DirectiveLocation.INPUT_OBJECT,description:"Location adjacent to an input object type definition."},INPUT_FIELD_DEFINITION:{value:u.DirectiveLocation.INPUT_FIELD_DEFINITION,description:"Location adjacent to an input object field definition."}}});t.__DirectiveLocation=y;var v=new p.GraphQLObjectType({name:"__Type",description:"The fundamental unit of any GraphQL Schema is the type. There are many kinds of types in GraphQL as represented by the `__TypeKind` enum.\\n\\nDepending on the kind of a type, certain fields describe information about that type. Scalar types provide no information beyond a name and description, while Enum types provide their values. Object and Interface types provide the fields they describe. Abstract types, Union and Interface, provide the Object types possible at runtime. List and NonNull types compose other types.",fields:function(){return{kind:{type:(0,p.GraphQLNonNull)(E),resolve:function(e){return(0,p.isScalarType)(e)?g.SCALAR:(0,p.isObjectType)(e)?g.OBJECT:(0,p.isInterfaceType)(e)?g.INTERFACE:(0,p.isUnionType)(e)?g.UNION:(0,p.isEnumType)(e)?g.ENUM:(0,p.isInputObjectType)(e)?g.INPUT_OBJECT:(0,p.isListType)(e)?g.LIST:(0,p.isNonNullType)(e)?g.NON_NULL:void(0,a.default)(!1,\'Unexpected type: "\'.concat((0,i.default)(e),\'".\'))}},name:{type:s.GraphQLString,resolve:function(e){return void 0!==e.name?e.name:void 0}},description:{type:s.GraphQLString,resolve:function(e){return void 0!==e.description?e.description:void 0}},fields:{type:(0,p.GraphQLList)((0,p.GraphQLNonNull)(h)),args:{includeDeprecated:{type:s.GraphQLBoolean,defaultValue:!1}},resolve:function(e,t){var n=t.includeDeprecated;if((0,p.isObjectType)(e)||(0,p.isInterfaceType)(e)){var i=(0,r.default)(e.getFields());return n||(i=i.filter((function(e){return!e.deprecationReason}))),i}return null}},interfaces:{type:(0,p.GraphQLList)((0,p.GraphQLNonNull)(v)),resolve:function(e){if((0,p.isObjectType)(e))return e.getInterfaces()}},possibleTypes:{type:(0,p.GraphQLList)((0,p.GraphQLNonNull)(v)),resolve:function(e,t,n,r){var i=r.schema;if((0,p.isAbstractType)(e))return i.getPossibleTypes(e)}},enumValues:{type:(0,p.GraphQLList)((0,p.GraphQLNonNull)(T)),args:{includeDeprecated:{type:s.GraphQLBoolean,defaultValue:!1}},resolve:function(e,t){var n=t.includeDeprecated;if((0,p.isEnumType)(e)){var r=e.getValues();return n||(r=r.filter((function(e){return!e.deprecationReason}))),r}}},inputFields:{type:(0,p.GraphQLList)((0,p.GraphQLNonNull)(m)),resolve:function(e){if((0,p.isInputObjectType)(e))return(0,r.default)(e.getFields())}},ofType:{type:v,resolve:function(e){return void 0!==e.ofType?e.ofType:void 0}}}}});t.__Type=v;var h=new p.GraphQLObjectType({name:"__Field",description:"Object and Interface types are described by a list of Fields, each of which has a name, potentially a list of arguments, and a return type.",fields:function(){return{name:{type:(0,p.GraphQLNonNull)(s.GraphQLString),resolve:function(e){return e.name}},description:{type:s.GraphQLString,resolve:function(e){return e.description}},args:{type:(0,p.GraphQLNonNull)((0,p.GraphQLList)((0,p.GraphQLNonNull)(m))),resolve:function(e){return e.args}},type:{type:(0,p.GraphQLNonNull)(v),resolve:function(e){return e.type}},isDeprecated:{type:(0,p.GraphQLNonNull)(s.GraphQLBoolean),resolve:function(e){return e.isDeprecated}},deprecationReason:{type:s.GraphQLString,resolve:function(e){return e.deprecationReason}}}}});t.__Field=h;var m=new p.GraphQLObjectType({name:"__InputValue",description:"Arguments provided to Fields or Directives and the input fields of an InputObject are represented as Input Values which describe their type and optionally a default value.",fields:function(){return{name:{type:(0,p.GraphQLNonNull)(s.GraphQLString),resolve:function(e){return e.name}},description:{type:s.GraphQLString,resolve:function(e){return e.description}},type:{type:(0,p.GraphQLNonNull)(v),resolve:function(e){return e.type}},defaultValue:{type:s.GraphQLString,description:"A GraphQL-formatted string representing the default value for this input value.",resolve:function(e){var t=(0,c.astFromValue)(e.defaultValue,e.type);return t?(0,o.print)(t):null}}}}});t.__InputValue=m;var T=new p.GraphQLObjectType({name:"__EnumValue",description:"One possible value for a given Enum. Enum values are unique values, not a placeholder for a string or numeric value. However an Enum value is returned in a JSON response as a string.",fields:function(){return{name:{type:(0,p.GraphQLNonNull)(s.GraphQLString),resolve:function(e){return e.name}},description:{type:s.GraphQLString,resolve:function(e){return e.description}},isDeprecated:{type:(0,p.GraphQLNonNull)(s.GraphQLBoolean),resolve:function(e){return e.isDeprecated}},deprecationReason:{type:s.GraphQLString,resolve:function(e){return e.deprecationReason}}}}});t.__EnumValue=T;var g=Object.freeze({SCALAR:"SCALAR",OBJECT:"OBJECT",INTERFACE:"INTERFACE",UNION:"UNION",ENUM:"ENUM",INPUT_OBJECT:"INPUT_OBJECT",LIST:"LIST",NON_NULL:"NON_NULL"});t.TypeKind=g;var E=new p.GraphQLEnumType({name:"__TypeKind",description:"An enum describing what kind of type a given `__Type` is.",values:{SCALAR:{value:g.SCALAR,description:"Indicates this type is a scalar."},OBJECT:{value:g.OBJECT,description:"Indicates this type is an object. `fields` and `interfaces` are valid fields."},INTERFACE:{value:g.INTERFACE,description:"Indicates this type is an interface. `fields` and `possibleTypes` are valid fields."},UNION:{value:g.UNION,description:"Indicates this type is a union. `possibleTypes` is a valid field."},ENUM:{value:g.ENUM,description:"Indicates this type is an enum. `enumValues` is a valid field."},INPUT_OBJECT:{value:g.INPUT_OBJECT,description:"Indicates this type is an input object. `inputFields` is a valid field."},LIST:{value:g.LIST,description:"Indicates this type is a list. `ofType` is a valid field."},NON_NULL:{value:g.NON_NULL,description:"Indicates this type is a non-null. `ofType` is a valid field."}}});t.__TypeKind=E;var b={name:"__schema",type:(0,p.GraphQLNonNull)(f),description:"Access the current type schema of this server.",args:[],resolve:function(e,t,n,r){return r.schema},deprecationReason:void 0,extensions:void 0,astNode:void 0};t.SchemaMetaFieldDef=b;var N={name:"__type",type:v,description:"Request the type information of a single type.",args:[{name:"name",description:void 0,type:(0,p.GraphQLNonNull)(s.GraphQLString),defaultValue:void 0,extensions:void 0,astNode:void 0}],resolve:function(e,t,n,r){var i=t.name;return r.schema.getType(i)},deprecationReason:void 0,extensions:void 0,astNode:void 0};t.TypeMetaFieldDef=N;var O={name:"__typename",type:(0,p.GraphQLNonNull)(s.GraphQLString),description:"The name of the current Object type at runtime.",args:[],resolve:function(e,t,n,r){return r.parentType.name},deprecationReason:void 0,extensions:void 0,astNode:void 0};t.TypeNameMetaFieldDef=O;var _=Object.freeze([f,d,y,v,h,m,T,E]);t.introspectionTypes=_},function(e,t,n){"use strict";Object.defineProperty(t,"__esModule",{value:!0}),t.print=function(e){return(0,r.visit)(e,{leave:a})};var r=n(17),i=n(28);var a={Name:function(e){return e.value},Variable:function(e){return"$"+e.name},Document:function(e){return u(e.definitions,"\\n\\n")+"\\n"},OperationDefinition:function(e){var t=e.operation,n=e.name,r=s("(",u(e.variableDefinitions,", "),")"),i=u(e.directives," "),a=e.selectionSet;return n||i||r||"query"!==t?u([t,u([n,r]),i,a]," "):a},VariableDefinition:function(e){var t=e.variable,n=e.type,r=e.defaultValue,i=e.directives;return t+": "+n+s(" = ",r)+s(" ",u(i," "))},SelectionSet:function(e){return c(e.selections)},Field:function(e){var t=e.alias,n=e.name,r=e.arguments,i=e.directives,a=e.selectionSet;return u([s("",t,": ")+n+s("(",u(r,", "),")"),u(i," "),a]," ")},Argument:function(e){return e.name+": "+e.value},FragmentSpread:function(e){return"..."+e.name+s(" ",u(e.directives," "))},InlineFragment:function(e){var t=e.typeCondition,n=e.directives,r=e.selectionSet;return u(["...",s("on ",t),u(n," "),r]," ")},FragmentDefinition:function(e){var t=e.name,n=e.typeCondition,r=e.variableDefinitions,i=e.directives,a=e.selectionSet;return("fragment ".concat(t).concat(s("(",u(r,", "),")")," ")+"on ".concat(n," ").concat(s("",u(i," ")," "))+a)},IntValue:function(e){return e.value},FloatValue:function(e){return e.value},StringValue:function(e,t){var n=e.value;return e.block?(0,i.printBlockString)(n,"description"===t?"":" "):JSON.stringify(n)},BooleanValue:function(e){return e.value?"true":"false"},NullValue:function(){return"null"},EnumValue:function(e){return e.value},ListValue:function(e){return"["+u(e.values,", ")+"]"},ObjectValue:function(e){return"{"+u(e.fields,", ")+"}"},ObjectField:function(e){return e.name+": "+e.value},Directive:function(e){return"@"+e.name+s("(",u(e.arguments,", "),")")},NamedType:function(e){return e.name},ListType:function(e){return"["+e.type+"]"},NonNullType:function(e){return e.type+"!"},SchemaDefinition:function(e){var t=e.directives,n=e.operationTypes;return u(["schema",u(t," "),c(n)]," ")},OperationTypeDefinition:function(e){return e.operation+": "+e.type},ScalarTypeDefinition:o((function(e){return u(["scalar",e.name,u(e.directives," ")]," ")})),ObjectTypeDefinition:o((function(e){var t=e.name,n=e.interfaces,r=e.directives,i=e.fields;return u(["type",t,s("implements ",u(n," & ")),u(r," "),c(i)]," ")})),FieldDefinition:o((function(e){var t=e.name,n=e.arguments,r=e.type,i=e.directives;return t+(f(n)?s("(\\n",p(u(n,"\\n")),"\\n)"):s("(",u(n,", "),")"))+": "+r+s(" ",u(i," "))})),InputValueDefinition:o((function(e){var t=e.name,n=e.type,r=e.defaultValue,i=e.directives;return u([t+": "+n,s("= ",r),u(i," ")]," ")})),InterfaceTypeDefinition:o((function(e){var t=e.name,n=e.directives,r=e.fields;return u(["interface",t,u(n," "),c(r)]," ")})),UnionTypeDefinition:o((function(e){var t=e.name,n=e.directives,r=e.types;return u(["union",t,u(n," "),r&&0!==r.length?"= "+u(r," | "):""]," ")})),EnumTypeDefinition:o((function(e){var t=e.name,n=e.directives,r=e.values;return u(["enum",t,u(n," "),c(r)]," ")})),EnumValueDefinition:o((function(e){return u([e.name,u(e.directives," ")]," ")})),InputObjectTypeDefinition:o((function(e){var t=e.name,n=e.directives,r=e.fields;return u(["input",t,u(n," "),c(r)]," ")})),DirectiveDefinition:o((function(e){var t=e.name,n=e.arguments,r=e.repeatable,i=e.locations;return"directive @"+t+(f(n)?s("(\\n",p(u(n,"\\n")),"\\n)"):s("(",u(n,", "),")"))+(r?" repeatable":"")+" on "+u(i," | ")})),SchemaExtension:function(e){var t=e.directives,n=e.operationTypes;return u(["extend schema",u(t," "),c(n)]," ")},ScalarTypeExtension:function(e){return u(["extend scalar",e.name,u(e.directives," ")]," ")},ObjectTypeExtension:function(e){var t=e.name,n=e.interfaces,r=e.directives,i=e.fields;return u(["extend type",t,s("implements ",u(n," & ")),u(r," "),c(i)]," ")},InterfaceTypeExtension:function(e){var t=e.name,n=e.directives,r=e.fields;return u(["extend interface",t,u(n," "),c(r)]," ")},UnionTypeExtension:function(e){var t=e.name,n=e.directives,r=e.types;return u(["extend union",t,u(n," "),r&&0!==r.length?"= "+u(r," | "):""]," ")},EnumTypeExtension:function(e){var t=e.name,n=e.directives,r=e.values;return u(["extend enum",t,u(n," "),c(r)]," ")},InputObjectTypeExtension:function(e){var t=e.name,n=e.directives,r=e.fields;return u(["extend input",t,u(n," "),c(r)]," ")}};function o(e){return function(t){return u([t.description,e(t)],"\\n")}}function u(e,t){return e?e.filter((function(e){return e})).join(t||""):""}function c(e){return e&&0!==e.length?"{\\n"+p(u(e,"\\n"))+"\\n}":""}function s(e,t,n){return t?e+t+(n||""):""}function p(e){return e&&" "+e.replace(/\\n/g,"\\n ")}function l(e){return-1!==e.indexOf("\\n")}function f(e){return e&&e.some(l)}},function(e,t,n){"use strict";function r(e){return(r="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(e){return typeof e}:function(e){return e&&"function"==typeof Symbol&&e.constructor===Symbol&&e!==Symbol.prototype?"symbol":typeof e})(e)}Object.defineProperty(t,"__esModule",{value:!0}),t.default=function(e){return"object"==r(e)&&null!==e}},function(e,t,n){"use strict";Object.defineProperty(t,"__esModule",{value:!0}),t.isSpecifiedScalarType=function(e){return(0,c.isScalarType)(e)&&h.some((function(t){var n=t.name;return e.name===n}))},t.specifiedScalarTypes=t.GraphQLID=t.GraphQLBoolean=t.GraphQLString=t.GraphQLFloat=t.GraphQLInt=void 0;var r=s(n(108)),i=s(n(109)),a=s(n(5)),o=s(n(14)),u=n(7),c=n(4);function s(e){return e&&e.__esModule?e:{default:e}}var p=new c.GraphQLScalarType({name:"Int",description:"The `Int` scalar type represents non-fractional signed whole numeric values. Int can represent values between -(2^31) and 2^31 - 1.",serialize:function(e){if("boolean"==typeof e)return e?1:0;var t=e;if("string"==typeof e&&""!==e&&(t=Number(e)),!(0,i.default)(t))throw new TypeError("Int cannot represent non-integer value: ".concat((0,a.default)(e)));if(t>2147483647||t<-2147483648)throw new TypeError("Int cannot represent non 32-bit signed integer value: ".concat((0,a.default)(e)));return t},parseValue:function(e){if(!(0,i.default)(e))throw new TypeError("Int cannot represent non-integer value: ".concat((0,a.default)(e)));if(e>2147483647||e<-2147483648)throw new TypeError("Int cannot represent non 32-bit signed integer value: ".concat((0,a.default)(e)));return e},parseLiteral:function(e){if(e.kind===u.Kind.INT){var t=parseInt(e.value,10);if(t<=2147483647&&t>=-2147483648)return t}}});t.GraphQLInt=p;var l=new c.GraphQLScalarType({name:"Float",description:"The `Float` scalar type represents signed double-precision fractional values as specified by [IEEE 754](https://en.wikipedia.org/wiki/IEEE_floating_point).",serialize:function(e){if("boolean"==typeof e)return e?1:0;var t=e;if("string"==typeof e&&""!==e&&(t=Number(e)),!(0,r.default)(t))throw new TypeError("Float cannot represent non numeric value: ".concat((0,a.default)(e)));return t},parseValue:function(e){if(!(0,r.default)(e))throw new TypeError("Float cannot represent non numeric value: ".concat((0,a.default)(e)));return e},parseLiteral:function(e){return e.kind===u.Kind.FLOAT||e.kind===u.Kind.INT?parseFloat(e.value):void 0}});function f(e){if((0,o.default)(e)){if("function"==typeof e.valueOf){var t=e.valueOf();if(!(0,o.default)(t))return t}if("function"==typeof e.toJSON)return e.toJSON()}return e}t.GraphQLFloat=l;var d=new c.GraphQLScalarType({name:"String",description:"The `String` scalar type represents textual data, represented as UTF-8 character sequences. The String type is most often used by GraphQL to represent free-form human-readable text.",serialize:function(e){var t=f(e);if("string"==typeof t)return t;if("boolean"==typeof t)return t?"true":"false";if((0,r.default)(t))return t.toString();throw new TypeError("String cannot represent value: ".concat((0,a.default)(e)))},parseValue:function(e){if("string"!=typeof e)throw new TypeError("String cannot represent a non string value: ".concat((0,a.default)(e)));return e},parseLiteral:function(e){return e.kind===u.Kind.STRING?e.value:void 0}});t.GraphQLString=d;var y=new c.GraphQLScalarType({name:"Boolean",description:"The `Boolean` scalar type represents `true` or `false`.",serialize:function(e){if("boolean"==typeof e)return e;if((0,r.default)(e))return 0!==e;throw new TypeError("Boolean cannot represent a non boolean value: ".concat((0,a.default)(e)))},parseValue:function(e){if("boolean"!=typeof e)throw new TypeError("Boolean cannot represent a non boolean value: ".concat((0,a.default)(e)));return e},parseLiteral:function(e){return e.kind===u.Kind.BOOLEAN?e.value:void 0}});t.GraphQLBoolean=y;var v=new c.GraphQLScalarType({name:"ID",description:\'The `ID` scalar type represents a unique identifier, often used to refetch an object or as key for a cache. The ID type appears in a JSON response as a String; however, it is not intended to be human-readable. When expected as an input type, any string (such as `"4"`) or integer (such as `4`) input value will be accepted as an ID.\',serialize:function(e){var t=f(e);if("string"==typeof t)return t;if((0,i.default)(t))return String(t);throw new TypeError("ID cannot represent value: ".concat((0,a.default)(e)))},parseValue:function(e){if("string"==typeof e)return e;if((0,i.default)(e))return e.toString();throw new TypeError("ID cannot represent value: ".concat((0,a.default)(e)))},parseLiteral:function(e){return e.kind===u.Kind.STRING||e.kind===u.Kind.INT?e.value:void 0}});t.GraphQLID=v;var h=Object.freeze([d,p,l,y,v]);t.specifiedScalarTypes=h},function(e,t,n){"use strict";Object.defineProperty(t,"__esModule",{value:!0}),t.typeFromAST=function e(t,n){var u;if(n.kind===a.Kind.LIST_TYPE)return(u=e(t,n.type))&&(0,o.GraphQLList)(u);if(n.kind===a.Kind.NON_NULL_TYPE)return(u=e(t,n.type))&&(0,o.GraphQLNonNull)(u);if(n.kind===a.Kind.NAMED_TYPE)return t.getType(n.name.value);(0,i.default)(!1,"Unexpected type node: "+(0,r.default)(n))};var r=u(n(5)),i=u(n(9)),a=n(7),o=n(4);function u(e){return e&&e.__esModule?e:{default:e}}},function(e,t,n){"use strict";Object.defineProperty(t,"__esModule",{value:!0}),t.visit=function(e,t){var n=arguments.length>2&&void 0!==arguments[2]?arguments[2]:a,r=void 0,s=Array.isArray(e),p=[e],l=-1,f=[],d=void 0,y=void 0,v=void 0,h=[],m=[],T=e;do{var g=++l===p.length,E=g&&0!==f.length;if(g){if(y=0===m.length?void 0:h[h.length-1],d=v,v=m.pop(),E){if(s)d=d.slice();else{for(var b={},N=0,O=Object.keys(d);N1&&p>1&&r[s-1]===i[p-2]&&r[s-2]===i[p-1]&&(n[s][p]=Math.min(n[s][p],n[s-2][p-2]+l))}return n[a][o]}Object.defineProperty(t,"__esModule",{value:!0}),t.default=function(e,t){for(var n=Object.create(null),i=e.length/2,a=0;a0&&a(t[0]);)t.shift();for(;t.length>0&&a(t[t.length-1]);)t.pop();return t.join("\\n")},t.getBlockStringIndentation=r,t.printBlockString=function(e){var t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:"",n=arguments.length>2&&void 0!==arguments[2]&&arguments[2],r=-1===e.indexOf("\\n"),i=" "===e[0]||"\\t"===e[0],a=\'"\'===e[e.length-1],o=!r||a||n,u="";!o||r&&i||(u+="\\n"+t);u+=t?e.replace(/\\n/g,"\\n"+t):e,o&&(u+="\\n");return\'"""\'+u.replace(/"""/g,\'\\\\"""\')+\'"""\'}},function(e,t,n){"use strict";Object.defineProperty(t,"__esModule",{value:!0}),t.TokenKind=void 0;var r=Object.freeze({SOF:"",EOF:"",BANG:"!",DOLLAR:"$",AMP:"&",PAREN_L:"(",PAREN_R:")",SPREAD:"...",COLON:":",EQUALS:"=",AT:"@",BRACKET_L:"[",BRACKET_R:"]",BRACE_L:"{",PIPE:"|",BRACE_R:"}",NAME:"Name",INT:"Int",FLOAT:"Float",STRING:"String",BLOCK_STRING:"BlockString",COMMENT:"Comment"});t.TokenKind=r},function(e,t,n){"use strict";Object.defineProperty(t,"__esModule",{value:!0}),t.DirectiveLocation=void 0;var r=Object.freeze({QUERY:"QUERY",MUTATION:"MUTATION",SUBSCRIPTION:"SUBSCRIPTION",FIELD:"FIELD",FRAGMENT_DEFINITION:"FRAGMENT_DEFINITION",FRAGMENT_SPREAD:"FRAGMENT_SPREAD",INLINE_FRAGMENT:"INLINE_FRAGMENT",VARIABLE_DEFINITION:"VARIABLE_DEFINITION",SCHEMA:"SCHEMA",SCALAR:"SCALAR",OBJECT:"OBJECT",FIELD_DEFINITION:"FIELD_DEFINITION",ARGUMENT_DEFINITION:"ARGUMENT_DEFINITION",INTERFACE:"INTERFACE",UNION:"UNION",ENUM:"ENUM",ENUM_VALUE:"ENUM_VALUE",INPUT_OBJECT:"INPUT_OBJECT",INPUT_FIELD_DEFINITION:"INPUT_FIELD_DEFINITION"});t.DirectiveLocation=r},function(e,t,n){"use strict";Object.defineProperty(t,"__esModule",{value:!0}),t.validate=function(e,t){var n=arguments.length>2&&void 0!==arguments[2]?arguments[2]:s.specifiedRules,r=arguments.length>3&&void 0!==arguments[3]?arguments[3]:new c.TypeInfo(e),l=arguments.length>4?arguments[4]:void 0;t||(0,i.default)(0,"Must provide document"),(0,u.assertValidSchema)(e);var f=Object.freeze({}),d=[],y=l&&l.maxErrors,v=new p.ValidationContext(e,t,r,(function(e){if(null!=y&&d.length>=y)throw d.push(new a.GraphQLError("Too many validation errors, error limit reached. Validation aborted.")),f;d.push(e)})),h=(0,o.visitInParallel)(n.map((function(e){return e(v)})));try{(0,o.visit)(t,(0,o.visitWithTypeInfo)(r,h))}catch(e){if(e!==f)throw e}return d},t.validateSDL=f,t.assertValidSDL=function(e){var t=f(e);if(0!==t.length)throw new Error(t.map((function(e){return e.message})).join("\\n\\n"))},t.assertValidSDLExtension=function(e,t){var n=f(e,t);if(0!==n.length)throw new Error(n.map((function(e){return e.message})).join("\\n\\n"))},t.ABORT_VALIDATION=void 0;var r,i=(r=n(11))&&r.__esModule?r:{default:r},a=n(1),o=n(17),u=n(40),c=n(35),s=n(68),p=n(55);var l=Object.freeze({});function f(e,t){var n=arguments.length>2&&void 0!==arguments[2]?arguments[2]:s.specifiedSDLRules,r=[],i=new p.SDLValidationContext(e,t,(function(e){r.push(e)})),a=n.map((function(e){return e(i)}));return(0,o.visit)(e,(0,o.visitInParallel)(a)),r}t.ABORT_VALIDATION=l},function(e,t,n){"use strict";Object.defineProperty(t,"__esModule",{value:!0}),t.default=void 0;var r=Array.prototype.find?function(e,t){return Array.prototype.find.call(e,t)}:function(e,t){for(var n=0;n=0&&t%1==0}function c(e){return Object(e)===e&&(u(e)||o(e))}function s(e){var t=p(e);if(t)return t.call(e)}function p(e){if(null!=e){var t=i&&e[i]||e["@@iterator"];if("function"==typeof t)return t}}function l(e){if(null!=e){var t=s(e);if(t)return t;if(u(e))return new f(e)}}function f(e){this._o=e,this._i=0}function d(e,t,n){if(null!=e){if("function"==typeof e.forEach)return e.forEach(t,n);var r=0,i=s(e);if(i){for(var a;!(a=i.next()).done;)if(t.call(n,a.value,r++,e),r>9999999)throw new TypeError("Near-infinite iteration.")}else if(u(e))for(;r=this._o.length?(this._o=void 0,{value:void 0,done:!0}):{value:this._o[this._i++],done:!1}};var y=r&&r.asyncIterator,v=y||"@@asyncIterator";function h(e){return!!T(e)}function m(e){var t=T(e);if(t)return t.call(e)}function T(e){if(null!=e){var t=y&&e[y]||e["@@asyncIterator"];if("function"==typeof t)return t}}function g(e){if(null!=e){var t=m(e);if(t)return t;var n=l(e);if(n)return new E(n)}}function E(e){this._i=e}function b(e,t,n){var r;return new Promise((function(i){i((r=e[t](n)).value)})).then((function(e){return{value:e,done:r.done}}))}function N(e,t,n){var r=g(e);if(r){var i=0;return new Promise((function(a,o){!function u(){return r.next().then((function(r){return r.done?a():Promise.resolve(t.call(n,r.value,i++,e)).then(u).catch(o),null})).catch(o),null}()}))}}E.prototype[v]=function(){return this},E.prototype.next=function(e){return b(this._i,"next",e)},E.prototype.return=function(e){return this._i.return?b(this._i,"return",e):Promise.resolve({value:e,done:!0})},E.prototype.throw=function(e){return this._i.throw?b(this._i,"throw",e):Promise.reject(e)}},function(e,t,n){"use strict";Object.defineProperty(t,"__esModule",{value:!0}),t.TypeInfo=void 0;var r,i=(r=n(32))&&r.__esModule?r:{default:r},a=n(7),o=n(4),u=n(12),c=n(16);var s=function(){function e(e,t,n){this._schema=e,this._typeStack=[],this._parentTypeStack=[],this._inputTypeStack=[],this._fieldDefStack=[],this._defaultValueStack=[],this._directive=null,this._argument=null,this._enumValue=null,this._getFieldDef=t||p,n&&((0,o.isInputType)(n)&&this._inputTypeStack.push(n),(0,o.isCompositeType)(n)&&this._parentTypeStack.push(n),(0,o.isOutputType)(n)&&this._typeStack.push(n))}var t=e.prototype;return t.getType=function(){if(this._typeStack.length>0)return this._typeStack[this._typeStack.length-1]},t.getParentType=function(){if(this._parentTypeStack.length>0)return this._parentTypeStack[this._parentTypeStack.length-1]},t.getInputType=function(){if(this._inputTypeStack.length>0)return this._inputTypeStack[this._inputTypeStack.length-1]},t.getParentInputType=function(){if(this._inputTypeStack.length>1)return this._inputTypeStack[this._inputTypeStack.length-2]},t.getFieldDef=function(){if(this._fieldDefStack.length>0)return this._fieldDefStack[this._fieldDefStack.length-1]},t.getDefaultValue=function(){if(this._defaultValueStack.length>0)return this._defaultValueStack[this._defaultValueStack.length-1]},t.getDirective=function(){return this._directive},t.getArgument=function(){return this._argument},t.getEnumValue=function(){return this._enumValue},t.enter=function(e){var t=this._schema;switch(e.kind){case a.Kind.SELECTION_SET:var n=(0,o.getNamedType)(this.getType());this._parentTypeStack.push((0,o.isCompositeType)(n)?n:void 0);break;case a.Kind.FIELD:var r,u,s=this.getParentType();s&&(r=this._getFieldDef(t,s,e))&&(u=r.type),this._fieldDefStack.push(r),this._typeStack.push((0,o.isOutputType)(u)?u:void 0);break;case a.Kind.DIRECTIVE:this._directive=t.getDirective(e.name.value);break;case a.Kind.OPERATION_DEFINITION:var p;"query"===e.operation?p=t.getQueryType():"mutation"===e.operation?p=t.getMutationType():"subscription"===e.operation&&(p=t.getSubscriptionType()),this._typeStack.push((0,o.isObjectType)(p)?p:void 0);break;case a.Kind.INLINE_FRAGMENT:case a.Kind.FRAGMENT_DEFINITION:var l=e.typeCondition,f=l?(0,c.typeFromAST)(t,l):(0,o.getNamedType)(this.getType());this._typeStack.push((0,o.isOutputType)(f)?f:void 0);break;case a.Kind.VARIABLE_DEFINITION:var d=(0,c.typeFromAST)(t,e.type);this._inputTypeStack.push((0,o.isInputType)(d)?d:void 0);break;case a.Kind.ARGUMENT:var y,v,h=this.getDirective()||this.getFieldDef();h&&(y=(0,i.default)(h.args,(function(t){return t.name===e.name.value})))&&(v=y.type),this._argument=y,this._defaultValueStack.push(y?y.defaultValue:void 0),this._inputTypeStack.push((0,o.isInputType)(v)?v:void 0);break;case a.Kind.LIST:var m=(0,o.getNullableType)(this.getInputType()),T=(0,o.isListType)(m)?m.ofType:m;this._defaultValueStack.push(void 0),this._inputTypeStack.push((0,o.isInputType)(T)?T:void 0);break;case a.Kind.OBJECT_FIELD:var g,E,b=(0,o.getNamedType)(this.getInputType());(0,o.isInputObjectType)(b)&&(E=b.getFields()[e.name.value])&&(g=E.type),this._defaultValueStack.push(E?E.defaultValue:void 0),this._inputTypeStack.push((0,o.isInputType)(g)?g:void 0);break;case a.Kind.ENUM:var N,O=(0,o.getNamedType)(this.getInputType());(0,o.isEnumType)(O)&&(N=O.getValue(e.value)),this._enumValue=N}},t.leave=function(e){switch(e.kind){case a.Kind.SELECTION_SET:this._parentTypeStack.pop();break;case a.Kind.FIELD:this._fieldDefStack.pop(),this._typeStack.pop();break;case a.Kind.DIRECTIVE:this._directive=null;break;case a.Kind.OPERATION_DEFINITION:case a.Kind.INLINE_FRAGMENT:case a.Kind.FRAGMENT_DEFINITION:this._typeStack.pop();break;case a.Kind.VARIABLE_DEFINITION:this._inputTypeStack.pop();break;case a.Kind.ARGUMENT:this._argument=null,this._defaultValueStack.pop(),this._inputTypeStack.pop();break;case a.Kind.LIST:case a.Kind.OBJECT_FIELD:this._defaultValueStack.pop(),this._inputTypeStack.pop();break;case a.Kind.ENUM:this._enumValue=null}},e}();function p(e,t,n){var r=n.name.value;return r===u.SchemaMetaFieldDef.name&&e.getQueryType()===t?u.SchemaMetaFieldDef:r===u.TypeMetaFieldDef.name&&e.getQueryType()===t?u.TypeMetaFieldDef:r===u.TypeNameMetaFieldDef.name&&(0,o.isCompositeType)(t)?u.TypeNameMetaFieldDef:(0,o.isObjectType)(t)||(0,o.isInterfaceType)(t)?t.getFields()[r]:void 0}t.TypeInfo=s},function(e,t,n){"use strict";Object.defineProperty(t,"__esModule",{value:!0}),t.addPath=function(e,t){return{prev:e,key:t}},t.pathToArray=function(e){var t=[],n=e;for(;n;)t.push(n.key),n=n.prev;return t.reverse()}},function(e,t,n){"use strict";Object.defineProperty(t,"__esModule",{value:!0}),t.default=function(e){return Boolean(e&&"function"==typeof e.then)}},function(e,t,n){"use strict";Object.defineProperty(t,"__esModule",{value:!0}),t.default=function(e){var t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:e.prototype.toString;e.prototype.toJSON=t,e.prototype.inspect=t,i.default&&(e.prototype[i.default]=t)};var r,i=(r=n(62))&&r.__esModule?r:{default:r}},function(e,t,n){"use strict";Object.defineProperty(t,"__esModule",{value:!0}),t.default=function(e){"function"==typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(e.prototype,Symbol.toStringTag,{get:function(){return this.constructor.name}})}},function(e,t,n){"use strict";Object.defineProperty(t,"__esModule",{value:!0}),t.validateSchema=h,t.assertValidSchema=function(e){var t=h(e);if(0!==t.length)throw new Error(t.map((function(e){return e.message})).join("\\n\\n"))};var r=v(n(32)),i=v(n(41)),a=v(n(8)),o=v(n(20)),u=v(n(5)),c=n(1),s=n(64),p=n(42),l=n(10),f=n(12),d=n(19),y=n(4);function v(e){return e&&e.__esModule?e:{default:e}}function h(e){if((0,d.assertSchema)(e),e.__validationErrors)return e.__validationErrors;var t=new m(e);!function(e){var t=e.schema,n=t.getQueryType();n?(0,y.isObjectType)(n)||e.reportError("Query root type must be Object type, it cannot be ".concat((0,u.default)(n),"."),T(t,n,"query")):e.reportError("Query root type must be provided.",t.astNode);var r=t.getMutationType();r&&!(0,y.isObjectType)(r)&&e.reportError("Mutation root type must be Object type if provided, it cannot be "+"".concat((0,u.default)(r),"."),T(t,r,"mutation"));var i=t.getSubscriptionType();i&&!(0,y.isObjectType)(i)&&e.reportError("Subscription root type must be Object type if provided, it cannot be "+"".concat((0,u.default)(i),"."),T(t,i,"subscription"))}(t),function(e){for(var t=0,n=e.schema.getDirectives();t0)return{errors:y};try{t=(0,a.parse)(r)}catch(e){return{errors:[e]}}var v=(0,o.validate)(n,t);return v.length>0?{errors:v}:(0,c.execute)({schema:n,document:t,rootValue:i,contextValue:s,variableValues:p,operationName:l,fieldResolver:f,typeResolver:d})}},function(e,t,n){"use strict";Object.defineProperty(t,"__esModule",{value:!0}),t.syntaxError=function(e,t,n){return new r.GraphQLError("Syntax Error: ".concat(n),void 0,e,[t])};var r=n(1)},function(e,t,n){"use strict";Object.defineProperty(t,"__esModule",{value:!0}),t.getLocation=function(e,t){var n,r=/\\r\\n|[\\n\\r]/g,i=1,a=t+1;for(;(n=r.exec(e.body))&&n.index0||(0,r.default)(0,"line in locationOffset is 1-indexed and must be positive"),this.locationOffset.column>0||(0,r.default)(0,"column in locationOffset is 1-indexed and must be positive")};t.Source=o,(0,i.default)(o)},function(e,t,n){"use strict";Object.defineProperty(t,"__esModule",{value:!0}),t.createLexer=function(e,t){var n=new p(u.TokenKind.SOF,0,0,0,0,null);return{source:e,options:t,lastToken:n,token:n,line:1,lineStart:0,advance:c,lookahead:s}},t.isPunctuatorToken=function(e){var t=e.kind;return t===u.TokenKind.BANG||t===u.TokenKind.DOLLAR||t===u.TokenKind.AMP||t===u.TokenKind.PAREN_L||t===u.TokenKind.PAREN_R||t===u.TokenKind.SPREAD||t===u.TokenKind.COLON||t===u.TokenKind.EQUALS||t===u.TokenKind.AT||t===u.TokenKind.BRACKET_L||t===u.TokenKind.BRACKET_R||t===u.TokenKind.BRACE_L||t===u.TokenKind.PIPE||t===u.TokenKind.BRACE_R};var r,i=(r=n(38))&&r.__esModule?r:{default:r},a=n(48),o=n(28),u=n(29);function c(){return this.lastToken=this.token,this.token=this.lookahead()}function s(){var e=this.token;if(e.kind!==u.TokenKind.EOF)do{e=e.next||(e.next=f(this,e))}while(e.kind===u.TokenKind.COMMENT);return e}function p(e,t,n,r,i,a,o){this.kind=e,this.start=t,this.end=n,this.line=r,this.column=i,this.value=o,this.prev=a,this.next=null}function l(e){return isNaN(e)?u.TokenKind.EOF:e<127?JSON.stringify(String.fromCharCode(e)):\'"\\\\u\'.concat(("00"+e.toString(16).toUpperCase()).slice(-4),\'"\')}function f(e,t){var n=e.source,r=n.body,i=r.length,c=function(e,t,n){var r=e.length,i=t;for(;i=i)return new p(u.TokenKind.EOF,i,i,s,f,t);var v=r.charCodeAt(c);switch(v){case 33:return new p(u.TokenKind.BANG,c,c+1,s,f,t);case 35:return function(e,t,n,r,i){var a,o=e.body,c=t;do{a=o.charCodeAt(++c)}while(!isNaN(a)&&(a>31||9===a));return new p(u.TokenKind.COMMENT,t,c,n,r,i,o.slice(t+1,c))}(n,c,s,f,t);case 36:return new p(u.TokenKind.DOLLAR,c,c+1,s,f,t);case 38:return new p(u.TokenKind.AMP,c,c+1,s,f,t);case 40:return new p(u.TokenKind.PAREN_L,c,c+1,s,f,t);case 41:return new p(u.TokenKind.PAREN_R,c,c+1,s,f,t);case 46:if(46===r.charCodeAt(c+1)&&46===r.charCodeAt(c+2))return new p(u.TokenKind.SPREAD,c,c+3,s,f,t);break;case 58:return new p(u.TokenKind.COLON,c,c+1,s,f,t);case 61:return new p(u.TokenKind.EQUALS,c,c+1,s,f,t);case 64:return new p(u.TokenKind.AT,c,c+1,s,f,t);case 91:return new p(u.TokenKind.BRACKET_L,c,c+1,s,f,t);case 93:return new p(u.TokenKind.BRACKET_R,c,c+1,s,f,t);case 123:return new p(u.TokenKind.BRACE_L,c,c+1,s,f,t);case 124:return new p(u.TokenKind.PIPE,c,c+1,s,f,t);case 125:return new p(u.TokenKind.BRACE_R,c,c+1,s,f,t);case 65:case 66:case 67:case 68:case 69:case 70:case 71:case 72:case 73:case 74:case 75:case 76:case 77:case 78:case 79:case 80:case 81:case 82:case 83:case 84:case 85:case 86:case 87:case 88:case 89:case 90:case 95:case 97:case 98:case 99:case 100:case 101:case 102:case 103:case 104:case 105:case 106:case 107:case 108:case 109:case 110:case 111:case 112:case 113:case 114:case 115:case 116:case 117:case 118:case 119:case 120:case 121:case 122:return function(e,t,n,r,i){var a=e.body,o=a.length,c=t+1,s=0;for(;c!==o&&!isNaN(s=a.charCodeAt(c))&&(95===s||s>=48&&s<=57||s>=65&&s<=90||s>=97&&s<=122);)++c;return new p(u.TokenKind.NAME,t,c,n,r,i,a.slice(t,c))}(n,c,s,f,t);case 45:case 48:case 49:case 50:case 51:case 52:case 53:case 54:case 55:case 56:case 57:return function(e,t,n,r,i,o){var c=e.body,s=n,f=t,y=!1;45===s&&(s=c.charCodeAt(++f));if(48===s){if((s=c.charCodeAt(++f))>=48&&s<=57)throw(0,a.syntaxError)(e,f,"Invalid number, unexpected digit after 0: ".concat(l(s),"."))}else f=d(e,f,s),s=c.charCodeAt(f);46===s&&(y=!0,s=c.charCodeAt(++f),f=d(e,f,s),s=c.charCodeAt(f));69!==s&&101!==s||(y=!0,43!==(s=c.charCodeAt(++f))&&45!==s||(s=c.charCodeAt(++f)),f=d(e,f,s),s=c.charCodeAt(f));if(46===s||69===s||101===s)throw(0,a.syntaxError)(e,f,"Invalid number, expected digit but got: ".concat(l(s),"."));return new p(y?u.TokenKind.FLOAT:u.TokenKind.INT,t,f,r,i,o,c.slice(t,f))}(n,c,v,s,f,t);case 34:return 34===r.charCodeAt(c+1)&&34===r.charCodeAt(c+2)?function(e,t,n,r,i,c){var s=e.body,f=t+3,d=f,y=0,v="";for(;f=48&&o<=57){do{o=r.charCodeAt(++i)}while(o>=48&&o<=57);return i}throw(0,a.syntaxError)(e,i,"Invalid number, expected digit but got: ".concat(l(o),"."))}function y(e){return e>=48&&e<=57?e-48:e>=65&&e<=70?e-55:e>=97&&e<=102?e-87:-1}(0,i.default)(p,(function(){return{kind:this.kind,value:this.value,line:this.line,column:this.column}}))},function(e,t,n){"use strict";Object.defineProperty(t,"__esModule",{value:!0}),t.default=function(e){if(null===Object.getPrototypeOf(e))return e;for(var t=Object.create(null),n=0,r=(0,i.default)(e);n0&&(i+=\' at "\'.concat(v).concat((0,o.default)(e),\'"\')),r(new u.GraphQLError(i+"; "+n.message,y,void 0,void 0,void 0,n.originalError))}))},y=0;y=i)throw new u.GraphQLError("Too many errors processing variables, error limit reached. Execution aborted.");c.push(e)}));if(0===c.length)return{coerced:y}}catch(e){c.push(e)}return{errors:c}},t.getArgumentValues=v,t.getDirectiveValues=function(e,t,n){var i=t.directives&&(0,r.default)(t.directives,(function(t){return t.name.value===e.name}));if(i)return v(e,i,n)};var r=y(n(32)),i=y(n(18)),a=y(n(5)),o=y(n(59)),u=n(1),c=n(7),s=n(13),p=n(4),l=n(16),f=n(45),d=n(60);function y(e){return e&&e.__esModule?e:{default:e}}function v(e,t,n){for(var r={},o=(0,i.default)(t.arguments||[],(function(e){return e.name.value})),l=0,d=e.args;l2&&void 0!==arguments[2]?arguments[2]:v;return h(e,t,n)};var r=n(34),i=y(n(8)),a=y(n(5)),o=y(n(9)),u=y(n(23)),c=y(n(14)),s=y(n(24)),p=y(n(59)),l=n(36),f=n(1),d=n(4);function y(e){return e&&e.__esModule?e:{default:e}}function v(e,t,n){var r="Invalid value "+(0,a.default)(t);throw e.length>0&&(r+=\' at "value\'.concat((0,p.default)(e),\'": \')),n.message=r+": "+n.message,n}function h(e,t,n,p){if((0,d.isNonNullType)(t))return null!=e?h(e,t.ofType,n,p):void n((0,l.pathToArray)(p),e,new f.GraphQLError("Expected non-nullable type ".concat((0,a.default)(t)," not to be null.")));if(null==e)return null;if((0,d.isListType)(t)){var y=t.ofType;if((0,r.isCollection)(e)){var v=[];return(0,r.forEach)(e,(function(e,t){v.push(h(e,y,n,(0,l.addPath)(p,t)))})),v}return[h(e,y,n,p)]}if((0,d.isInputObjectType)(t)){if(!(0,c.default)(e))return void n((0,l.pathToArray)(p),e,new f.GraphQLError("Expected type ".concat(t.name," to be an object.")));for(var m={},T=t.getFields(),g=0,E=(0,i.default)(T);g120){for(var y=Math.floor(p/80),v=p%80,h=[],m=0;m1&&"_"===e[0]&&"_"===e[1]?new a.GraphQLError(\'Name "\'.concat(e,\'" must not begin with "__", which is reserved by GraphQL introspection.\'),t):o.test(e)?void 0:new a.GraphQLError(\'Names must match /^[_a-zA-Z][_a-zA-Z0-9]*$/ but "\'.concat(e,\'" does not.\'),t)}},function(e,t,n){"use strict";Object.defineProperty(t,"__esModule",{value:!0}),t.default=function(e,t){for(var n=Object.create(null),r=0,a=(0,i.default)(e);r1&&e.reportError(new r.GraphQLError("This anonymous operation must be the only defined operation.",n))}}};var r=n(1),i=n(7);function a(){return"This anonymous operation must be the only defined operation."}},function(e,t,n){"use strict";Object.defineProperty(t,"__esModule",{value:!0}),t.singleFieldOnlyMessage=i,t.SingleFieldSubscriptions=function(e){return{OperationDefinition:function(t){"subscription"===t.operation&&1!==t.selectionSet.selections.length&&e.reportError(new r.GraphQLError(i(t.name&&t.name.value),t.selectionSet.selections.slice(1)))}}};var r=n(1);function i(e){return e?\'Subscription "\'.concat(e,\'" must select only one top level field.\'):"Anonymous Subscription must select only one top level field."}},function(e,t,n){"use strict";Object.defineProperty(t,"__esModule",{value:!0}),t.unknownTypeMessage=c,t.KnownTypeNames=function(e){for(var t=e.getSchema(),n=t?t.getTypeMap():Object.create(null),r=Object.create(null),u=0,p=e.getDocument().definitions;u1)for(var l=0;l0)return[[t,e.map((function(e){return e[0]}))],e.reduce((function(e,t){var n=t[1];return e.concat(n)}),[n]),e.reduce((function(e,t){var n=t[2];return e.concat(n)}),[r])]}(function(e,t,n,r,i,a,o,u){var c=[],s=m(e,t,i,a),p=s[0],l=s[1],f=m(e,t,o,u),h=f[0],T=f[1];if(v(e,c,t,n,r,p,h),0!==T.length)for(var g=Object.create(null),E=0;E0&&e.reportError(new r.GraphQLError("Must provide only one schema definition.",t)),++i)}}};var r=n(1);function i(){return"Must provide only one schema definition."}function a(){return"Cannot define a new schema within a schema extension."}},function(e,t,n){"use strict";Object.defineProperty(t,"__esModule",{value:!0}),t.duplicateOperationTypeMessage=i,t.existedOperationTypeMessage=a,t.UniqueOperationTypes=function(e){var t=e.getSchema(),n=Object.create(null),o=t?{query:t.getQueryType(),mutation:t.getMutationType(),subscription:t.getSubscriptionType()}:{};return{SchemaDefinition:u,SchemaExtension:u};function u(t){if(t.operationTypes)for(var u=0,c=t.operationTypes||[];u0?function(){return n.map((function(e){return t.getNamedType(e)}))}:[],a=r&&r.length>0?function(){return D(r,(function(e){return t.buildField(e)}))}:Object.create(null);return new E.GraphQLObjectType({name:e.name.value,description:S(e,this._options),interfaces:i,fields:a,astNode:e})},t._makeInterfaceDef=function(e){var t=this,n=e.fields,r=n&&n.length>0?function(){return D(n,(function(e){return t.buildField(e)}))}:Object.create(null);return new E.GraphQLInterfaceType({name:e.name.value,description:S(e,this._options),fields:r,astNode:e})},t._makeEnumDef=function(e){var t=this,n=e.values||[];return new E.GraphQLEnumType({name:e.name.value,description:S(e,this._options),values:D(n,(function(e){return t.buildEnumValue(e)})),astNode:e})},t._makeUnionDef=function(e){var t=this,n=e.types,r=n&&n.length>0?function(){return n.map((function(e){return t.getNamedType(e)}))}:[];return new E.GraphQLUnionType({name:e.name.value,description:S(e,this._options),types:r,astNode:e})},t._makeScalarDef=function(e){return new E.GraphQLScalarType({name:e.name.value,description:S(e,this._options),astNode:e})},t._makeInputObjectDef=function(e){var t=this,n=e.fields;return new E.GraphQLInputObjectType({name:e.name.value,description:S(e,this._options),fields:n?function(){return D(n,(function(e){return t.buildInputField(e)}))}:Object.create(null),astNode:e})},e}();function D(e,t){return(0,c.default)(e,(function(e){return e.name.value}),t)}function L(e){var t=(0,v.getDirectiveValues)(g.GraphQLDeprecatedDirective,e);return t&&t.reason}function S(e,t){if(e.description)return e.description.value;if(t&&t.commentDescriptions){var n=function(e){var t=e.loc;if(!t)return;var n=[],r=t.startToken.prev;for(;r&&r.kind===p.TokenKind.COMMENT&&r.next&&r.prev&&r.line+1===r.next.line&&r.line!==r.prev.line;){var i=String(r.value);n.push(i),r=r.prev}return n.reverse().join("\\n")}(e);if(void 0!==n)return(0,d.dedentBlockStringValue)("\\n"+n)}}t.ASTDefinitionBuilder=I},function(e,t,n){"use strict";Object.defineProperty(t,"__esModule",{value:!0}),t.coerceValue=function(e,t,n,c){var s=[],p=(0,u.coerceInputValue)(e,t,(function(e,t,u){var p="Invalid value "+(0,r.default)(t),l=[].concat((0,a.pathToArray)(c),e);l.length>0&&(p+=\' at "value\'.concat((0,i.default)(l),\'"\')),s.push(new o.GraphQLError(p+": "+u.message,n,void 0,void 0,void 0,u.originalError))}));return s.length>0?{errors:s,value:void 0}:{errors:void 0,value:p}};var r=c(n(5)),i=c(n(59)),a=n(36),o=n(1),u=n(60);function c(e){return e&&e.__esModule?e:{default:e}}},function(e,t,n){"use strict";Object.defineProperty(t,"__esModule",{value:!0});const r=n(105);self.addEventListener("message",e=>{const t=e.data;postMessage(r.catchSchemaErrors(t.code,t.libraries))})},function(e,t,n){"use strict";Object.defineProperty(t,"__esModule",{value:!0});const r=n(106),i=n(31),a=e=>[...(e.locations||[]).map(t=>({column:t.column,row:t.line-1,position:1,text:e.message,type:"error"}))];t.catchSchemaErrors=(e,t="")=>{const n=t+"\\n"+e,o=(e=>{const t=e.split("\\n").length;return e=>Object.assign(Object.assign({},e),{row:e.row-t})})(t);try{const e=(e=>{const t=r.parse(e);return i.validateSDL(t).map(a).flat(1)})(n);if(e.length>0)return e.map(o);try{return(e=>{const t=r.buildSchema(e);return r.validateSchema(t).map(a).flat(1)})(n).map(o)}catch(e){console.log(e)}}catch(e){return a(e).map(o)}return[]}},function(e,t,n){"use strict";n.r(t);var r=n(46);n.d(t,"version",(function(){return r.version})),n.d(t,"versionInfo",(function(){return r.versionInfo}));var i=n(47);n.d(t,"graphql",(function(){return i.graphql})),n.d(t,"graphqlSync",(function(){return i.graphqlSync}));var a=n(0);n.d(t,"GraphQLSchema",(function(){return a.GraphQLSchema})),n.d(t,"GraphQLDirective",(function(){return a.GraphQLDirective})),n.d(t,"GraphQLScalarType",(function(){return a.GraphQLScalarType})),n.d(t,"GraphQLObjectType",(function(){return a.GraphQLObjectType})),n.d(t,"GraphQLInterfaceType",(function(){return a.GraphQLInterfaceType})),n.d(t,"GraphQLUnionType",(function(){return a.GraphQLUnionType})),n.d(t,"GraphQLEnumType",(function(){return a.GraphQLEnumType})),n.d(t,"GraphQLInputObjectType",(function(){return a.GraphQLInputObjectType})),n.d(t,"GraphQLList",(function(){return a.GraphQLList})),n.d(t,"GraphQLNonNull",(function(){return a.GraphQLNonNull})),n.d(t,"specifiedScalarTypes",(function(){return a.specifiedScalarTypes})),n.d(t,"GraphQLInt",(function(){return a.GraphQLInt})),n.d(t,"GraphQLFloat",(function(){return a.GraphQLFloat})),n.d(t,"GraphQLString",(function(){return a.GraphQLString})),n.d(t,"GraphQLBoolean",(function(){return a.GraphQLBoolean})),n.d(t,"GraphQLID",(function(){return a.GraphQLID})),n.d(t,"specifiedDirectives",(function(){return a.specifiedDirectives})),n.d(t,"GraphQLIncludeDirective",(function(){return a.GraphQLIncludeDirective})),n.d(t,"GraphQLSkipDirective",(function(){return a.GraphQLSkipDirective})),n.d(t,"GraphQLDeprecatedDirective",(function(){return a.GraphQLDeprecatedDirective})),n.d(t,"TypeKind",(function(){return a.TypeKind})),n.d(t,"DEFAULT_DEPRECATION_REASON",(function(){return a.DEFAULT_DEPRECATION_REASON})),n.d(t,"introspectionTypes",(function(){return a.introspectionTypes})),n.d(t,"__Schema",(function(){return a.__Schema})),n.d(t,"__Directive",(function(){return a.__Directive})),n.d(t,"__DirectiveLocation",(function(){return a.__DirectiveLocation})),n.d(t,"__Type",(function(){return a.__Type})),n.d(t,"__Field",(function(){return a.__Field})),n.d(t,"__InputValue",(function(){return a.__InputValue})),n.d(t,"__EnumValue",(function(){return a.__EnumValue})),n.d(t,"__TypeKind",(function(){return a.__TypeKind})),n.d(t,"SchemaMetaFieldDef",(function(){return a.SchemaMetaFieldDef})),n.d(t,"TypeMetaFieldDef",(function(){return a.TypeMetaFieldDef})),n.d(t,"TypeNameMetaFieldDef",(function(){return a.TypeNameMetaFieldDef})),n.d(t,"isSchema",(function(){return a.isSchema})),n.d(t,"isDirective",(function(){return a.isDirective})),n.d(t,"isType",(function(){return a.isType})),n.d(t,"isScalarType",(function(){return a.isScalarType})),n.d(t,"isObjectType",(function(){return a.isObjectType})),n.d(t,"isInterfaceType",(function(){return a.isInterfaceType})),n.d(t,"isUnionType",(function(){return a.isUnionType})),n.d(t,"isEnumType",(function(){return a.isEnumType})),n.d(t,"isInputObjectType",(function(){return a.isInputObjectType})),n.d(t,"isListType",(function(){return a.isListType})),n.d(t,"isNonNullType",(function(){return a.isNonNullType})),n.d(t,"isInputType",(function(){return a.isInputType})),n.d(t,"isOutputType",(function(){return a.isOutputType})),n.d(t,"isLeafType",(function(){return a.isLeafType})),n.d(t,"isCompositeType",(function(){return a.isCompositeType})),n.d(t,"isAbstractType",(function(){return a.isAbstractType})),n.d(t,"isWrappingType",(function(){return a.isWrappingType})),n.d(t,"isNullableType",(function(){return a.isNullableType})),n.d(t,"isNamedType",(function(){return a.isNamedType})),n.d(t,"isRequiredArgument",(function(){return a.isRequiredArgument})),n.d(t,"isRequiredInputField",(function(){return a.isRequiredInputField})),n.d(t,"isSpecifiedScalarType",(function(){return a.isSpecifiedScalarType})),n.d(t,"isIntrospectionType",(function(){return a.isIntrospectionType})),n.d(t,"isSpecifiedDirective",(function(){return a.isSpecifiedDirective})),n.d(t,"assertSchema",(function(){return a.assertSchema})),n.d(t,"assertDirective",(function(){return a.assertDirective})),n.d(t,"assertType",(function(){return a.assertType})),n.d(t,"assertScalarType",(function(){return a.assertScalarType})),n.d(t,"assertObjectType",(function(){return a.assertObjectType})),n.d(t,"assertInterfaceType",(function(){return a.assertInterfaceType})),n.d(t,"assertUnionType",(function(){return a.assertUnionType})),n.d(t,"assertEnumType",(function(){return a.assertEnumType})),n.d(t,"assertInputObjectType",(function(){return a.assertInputObjectType})),n.d(t,"assertListType",(function(){return a.assertListType})),n.d(t,"assertNonNullType",(function(){return a.assertNonNullType})),n.d(t,"assertInputType",(function(){return a.assertInputType})),n.d(t,"assertOutputType",(function(){return a.assertOutputType})),n.d(t,"assertLeafType",(function(){return a.assertLeafType})),n.d(t,"assertCompositeType",(function(){return a.assertCompositeType})),n.d(t,"assertAbstractType",(function(){return a.assertAbstractType})),n.d(t,"assertWrappingType",(function(){return a.assertWrappingType})),n.d(t,"assertNullableType",(function(){return a.assertNullableType})),n.d(t,"assertNamedType",(function(){return a.assertNamedType})),n.d(t,"getNullableType",(function(){return a.getNullableType})),n.d(t,"getNamedType",(function(){return a.getNamedType})),n.d(t,"validateSchema",(function(){return a.validateSchema})),n.d(t,"assertValidSchema",(function(){return a.assertValidSchema}));var o=n(6);n.d(t,"Source",(function(){return o.Source})),n.d(t,"getLocation",(function(){return o.getLocation})),n.d(t,"printLocation",(function(){return o.printLocation})),n.d(t,"printSourceLocation",(function(){return o.printSourceLocation})),n.d(t,"createLexer",(function(){return o.createLexer})),n.d(t,"TokenKind",(function(){return o.TokenKind})),n.d(t,"parse",(function(){return o.parse})),n.d(t,"parseValue",(function(){return o.parseValue})),n.d(t,"parseType",(function(){return o.parseType})),n.d(t,"print",(function(){return o.print})),n.d(t,"visit",(function(){return o.visit})),n.d(t,"visitInParallel",(function(){return o.visitInParallel})),n.d(t,"visitWithTypeInfo",(function(){return o.visitWithTypeInfo})),n.d(t,"getVisitFn",(function(){return o.getVisitFn})),n.d(t,"BREAK",(function(){return o.BREAK})),n.d(t,"Kind",(function(){return o.Kind})),n.d(t,"DirectiveLocation",(function(){return o.DirectiveLocation})),n.d(t,"isDefinitionNode",(function(){return o.isDefinitionNode})),n.d(t,"isExecutableDefinitionNode",(function(){return o.isExecutableDefinitionNode})),n.d(t,"isSelectionNode",(function(){return o.isSelectionNode})),n.d(t,"isValueNode",(function(){return o.isValueNode})),n.d(t,"isTypeNode",(function(){return o.isTypeNode})),n.d(t,"isTypeSystemDefinitionNode",(function(){return o.isTypeSystemDefinitionNode})),n.d(t,"isTypeDefinitionNode",(function(){return o.isTypeDefinitionNode})),n.d(t,"isTypeSystemExtensionNode",(function(){return o.isTypeSystemExtensionNode})),n.d(t,"isTypeExtensionNode",(function(){return o.isTypeExtensionNode}));var u=n(25);n.d(t,"execute",(function(){return u.execute})),n.d(t,"defaultFieldResolver",(function(){return u.defaultFieldResolver})),n.d(t,"defaultTypeResolver",(function(){return u.defaultTypeResolver})),n.d(t,"responsePathAsArray",(function(){return u.responsePathAsArray})),n.d(t,"getDirectiveValues",(function(){return u.getDirectiveValues}));var c=n(61);n.d(t,"subscribe",(function(){return c.subscribe})),n.d(t,"createSourceEventStream",(function(){return c.createSourceEventStream}));var s=n(2);n.d(t,"validate",(function(){return s.validate})),n.d(t,"ValidationContext",(function(){return s.ValidationContext})),n.d(t,"specifiedRules",(function(){return s.specifiedRules})),n.d(t,"ExecutableDefinitionsRule",(function(){return s.ExecutableDefinitionsRule})),n.d(t,"FieldsOnCorrectTypeRule",(function(){return s.FieldsOnCorrectTypeRule})),n.d(t,"FragmentsOnCompositeTypesRule",(function(){return s.FragmentsOnCompositeTypesRule})),n.d(t,"KnownArgumentNamesRule",(function(){return s.KnownArgumentNamesRule})),n.d(t,"KnownDirectivesRule",(function(){return s.KnownDirectivesRule})),n.d(t,"KnownFragmentNamesRule",(function(){return s.KnownFragmentNamesRule})),n.d(t,"KnownTypeNamesRule",(function(){return s.KnownTypeNamesRule})),n.d(t,"LoneAnonymousOperationRule",(function(){return s.LoneAnonymousOperationRule})),n.d(t,"NoFragmentCyclesRule",(function(){return s.NoFragmentCyclesRule})),n.d(t,"NoUndefinedVariablesRule",(function(){return s.NoUndefinedVariablesRule})),n.d(t,"NoUnusedFragmentsRule",(function(){return s.NoUnusedFragmentsRule})),n.d(t,"NoUnusedVariablesRule",(function(){return s.NoUnusedVariablesRule})),n.d(t,"OverlappingFieldsCanBeMergedRule",(function(){return s.OverlappingFieldsCanBeMergedRule})),n.d(t,"PossibleFragmentSpreadsRule",(function(){return s.PossibleFragmentSpreadsRule})),n.d(t,"ProvidedRequiredArgumentsRule",(function(){return s.ProvidedRequiredArgumentsRule})),n.d(t,"ScalarLeafsRule",(function(){return s.ScalarLeafsRule})),n.d(t,"SingleFieldSubscriptionsRule",(function(){return s.SingleFieldSubscriptionsRule})),n.d(t,"UniqueArgumentNamesRule",(function(){return s.UniqueArgumentNamesRule})),n.d(t,"UniqueDirectivesPerLocationRule",(function(){return s.UniqueDirectivesPerLocationRule})),n.d(t,"UniqueFragmentNamesRule",(function(){return s.UniqueFragmentNamesRule})),n.d(t,"UniqueInputFieldNamesRule",(function(){return s.UniqueInputFieldNamesRule})),n.d(t,"UniqueOperationNamesRule",(function(){return s.UniqueOperationNamesRule})),n.d(t,"UniqueVariableNamesRule",(function(){return s.UniqueVariableNamesRule})),n.d(t,"ValuesOfCorrectTypeRule",(function(){return s.ValuesOfCorrectTypeRule})),n.d(t,"VariablesAreInputTypesRule",(function(){return s.VariablesAreInputTypesRule})),n.d(t,"VariablesInAllowedPositionRule",(function(){return s.VariablesInAllowedPositionRule})),n.d(t,"LoneSchemaDefinitionRule",(function(){return s.LoneSchemaDefinitionRule})),n.d(t,"UniqueOperationTypesRule",(function(){return s.UniqueOperationTypesRule})),n.d(t,"UniqueTypeNamesRule",(function(){return s.UniqueTypeNamesRule})),n.d(t,"UniqueEnumValueNamesRule",(function(){return s.UniqueEnumValueNamesRule})),n.d(t,"UniqueFieldDefinitionNamesRule",(function(){return s.UniqueFieldDefinitionNamesRule})),n.d(t,"UniqueDirectiveNamesRule",(function(){return s.UniqueDirectiveNamesRule})),n.d(t,"PossibleTypeExtensionsRule",(function(){return s.PossibleTypeExtensionsRule}));var p=n(26);n.d(t,"GraphQLError",(function(){return p.GraphQLError})),n.d(t,"syntaxError",(function(){return p.syntaxError})),n.d(t,"locatedError",(function(){return p.locatedError})),n.d(t,"printError",(function(){return p.printError})),n.d(t,"formatError",(function(){return p.formatError}));var l=n(3);n.d(t,"getIntrospectionQuery",(function(){return l.getIntrospectionQuery})),n.d(t,"introspectionQuery",(function(){return l.introspectionQuery})),n.d(t,"getOperationAST",(function(){return l.getOperationAST})),n.d(t,"getOperationRootType",(function(){return l.getOperationRootType})),n.d(t,"introspectionFromSchema",(function(){return l.introspectionFromSchema})),n.d(t,"buildClientSchema",(function(){return l.buildClientSchema})),n.d(t,"buildASTSchema",(function(){return l.buildASTSchema})),n.d(t,"buildSchema",(function(){return l.buildSchema})),n.d(t,"getDescription",(function(){return l.getDescription})),n.d(t,"extendSchema",(function(){return l.extendSchema})),n.d(t,"lexicographicSortSchema",(function(){return l.lexicographicSortSchema})),n.d(t,"printSchema",(function(){return l.printSchema})),n.d(t,"printType",(function(){return l.printType})),n.d(t,"printIntrospectionSchema",(function(){return l.printIntrospectionSchema})),n.d(t,"typeFromAST",(function(){return l.typeFromAST})),n.d(t,"valueFromAST",(function(){return l.valueFromAST})),n.d(t,"valueFromASTUntyped",(function(){return l.valueFromASTUntyped})),n.d(t,"astFromValue",(function(){return l.astFromValue})),n.d(t,"TypeInfo",(function(){return l.TypeInfo})),n.d(t,"coerceInputValue",(function(){return l.coerceInputValue})),n.d(t,"coerceValue",(function(){return l.coerceValue})),n.d(t,"isValidJSValue",(function(){return l.isValidJSValue})),n.d(t,"isValidLiteralValue",(function(){return l.isValidLiteralValue})),n.d(t,"concatAST",(function(){return l.concatAST})),n.d(t,"separateOperations",(function(){return l.separateOperations})),n.d(t,"stripIgnoredCharacters",(function(){return l.stripIgnoredCharacters})),n.d(t,"isEqualType",(function(){return l.isEqualType})),n.d(t,"isTypeSubTypeOf",(function(){return l.isTypeSubTypeOf})),n.d(t,"doTypesOverlap",(function(){return l.doTypesOverlap})),n.d(t,"assertValidName",(function(){return l.assertValidName})),n.d(t,"isValidNameError",(function(){return l.isValidNameError})),n.d(t,"BreakingChangeType",(function(){return l.BreakingChangeType})),n.d(t,"DangerousChangeType",(function(){return l.DangerousChangeType})),n.d(t,"findBreakingChanges",(function(){return l.findBreakingChanges})),n.d(t,"findDangerousChanges",(function(){return l.findDangerousChanges})),n.d(t,"findDeprecatedUsages",(function(){return l.findDeprecatedUsages}))},function(e,t,n){"use strict";Object.defineProperty(t,"__esModule",{value:!0}),t.default=function(e){return e}},function(e,t,n){"use strict";Object.defineProperty(t,"__esModule",{value:!0}),t.default=void 0;var r=Number.isFinite||function(e){return"number"==typeof e&&isFinite(e)};t.default=r},function(e,t,n){"use strict";Object.defineProperty(t,"__esModule",{value:!0}),t.default=void 0;var r=Number.isInteger||function(e){return"number"==typeof e&&isFinite(e)&&Math.floor(e)===e};t.default=r},function(e,t,n){"use strict";Object.defineProperty(t,"__esModule",{value:!0}),t.default=function(e){var t;return function(n,r,i){t||(t=new WeakMap);var a,o=t.get(n);if(o){if(a=o.get(r)){var u=a.get(i);if(void 0!==u)return u}}else o=new WeakMap,t.set(n,o);a||(a=new WeakMap,o.set(r,a));var c=e(n,r,i);return a.set(i,c),c}}},function(e,t,n){"use strict";Object.defineProperty(t,"__esModule",{value:!0}),t.default=function(e,t,n){return e.reduce((function(e,n){return(0,i.default)(e)?e.then((function(e){return t(e,n)})):t(e,n)}),n)};var r,i=(r=n(37))&&r.__esModule?r:{default:r}},function(e,t,n){"use strict";Object.defineProperty(t,"__esModule",{value:!0}),t.default=function(e){var t=Object.keys(e),n=t.map((function(t){return e[t]}));return Promise.all(n).then((function(e){return e.reduce((function(e,n,r){return e[t[r]]=n,e}),Object.create(null))}))}},function(e,t,n){"use strict";Object.defineProperty(t,"__esModule",{value:!0}),t.subscribe=function(e,t,n,r,i,a,o,u){return 1===arguments.length?d(e):d({schema:e,document:t,rootValue:n,contextValue:r,variableValues:i,operationName:a,fieldResolver:o,subscribeFieldResolver:u})},t.createSourceEventStream=y;var r=n(34),i=l(n(5)),a=n(36),o=n(1),u=n(56),c=n(44),s=n(57),p=l(n(114));function l(e){return e&&e.__esModule?e:{default:e}}function f(e){if(e instanceof o.GraphQLError)return{errors:[e]};throw e}function d(e){var t=e.schema,n=e.document,i=e.rootValue,a=e.contextValue,o=e.variableValues,u=e.operationName,s=e.fieldResolver,l=e.subscribeFieldResolver,d=y(t,n,i,a,o,u,l),v=function(e){return(0,c.execute)(t,n,e,a,o,u,s)};return d.then((function(e){return(0,r.isAsyncIterable)(e)?(0,p.default)(e,v,f):e}))}function y(e,t,n,p,l,f,d){(0,c.assertValidExecutionArguments)(e,t,l);try{var y=(0,c.buildExecutionContext)(e,t,n,p,l,f,d);if(Array.isArray(y))return Promise.resolve({errors:y});var v=(0,s.getOperationRootType)(e,y.operation),h=(0,c.collectFields)(y,v,y.operation.selectionSet,Object.create(null),Object.create(null)),m=Object.keys(h)[0],T=h[m],g=T[0].name.value,E=(0,c.getFieldDef)(e,v,g);if(!E)throw new o.GraphQLError(\'The subscription field "\'.concat(g,\'" is not defined.\'),T);var b=E.subscribe||y.fieldResolver,N=(0,a.addPath)(void 0,m),O=(0,c.buildResolveInfo)(y,E,T,v,N),_=(0,c.resolveFieldValueOrError)(y,E,T,b,n,O);return Promise.resolve(_).then((function(e){if(e instanceof Error)return{errors:[(0,u.locatedError)(e,T,(0,a.pathToArray)(N))]};if((0,r.isAsyncIterable)(e))return e;throw new Error("Subscription field must return Async Iterable. Received: "+(0,i.default)(e))}))}catch(e){return e instanceof o.GraphQLError?Promise.resolve({errors:[e]}):Promise.reject(e)}}},function(e,t,n){"use strict";Object.defineProperty(t,"__esModule",{value:!0}),t.default=function(e,t,n){var o,u,c,s=(0,r.getAsyncIterator)(e);"function"==typeof s.return&&(o=s.return,u=function(e){var t=function(){return Promise.reject(e)};return o.call(s).then(t,t)});function p(e){return e.done?e:i(e.value,t).then(a,u)}if(n){var l=n;c=function(e){return i(e,l).then(a,u)}}return function(e,t,n){t in e?Object.defineProperty(e,t,{value:n,enumerable:!0,configurable:!0,writable:!0}):e[t]=n;return e}({next:function(){return s.next().then(p,c)},return:function(){return o?o.call(s).then(p,c):Promise.resolve({value:void 0,done:!0})},throw:function(e){return"function"==typeof s.throw?s.throw(e).then(p,c):Promise.reject(e).catch(u)}},r.$$asyncIterator,(function(){return this}))};var r=n(34);function i(e,t){return new Promise((function(n){return n(t(e))}))}function a(e){return{value:e,done:!1}}},function(e,t,n){"use strict";Object.defineProperty(t,"__esModule",{value:!0}),t.formatError=function(e){e||(0,i.default)(0,"Received null or undefined error.");var t=e.message||"An unknown error occurred.",n=e.locations,r=e.path,a=e.extensions;return a?{message:t,locations:n,path:r,extensions:a}:{message:t,locations:n,path:r}};var r,i=(r=n(11))&&r.__esModule?r:{default:r}},function(e,t,n){"use strict";Object.defineProperty(t,"__esModule",{value:!0}),t.getOperationAST=function(e,t){for(var n=null,i=0,a=e.definitions;i2&&void 0!==arguments[2]?arguments[2]:"";return 0===t.length?"":t.every((function(e){return!e.description}))?"("+t.map(N).join(", ")+")":"(\\n"+t.map((function(t,r){return _(e,t," "+n,!r)+" "+n+N(t)})).join("\\n")+"\\n"+n+")"}function N(e){var t=(0,d.astFromValue)(e.defaultValue,e.type),n=e.name+": "+String(e.type);return t&&(n+=" = ".concat((0,u.print)(t))),n}function O(e){if(!e.isDeprecated)return"";var t=e.deprecationReason,n=(0,d.astFromValue)(t,p.GraphQLString);return n&&""!==t&&t!==l.DEFAULT_DEPRECATION_REASON?" @deprecated(reason: "+(0,u.print)(n)+")":" @deprecated"}function _(e,t){var n=arguments.length>2&&void 0!==arguments[2]?arguments[2]:"",r=!(arguments.length>3&&void 0!==arguments[3])||arguments[3];if(!t.description)return"";var i=D(t.description,120-n.length);if(e&&e.commentDescriptions)return I(i,n,r);var a=i.join("\\n"),o=a.length>70,u=(0,c.printBlockString)(a,"",o),s=n&&!r?"\\n"+n:n;return s+u.replace(/\\n/g,"\\n"+n)+"\\n"}function I(e,t,n){for(var r=t&&!n?"\\n":"",i=0;i0&&(n="\\n"+n);var i=n[n.length-1];return(\'"\'===i&&\'\\\\"""\'!==n.slice(-4)||"\\\\"===i)&&(n+="\\n"),\'"""\'+n+\'"""\'}},function(e,t,n){"use strict";Object.defineProperty(t,"__esModule",{value:!0}),t.findBreakingChanges=function(e,t){return h(e,t).filter((function(e){return e.type in y}))},t.findDangerousChanges=function(e,t){return h(e,t).filter((function(e){return e.type in v}))},t.DangerousChangeType=t.BreakingChangeType=void 0;var r=l(n(8)),i=l(n(18)),a=l(n(5)),o=l(n(9)),u=n(13),c=n(17),s=n(4),p=n(43);function l(e){return e&&e.__esModule?e:{default:e}}function f(e,t){var n=Object.keys(e);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(e);t&&(r=r.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),n.push.apply(n,r)}return n}function d(e,t,n){return t in e?Object.defineProperty(e,t,{value:n,enumerable:!0,configurable:!0,writable:!0}):e[t]=n,e}var y=Object.freeze({TYPE_REMOVED:"TYPE_REMOVED",TYPE_CHANGED_KIND:"TYPE_CHANGED_KIND",TYPE_REMOVED_FROM_UNION:"TYPE_REMOVED_FROM_UNION",VALUE_REMOVED_FROM_ENUM:"VALUE_REMOVED_FROM_ENUM",REQUIRED_INPUT_FIELD_ADDED:"REQUIRED_INPUT_FIELD_ADDED",INTERFACE_REMOVED_FROM_OBJECT:"INTERFACE_REMOVED_FROM_OBJECT",FIELD_REMOVED:"FIELD_REMOVED",FIELD_CHANGED_KIND:"FIELD_CHANGED_KIND",REQUIRED_ARG_ADDED:"REQUIRED_ARG_ADDED",ARG_REMOVED:"ARG_REMOVED",ARG_CHANGED_KIND:"ARG_CHANGED_KIND",DIRECTIVE_REMOVED:"DIRECTIVE_REMOVED",DIRECTIVE_ARG_REMOVED:"DIRECTIVE_ARG_REMOVED",REQUIRED_DIRECTIVE_ARG_ADDED:"REQUIRED_DIRECTIVE_ARG_ADDED",DIRECTIVE_LOCATION_REMOVED:"DIRECTIVE_LOCATION_REMOVED"});t.BreakingChangeType=y;var v=Object.freeze({VALUE_ADDED_TO_ENUM:"VALUE_ADDED_TO_ENUM",TYPE_ADDED_TO_UNION:"TYPE_ADDED_TO_UNION",OPTIONAL_INPUT_FIELD_ADDED:"OPTIONAL_INPUT_FIELD_ADDED",OPTIONAL_ARG_ADDED:"OPTIONAL_ARG_ADDED",INTERFACE_ADDED_TO_OBJECT:"INTERFACE_ADDED_TO_OBJECT",ARG_DEFAULT_VALUE_CHANGE:"ARG_DEFAULT_VALUE_CHANGE"});function h(e,t){return[].concat(function(e,t){for(var n=[],i=L((0,r.default)(e.getTypeMap()),(0,r.default)(t.getTypeMap())),a=0,o=i.removed;a offset) {\r\n high = mid;\r\n }\r\n else {\r\n low = mid + 1;\r\n }\r\n }\r\n // low is the least x for which the line offset is larger than the current offset\r\n // or array.length if no line offset is larger than the current offset\r\n var line = low - 1;\r\n return { line: line, character: offset - lineOffsets[line] };\r\n };\r\n FullTextDocument.prototype.offsetAt = function (position) {\r\n var lineOffsets = this.getLineOffsets();\r\n if (position.line >= lineOffsets.length) {\r\n return this._content.length;\r\n }\r\n else if (position.line < 0) {\r\n return 0;\r\n }\r\n var lineOffset = lineOffsets[position.line];\r\n var nextLineOffset = (position.line + 1 < lineOffsets.length) ? lineOffsets[position.line + 1] : this._content.length;\r\n return Math.max(Math.min(lineOffset + position.character, nextLineOffset), lineOffset);\r\n };\r\n Object.defineProperty(FullTextDocument.prototype, \"lineCount\", {\r\n get: function () {\r\n return this.getLineOffsets().length;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n FullTextDocument.isIncremental = function (event) {\r\n var candidate = event;\r\n return candidate !== undefined && candidate !== null &&\r\n typeof candidate.text === 'string' && candidate.range !== undefined &&\r\n (candidate.rangeLength === undefined || typeof candidate.rangeLength === 'number');\r\n };\r\n FullTextDocument.isFull = function (event) {\r\n var candidate = event;\r\n return candidate !== undefined && candidate !== null &&\r\n typeof candidate.text === 'string' && candidate.range === undefined && candidate.rangeLength === undefined;\r\n };\r\n return FullTextDocument;\r\n}());\r\nvar TextDocument;\r\n(function (TextDocument) {\r\n /**\r\n * Creates a new text document.\r\n *\r\n * @param uri The document's uri.\r\n * @param languageId The document's language Id.\r\n * @param version The document's initial version number.\r\n * @param content The document's content.\r\n */\r\n function create(uri, languageId, version, content) {\r\n return new FullTextDocument(uri, languageId, version, content);\r\n }\r\n TextDocument.create = create;\r\n /**\r\n * Updates a TextDocument by modifing its content.\r\n *\r\n * @param document the document to update. Only documents created by TextDocument.create are valid inputs.\r\n * @param changes the changes to apply to the document.\r\n * @returns The updated TextDocument. Note: That's the same document instance passed in as first parameter.\r\n *\r\n */\r\n function update(document, changes, version) {\r\n if (document instanceof FullTextDocument) {\r\n document.update(changes, version);\r\n return document;\r\n }\r\n else {\r\n throw new Error('TextDocument.update: document must be created by TextDocument.create');\r\n }\r\n }\r\n TextDocument.update = update;\r\n function applyEdits(document, edits) {\r\n var text = document.getText();\r\n var sortedEdits = mergeSort(edits.map(getWellformedEdit), function (a, b) {\r\n var diff = a.range.start.line - b.range.start.line;\r\n if (diff === 0) {\r\n return a.range.start.character - b.range.start.character;\r\n }\r\n return diff;\r\n });\r\n var lastModifiedOffset = text.length;\r\n for (var i = sortedEdits.length - 1; i >= 0; i--) {\r\n var e = sortedEdits[i];\r\n var startOffset = document.offsetAt(e.range.start);\r\n var endOffset = document.offsetAt(e.range.end);\r\n if (endOffset <= lastModifiedOffset) {\r\n text = text.substring(0, startOffset) + e.newText + text.substring(endOffset, text.length);\r\n }\r\n else {\r\n throw new Error('Overlapping edit');\r\n }\r\n lastModifiedOffset = startOffset;\r\n }\r\n return text;\r\n }\r\n TextDocument.applyEdits = applyEdits;\r\n})(TextDocument || (TextDocument = {}));\r\nfunction mergeSort(data, compare) {\r\n if (data.length <= 1) {\r\n // sorted\r\n return data;\r\n }\r\n var p = (data.length / 2) | 0;\r\n var left = data.slice(0, p);\r\n var right = data.slice(p);\r\n mergeSort(left, compare);\r\n mergeSort(right, compare);\r\n var leftIdx = 0;\r\n var rightIdx = 0;\r\n var i = 0;\r\n while (leftIdx < left.length && rightIdx < right.length) {\r\n var ret = compare(left[leftIdx], right[rightIdx]);\r\n if (ret <= 0) {\r\n // smaller_equal -> take left to preserve order\r\n data[i++] = left[leftIdx++];\r\n }\r\n else {\r\n // greater -> take right\r\n data[i++] = right[rightIdx++];\r\n }\r\n }\r\n while (leftIdx < left.length) {\r\n data[i++] = left[leftIdx++];\r\n }\r\n while (rightIdx < right.length) {\r\n data[i++] = right[rightIdx++];\r\n }\r\n return data;\r\n}\r\nfunction computeLineOffsets(text, isAtLineStart, textOffset) {\r\n if (textOffset === void 0) { textOffset = 0; }\r\n var result = isAtLineStart ? [textOffset] : [];\r\n for (var i = 0; i < text.length; i++) {\r\n var ch = text.charCodeAt(i);\r\n if (ch === 13 /* CarriageReturn */ || ch === 10 /* LineFeed */) {\r\n if (ch === 13 /* CarriageReturn */ && i + 1 < text.length && text.charCodeAt(i + 1) === 10 /* LineFeed */) {\r\n i++;\r\n }\r\n result.push(textOffset + i + 1);\r\n }\r\n }\r\n return result;\r\n}\r\nfunction getWellformedRange(range) {\r\n var start = range.start;\r\n var end = range.end;\r\n if (start.line > end.line || (start.line === end.line && start.character > end.character)) {\r\n return { start: end, end: start };\r\n }\r\n return range;\r\n}\r\nfunction getWellformedEdit(textEdit) {\r\n var range = getWellformedRange(textEdit.range);\r\n if (range !== textEdit.range) {\r\n return { newText: textEdit.newText, range: range };\r\n }\r\n return textEdit;\r\n}\r\n\n\n//# sourceURL=webpack:///./node_modules/monaco-editor/esm/vs/language/css/_deps/vscode-css-languageservice/_deps/vscode-languageserver-textdocument/lib/esm/main.js?"); - -/***/ }), - -/***/ "./node_modules/monaco-editor/esm/vs/language/css/_deps/vscode-css-languageservice/cssLanguageService.js": -/*!***************************************************************************************************************!*\ - !*** ./node_modules/monaco-editor/esm/vs/language/css/_deps/vscode-css-languageservice/cssLanguageService.js ***! - \***************************************************************************************************************/ -/*! exports provided: TextDocument, Position, Range, Location, LocationLink, Color, ColorInformation, ColorPresentation, FoldingRangeKind, FoldingRange, DiagnosticRelatedInformation, DiagnosticSeverity, DiagnosticTag, Diagnostic, Command, TextEdit, TextDocumentEdit, CreateFile, RenameFile, DeleteFile, WorkspaceEdit, WorkspaceChange, TextDocumentIdentifier, VersionedTextDocumentIdentifier, TextDocumentItem, MarkupKind, MarkupContent, CompletionItemKind, InsertTextFormat, CompletionItemTag, CompletionItem, CompletionList, MarkedString, Hover, ParameterInformation, SignatureInformation, DocumentHighlightKind, DocumentHighlight, SymbolKind, SymbolTag, SymbolInformation, DocumentSymbol, CodeActionKind, CodeActionContext, CodeAction, CodeLens, FormattingOptions, DocumentLink, SelectionRange, EOL, ClientCapabilities, FileType, getCSSLanguageService, getSCSSLanguageService, getLESSLanguageService */ -/***/ (function(module, __webpack_exports__, __webpack_require__) { - -"use strict"; -eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"getCSSLanguageService\", function() { return getCSSLanguageService; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"getSCSSLanguageService\", function() { return getSCSSLanguageService; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"getLESSLanguageService\", function() { return getLESSLanguageService; });\n/* harmony import */ var _parser_cssParser_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./parser/cssParser.js */ \"./node_modules/monaco-editor/esm/vs/language/css/_deps/vscode-css-languageservice/parser/cssParser.js\");\n/* harmony import */ var _services_cssCompletion_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./services/cssCompletion.js */ \"./node_modules/monaco-editor/esm/vs/language/css/_deps/vscode-css-languageservice/services/cssCompletion.js\");\n/* harmony import */ var _services_cssHover_js__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./services/cssHover.js */ \"./node_modules/monaco-editor/esm/vs/language/css/_deps/vscode-css-languageservice/services/cssHover.js\");\n/* harmony import */ var _services_cssNavigation_js__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./services/cssNavigation.js */ \"./node_modules/monaco-editor/esm/vs/language/css/_deps/vscode-css-languageservice/services/cssNavigation.js\");\n/* harmony import */ var _services_cssCodeActions_js__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./services/cssCodeActions.js */ \"./node_modules/monaco-editor/esm/vs/language/css/_deps/vscode-css-languageservice/services/cssCodeActions.js\");\n/* harmony import */ var _services_cssValidation_js__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ./services/cssValidation.js */ \"./node_modules/monaco-editor/esm/vs/language/css/_deps/vscode-css-languageservice/services/cssValidation.js\");\n/* harmony import */ var _parser_scssParser_js__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ./parser/scssParser.js */ \"./node_modules/monaco-editor/esm/vs/language/css/_deps/vscode-css-languageservice/parser/scssParser.js\");\n/* harmony import */ var _services_scssCompletion_js__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(/*! ./services/scssCompletion.js */ \"./node_modules/monaco-editor/esm/vs/language/css/_deps/vscode-css-languageservice/services/scssCompletion.js\");\n/* harmony import */ var _parser_lessParser_js__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(/*! ./parser/lessParser.js */ \"./node_modules/monaco-editor/esm/vs/language/css/_deps/vscode-css-languageservice/parser/lessParser.js\");\n/* harmony import */ var _services_lessCompletion_js__WEBPACK_IMPORTED_MODULE_9__ = __webpack_require__(/*! ./services/lessCompletion.js */ \"./node_modules/monaco-editor/esm/vs/language/css/_deps/vscode-css-languageservice/services/lessCompletion.js\");\n/* harmony import */ var _services_cssFolding_js__WEBPACK_IMPORTED_MODULE_10__ = __webpack_require__(/*! ./services/cssFolding.js */ \"./node_modules/monaco-editor/esm/vs/language/css/_deps/vscode-css-languageservice/services/cssFolding.js\");\n/* harmony import */ var _languageFacts_facts_js__WEBPACK_IMPORTED_MODULE_11__ = __webpack_require__(/*! ./languageFacts/facts.js */ \"./node_modules/monaco-editor/esm/vs/language/css/_deps/vscode-css-languageservice/languageFacts/facts.js\");\n/* harmony import */ var _services_cssSelectionRange_js__WEBPACK_IMPORTED_MODULE_12__ = __webpack_require__(/*! ./services/cssSelectionRange.js */ \"./node_modules/monaco-editor/esm/vs/language/css/_deps/vscode-css-languageservice/services/cssSelectionRange.js\");\n/* harmony import */ var _services_scssNavigation_js__WEBPACK_IMPORTED_MODULE_13__ = __webpack_require__(/*! ./services/scssNavigation.js */ \"./node_modules/monaco-editor/esm/vs/language/css/_deps/vscode-css-languageservice/services/scssNavigation.js\");\n/* harmony import */ var _cssLanguageTypes_js__WEBPACK_IMPORTED_MODULE_14__ = __webpack_require__(/*! ./cssLanguageTypes.js */ \"./node_modules/monaco-editor/esm/vs/language/css/_deps/vscode-css-languageservice/cssLanguageTypes.js\");\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"TextDocument\", function() { return _cssLanguageTypes_js__WEBPACK_IMPORTED_MODULE_14__[\"TextDocument\"]; });\n\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"Position\", function() { return _cssLanguageTypes_js__WEBPACK_IMPORTED_MODULE_14__[\"Position\"]; });\n\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"Range\", function() { return _cssLanguageTypes_js__WEBPACK_IMPORTED_MODULE_14__[\"Range\"]; });\n\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"Location\", function() { return _cssLanguageTypes_js__WEBPACK_IMPORTED_MODULE_14__[\"Location\"]; });\n\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"LocationLink\", function() { return _cssLanguageTypes_js__WEBPACK_IMPORTED_MODULE_14__[\"LocationLink\"]; });\n\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"Color\", function() { return _cssLanguageTypes_js__WEBPACK_IMPORTED_MODULE_14__[\"Color\"]; });\n\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"ColorInformation\", function() { return _cssLanguageTypes_js__WEBPACK_IMPORTED_MODULE_14__[\"ColorInformation\"]; });\n\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"ColorPresentation\", function() { return _cssLanguageTypes_js__WEBPACK_IMPORTED_MODULE_14__[\"ColorPresentation\"]; });\n\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"FoldingRangeKind\", function() { return _cssLanguageTypes_js__WEBPACK_IMPORTED_MODULE_14__[\"FoldingRangeKind\"]; });\n\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"FoldingRange\", function() { return _cssLanguageTypes_js__WEBPACK_IMPORTED_MODULE_14__[\"FoldingRange\"]; });\n\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"DiagnosticRelatedInformation\", function() { return _cssLanguageTypes_js__WEBPACK_IMPORTED_MODULE_14__[\"DiagnosticRelatedInformation\"]; });\n\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"DiagnosticSeverity\", function() { return _cssLanguageTypes_js__WEBPACK_IMPORTED_MODULE_14__[\"DiagnosticSeverity\"]; });\n\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"DiagnosticTag\", function() { return _cssLanguageTypes_js__WEBPACK_IMPORTED_MODULE_14__[\"DiagnosticTag\"]; });\n\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"Diagnostic\", function() { return _cssLanguageTypes_js__WEBPACK_IMPORTED_MODULE_14__[\"Diagnostic\"]; });\n\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"Command\", function() { return _cssLanguageTypes_js__WEBPACK_IMPORTED_MODULE_14__[\"Command\"]; });\n\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"TextEdit\", function() { return _cssLanguageTypes_js__WEBPACK_IMPORTED_MODULE_14__[\"TextEdit\"]; });\n\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"TextDocumentEdit\", function() { return _cssLanguageTypes_js__WEBPACK_IMPORTED_MODULE_14__[\"TextDocumentEdit\"]; });\n\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"CreateFile\", function() { return _cssLanguageTypes_js__WEBPACK_IMPORTED_MODULE_14__[\"CreateFile\"]; });\n\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"RenameFile\", function() { return _cssLanguageTypes_js__WEBPACK_IMPORTED_MODULE_14__[\"RenameFile\"]; });\n\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"DeleteFile\", function() { return _cssLanguageTypes_js__WEBPACK_IMPORTED_MODULE_14__[\"DeleteFile\"]; });\n\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"WorkspaceEdit\", function() { return _cssLanguageTypes_js__WEBPACK_IMPORTED_MODULE_14__[\"WorkspaceEdit\"]; });\n\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"WorkspaceChange\", function() { return _cssLanguageTypes_js__WEBPACK_IMPORTED_MODULE_14__[\"WorkspaceChange\"]; });\n\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"TextDocumentIdentifier\", function() { return _cssLanguageTypes_js__WEBPACK_IMPORTED_MODULE_14__[\"TextDocumentIdentifier\"]; });\n\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"VersionedTextDocumentIdentifier\", function() { return _cssLanguageTypes_js__WEBPACK_IMPORTED_MODULE_14__[\"VersionedTextDocumentIdentifier\"]; });\n\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"TextDocumentItem\", function() { return _cssLanguageTypes_js__WEBPACK_IMPORTED_MODULE_14__[\"TextDocumentItem\"]; });\n\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"MarkupKind\", function() { return _cssLanguageTypes_js__WEBPACK_IMPORTED_MODULE_14__[\"MarkupKind\"]; });\n\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"MarkupContent\", function() { return _cssLanguageTypes_js__WEBPACK_IMPORTED_MODULE_14__[\"MarkupContent\"]; });\n\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"CompletionItemKind\", function() { return _cssLanguageTypes_js__WEBPACK_IMPORTED_MODULE_14__[\"CompletionItemKind\"]; });\n\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"InsertTextFormat\", function() { return _cssLanguageTypes_js__WEBPACK_IMPORTED_MODULE_14__[\"InsertTextFormat\"]; });\n\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"CompletionItemTag\", function() { return _cssLanguageTypes_js__WEBPACK_IMPORTED_MODULE_14__[\"CompletionItemTag\"]; });\n\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"CompletionItem\", function() { return _cssLanguageTypes_js__WEBPACK_IMPORTED_MODULE_14__[\"CompletionItem\"]; });\n\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"CompletionList\", function() { return _cssLanguageTypes_js__WEBPACK_IMPORTED_MODULE_14__[\"CompletionList\"]; });\n\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"MarkedString\", function() { return _cssLanguageTypes_js__WEBPACK_IMPORTED_MODULE_14__[\"MarkedString\"]; });\n\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"Hover\", function() { return _cssLanguageTypes_js__WEBPACK_IMPORTED_MODULE_14__[\"Hover\"]; });\n\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"ParameterInformation\", function() { return _cssLanguageTypes_js__WEBPACK_IMPORTED_MODULE_14__[\"ParameterInformation\"]; });\n\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"SignatureInformation\", function() { return _cssLanguageTypes_js__WEBPACK_IMPORTED_MODULE_14__[\"SignatureInformation\"]; });\n\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"DocumentHighlightKind\", function() { return _cssLanguageTypes_js__WEBPACK_IMPORTED_MODULE_14__[\"DocumentHighlightKind\"]; });\n\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"DocumentHighlight\", function() { return _cssLanguageTypes_js__WEBPACK_IMPORTED_MODULE_14__[\"DocumentHighlight\"]; });\n\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"SymbolKind\", function() { return _cssLanguageTypes_js__WEBPACK_IMPORTED_MODULE_14__[\"SymbolKind\"]; });\n\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"SymbolTag\", function() { return _cssLanguageTypes_js__WEBPACK_IMPORTED_MODULE_14__[\"SymbolTag\"]; });\n\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"SymbolInformation\", function() { return _cssLanguageTypes_js__WEBPACK_IMPORTED_MODULE_14__[\"SymbolInformation\"]; });\n\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"DocumentSymbol\", function() { return _cssLanguageTypes_js__WEBPACK_IMPORTED_MODULE_14__[\"DocumentSymbol\"]; });\n\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"CodeActionKind\", function() { return _cssLanguageTypes_js__WEBPACK_IMPORTED_MODULE_14__[\"CodeActionKind\"]; });\n\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"CodeActionContext\", function() { return _cssLanguageTypes_js__WEBPACK_IMPORTED_MODULE_14__[\"CodeActionContext\"]; });\n\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"CodeAction\", function() { return _cssLanguageTypes_js__WEBPACK_IMPORTED_MODULE_14__[\"CodeAction\"]; });\n\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"CodeLens\", function() { return _cssLanguageTypes_js__WEBPACK_IMPORTED_MODULE_14__[\"CodeLens\"]; });\n\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"FormattingOptions\", function() { return _cssLanguageTypes_js__WEBPACK_IMPORTED_MODULE_14__[\"FormattingOptions\"]; });\n\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"DocumentLink\", function() { return _cssLanguageTypes_js__WEBPACK_IMPORTED_MODULE_14__[\"DocumentLink\"]; });\n\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"SelectionRange\", function() { return _cssLanguageTypes_js__WEBPACK_IMPORTED_MODULE_14__[\"SelectionRange\"]; });\n\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"EOL\", function() { return _cssLanguageTypes_js__WEBPACK_IMPORTED_MODULE_14__[\"EOL\"]; });\n\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"ClientCapabilities\", function() { return _cssLanguageTypes_js__WEBPACK_IMPORTED_MODULE_14__[\"ClientCapabilities\"]; });\n\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"FileType\", function() { return _cssLanguageTypes_js__WEBPACK_IMPORTED_MODULE_14__[\"FileType\"]; });\n\n/*---------------------------------------------------------------------------------------------\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * Licensed under the MIT License. See License.txt in the project root for license information.\n *--------------------------------------------------------------------------------------------*/\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\nfunction createFacade(parser, completion, hover, navigation, codeActions, validation) {\n return {\n configure: function (settings) {\n validation.configure(settings);\n completion.configure(settings);\n },\n doValidation: validation.doValidation.bind(validation),\n parseStylesheet: parser.parseStylesheet.bind(parser),\n doComplete: completion.doComplete.bind(completion),\n setCompletionParticipants: completion.setCompletionParticipants.bind(completion),\n doHover: hover.doHover.bind(hover),\n findDefinition: navigation.findDefinition.bind(navigation),\n findReferences: navigation.findReferences.bind(navigation),\n findDocumentHighlights: navigation.findDocumentHighlights.bind(navigation),\n findDocumentLinks: navigation.findDocumentLinks.bind(navigation),\n findDocumentLinks2: navigation.findDocumentLinks2.bind(navigation),\n findDocumentSymbols: navigation.findDocumentSymbols.bind(navigation),\n doCodeActions: codeActions.doCodeActions.bind(codeActions),\n doCodeActions2: codeActions.doCodeActions2.bind(codeActions),\n findColorSymbols: function (d, s) { return navigation.findDocumentColors(d, s).map(function (s) { return s.range; }); },\n findDocumentColors: navigation.findDocumentColors.bind(navigation),\n getColorPresentations: navigation.getColorPresentations.bind(navigation),\n doRename: navigation.doRename.bind(navigation),\n getFoldingRanges: _services_cssFolding_js__WEBPACK_IMPORTED_MODULE_10__[\"getFoldingRanges\"],\n getSelectionRanges: _services_cssSelectionRange_js__WEBPACK_IMPORTED_MODULE_12__[\"getSelectionRanges\"]\n };\n}\nfunction handleCustomData(options) {\n if (options && options.customDataProviders) {\n _languageFacts_facts_js__WEBPACK_IMPORTED_MODULE_11__[\"cssDataManager\"].addDataProviders(options.customDataProviders);\n }\n}\nfunction getCSSLanguageService(options) {\n handleCustomData(options);\n return createFacade(new _parser_cssParser_js__WEBPACK_IMPORTED_MODULE_0__[\"Parser\"](), new _services_cssCompletion_js__WEBPACK_IMPORTED_MODULE_1__[\"CSSCompletion\"](null, options && options.clientCapabilities), new _services_cssHover_js__WEBPACK_IMPORTED_MODULE_2__[\"CSSHover\"](options && options.clientCapabilities), new _services_cssNavigation_js__WEBPACK_IMPORTED_MODULE_3__[\"CSSNavigation\"](), new _services_cssCodeActions_js__WEBPACK_IMPORTED_MODULE_4__[\"CSSCodeActions\"](), new _services_cssValidation_js__WEBPACK_IMPORTED_MODULE_5__[\"CSSValidation\"]());\n}\nfunction getSCSSLanguageService(options) {\n handleCustomData(options);\n return createFacade(new _parser_scssParser_js__WEBPACK_IMPORTED_MODULE_6__[\"SCSSParser\"](), new _services_scssCompletion_js__WEBPACK_IMPORTED_MODULE_7__[\"SCSSCompletion\"](options && options.clientCapabilities), new _services_cssHover_js__WEBPACK_IMPORTED_MODULE_2__[\"CSSHover\"](options && options.clientCapabilities), new _services_scssNavigation_js__WEBPACK_IMPORTED_MODULE_13__[\"SCSSNavigation\"](options && options.fileSystemProvider), new _services_cssCodeActions_js__WEBPACK_IMPORTED_MODULE_4__[\"CSSCodeActions\"](), new _services_cssValidation_js__WEBPACK_IMPORTED_MODULE_5__[\"CSSValidation\"]());\n}\nfunction getLESSLanguageService(options) {\n handleCustomData(options);\n return createFacade(new _parser_lessParser_js__WEBPACK_IMPORTED_MODULE_8__[\"LESSParser\"](), new _services_lessCompletion_js__WEBPACK_IMPORTED_MODULE_9__[\"LESSCompletion\"](options && options.clientCapabilities), new _services_cssHover_js__WEBPACK_IMPORTED_MODULE_2__[\"CSSHover\"](options && options.clientCapabilities), new _services_cssNavigation_js__WEBPACK_IMPORTED_MODULE_3__[\"CSSNavigation\"](), new _services_cssCodeActions_js__WEBPACK_IMPORTED_MODULE_4__[\"CSSCodeActions\"](), new _services_cssValidation_js__WEBPACK_IMPORTED_MODULE_5__[\"CSSValidation\"]());\n}\n\n\n//# sourceURL=webpack:///./node_modules/monaco-editor/esm/vs/language/css/_deps/vscode-css-languageservice/cssLanguageService.js?"); - -/***/ }), - -/***/ "./node_modules/monaco-editor/esm/vs/language/css/_deps/vscode-css-languageservice/cssLanguageTypes.js": -/*!*************************************************************************************************************!*\ - !*** ./node_modules/monaco-editor/esm/vs/language/css/_deps/vscode-css-languageservice/cssLanguageTypes.js ***! - \*************************************************************************************************************/ -/*! exports provided: TextDocument, Position, Range, Location, LocationLink, Color, ColorInformation, ColorPresentation, FoldingRangeKind, FoldingRange, DiagnosticRelatedInformation, DiagnosticSeverity, DiagnosticTag, Diagnostic, Command, TextEdit, TextDocumentEdit, CreateFile, RenameFile, DeleteFile, WorkspaceEdit, WorkspaceChange, TextDocumentIdentifier, VersionedTextDocumentIdentifier, TextDocumentItem, MarkupKind, MarkupContent, CompletionItemKind, InsertTextFormat, CompletionItemTag, CompletionItem, CompletionList, MarkedString, Hover, ParameterInformation, SignatureInformation, DocumentHighlightKind, DocumentHighlight, SymbolKind, SymbolTag, SymbolInformation, DocumentSymbol, CodeActionKind, CodeActionContext, CodeAction, CodeLens, FormattingOptions, DocumentLink, SelectionRange, EOL, ClientCapabilities, FileType */ -/***/ (function(module, __webpack_exports__, __webpack_require__) { - -"use strict"; -eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"ClientCapabilities\", function() { return ClientCapabilities; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"FileType\", function() { return FileType; });\n/* harmony import */ var _vscode_languageserver_types_main_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./../vscode-languageserver-types/main.js */ \"./node_modules/monaco-editor/esm/vs/language/css/_deps/vscode-languageserver-types/main.js\");\n/* harmony import */ var _deps_vscode_languageserver_textdocument_lib_esm_main_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./_deps/vscode-languageserver-textdocument/lib/esm/main.js */ \"./node_modules/monaco-editor/esm/vs/language/css/_deps/vscode-css-languageservice/_deps/vscode-languageserver-textdocument/lib/esm/main.js\");\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"TextDocument\", function() { return _deps_vscode_languageserver_textdocument_lib_esm_main_js__WEBPACK_IMPORTED_MODULE_1__[\"TextDocument\"]; });\n\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"Position\", function() { return _vscode_languageserver_types_main_js__WEBPACK_IMPORTED_MODULE_0__[\"Position\"]; });\n\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"Range\", function() { return _vscode_languageserver_types_main_js__WEBPACK_IMPORTED_MODULE_0__[\"Range\"]; });\n\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"Location\", function() { return _vscode_languageserver_types_main_js__WEBPACK_IMPORTED_MODULE_0__[\"Location\"]; });\n\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"LocationLink\", function() { return _vscode_languageserver_types_main_js__WEBPACK_IMPORTED_MODULE_0__[\"LocationLink\"]; });\n\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"Color\", function() { return _vscode_languageserver_types_main_js__WEBPACK_IMPORTED_MODULE_0__[\"Color\"]; });\n\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"ColorInformation\", function() { return _vscode_languageserver_types_main_js__WEBPACK_IMPORTED_MODULE_0__[\"ColorInformation\"]; });\n\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"ColorPresentation\", function() { return _vscode_languageserver_types_main_js__WEBPACK_IMPORTED_MODULE_0__[\"ColorPresentation\"]; });\n\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"FoldingRangeKind\", function() { return _vscode_languageserver_types_main_js__WEBPACK_IMPORTED_MODULE_0__[\"FoldingRangeKind\"]; });\n\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"FoldingRange\", function() { return _vscode_languageserver_types_main_js__WEBPACK_IMPORTED_MODULE_0__[\"FoldingRange\"]; });\n\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"DiagnosticRelatedInformation\", function() { return _vscode_languageserver_types_main_js__WEBPACK_IMPORTED_MODULE_0__[\"DiagnosticRelatedInformation\"]; });\n\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"DiagnosticSeverity\", function() { return _vscode_languageserver_types_main_js__WEBPACK_IMPORTED_MODULE_0__[\"DiagnosticSeverity\"]; });\n\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"DiagnosticTag\", function() { return _vscode_languageserver_types_main_js__WEBPACK_IMPORTED_MODULE_0__[\"DiagnosticTag\"]; });\n\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"Diagnostic\", function() { return _vscode_languageserver_types_main_js__WEBPACK_IMPORTED_MODULE_0__[\"Diagnostic\"]; });\n\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"Command\", function() { return _vscode_languageserver_types_main_js__WEBPACK_IMPORTED_MODULE_0__[\"Command\"]; });\n\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"TextEdit\", function() { return _vscode_languageserver_types_main_js__WEBPACK_IMPORTED_MODULE_0__[\"TextEdit\"]; });\n\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"TextDocumentEdit\", function() { return _vscode_languageserver_types_main_js__WEBPACK_IMPORTED_MODULE_0__[\"TextDocumentEdit\"]; });\n\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"CreateFile\", function() { return _vscode_languageserver_types_main_js__WEBPACK_IMPORTED_MODULE_0__[\"CreateFile\"]; });\n\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"RenameFile\", function() { return _vscode_languageserver_types_main_js__WEBPACK_IMPORTED_MODULE_0__[\"RenameFile\"]; });\n\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"DeleteFile\", function() { return _vscode_languageserver_types_main_js__WEBPACK_IMPORTED_MODULE_0__[\"DeleteFile\"]; });\n\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"WorkspaceEdit\", function() { return _vscode_languageserver_types_main_js__WEBPACK_IMPORTED_MODULE_0__[\"WorkspaceEdit\"]; });\n\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"WorkspaceChange\", function() { return _vscode_languageserver_types_main_js__WEBPACK_IMPORTED_MODULE_0__[\"WorkspaceChange\"]; });\n\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"TextDocumentIdentifier\", function() { return _vscode_languageserver_types_main_js__WEBPACK_IMPORTED_MODULE_0__[\"TextDocumentIdentifier\"]; });\n\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"VersionedTextDocumentIdentifier\", function() { return _vscode_languageserver_types_main_js__WEBPACK_IMPORTED_MODULE_0__[\"VersionedTextDocumentIdentifier\"]; });\n\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"TextDocumentItem\", function() { return _vscode_languageserver_types_main_js__WEBPACK_IMPORTED_MODULE_0__[\"TextDocumentItem\"]; });\n\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"MarkupKind\", function() { return _vscode_languageserver_types_main_js__WEBPACK_IMPORTED_MODULE_0__[\"MarkupKind\"]; });\n\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"MarkupContent\", function() { return _vscode_languageserver_types_main_js__WEBPACK_IMPORTED_MODULE_0__[\"MarkupContent\"]; });\n\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"CompletionItemKind\", function() { return _vscode_languageserver_types_main_js__WEBPACK_IMPORTED_MODULE_0__[\"CompletionItemKind\"]; });\n\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"InsertTextFormat\", function() { return _vscode_languageserver_types_main_js__WEBPACK_IMPORTED_MODULE_0__[\"InsertTextFormat\"]; });\n\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"CompletionItemTag\", function() { return _vscode_languageserver_types_main_js__WEBPACK_IMPORTED_MODULE_0__[\"CompletionItemTag\"]; });\n\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"CompletionItem\", function() { return _vscode_languageserver_types_main_js__WEBPACK_IMPORTED_MODULE_0__[\"CompletionItem\"]; });\n\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"CompletionList\", function() { return _vscode_languageserver_types_main_js__WEBPACK_IMPORTED_MODULE_0__[\"CompletionList\"]; });\n\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"MarkedString\", function() { return _vscode_languageserver_types_main_js__WEBPACK_IMPORTED_MODULE_0__[\"MarkedString\"]; });\n\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"Hover\", function() { return _vscode_languageserver_types_main_js__WEBPACK_IMPORTED_MODULE_0__[\"Hover\"]; });\n\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"ParameterInformation\", function() { return _vscode_languageserver_types_main_js__WEBPACK_IMPORTED_MODULE_0__[\"ParameterInformation\"]; });\n\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"SignatureInformation\", function() { return _vscode_languageserver_types_main_js__WEBPACK_IMPORTED_MODULE_0__[\"SignatureInformation\"]; });\n\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"DocumentHighlightKind\", function() { return _vscode_languageserver_types_main_js__WEBPACK_IMPORTED_MODULE_0__[\"DocumentHighlightKind\"]; });\n\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"DocumentHighlight\", function() { return _vscode_languageserver_types_main_js__WEBPACK_IMPORTED_MODULE_0__[\"DocumentHighlight\"]; });\n\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"SymbolKind\", function() { return _vscode_languageserver_types_main_js__WEBPACK_IMPORTED_MODULE_0__[\"SymbolKind\"]; });\n\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"SymbolTag\", function() { return _vscode_languageserver_types_main_js__WEBPACK_IMPORTED_MODULE_0__[\"SymbolTag\"]; });\n\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"SymbolInformation\", function() { return _vscode_languageserver_types_main_js__WEBPACK_IMPORTED_MODULE_0__[\"SymbolInformation\"]; });\n\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"DocumentSymbol\", function() { return _vscode_languageserver_types_main_js__WEBPACK_IMPORTED_MODULE_0__[\"DocumentSymbol\"]; });\n\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"CodeActionKind\", function() { return _vscode_languageserver_types_main_js__WEBPACK_IMPORTED_MODULE_0__[\"CodeActionKind\"]; });\n\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"CodeActionContext\", function() { return _vscode_languageserver_types_main_js__WEBPACK_IMPORTED_MODULE_0__[\"CodeActionContext\"]; });\n\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"CodeAction\", function() { return _vscode_languageserver_types_main_js__WEBPACK_IMPORTED_MODULE_0__[\"CodeAction\"]; });\n\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"CodeLens\", function() { return _vscode_languageserver_types_main_js__WEBPACK_IMPORTED_MODULE_0__[\"CodeLens\"]; });\n\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"FormattingOptions\", function() { return _vscode_languageserver_types_main_js__WEBPACK_IMPORTED_MODULE_0__[\"FormattingOptions\"]; });\n\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"DocumentLink\", function() { return _vscode_languageserver_types_main_js__WEBPACK_IMPORTED_MODULE_0__[\"DocumentLink\"]; });\n\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"SelectionRange\", function() { return _vscode_languageserver_types_main_js__WEBPACK_IMPORTED_MODULE_0__[\"SelectionRange\"]; });\n\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"EOL\", function() { return _vscode_languageserver_types_main_js__WEBPACK_IMPORTED_MODULE_0__[\"EOL\"]; });\n\n/*---------------------------------------------------------------------------------------------\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * Licensed under the MIT License. See License.txt in the project root for license information.\n *--------------------------------------------------------------------------------------------*/\n\n\n\n\nvar ClientCapabilities;\n(function (ClientCapabilities) {\n ClientCapabilities.LATEST = {\n textDocument: {\n completion: {\n completionItem: {\n documentationFormat: [_vscode_languageserver_types_main_js__WEBPACK_IMPORTED_MODULE_0__[\"MarkupKind\"].Markdown, _vscode_languageserver_types_main_js__WEBPACK_IMPORTED_MODULE_0__[\"MarkupKind\"].PlainText]\n }\n },\n hover: {\n contentFormat: [_vscode_languageserver_types_main_js__WEBPACK_IMPORTED_MODULE_0__[\"MarkupKind\"].Markdown, _vscode_languageserver_types_main_js__WEBPACK_IMPORTED_MODULE_0__[\"MarkupKind\"].PlainText]\n }\n }\n };\n})(ClientCapabilities || (ClientCapabilities = {}));\nvar FileType;\n(function (FileType) {\n /**\n * The file type is unknown.\n */\n FileType[FileType[\"Unknown\"] = 0] = \"Unknown\";\n /**\n * A regular file.\n */\n FileType[FileType[\"File\"] = 1] = \"File\";\n /**\n * A directory.\n */\n FileType[FileType[\"Directory\"] = 2] = \"Directory\";\n /**\n * A symbolic link to a file.\n */\n FileType[FileType[\"SymbolicLink\"] = 64] = \"SymbolicLink\";\n})(FileType || (FileType = {}));\n\n\n//# sourceURL=webpack:///./node_modules/monaco-editor/esm/vs/language/css/_deps/vscode-css-languageservice/cssLanguageTypes.js?"); - -/***/ }), - -/***/ "./node_modules/monaco-editor/esm/vs/language/css/_deps/vscode-css-languageservice/data/webCustomData.js": -/*!***************************************************************************************************************!*\ - !*** ./node_modules/monaco-editor/esm/vs/language/css/_deps/vscode-css-languageservice/data/webCustomData.js ***! - \***************************************************************************************************************/ -/*! exports provided: cssData */ -/***/ (function(module, __webpack_exports__, __webpack_require__) { - -"use strict"; -eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"cssData\", function() { return cssData; });\n/*---------------------------------------------------------------------------------------------\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * Licensed under the MIT License. See License.txt in the project root for license information.\n *--------------------------------------------------------------------------------------------*/\n// file generated from vscode-web-custom-data NPM package\nvar cssData = {\n \"version\": 1.1,\n \"properties\": [\n {\n \"name\": \"width\",\n \"values\": [\n {\n \"name\": \"auto\",\n \"description\": \"The width depends on the values of other properties.\"\n },\n {\n \"name\": \"fit-content\",\n \"description\": \"Use the fit-content inline size or fit-content block size, as appropriate to the writing mode.\"\n },\n {\n \"name\": \"max-content\",\n \"description\": \"Use the max-content inline size or max-content block size, as appropriate to the writing mode.\"\n },\n {\n \"name\": \"min-content\",\n \"description\": \"Use the min-content inline size or min-content block size, as appropriate to the writing mode.\"\n }\n ],\n \"syntax\": \"{1,2}\",\n \"references\": [\n {\n \"name\": \"MDN Reference\",\n \"url\": \"https://developer.mozilla.org/docs/Web/CSS/width\"\n }\n ],\n \"description\": \"Specifies the width of the content area, padding area or border area (depending on 'box-sizing') of certain boxes.\",\n \"restrictions\": [\n \"length\",\n \"percentage\"\n ]\n },\n {\n \"name\": \"height\",\n \"values\": [\n {\n \"name\": \"auto\",\n \"description\": \"The height depends on the values of other properties.\"\n },\n {\n \"name\": \"fit-content\",\n \"description\": \"Use the fit-content inline size or fit-content block size, as appropriate to the writing mode.\"\n },\n {\n \"name\": \"max-content\",\n \"description\": \"Use the max-content inline size or max-content block size, as appropriate to the writing mode.\"\n },\n {\n \"name\": \"min-content\",\n \"description\": \"Use the min-content inline size or min-content block size, as appropriate to the writing mode.\"\n }\n ],\n \"syntax\": \"{1,2}\",\n \"references\": [\n {\n \"name\": \"MDN Reference\",\n \"url\": \"https://developer.mozilla.org/docs/Web/CSS/height\"\n }\n ],\n \"description\": \"Specifies the height of the content area, padding area or border area (depending on 'box-sizing') of certain boxes.\",\n \"restrictions\": [\n \"length\",\n \"percentage\"\n ]\n },\n {\n \"name\": \"display\",\n \"values\": [\n {\n \"name\": \"block\",\n \"description\": \"The element generates a block-level box\"\n },\n {\n \"name\": \"contents\",\n \"description\": \"The element itself does not generate any boxes, but its children and pseudo-elements still generate boxes as normal.\"\n },\n {\n \"name\": \"flex\",\n \"description\": \"The element generates a principal flex container box and establishes a flex formatting context.\"\n },\n {\n \"name\": \"flexbox\",\n \"description\": \"The element lays out its contents using flow layout (block-and-inline layout). Standardized as 'flex'.\"\n },\n {\n \"name\": \"flow-root\",\n \"description\": \"The element generates a block container box, and lays out its contents using flow layout.\"\n },\n {\n \"name\": \"grid\",\n \"description\": \"The element generates a principal grid container box, and establishes a grid formatting context.\"\n },\n {\n \"name\": \"inline\",\n \"description\": \"The element generates an inline-level box.\"\n },\n {\n \"name\": \"inline-block\",\n \"description\": \"A block box, which itself is flowed as a single inline box, similar to a replaced element. The inside of an inline-block is formatted as a block box, and the box itself is formatted as an inline box.\"\n },\n {\n \"name\": \"inline-flex\",\n \"description\": \"Inline-level flex container.\"\n },\n {\n \"name\": \"inline-flexbox\",\n \"description\": \"Inline-level flex container. Standardized as 'inline-flex'\"\n },\n {\n \"name\": \"inline-table\",\n \"description\": \"Inline-level table wrapper box containing table box.\"\n },\n {\n \"name\": \"list-item\",\n \"description\": \"One or more block boxes and one marker box.\"\n },\n {\n \"name\": \"-moz-box\",\n \"description\": \"The element lays out its contents using flow layout (block-and-inline layout). Standardized as 'flex'.\"\n },\n {\n \"name\": \"-moz-deck\"\n },\n {\n \"name\": \"-moz-grid\"\n },\n {\n \"name\": \"-moz-grid-group\"\n },\n {\n \"name\": \"-moz-grid-line\"\n },\n {\n \"name\": \"-moz-groupbox\"\n },\n {\n \"name\": \"-moz-inline-box\",\n \"description\": \"Inline-level flex container. Standardized as 'inline-flex'\"\n },\n {\n \"name\": \"-moz-inline-grid\"\n },\n {\n \"name\": \"-moz-inline-stack\"\n },\n {\n \"name\": \"-moz-marker\"\n },\n {\n \"name\": \"-moz-popup\"\n },\n {\n \"name\": \"-moz-stack\"\n },\n {\n \"name\": \"-ms-flexbox\",\n \"description\": \"The element lays out its contents using flow layout (block-and-inline layout). Standardized as 'flex'.\"\n },\n {\n \"name\": \"-ms-grid\",\n \"description\": \"The element generates a principal grid container box, and establishes a grid formatting context.\"\n },\n {\n \"name\": \"-ms-inline-flexbox\",\n \"description\": \"Inline-level flex container. Standardized as 'inline-flex'\"\n },\n {\n \"name\": \"-ms-inline-grid\",\n \"description\": \"Inline-level grid container.\"\n },\n {\n \"name\": \"none\",\n \"description\": \"The element and its descendants generates no boxes.\"\n },\n {\n \"name\": \"ruby\",\n \"description\": \"The element generates a principal ruby container box, and establishes a ruby formatting context.\"\n },\n {\n \"name\": \"ruby-base\"\n },\n {\n \"name\": \"ruby-base-container\"\n },\n {\n \"name\": \"ruby-text\"\n },\n {\n \"name\": \"ruby-text-container\"\n },\n {\n \"name\": \"run-in\",\n \"description\": \"The element generates a run-in box. Run-in elements act like inlines or blocks, depending on the surrounding elements.\"\n },\n {\n \"name\": \"table\",\n \"description\": \"The element generates a principal table wrapper box containing an additionally-generated table box, and establishes a table formatting context.\"\n },\n {\n \"name\": \"table-caption\"\n },\n {\n \"name\": \"table-cell\"\n },\n {\n \"name\": \"table-column\"\n },\n {\n \"name\": \"table-column-group\"\n },\n {\n \"name\": \"table-footer-group\"\n },\n {\n \"name\": \"table-header-group\"\n },\n {\n \"name\": \"table-row\"\n },\n {\n \"name\": \"table-row-group\"\n },\n {\n \"name\": \"-webkit-box\",\n \"description\": \"The element lays out its contents using flow layout (block-and-inline layout). Standardized as 'flex'.\"\n },\n {\n \"name\": \"-webkit-flex\",\n \"description\": \"The element lays out its contents using flow layout (block-and-inline layout).\"\n },\n {\n \"name\": \"-webkit-inline-box\",\n \"description\": \"Inline-level flex container. Standardized as 'inline-flex'\"\n },\n {\n \"name\": \"-webkit-inline-flex\",\n \"description\": \"Inline-level flex container.\"\n }\n ],\n \"syntax\": \"[ || ] | | | | \",\n \"references\": [\n {\n \"name\": \"MDN Reference\",\n \"url\": \"https://developer.mozilla.org/docs/Web/CSS/display\"\n }\n ],\n \"description\": \"In combination with 'float' and 'position', determines the type of box or boxes that are generated for an element.\",\n \"restrictions\": [\n \"enum\"\n ]\n },\n {\n \"name\": \"padding\",\n \"values\": [],\n \"syntax\": \"[ | ]{1,4}\",\n \"references\": [\n {\n \"name\": \"MDN Reference\",\n \"url\": \"https://developer.mozilla.org/docs/Web/CSS/padding\"\n }\n ],\n \"description\": \"Shorthand property to set values the thickness of the padding area. If left is omitted, it is the same as right. If bottom is omitted it is the same as top, if right is omitted it is the same as top. The value may not be negative.\",\n \"restrictions\": [\n \"length\",\n \"percentage\"\n ]\n },\n {\n \"name\": \"position\",\n \"values\": [\n {\n \"name\": \"absolute\",\n \"description\": \"The box's position (and possibly size) is specified with the 'top', 'right', 'bottom', and 'left' properties. These properties specify offsets with respect to the box's 'containing block'.\"\n },\n {\n \"name\": \"fixed\",\n \"description\": \"The box's position is calculated according to the 'absolute' model, but in addition, the box is fixed with respect to some reference. As with the 'absolute' model, the box's margins do not collapse with any other margins.\"\n },\n {\n \"name\": \"-ms-page\",\n \"description\": \"The box's position is calculated according to the 'absolute' model.\"\n },\n {\n \"name\": \"relative\",\n \"description\": \"The box's position is calculated according to the normal flow (this is called the position in normal flow). Then the box is offset relative to its normal position.\"\n },\n {\n \"name\": \"static\",\n \"description\": \"The box is a normal box, laid out according to the normal flow. The 'top', 'right', 'bottom', and 'left' properties do not apply.\"\n },\n {\n \"name\": \"sticky\",\n \"description\": \"The box's position is calculated according to the normal flow. Then the box is offset relative to its flow root and containing block and in all cases, including table elements, does not affect the position of any following boxes.\"\n },\n {\n \"name\": \"-webkit-sticky\",\n \"description\": \"The box's position is calculated according to the normal flow. Then the box is offset relative to its flow root and containing block and in all cases, including table elements, does not affect the position of any following boxes.\"\n }\n ],\n \"syntax\": \"static | relative | absolute | sticky | fixed\",\n \"references\": [\n {\n \"name\": \"MDN Reference\",\n \"url\": \"https://developer.mozilla.org/docs/Web/CSS/position\"\n }\n ],\n \"restrictions\": [\n \"enum\"\n ]\n },\n {\n \"name\": \"border\",\n \"syntax\": \" || || \",\n \"references\": [\n {\n \"name\": \"MDN Reference\",\n \"url\": \"https://developer.mozilla.org/docs/Web/CSS/border\"\n }\n ],\n \"description\": \"Shorthand property for setting border width, style, and color.\",\n \"restrictions\": [\n \"length\",\n \"line-width\",\n \"line-style\",\n \"color\"\n ]\n },\n {\n \"name\": \"margin\",\n \"values\": [\n {\n \"name\": \"auto\"\n }\n ],\n \"syntax\": \"[ | | auto ]{1,4}\",\n \"references\": [\n {\n \"name\": \"MDN Reference\",\n \"url\": \"https://developer.mozilla.org/docs/Web/CSS/margin\"\n }\n ],\n \"description\": \"Shorthand property to set values the thickness of the margin area. If left is omitted, it is the same as right. If bottom is omitted it is the same as top, if right is omitted it is the same as top. Negative values for margin properties are allowed, but there may be implementation-specific limits.\",\n \"restrictions\": [\n \"length\",\n \"percentage\"\n ]\n },\n {\n \"name\": \"top\",\n \"values\": [\n {\n \"name\": \"auto\",\n \"description\": \"For non-replaced elements, the effect of this value depends on which of related properties have the value 'auto' as well\"\n }\n ],\n \"syntax\": \" | | auto\",\n \"references\": [\n {\n \"name\": \"MDN Reference\",\n \"url\": \"https://developer.mozilla.org/docs/Web/CSS/top\"\n }\n ],\n \"description\": \"Specifies how far an absolutely positioned box's top margin edge is offset below the top edge of the box's 'containing block'.\",\n \"restrictions\": [\n \"length\",\n \"percentage\"\n ]\n },\n {\n \"name\": \"left\",\n \"values\": [\n {\n \"name\": \"auto\",\n \"description\": \"For non-replaced elements, the effect of this value depends on which of related properties have the value 'auto' as well\"\n }\n ],\n \"syntax\": \" | | auto\",\n \"references\": [\n {\n \"name\": \"MDN Reference\",\n \"url\": \"https://developer.mozilla.org/docs/Web/CSS/left\"\n }\n ],\n \"description\": \"Specifies how far an absolutely positioned box's left margin edge is offset to the right of the left edge of the box's 'containing block'.\",\n \"restrictions\": [\n \"length\",\n \"percentage\"\n ]\n },\n {\n \"name\": \"margin-top\",\n \"values\": [\n {\n \"name\": \"auto\"\n }\n ],\n \"syntax\": \" | | auto\",\n \"references\": [\n {\n \"name\": \"MDN Reference\",\n \"url\": \"https://developer.mozilla.org/docs/Web/CSS/margin-top\"\n }\n ],\n \"description\": \"Shorthand property to set values the thickness of the margin area. If left is omitted, it is the same as right. If bottom is omitted it is the same as top, if right is omitted it is the same as top. Negative values for margin properties are allowed, but there may be implementation-specific limits..\",\n \"restrictions\": [\n \"length\",\n \"percentage\"\n ]\n },\n {\n \"name\": \"color\",\n \"syntax\": \"\",\n \"references\": [\n {\n \"name\": \"MDN Reference\",\n \"url\": \"https://developer.mozilla.org/docs/Web/CSS/color\"\n }\n ],\n \"description\": \"Color of an element's text\",\n \"restrictions\": [\n \"color\"\n ]\n },\n {\n \"name\": \"font-size\",\n \"values\": [\n {\n \"name\": \"large\"\n },\n {\n \"name\": \"larger\"\n },\n {\n \"name\": \"medium\"\n },\n {\n \"name\": \"small\"\n },\n {\n \"name\": \"smaller\"\n },\n {\n \"name\": \"x-large\"\n },\n {\n \"name\": \"x-small\"\n },\n {\n \"name\": \"xx-large\"\n },\n {\n \"name\": \"xx-small\"\n }\n ],\n \"syntax\": \" | | \",\n \"references\": [\n {\n \"name\": \"MDN Reference\",\n \"url\": \"https://developer.mozilla.org/docs/Web/CSS/font-size\"\n }\n ],\n \"description\": \"Indicates the desired height of glyphs from the font. For scalable fonts, the font-size is a scale factor applied to the EM unit of the font. (Note that certain glyphs may bleed outside their EM box.) For non-scalable fonts, the font-size is converted into absolute units and matched against the declared font-size of the font, using the same absolute coordinate space for both of the matched values.\",\n \"restrictions\": [\n \"length\",\n \"percentage\"\n ]\n },\n {\n \"name\": \"background-color\",\n \"syntax\": \"\",\n \"references\": [\n {\n \"name\": \"MDN Reference\",\n \"url\": \"https://developer.mozilla.org/docs/Web/CSS/background-color\"\n }\n ],\n \"description\": \"Sets the background color of an element.\",\n \"restrictions\": [\n \"color\"\n ]\n },\n {\n \"name\": \"text-align\",\n \"values\": [\n {\n \"name\": \"center\",\n \"description\": \"The inline contents are centered within the line box.\"\n },\n {\n \"name\": \"end\",\n \"description\": \"The inline contents are aligned to the end edge of the line box.\"\n },\n {\n \"name\": \"justify\",\n \"description\": \"The text is justified according to the method specified by the 'text-justify' property.\"\n },\n {\n \"name\": \"left\",\n \"description\": \"The inline contents are aligned to the left edge of the line box. In vertical text, 'left' aligns to the edge of the line box that would be the start edge for left-to-right text.\"\n },\n {\n \"name\": \"right\",\n \"description\": \"The inline contents are aligned to the right edge of the line box. In vertical text, 'right' aligns to the edge of the line box that would be the end edge for left-to-right text.\"\n },\n {\n \"name\": \"start\",\n \"description\": \"The inline contents are aligned to the start edge of the line box.\"\n }\n ],\n \"syntax\": \"start | end | left | right | center | justify | match-parent\",\n \"references\": [\n {\n \"name\": \"MDN Reference\",\n \"url\": \"https://developer.mozilla.org/docs/Web/CSS/text-align\"\n }\n ],\n \"description\": \"Describes how inline contents of a block are horizontally aligned if the contents do not completely fill the line box.\",\n \"restrictions\": [\n \"string\"\n ]\n },\n {\n \"name\": \"opacity\",\n \"syntax\": \"\",\n \"references\": [\n {\n \"name\": \"MDN Reference\",\n \"url\": \"https://developer.mozilla.org/docs/Web/CSS/opacity\"\n }\n ],\n \"description\": \"Opacity of an element's text, where 1 is opaque and 0 is entirely transparent.\",\n \"restrictions\": [\n \"number(0-1)\"\n ]\n },\n {\n \"name\": \"background\",\n \"values\": [\n {\n \"name\": \"fixed\",\n \"description\": \"The background is fixed with regard to the viewport. In paged media where there is no viewport, a 'fixed' background is fixed with respect to the page box and therefore replicated on every page.\"\n },\n {\n \"name\": \"local\",\n \"description\": \"The background is fixed with regard to the element's contents: if the element has a scrolling mechanism, the background scrolls with the element's contents.\"\n },\n {\n \"name\": \"none\",\n \"description\": \"A value of 'none' counts as an image layer but draws nothing.\"\n },\n {\n \"name\": \"scroll\",\n \"description\": \"The background is fixed with regard to the element itself and does not scroll with its contents. (It is effectively attached to the element's border.)\"\n }\n ],\n \"syntax\": \"[ , ]* \",\n \"references\": [\n {\n \"name\": \"MDN Reference\",\n \"url\": \"https://developer.mozilla.org/docs/Web/CSS/background\"\n }\n ],\n \"description\": \"Shorthand property for setting most background properties at the same place in the style sheet.\",\n \"restrictions\": [\n \"enum\",\n \"image\",\n \"color\",\n \"position\",\n \"length\",\n \"repeat\",\n \"percentage\",\n \"box\"\n ]\n },\n {\n \"name\": \"float\",\n \"values\": [\n {\n \"name\": \"inline-end\",\n \"description\": \"A keyword indicating that the element must float on the end side of its containing block. That is the right side with ltr scripts, and the left side with rtl scripts.\"\n },\n {\n \"name\": \"inline-start\",\n \"description\": \"A keyword indicating that the element must float on the start side of its containing block. That is the left side with ltr scripts, and the right side with rtl scripts.\"\n },\n {\n \"name\": \"left\",\n \"description\": \"The element generates a block box that is floated to the left. Content flows on the right side of the box, starting at the top (subject to the 'clear' property).\"\n },\n {\n \"name\": \"none\",\n \"description\": \"The box is not floated.\"\n },\n {\n \"name\": \"right\",\n \"description\": \"Similar to 'left', except the box is floated to the right, and content flows on the left side of the box, starting at the top.\"\n }\n ],\n \"syntax\": \"left | right | none | inline-start | inline-end\",\n \"references\": [\n {\n \"name\": \"MDN Reference\",\n \"url\": \"https://developer.mozilla.org/docs/Web/CSS/float\"\n }\n ],\n \"description\": \"Specifies how a box should be floated. It may be set for any element, but only applies to elements that generate boxes that are not absolutely positioned.\",\n \"restrictions\": [\n \"enum\"\n ]\n },\n {\n \"name\": \"font-weight\",\n \"values\": [\n {\n \"name\": \"100\",\n \"description\": \"Thin\"\n },\n {\n \"name\": \"200\",\n \"description\": \"Extra Light (Ultra Light)\"\n },\n {\n \"name\": \"300\",\n \"description\": \"Light\"\n },\n {\n \"name\": \"400\",\n \"description\": \"Normal\"\n },\n {\n \"name\": \"500\",\n \"description\": \"Medium\"\n },\n {\n \"name\": \"600\",\n \"description\": \"Semi Bold (Demi Bold)\"\n },\n {\n \"name\": \"700\",\n \"description\": \"Bold\"\n },\n {\n \"name\": \"800\",\n \"description\": \"Extra Bold (Ultra Bold)\"\n },\n {\n \"name\": \"900\",\n \"description\": \"Black (Heavy)\"\n },\n {\n \"name\": \"bold\",\n \"description\": \"Same as 700\"\n },\n {\n \"name\": \"bolder\",\n \"description\": \"Specifies the weight of the face bolder than the inherited value.\"\n },\n {\n \"name\": \"lighter\",\n \"description\": \"Specifies the weight of the face lighter than the inherited value.\"\n },\n {\n \"name\": \"normal\",\n \"description\": \"Same as 400\"\n }\n ],\n \"syntax\": \"{1,2}\",\n \"references\": [\n {\n \"name\": \"MDN Reference\",\n \"url\": \"https://developer.mozilla.org/docs/Web/CSS/font-weight\"\n }\n ],\n \"description\": \"Specifies weight of glyphs in the font, their degree of blackness or stroke thickness.\",\n \"restrictions\": [\n \"enum\"\n ]\n },\n {\n \"name\": \"overflow\",\n \"values\": [\n {\n \"name\": \"auto\",\n \"description\": \"The behavior of the 'auto' value is UA-dependent, but should cause a scrolling mechanism to be provided for overflowing boxes.\"\n },\n {\n \"name\": \"hidden\",\n \"description\": \"Content is clipped and no scrolling mechanism should be provided to view the content outside the clipping region.\"\n },\n {\n \"name\": \"-moz-hidden-unscrollable\",\n \"description\": \"Same as the standardized 'clip', except doesn’t establish a block formatting context.\"\n },\n {\n \"name\": \"scroll\",\n \"description\": \"Content is clipped and if the user agent uses a scrolling mechanism that is visible on the screen (such as a scroll bar or a panner), that mechanism should be displayed for a box whether or not any of its content is clipped.\"\n },\n {\n \"name\": \"visible\",\n \"description\": \"Content is not clipped, i.e., it may be rendered outside the content box.\"\n }\n ],\n \"syntax\": \"[ visible | hidden | clip | scroll | auto ]{1,2}\",\n \"references\": [\n {\n \"name\": \"MDN Reference\",\n \"url\": \"https://developer.mozilla.org/docs/Web/CSS/overflow\"\n }\n ],\n \"description\": \"Shorthand for setting 'overflow-x' and 'overflow-y'.\",\n \"restrictions\": [\n \"enum\"\n ]\n },\n {\n \"name\": \"line-height\",\n \"values\": [\n {\n \"name\": \"normal\",\n \"description\": \"Tells user agents to set the computed value to a 'reasonable' value based on the font size of the element.\"\n }\n ],\n \"syntax\": \"normal | | | \",\n \"references\": [\n {\n \"name\": \"MDN Reference\",\n \"url\": \"https://developer.mozilla.org/docs/Web/CSS/line-height\"\n }\n ],\n \"description\": \"Determines the block-progression dimension of the text content area of an inline box.\",\n \"restrictions\": [\n \"number\",\n \"length\",\n \"percentage\"\n ]\n },\n {\n \"name\": \"font-family\",\n \"values\": [\n {\n \"name\": \"-apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Oxygen, Ubuntu, Cantarell, 'Open Sans', 'Helvetica Neue', sans-serif\"\n },\n {\n \"name\": \"Arial, Helvetica, sans-serif\"\n },\n {\n \"name\": \"Cambria, Cochin, Georgia, Times, 'Times New Roman', serif\"\n },\n {\n \"name\": \"'Courier New', Courier, monospace\"\n },\n {\n \"name\": \"cursive\"\n },\n {\n \"name\": \"fantasy\"\n },\n {\n \"name\": \"'Franklin Gothic Medium', 'Arial Narrow', Arial, sans-serif\"\n },\n {\n \"name\": \"Georgia, 'Times New Roman', Times, serif\"\n },\n {\n \"name\": \"'Gill Sans', 'Gill Sans MT', Calibri, 'Trebuchet MS', sans-serif\"\n },\n {\n \"name\": \"Impact, Haettenschweiler, 'Arial Narrow Bold', sans-serif\"\n },\n {\n \"name\": \"'Lucida Sans', 'Lucida Sans Regular', 'Lucida Grande', 'Lucida Sans Unicode', Geneva, Verdana, sans-serif\"\n },\n {\n \"name\": \"monospace\"\n },\n {\n \"name\": \"sans-serif\"\n },\n {\n \"name\": \"'Segoe UI', Tahoma, Geneva, Verdana, sans-serif\"\n },\n {\n \"name\": \"serif\"\n },\n {\n \"name\": \"'Times New Roman', Times, serif\"\n },\n {\n \"name\": \"'Trebuchet MS', 'Lucida Sans Unicode', 'Lucida Grande', 'Lucida Sans', Arial, sans-serif\"\n },\n {\n \"name\": \"Verdana, Geneva, Tahoma, sans-serif\"\n }\n ],\n \"syntax\": \"\",\n \"references\": [\n {\n \"name\": \"MDN Reference\",\n \"url\": \"https://developer.mozilla.org/docs/Web/CSS/font-family\"\n }\n ],\n \"description\": \"Specifies a prioritized list of font family names or generic family names. A user agent iterates through the list of family names until it matches an available font that contains a glyph for the character to be rendered.\",\n \"restrictions\": [\n \"font\"\n ]\n },\n {\n \"name\": \"text-decoration\",\n \"values\": [\n {\n \"name\": \"dashed\",\n \"description\": \"Produces a dashed line style.\"\n },\n {\n \"name\": \"dotted\",\n \"description\": \"Produces a dotted line.\"\n },\n {\n \"name\": \"double\",\n \"description\": \"Produces a double line.\"\n },\n {\n \"name\": \"line-through\",\n \"description\": \"Each line of text has a line through the middle.\"\n },\n {\n \"name\": \"none\",\n \"description\": \"Produces no line.\"\n },\n {\n \"name\": \"overline\",\n \"description\": \"Each line of text has a line above it.\"\n },\n {\n \"name\": \"solid\",\n \"description\": \"Produces a solid line.\"\n },\n {\n \"name\": \"underline\",\n \"description\": \"Each line of text is underlined.\"\n },\n {\n \"name\": \"wavy\",\n \"description\": \"Produces a wavy line.\"\n }\n ],\n \"syntax\": \"<'text-decoration-line'> || <'text-decoration-style'> || <'text-decoration-color'> || <'text-decoration-thickness'>\",\n \"references\": [\n {\n \"name\": \"MDN Reference\",\n \"url\": \"https://developer.mozilla.org/docs/Web/CSS/text-decoration\"\n }\n ],\n \"description\": \"Decorations applied to font used for an element's text.\",\n \"restrictions\": [\n \"enum\",\n \"color\"\n ]\n },\n {\n \"name\": \"box-sizing\",\n \"values\": [\n {\n \"name\": \"border-box\",\n \"description\": \"The specified width and height (and respective min/max properties) on this element determine the border box of the element.\"\n },\n {\n \"name\": \"content-box\",\n \"description\": \"Behavior of width and height as specified by CSS2.1. The specified width and height (and respective min/max properties) apply to the width and height respectively of the content box of the element.\"\n }\n ],\n \"syntax\": \"content-box | border-box\",\n \"references\": [\n {\n \"name\": \"MDN Reference\",\n \"url\": \"https://developer.mozilla.org/docs/Web/CSS/box-sizing\"\n }\n ],\n \"description\": \"Specifies the behavior of the 'width' and 'height' properties.\",\n \"restrictions\": [\n \"enum\"\n ]\n },\n {\n \"name\": \"z-index\",\n \"values\": [\n {\n \"name\": \"auto\",\n \"description\": \"The stack level of the generated box in the current stacking context is 0. The box does not establish a new stacking context unless it is the root element.\"\n }\n ],\n \"syntax\": \"auto | \",\n \"references\": [\n {\n \"name\": \"MDN Reference\",\n \"url\": \"https://developer.mozilla.org/docs/Web/CSS/z-index\"\n }\n ],\n \"description\": \"For a positioned box, the 'z-index' property specifies the stack level of the box in the current stacking context and whether the box establishes a local stacking context.\",\n \"restrictions\": [\n \"integer\"\n ]\n },\n {\n \"name\": \"vertical-align\",\n \"values\": [\n {\n \"name\": \"auto\",\n \"description\": \"Align the dominant baseline of the parent box with the equivalent, or heuristically reconstructed, baseline of the element inline box.\"\n },\n {\n \"name\": \"baseline\",\n \"description\": \"Align the 'alphabetic' baseline of the element with the 'alphabetic' baseline of the parent element.\"\n },\n {\n \"name\": \"bottom\",\n \"description\": \"Align the after edge of the extended inline box with the after-edge of the line box.\"\n },\n {\n \"name\": \"middle\",\n \"description\": \"Align the 'middle' baseline of the inline element with the middle baseline of the parent.\"\n },\n {\n \"name\": \"sub\",\n \"description\": \"Lower the baseline of the box to the proper position for subscripts of the parent's box. (This value has no effect on the font size of the element's text.)\"\n },\n {\n \"name\": \"super\",\n \"description\": \"Raise the baseline of the box to the proper position for superscripts of the parent's box. (This value has no effect on the font size of the element's text.)\"\n },\n {\n \"name\": \"text-bottom\",\n \"description\": \"Align the bottom of the box with the after-edge of the parent element's font.\"\n },\n {\n \"name\": \"text-top\",\n \"description\": \"Align the top of the box with the before-edge of the parent element's font.\"\n },\n {\n \"name\": \"top\",\n \"description\": \"Align the before edge of the extended inline box with the before-edge of the line box.\"\n },\n {\n \"name\": \"-webkit-baseline-middle\"\n }\n ],\n \"syntax\": \"baseline | sub | super | text-top | text-bottom | middle | top | bottom | | \",\n \"references\": [\n {\n \"name\": \"MDN Reference\",\n \"url\": \"https://developer.mozilla.org/docs/Web/CSS/vertical-align\"\n }\n ],\n \"description\": \"Affects the vertical positioning of the inline boxes generated by an inline-level element inside a line box.\",\n \"restrictions\": [\n \"percentage\",\n \"length\"\n ]\n },\n {\n \"name\": \"border-radius\",\n \"syntax\": \"{1,4} [ / {1,4} ]?\",\n \"references\": [\n {\n \"name\": \"MDN Reference\",\n \"url\": \"https://developer.mozilla.org/docs/Web/CSS/border-radius\"\n }\n ],\n \"description\": \"Defines the radii of the outer border edge.\",\n \"restrictions\": [\n \"length\",\n \"percentage\"\n ]\n },\n {\n \"name\": \"margin-left\",\n \"values\": [\n {\n \"name\": \"auto\"\n }\n ],\n \"syntax\": \" | | auto\",\n \"references\": [\n {\n \"name\": \"MDN Reference\",\n \"url\": \"https://developer.mozilla.org/docs/Web/CSS/margin-left\"\n }\n ],\n \"description\": \"Shorthand property to set values the thickness of the margin area. If left is omitted, it is the same as right. If bottom is omitted it is the same as top, if right is omitted it is the same as top. Negative values for margin properties are allowed, but there may be implementation-specific limits..\",\n \"restrictions\": [\n \"length\",\n \"percentage\"\n ]\n },\n {\n \"name\": \"cursor\",\n \"values\": [\n {\n \"name\": \"alias\",\n \"description\": \"Indicates an alias of/shortcut to something is to be created. Often rendered as an arrow with a small curved arrow next to it.\"\n },\n {\n \"name\": \"all-scroll\",\n \"description\": \"Indicates that the something can be scrolled in any direction. Often rendered as arrows pointing up, down, left, and right with a dot in the middle.\"\n },\n {\n \"name\": \"auto\",\n \"description\": \"The UA determines the cursor to display based on the current context.\"\n },\n {\n \"name\": \"cell\",\n \"description\": \"Indicates that a cell or set of cells may be selected. Often rendered as a thick plus-sign with a dot in the middle.\"\n },\n {\n \"name\": \"col-resize\",\n \"description\": \"Indicates that the item/column can be resized horizontally. Often rendered as arrows pointing left and right with a vertical bar separating them.\"\n },\n {\n \"name\": \"context-menu\",\n \"description\": \"A context menu is available for the object under the cursor. Often rendered as an arrow with a small menu-like graphic next to it.\"\n },\n {\n \"name\": \"copy\",\n \"description\": \"Indicates something is to be copied. Often rendered as an arrow with a small plus sign next to it.\"\n },\n {\n \"name\": \"crosshair\",\n \"description\": \"A simple crosshair (e.g., short line segments resembling a '+' sign). Often used to indicate a two dimensional bitmap selection mode.\"\n },\n {\n \"name\": \"default\",\n \"description\": \"The platform-dependent default cursor. Often rendered as an arrow.\"\n },\n {\n \"name\": \"e-resize\",\n \"description\": \"Indicates that east edge is to be moved.\"\n },\n {\n \"name\": \"ew-resize\",\n \"description\": \"Indicates a bidirectional east-west resize cursor.\"\n },\n {\n \"name\": \"grab\",\n \"description\": \"Indicates that something can be grabbed.\"\n },\n {\n \"name\": \"grabbing\",\n \"description\": \"Indicates that something is being grabbed.\"\n },\n {\n \"name\": \"help\",\n \"description\": \"Help is available for the object under the cursor. Often rendered as a question mark or a balloon.\"\n },\n {\n \"name\": \"move\",\n \"description\": \"Indicates something is to be moved.\"\n },\n {\n \"name\": \"-moz-grab\",\n \"description\": \"Indicates that something can be grabbed.\"\n },\n {\n \"name\": \"-moz-grabbing\",\n \"description\": \"Indicates that something is being grabbed.\"\n },\n {\n \"name\": \"-moz-zoom-in\",\n \"description\": \"Indicates that something can be zoomed (magnified) in.\"\n },\n {\n \"name\": \"-moz-zoom-out\",\n \"description\": \"Indicates that something can be zoomed (magnified) out.\"\n },\n {\n \"name\": \"ne-resize\",\n \"description\": \"Indicates that movement starts from north-east corner.\"\n },\n {\n \"name\": \"nesw-resize\",\n \"description\": \"Indicates a bidirectional north-east/south-west cursor.\"\n },\n {\n \"name\": \"no-drop\",\n \"description\": \"Indicates that the dragged item cannot be dropped at the current cursor location. Often rendered as a hand or pointer with a small circle with a line through it.\"\n },\n {\n \"name\": \"none\",\n \"description\": \"No cursor is rendered for the element.\"\n },\n {\n \"name\": \"not-allowed\",\n \"description\": \"Indicates that the requested action will not be carried out. Often rendered as a circle with a line through it.\"\n },\n {\n \"name\": \"n-resize\",\n \"description\": \"Indicates that north edge is to be moved.\"\n },\n {\n \"name\": \"ns-resize\",\n \"description\": \"Indicates a bidirectional north-south cursor.\"\n },\n {\n \"name\": \"nw-resize\",\n \"description\": \"Indicates that movement starts from north-west corner.\"\n },\n {\n \"name\": \"nwse-resize\",\n \"description\": \"Indicates a bidirectional north-west/south-east cursor.\"\n },\n {\n \"name\": \"pointer\",\n \"description\": \"The cursor is a pointer that indicates a link.\"\n },\n {\n \"name\": \"progress\",\n \"description\": \"A progress indicator. The program is performing some processing, but is different from 'wait' in that the user may still interact with the program. Often rendered as a spinning beach ball, or an arrow with a watch or hourglass.\"\n },\n {\n \"name\": \"row-resize\",\n \"description\": \"Indicates that the item/row can be resized vertically. Often rendered as arrows pointing up and down with a horizontal bar separating them.\"\n },\n {\n \"name\": \"se-resize\",\n \"description\": \"Indicates that movement starts from south-east corner.\"\n },\n {\n \"name\": \"s-resize\",\n \"description\": \"Indicates that south edge is to be moved.\"\n },\n {\n \"name\": \"sw-resize\",\n \"description\": \"Indicates that movement starts from south-west corner.\"\n },\n {\n \"name\": \"text\",\n \"description\": \"Indicates text that may be selected. Often rendered as a vertical I-beam.\"\n },\n {\n \"name\": \"vertical-text\",\n \"description\": \"Indicates vertical-text that may be selected. Often rendered as a horizontal I-beam.\"\n },\n {\n \"name\": \"wait\",\n \"description\": \"Indicates that the program is busy and the user should wait. Often rendered as a watch or hourglass.\"\n },\n {\n \"name\": \"-webkit-grab\",\n \"description\": \"Indicates that something can be grabbed.\"\n },\n {\n \"name\": \"-webkit-grabbing\",\n \"description\": \"Indicates that something is being grabbed.\"\n },\n {\n \"name\": \"-webkit-zoom-in\",\n \"description\": \"Indicates that something can be zoomed (magnified) in.\"\n },\n {\n \"name\": \"-webkit-zoom-out\",\n \"description\": \"Indicates that something can be zoomed (magnified) out.\"\n },\n {\n \"name\": \"w-resize\",\n \"description\": \"Indicates that west edge is to be moved.\"\n },\n {\n \"name\": \"zoom-in\",\n \"description\": \"Indicates that something can be zoomed (magnified) in.\"\n },\n {\n \"name\": \"zoom-out\",\n \"description\": \"Indicates that something can be zoomed (magnified) out.\"\n }\n ],\n \"syntax\": \"[ [ [ ]? , ]* [ auto | default | none | context-menu | help | pointer | progress | wait | cell | crosshair | text | vertical-text | alias | copy | move | no-drop | not-allowed | e-resize | n-resize | ne-resize | nw-resize | s-resize | se-resize | sw-resize | w-resize | ew-resize | ns-resize | nesw-resize | nwse-resize | col-resize | row-resize | all-scroll | zoom-in | zoom-out | grab | grabbing ] ]\",\n \"references\": [\n {\n \"name\": \"MDN Reference\",\n \"url\": \"https://developer.mozilla.org/docs/Web/CSS/cursor\"\n }\n ],\n \"description\": \"Allows control over cursor appearance in an element\",\n \"restrictions\": [\n \"url\",\n \"number\",\n \"enum\"\n ]\n },\n {\n \"name\": \"margin-bottom\",\n \"values\": [\n {\n \"name\": \"auto\"\n }\n ],\n \"syntax\": \" | | auto\",\n \"references\": [\n {\n \"name\": \"MDN Reference\",\n \"url\": \"https://developer.mozilla.org/docs/Web/CSS/margin-bottom\"\n }\n ],\n \"description\": \"Shorthand property to set values the thickness of the margin area. If left is omitted, it is the same as right. If bottom is omitted it is the same as top, if right is omitted it is the same as top. Negative values for margin properties are allowed, but there may be implementation-specific limits..\",\n \"restrictions\": [\n \"length\",\n \"percentage\"\n ]\n },\n {\n \"name\": \"right\",\n \"values\": [\n {\n \"name\": \"auto\",\n \"description\": \"For non-replaced elements, the effect of this value depends on which of related properties have the value 'auto' as well\"\n }\n ],\n \"syntax\": \" | | auto\",\n \"references\": [\n {\n \"name\": \"MDN Reference\",\n \"url\": \"https://developer.mozilla.org/docs/Web/CSS/right\"\n }\n ],\n \"description\": \"Specifies how far an absolutely positioned box's right margin edge is offset to the left of the right edge of the box's 'containing block'.\",\n \"restrictions\": [\n \"length\",\n \"percentage\"\n ]\n },\n {\n \"name\": \"margin-right\",\n \"values\": [\n {\n \"name\": \"auto\"\n }\n ],\n \"syntax\": \" | | auto\",\n \"references\": [\n {\n \"name\": \"MDN Reference\",\n \"url\": \"https://developer.mozilla.org/docs/Web/CSS/margin-right\"\n }\n ],\n \"description\": \"Shorthand property to set values the thickness of the margin area. If left is omitted, it is the same as right. If bottom is omitted it is the same as top, if right is omitted it is the same as top. Negative values for margin properties are allowed, but there may be implementation-specific limits..\",\n \"restrictions\": [\n \"length\",\n \"percentage\"\n ]\n },\n {\n \"name\": \"padding-left\",\n \"syntax\": \" | \",\n \"references\": [\n {\n \"name\": \"MDN Reference\",\n \"url\": \"https://developer.mozilla.org/docs/Web/CSS/padding-left\"\n }\n ],\n \"description\": \"Shorthand property to set values the thickness of the padding area. If left is omitted, it is the same as right. If bottom is omitted it is the same as top, if right is omitted it is the same as top. The value may not be negative.\",\n \"restrictions\": [\n \"length\",\n \"percentage\"\n ]\n },\n {\n \"name\": \"padding-top\",\n \"syntax\": \" | \",\n \"references\": [\n {\n \"name\": \"MDN Reference\",\n \"url\": \"https://developer.mozilla.org/docs/Web/CSS/padding-top\"\n }\n ],\n \"description\": \"Shorthand property to set values the thickness of the padding area. If left is omitted, it is the same as right. If bottom is omitted it is the same as top, if right is omitted it is the same as top. The value may not be negative.\",\n \"restrictions\": [\n \"length\",\n \"percentage\"\n ]\n },\n {\n \"name\": \"max-width\",\n \"values\": [\n {\n \"name\": \"none\",\n \"description\": \"No limit on the width of the box.\"\n },\n {\n \"name\": \"fit-content\",\n \"description\": \"Use the fit-content inline size or fit-content block size, as appropriate to the writing mode.\"\n },\n {\n \"name\": \"max-content\",\n \"description\": \"Use the max-content inline size or max-content block size, as appropriate to the writing mode.\"\n },\n {\n \"name\": \"min-content\",\n \"description\": \"Use the min-content inline size or min-content block size, as appropriate to the writing mode.\"\n }\n ],\n \"syntax\": \"\",\n \"references\": [\n {\n \"name\": \"MDN Reference\",\n \"url\": \"https://developer.mozilla.org/docs/Web/CSS/max-width\"\n }\n ],\n \"description\": \"Allows authors to constrain content width to a certain range.\",\n \"restrictions\": [\n \"length\",\n \"percentage\"\n ]\n },\n {\n \"name\": \"bottom\",\n \"values\": [\n {\n \"name\": \"auto\",\n \"description\": \"For non-replaced elements, the effect of this value depends on which of related properties have the value 'auto' as well\"\n }\n ],\n \"syntax\": \" | | auto\",\n \"references\": [\n {\n \"name\": \"MDN Reference\",\n \"url\": \"https://developer.mozilla.org/docs/Web/CSS/bottom\"\n }\n ],\n \"description\": \"Specifies how far an absolutely positioned box's bottom margin edge is offset above the bottom edge of the box's 'containing block'.\",\n \"restrictions\": [\n \"length\",\n \"percentage\"\n ]\n },\n {\n \"name\": \"background-image\",\n \"values\": [\n {\n \"name\": \"none\",\n \"description\": \"Counts as an image layer but draws nothing.\"\n }\n ],\n \"syntax\": \"#\",\n \"references\": [\n {\n \"name\": \"MDN Reference\",\n \"url\": \"https://developer.mozilla.org/docs/Web/CSS/background-image\"\n }\n ],\n \"description\": \"Sets the background image(s) of an element.\",\n \"restrictions\": [\n \"image\",\n \"enum\"\n ]\n },\n {\n \"name\": \"content\",\n \"values\": [\n {\n \"name\": \"attr()\",\n \"description\": \"The attr(n) function returns as a string the value of attribute n for the subject of the selector.\"\n },\n {\n \"name\": \"counter(name)\",\n \"description\": \"Counters are denoted by identifiers (see the 'counter-increment' and 'counter-reset' properties).\"\n },\n {\n \"name\": \"icon\",\n \"description\": \"The (pseudo-)element is replaced in its entirety by the resource referenced by its 'icon' property, and treated as a replaced element.\"\n },\n {\n \"name\": \"none\",\n \"description\": \"On elements, this inhibits the children of the element from being rendered as children of this element, as if the element was empty. On pseudo-elements it causes the pseudo-element to have no content.\"\n },\n {\n \"name\": \"normal\",\n \"description\": \"See http://www.w3.org/TR/css3-content/#content for computation rules.\"\n },\n {\n \"name\": \"url()\"\n }\n ],\n \"syntax\": \"normal | none | [ | ] [/ ]?\",\n \"references\": [\n {\n \"name\": \"MDN Reference\",\n \"url\": \"https://developer.mozilla.org/docs/Web/CSS/content\"\n }\n ],\n \"description\": \"Determines which page-based occurrence of a given element is applied to a counter or string value.\",\n \"restrictions\": [\n \"string\",\n \"url\"\n ]\n },\n {\n \"name\": \"padding-right\",\n \"syntax\": \" | \",\n \"references\": [\n {\n \"name\": \"MDN Reference\",\n \"url\": \"https://developer.mozilla.org/docs/Web/CSS/padding-right\"\n }\n ],\n \"description\": \"Shorthand property to set values the thickness of the padding area. If left is omitted, it is the same as right. If bottom is omitted it is the same as top, if right is omitted it is the same as top. The value may not be negative.\",\n \"restrictions\": [\n \"length\",\n \"percentage\"\n ]\n },\n {\n \"name\": \"white-space\",\n \"values\": [\n {\n \"name\": \"normal\",\n \"description\": \"Sets 'white-space-collapsing' to 'collapse' and 'text-wrap' to 'normal'.\"\n },\n {\n \"name\": \"nowrap\",\n \"description\": \"Sets 'white-space-collapsing' to 'collapse' and 'text-wrap' to 'none'.\"\n },\n {\n \"name\": \"pre\",\n \"description\": \"Sets 'white-space-collapsing' to 'preserve' and 'text-wrap' to 'none'.\"\n },\n {\n \"name\": \"pre-line\",\n \"description\": \"Sets 'white-space-collapsing' to 'preserve-breaks' and 'text-wrap' to 'normal'.\"\n },\n {\n \"name\": \"pre-wrap\",\n \"description\": \"Sets 'white-space-collapsing' to 'preserve' and 'text-wrap' to 'normal'.\"\n }\n ],\n \"syntax\": \"normal | pre | nowrap | pre-wrap | pre-line | break-spaces\",\n \"references\": [\n {\n \"name\": \"MDN Reference\",\n \"url\": \"https://developer.mozilla.org/docs/Web/CSS/white-space\"\n }\n ],\n \"description\": \"Shorthand property for the 'white-space-collapsing' and 'text-wrap' properties.\",\n \"restrictions\": [\n \"enum\"\n ]\n },\n {\n \"name\": \"padding-bottom\",\n \"syntax\": \" | \",\n \"references\": [\n {\n \"name\": \"MDN Reference\",\n \"url\": \"https://developer.mozilla.org/docs/Web/CSS/padding-bottom\"\n }\n ],\n \"description\": \"Shorthand property to set values the thickness of the padding area. If left is omitted, it is the same as right. If bottom is omitted it is the same as top, if right is omitted it is the same as top. The value may not be negative.\",\n \"restrictions\": [\n \"length\",\n \"percentage\"\n ]\n },\n {\n \"name\": \"border-bottom\",\n \"syntax\": \" || || \",\n \"references\": [\n {\n \"name\": \"MDN Reference\",\n \"url\": \"https://developer.mozilla.org/docs/Web/CSS/border-bottom\"\n }\n ],\n \"description\": \"Shorthand property for setting border width, style and color.\",\n \"restrictions\": [\n \"length\",\n \"line-width\",\n \"line-style\",\n \"color\"\n ]\n },\n {\n \"name\": \"box-shadow\",\n \"values\": [\n {\n \"name\": \"inset\",\n \"description\": \"Changes the drop shadow from an outer shadow (one that shadows the box onto the canvas, as if it were lifted above the canvas) to an inner shadow (one that shadows the canvas onto the box, as if the box were cut out of the canvas and shifted behind it).\"\n },\n {\n \"name\": \"none\",\n \"description\": \"No shadow.\"\n }\n ],\n \"syntax\": \"none | #\",\n \"references\": [\n {\n \"name\": \"MDN Reference\",\n \"url\": \"https://developer.mozilla.org/docs/Web/CSS/box-shadow\"\n }\n ],\n \"description\": \"Attaches one or more drop-shadows to the box. The property is a comma-separated list of shadows, each specified by 2-4 length values, an optional color, and an optional 'inset' keyword. Omitted lengths are 0; omitted colors are a user agent chosen color.\",\n \"restrictions\": [\n \"length\",\n \"color\",\n \"enum\"\n ]\n },\n {\n \"name\": \"transform\",\n \"values\": [\n {\n \"name\": \"matrix()\",\n \"description\": \"Specifies a 2D transformation in the form of a transformation matrix of six values. matrix(a,b,c,d,e,f) is equivalent to applying the transformation matrix [a b c d e f]\"\n },\n {\n \"name\": \"matrix3d()\",\n \"description\": \"Specifies a 3D transformation as a 4x4 homogeneous matrix of 16 values in column-major order.\"\n },\n {\n \"name\": \"none\"\n },\n {\n \"name\": \"perspective()\",\n \"description\": \"Specifies a perspective projection matrix.\"\n },\n {\n \"name\": \"rotate()\",\n \"description\": \"Specifies a 2D rotation by the angle specified in the parameter about the origin of the element, as defined by the transform-origin property.\"\n },\n {\n \"name\": \"rotate3d()\",\n \"description\": \"Specifies a clockwise 3D rotation by the angle specified in last parameter about the [x,y,z] direction vector described by the first 3 parameters.\"\n },\n {\n \"name\": \"rotateX('angle')\",\n \"description\": \"Specifies a clockwise rotation by the given angle about the X axis.\"\n },\n {\n \"name\": \"rotateY('angle')\",\n \"description\": \"Specifies a clockwise rotation by the given angle about the Y axis.\"\n },\n {\n \"name\": \"rotateZ('angle')\",\n \"description\": \"Specifies a clockwise rotation by the given angle about the Z axis.\"\n },\n {\n \"name\": \"scale()\",\n \"description\": \"Specifies a 2D scale operation by the [sx,sy] scaling vector described by the 2 parameters. If the second parameter is not provided, it is takes a value equal to the first.\"\n },\n {\n \"name\": \"scale3d()\",\n \"description\": \"Specifies a 3D scale operation by the [sx,sy,sz] scaling vector described by the 3 parameters.\"\n },\n {\n \"name\": \"scaleX()\",\n \"description\": \"Specifies a scale operation using the [sx,1] scaling vector, where sx is given as the parameter.\"\n },\n {\n \"name\": \"scaleY()\",\n \"description\": \"Specifies a scale operation using the [sy,1] scaling vector, where sy is given as the parameter.\"\n },\n {\n \"name\": \"scaleZ()\",\n \"description\": \"Specifies a scale operation using the [1,1,sz] scaling vector, where sz is given as the parameter.\"\n },\n {\n \"name\": \"skew()\",\n \"description\": \"Specifies a skew transformation along the X and Y axes. The first angle parameter specifies the skew on the X axis. The second angle parameter specifies the skew on the Y axis. If the second parameter is not given then a value of 0 is used for the Y angle (ie: no skew on the Y axis).\"\n },\n {\n \"name\": \"skewX()\",\n \"description\": \"Specifies a skew transformation along the X axis by the given angle.\"\n },\n {\n \"name\": \"skewY()\",\n \"description\": \"Specifies a skew transformation along the Y axis by the given angle.\"\n },\n {\n \"name\": \"translate()\",\n \"description\": \"Specifies a 2D translation by the vector [tx, ty], where tx is the first translation-value parameter and ty is the optional second translation-value parameter.\"\n },\n {\n \"name\": \"translate3d()\",\n \"description\": \"Specifies a 3D translation by the vector [tx,ty,tz], with tx, ty and tz being the first, second and third translation-value parameters respectively.\"\n },\n {\n \"name\": \"translateX()\",\n \"description\": \"Specifies a translation by the given amount in the X direction.\"\n },\n {\n \"name\": \"translateY()\",\n \"description\": \"Specifies a translation by the given amount in the Y direction.\"\n },\n {\n \"name\": \"translateZ()\",\n \"description\": \"Specifies a translation by the given amount in the Z direction. Note that percentage values are not allowed in the translateZ translation-value, and if present are evaluated as 0.\"\n }\n ],\n \"syntax\": \"none | \",\n \"references\": [\n {\n \"name\": \"MDN Reference\",\n \"url\": \"https://developer.mozilla.org/docs/Web/CSS/transform\"\n }\n ],\n \"description\": \"A two-dimensional transformation is applied to an element through the 'transform' property. This property contains a list of transform functions similar to those allowed by SVG.\",\n \"restrictions\": [\n \"enum\"\n ]\n },\n {\n \"name\": \"min-height\",\n \"values\": [\n {\n \"name\": \"auto\"\n },\n {\n \"name\": \"fit-content\",\n \"description\": \"Use the fit-content inline size or fit-content block size, as appropriate to the writing mode.\"\n },\n {\n \"name\": \"max-content\",\n \"description\": \"Use the max-content inline size or max-content block size, as appropriate to the writing mode.\"\n },\n {\n \"name\": \"min-content\",\n \"description\": \"Use the min-content inline size or min-content block size, as appropriate to the writing mode.\"\n }\n ],\n \"syntax\": \"\",\n \"references\": [\n {\n \"name\": \"MDN Reference\",\n \"url\": \"https://developer.mozilla.org/docs/Web/CSS/min-height\"\n }\n ],\n \"description\": \"Allows authors to constrain content height to a certain range.\",\n \"restrictions\": [\n \"length\",\n \"percentage\"\n ]\n },\n {\n \"name\": \"visibility\",\n \"values\": [\n {\n \"name\": \"collapse\",\n \"description\": \"Table-specific. If used on elements other than rows, row groups, columns, or column groups, 'collapse' has the same meaning as 'hidden'.\"\n },\n {\n \"name\": \"hidden\",\n \"description\": \"The generated box is invisible (fully transparent, nothing is drawn), but still affects layout.\"\n },\n {\n \"name\": \"visible\",\n \"description\": \"The generated box is visible.\"\n }\n ],\n \"syntax\": \"visible | hidden | collapse\",\n \"references\": [\n {\n \"name\": \"MDN Reference\",\n \"url\": \"https://developer.mozilla.org/docs/Web/CSS/visibility\"\n }\n ],\n \"description\": \"Specifies whether the boxes generated by an element are rendered. Invisible boxes still affect layout (set the ‘display’ property to ‘none’ to suppress box generation altogether).\",\n \"restrictions\": [\n \"enum\"\n ]\n },\n {\n \"name\": \"background-position\",\n \"syntax\": \"#\",\n \"references\": [\n {\n \"name\": \"MDN Reference\",\n \"url\": \"https://developer.mozilla.org/docs/Web/CSS/background-position\"\n }\n ],\n \"description\": \"Specifies the initial position of the background image(s) (after any resizing) within their corresponding background positioning area.\",\n \"restrictions\": [\n \"position\",\n \"length\",\n \"percentage\"\n ]\n },\n {\n \"name\": \"border-top\",\n \"syntax\": \" || || \",\n \"references\": [\n {\n \"name\": \"MDN Reference\",\n \"url\": \"https://developer.mozilla.org/docs/Web/CSS/border-top\"\n }\n ],\n \"description\": \"Shorthand property for setting border width, style and color\",\n \"restrictions\": [\n \"length\",\n \"line-width\",\n \"line-style\",\n \"color\"\n ]\n },\n {\n \"name\": \"min-width\",\n \"values\": [\n {\n \"name\": \"auto\"\n },\n {\n \"name\": \"fit-content\",\n \"description\": \"Use the fit-content inline size or fit-content block size, as appropriate to the writing mode.\"\n },\n {\n \"name\": \"max-content\",\n \"description\": \"Use the max-content inline size or max-content block size, as appropriate to the writing mode.\"\n },\n {\n \"name\": \"min-content\",\n \"description\": \"Use the min-content inline size or min-content block size, as appropriate to the writing mode.\"\n }\n ],\n \"syntax\": \"\",\n \"references\": [\n {\n \"name\": \"MDN Reference\",\n \"url\": \"https://developer.mozilla.org/docs/Web/CSS/min-width\"\n }\n ],\n \"description\": \"Allows authors to constrain content width to a certain range.\",\n \"restrictions\": [\n \"length\",\n \"percentage\"\n ]\n },\n {\n \"name\": \"outline\",\n \"values\": [\n {\n \"name\": \"auto\",\n \"description\": \"Permits the user agent to render a custom outline style, typically the default platform style.\"\n },\n {\n \"name\": \"invert\",\n \"description\": \"Performs a color inversion on the pixels on the screen.\"\n }\n ],\n \"syntax\": \"[ <'outline-color'> || <'outline-style'> || <'outline-width'> ]\",\n \"references\": [\n {\n \"name\": \"MDN Reference\",\n \"url\": \"https://developer.mozilla.org/docs/Web/CSS/outline\"\n }\n ],\n \"description\": \"Shorthand property for 'outline-style', 'outline-width', and 'outline-color'.\",\n \"restrictions\": [\n \"length\",\n \"line-width\",\n \"line-style\",\n \"color\",\n \"enum\"\n ]\n },\n {\n \"name\": \"transition\",\n \"values\": [\n {\n \"name\": \"all\",\n \"description\": \"Every property that is able to undergo a transition will do so.\"\n },\n {\n \"name\": \"none\",\n \"description\": \"No property will transition.\"\n }\n ],\n \"syntax\": \"#\",\n \"references\": [\n {\n \"name\": \"MDN Reference\",\n \"url\": \"https://developer.mozilla.org/docs/Web/CSS/transition\"\n }\n ],\n \"description\": \"Shorthand property combines four of the transition properties into a single property.\",\n \"restrictions\": [\n \"time\",\n \"property\",\n \"timing-function\",\n \"enum\"\n ]\n },\n {\n \"name\": \"clear\",\n \"values\": [\n {\n \"name\": \"both\",\n \"description\": \"The clearance of the generated box is set to the amount necessary to place the top border edge below the bottom outer edge of any right-floating and left-floating boxes that resulted from elements earlier in the source document.\"\n },\n {\n \"name\": \"left\",\n \"description\": \"The clearance of the generated box is set to the amount necessary to place the top border edge below the bottom outer edge of any left-floating boxes that resulted from elements earlier in the source document.\"\n },\n {\n \"name\": \"none\",\n \"description\": \"No constraint on the box's position with respect to floats.\"\n },\n {\n \"name\": \"right\",\n \"description\": \"The clearance of the generated box is set to the amount necessary to place the top border edge below the bottom outer edge of any right-floating boxes that resulted from elements earlier in the source document.\"\n }\n ],\n \"syntax\": \"none | left | right | both | inline-start | inline-end\",\n \"references\": [\n {\n \"name\": \"MDN Reference\",\n \"url\": \"https://developer.mozilla.org/docs/Web/CSS/clear\"\n }\n ],\n \"description\": \"Indicates which sides of an element's box(es) may not be adjacent to an earlier floating box. The 'clear' property does not consider floats inside the element itself or in other block formatting contexts.\",\n \"restrictions\": [\n \"enum\"\n ]\n },\n {\n \"name\": \"border-color\",\n \"values\": [],\n \"syntax\": \"{1,4}\",\n \"references\": [\n {\n \"name\": \"MDN Reference\",\n \"url\": \"https://developer.mozilla.org/docs/Web/CSS/border-color\"\n }\n ],\n \"description\": \"The color of the border around all four edges of an element.\",\n \"restrictions\": [\n \"color\"\n ]\n },\n {\n \"name\": \"background-repeat\",\n \"values\": [],\n \"syntax\": \"#\",\n \"references\": [\n {\n \"name\": \"MDN Reference\",\n \"url\": \"https://developer.mozilla.org/docs/Web/CSS/background-repeat\"\n }\n ],\n \"description\": \"Specifies how background images are tiled after they have been sized and positioned.\",\n \"restrictions\": [\n \"repeat\"\n ]\n },\n {\n \"name\": \"background-size\",\n \"values\": [\n {\n \"name\": \"auto\",\n \"description\": \"Resolved by using the image’s intrinsic ratio and the size of the other dimension, or failing that, using the image’s intrinsic size, or failing that, treating it as 100%.\"\n },\n {\n \"name\": \"contain\",\n \"description\": \"Scale the image, while preserving its intrinsic aspect ratio (if any), to the largest size such that both its width and its height can fit inside the background positioning area.\"\n },\n {\n \"name\": \"cover\",\n \"description\": \"Scale the image, while preserving its intrinsic aspect ratio (if any), to the smallest size such that both its width and its height can completely cover the background positioning area.\"\n }\n ],\n \"syntax\": \"#\",\n \"references\": [\n {\n \"name\": \"MDN Reference\",\n \"url\": \"https://developer.mozilla.org/docs/Web/CSS/background-size\"\n }\n ],\n \"description\": \"Specifies the size of the background images.\",\n \"restrictions\": [\n \"length\",\n \"percentage\"\n ]\n },\n {\n \"name\": \"text-transform\",\n \"values\": [\n {\n \"name\": \"capitalize\",\n \"description\": \"Puts the first typographic letter unit of each word in titlecase.\"\n },\n {\n \"name\": \"lowercase\",\n \"description\": \"Puts all letters in lowercase.\"\n },\n {\n \"name\": \"none\",\n \"description\": \"No effects.\"\n },\n {\n \"name\": \"uppercase\",\n \"description\": \"Puts all letters in uppercase.\"\n }\n ],\n \"syntax\": \"none | capitalize | uppercase | lowercase | full-width | full-size-kana\",\n \"references\": [\n {\n \"name\": \"MDN Reference\",\n \"url\": \"https://developer.mozilla.org/docs/Web/CSS/text-transform\"\n }\n ],\n \"description\": \"Controls capitalization effects of an element’s text.\",\n \"restrictions\": [\n \"enum\"\n ]\n },\n {\n \"name\": \"max-height\",\n \"values\": [\n {\n \"name\": \"none\",\n \"description\": \"No limit on the height of the box.\"\n },\n {\n \"name\": \"fit-content\",\n \"description\": \"Use the fit-content inline size or fit-content block size, as appropriate to the writing mode.\"\n },\n {\n \"name\": \"max-content\",\n \"description\": \"Use the max-content inline size or max-content block size, as appropriate to the writing mode.\"\n },\n {\n \"name\": \"min-content\",\n \"description\": \"Use the min-content inline size or min-content block size, as appropriate to the writing mode.\"\n }\n ],\n \"syntax\": \"\",\n \"references\": [\n {\n \"name\": \"MDN Reference\",\n \"url\": \"https://developer.mozilla.org/docs/Web/CSS/max-height\"\n }\n ],\n \"description\": \"Allows authors to constrain content height to a certain range.\",\n \"restrictions\": [\n \"length\",\n \"percentage\"\n ]\n },\n {\n \"name\": \"list-style\",\n \"values\": [\n {\n \"name\": \"armenian\"\n },\n {\n \"name\": \"circle\",\n \"description\": \"A hollow circle.\"\n },\n {\n \"name\": \"decimal\"\n },\n {\n \"name\": \"decimal-leading-zero\"\n },\n {\n \"name\": \"disc\",\n \"description\": \"A filled circle.\"\n },\n {\n \"name\": \"georgian\"\n },\n {\n \"name\": \"inside\",\n \"description\": \"The marker box is outside the principal block box, as described in the section on the ::marker pseudo-element below.\"\n },\n {\n \"name\": \"lower-alpha\"\n },\n {\n \"name\": \"lower-greek\"\n },\n {\n \"name\": \"lower-latin\"\n },\n {\n \"name\": \"lower-roman\"\n },\n {\n \"name\": \"none\"\n },\n {\n \"name\": \"outside\",\n \"description\": \"The ::marker pseudo-element is an inline element placed immediately before all ::before pseudo-elements in the principal block box, after which the element's content flows.\"\n },\n {\n \"name\": \"square\",\n \"description\": \"A filled square.\"\n },\n {\n \"name\": \"symbols()\",\n \"description\": \"Allows a counter style to be defined inline.\"\n },\n {\n \"name\": \"upper-alpha\"\n },\n {\n \"name\": \"upper-latin\"\n },\n {\n \"name\": \"upper-roman\"\n },\n {\n \"name\": \"url()\"\n }\n ],\n \"syntax\": \"<'list-style-type'> || <'list-style-position'> || <'list-style-image'>\",\n \"references\": [\n {\n \"name\": \"MDN Reference\",\n \"url\": \"https://developer.mozilla.org/docs/Web/CSS/list-style\"\n }\n ],\n \"description\": \"Shorthand for setting 'list-style-type', 'list-style-position' and 'list-style-image'\",\n \"restrictions\": [\n \"image\",\n \"enum\",\n \"url\"\n ]\n },\n {\n \"name\": \"font-style\",\n \"values\": [\n {\n \"name\": \"italic\",\n \"description\": \"Selects a font that is labeled as an 'italic' face, or an 'oblique' face if one is not\"\n },\n {\n \"name\": \"normal\",\n \"description\": \"Selects a face that is classified as 'normal'.\"\n },\n {\n \"name\": \"oblique\",\n \"description\": \"Selects a font that is labeled as an 'oblique' face, or an 'italic' face if one is not.\"\n }\n ],\n \"syntax\": \"normal | italic | oblique {0,2}\",\n \"references\": [\n {\n \"name\": \"MDN Reference\",\n \"url\": \"https://developer.mozilla.org/docs/Web/CSS/font-style\"\n }\n ],\n \"description\": \"Allows italic or oblique faces to be selected. Italic forms are generally cursive in nature while oblique faces are typically sloped versions of the regular face.\",\n \"restrictions\": [\n \"enum\"\n ]\n },\n {\n \"name\": \"font\",\n \"values\": [\n {\n \"name\": \"100\",\n \"description\": \"Thin\"\n },\n {\n \"name\": \"200\",\n \"description\": \"Extra Light (Ultra Light)\"\n },\n {\n \"name\": \"300\",\n \"description\": \"Light\"\n },\n {\n \"name\": \"400\",\n \"description\": \"Normal\"\n },\n {\n \"name\": \"500\",\n \"description\": \"Medium\"\n },\n {\n \"name\": \"600\",\n \"description\": \"Semi Bold (Demi Bold)\"\n },\n {\n \"name\": \"700\",\n \"description\": \"Bold\"\n },\n {\n \"name\": \"800\",\n \"description\": \"Extra Bold (Ultra Bold)\"\n },\n {\n \"name\": \"900\",\n \"description\": \"Black (Heavy)\"\n },\n {\n \"name\": \"bold\",\n \"description\": \"Same as 700\"\n },\n {\n \"name\": \"bolder\",\n \"description\": \"Specifies the weight of the face bolder than the inherited value.\"\n },\n {\n \"name\": \"caption\",\n \"description\": \"The font used for captioned controls (e.g., buttons, drop-downs, etc.).\"\n },\n {\n \"name\": \"icon\",\n \"description\": \"The font used to label icons.\"\n },\n {\n \"name\": \"italic\",\n \"description\": \"Selects a font that is labeled 'italic', or, if that is not available, one labeled 'oblique'.\"\n },\n {\n \"name\": \"large\"\n },\n {\n \"name\": \"larger\"\n },\n {\n \"name\": \"lighter\",\n \"description\": \"Specifies the weight of the face lighter than the inherited value.\"\n },\n {\n \"name\": \"medium\"\n },\n {\n \"name\": \"menu\",\n \"description\": \"The font used in menus (e.g., dropdown menus and menu lists).\"\n },\n {\n \"name\": \"message-box\",\n \"description\": \"The font used in dialog boxes.\"\n },\n {\n \"name\": \"normal\",\n \"description\": \"Specifies a face that is not labeled as a small-caps font.\"\n },\n {\n \"name\": \"oblique\",\n \"description\": \"Selects a font that is labeled 'oblique'.\"\n },\n {\n \"name\": \"small\"\n },\n {\n \"name\": \"small-caps\",\n \"description\": \"Specifies a font that is labeled as a small-caps font. If a genuine small-caps font is not available, user agents should simulate a small-caps font.\"\n },\n {\n \"name\": \"small-caption\",\n \"description\": \"The font used for labeling small controls.\"\n },\n {\n \"name\": \"smaller\"\n },\n {\n \"name\": \"status-bar\",\n \"description\": \"The font used in window status bars.\"\n },\n {\n \"name\": \"x-large\"\n },\n {\n \"name\": \"x-small\"\n },\n {\n \"name\": \"xx-large\"\n },\n {\n \"name\": \"xx-small\"\n }\n ],\n \"syntax\": \"[ [ <'font-style'> || || <'font-weight'> || <'font-stretch'> ]? <'font-size'> [ / <'line-height'> ]? <'font-family'> ] | caption | icon | menu | message-box | small-caption | status-bar\",\n \"references\": [\n {\n \"name\": \"MDN Reference\",\n \"url\": \"https://developer.mozilla.org/docs/Web/CSS/font\"\n }\n ],\n \"description\": \"Shorthand property for setting 'font-style', 'font-variant', 'font-weight', 'font-size', 'line-height', and 'font-family', at the same place in the style sheet. The syntax of this property is based on a traditional typographical shorthand notation to set multiple properties related to fonts.\",\n \"restrictions\": [\n \"font\"\n ]\n },\n {\n \"name\": \"text-overflow\",\n \"values\": [\n {\n \"name\": \"clip\",\n \"description\": \"Clip inline content that overflows. Characters may be only partially rendered.\"\n },\n {\n \"name\": \"ellipsis\",\n \"description\": \"Render an ellipsis character (U+2026) to represent clipped inline content.\"\n }\n ],\n \"syntax\": \"[ clip | ellipsis | ]{1,2}\",\n \"references\": [\n {\n \"name\": \"MDN Reference\",\n \"url\": \"https://developer.mozilla.org/docs/Web/CSS/text-overflow\"\n }\n ],\n \"description\": \"Text can overflow for example when it is prevented from wrapping.\",\n \"restrictions\": [\n \"enum\",\n \"string\"\n ]\n },\n {\n \"name\": \"border-left\",\n \"syntax\": \" || || \",\n \"references\": [\n {\n \"name\": \"MDN Reference\",\n \"url\": \"https://developer.mozilla.org/docs/Web/CSS/border-left\"\n }\n ],\n \"description\": \"Shorthand property for setting border width, style and color\",\n \"restrictions\": [\n \"length\",\n \"line-width\",\n \"line-style\",\n \"color\"\n ]\n },\n {\n \"name\": \"border-right\",\n \"syntax\": \" || || \",\n \"references\": [\n {\n \"name\": \"MDN Reference\",\n \"url\": \"https://developer.mozilla.org/docs/Web/CSS/border-right\"\n }\n ],\n \"description\": \"Shorthand property for setting border width, style and color\",\n \"restrictions\": [\n \"length\",\n \"line-width\",\n \"line-style\",\n \"color\"\n ]\n },\n {\n \"name\": \"border-width\",\n \"values\": [],\n \"syntax\": \"{1,4}\",\n \"references\": [\n {\n \"name\": \"MDN Reference\",\n \"url\": \"https://developer.mozilla.org/docs/Web/CSS/border-width\"\n }\n ],\n \"description\": \"Shorthand that sets the four 'border-*-width' properties. If it has four values, they set top, right, bottom and left in that order. If left is missing, it is the same as right; if bottom is missing, it is the same as top; if right is missing, it is the same as top.\",\n \"restrictions\": [\n \"length\",\n \"line-width\"\n ]\n },\n {\n \"name\": \"justify-content\",\n \"values\": [\n {\n \"name\": \"center\",\n \"description\": \"Flex items are packed toward the center of the line.\"\n },\n {\n \"name\": \"start\",\n \"description\": \"The items are packed flush to each other toward the start edge of the alignment container in the main axis.\"\n },\n {\n \"name\": \"end\",\n \"description\": \"The items are packed flush to each other toward the end edge of the alignment container in the main axis.\"\n },\n {\n \"name\": \"left\",\n \"description\": \"The items are packed flush to each other toward the left edge of the alignment container in the main axis.\"\n },\n {\n \"name\": \"right\",\n \"description\": \"The items are packed flush to each other toward the right edge of the alignment container in the main axis.\"\n },\n {\n \"name\": \"safe\",\n \"description\": \"If the size of the item overflows the alignment container, the item is instead aligned as if the alignment mode were start.\"\n },\n {\n \"name\": \"unsafe\",\n \"description\": \"Regardless of the relative sizes of the item and alignment container, the given alignment value is honored.\"\n },\n {\n \"name\": \"stretch\",\n \"description\": \"If the combined size of the alignment subjects is less than the size of the alignment container, any auto-sized alignment subjects have their size increased equally (not proportionally), while still respecting the constraints imposed by max-height/max-width (or equivalent functionality), so that the combined size exactly fills the alignment container.\"\n },\n {\n \"name\": \"space-evenly\",\n \"description\": \"The items are evenly distributed within the alignment container along the main axis.\"\n },\n {\n \"name\": \"flex-end\",\n \"description\": \"Flex items are packed toward the end of the line.\"\n },\n {\n \"name\": \"flex-start\",\n \"description\": \"Flex items are packed toward the start of the line.\"\n },\n {\n \"name\": \"space-around\",\n \"description\": \"Flex items are evenly distributed in the line, with half-size spaces on either end.\"\n },\n {\n \"name\": \"space-between\",\n \"description\": \"Flex items are evenly distributed in the line.\"\n },\n {\n \"name\": \"baseline\",\n \"description\": \"Specifies participation in first-baseline alignment.\"\n },\n {\n \"name\": \"first baseline\",\n \"description\": \"Specifies participation in first-baseline alignment.\"\n },\n {\n \"name\": \"last baseline\",\n \"description\": \"Specifies participation in last-baseline alignment.\"\n }\n ],\n \"syntax\": \"normal | | ? [ | left | right ]\",\n \"description\": \"Aligns flex items along the main axis of the current line of the flex container.\",\n \"restrictions\": [\n \"enum\"\n ]\n },\n {\n \"name\": \"align-items\",\n \"values\": [\n {\n \"name\": \"baseline\",\n \"description\": \"If the flex item’s inline axis is the same as the cross axis, this value is identical to 'flex-start'. Otherwise, it participates in baseline alignment.\"\n },\n {\n \"name\": \"center\",\n \"description\": \"The flex item’s margin box is centered in the cross axis within the line.\"\n },\n {\n \"name\": \"flex-end\",\n \"description\": \"The cross-end margin edge of the flex item is placed flush with the cross-end edge of the line.\"\n },\n {\n \"name\": \"flex-start\",\n \"description\": \"The cross-start margin edge of the flex item is placed flush with the cross-start edge of the line.\"\n },\n {\n \"name\": \"stretch\",\n \"description\": \"If the cross size property of the flex item computes to auto, and neither of the cross-axis margins are auto, the flex item is stretched.\"\n }\n ],\n \"syntax\": \"normal | stretch | | [ ? ]\",\n \"description\": \"Aligns flex items along the cross axis of the current line of the flex container.\",\n \"restrictions\": [\n \"enum\"\n ]\n },\n {\n \"name\": \"overflow-y\",\n \"values\": [\n {\n \"name\": \"auto\",\n \"description\": \"The behavior of the 'auto' value is UA-dependent, but should cause a scrolling mechanism to be provided for overflowing boxes.\"\n },\n {\n \"name\": \"hidden\",\n \"description\": \"Content is clipped and no scrolling mechanism should be provided to view the content outside the clipping region.\"\n },\n {\n \"name\": \"scroll\",\n \"description\": \"Content is clipped and if the user agent uses a scrolling mechanism that is visible on the screen (such as a scroll bar or a panner), that mechanism should be displayed for a box whether or not any of its content is clipped.\"\n },\n {\n \"name\": \"visible\",\n \"description\": \"Content is not clipped, i.e., it may be rendered outside the content box.\"\n }\n ],\n \"syntax\": \"visible | hidden | clip | scroll | auto\",\n \"references\": [\n {\n \"name\": \"MDN Reference\",\n \"url\": \"https://developer.mozilla.org/docs/Web/CSS/overflow-y\"\n }\n ],\n \"description\": \"Specifies the handling of overflow in the vertical direction.\",\n \"restrictions\": [\n \"enum\"\n ]\n },\n {\n \"name\": \"pointer-events\",\n \"values\": [\n {\n \"name\": \"all\",\n \"description\": \"The given element can be the target element for pointer events whenever the pointer is over either the interior or the perimeter of the element.\"\n },\n {\n \"name\": \"fill\",\n \"description\": \"The given element can be the target element for pointer events whenever the pointer is over the interior of the element.\"\n },\n {\n \"name\": \"none\",\n \"description\": \"The given element does not receive pointer events.\"\n },\n {\n \"name\": \"painted\",\n \"description\": \"The given element can be the target element for pointer events when the pointer is over a \\\"painted\\\" area. \"\n },\n {\n \"name\": \"stroke\",\n \"description\": \"The given element can be the target element for pointer events whenever the pointer is over the perimeter of the element.\"\n },\n {\n \"name\": \"visible\",\n \"description\": \"The given element can be the target element for pointer events when the ‘visibility’ property is set to visible and the pointer is over either the interior or the perimete of the element.\"\n },\n {\n \"name\": \"visibleFill\",\n \"description\": \"The given element can be the target element for pointer events when the ‘visibility’ property is set to visible and when the pointer is over the interior of the element.\"\n },\n {\n \"name\": \"visiblePainted\",\n \"description\": \"The given element can be the target element for pointer events when the ‘visibility’ property is set to visible and when the pointer is over a ‘painted’ area.\"\n },\n {\n \"name\": \"visibleStroke\",\n \"description\": \"The given element can be the target element for pointer events when the ‘visibility’ property is set to visible and when the pointer is over the perimeter of the element.\"\n }\n ],\n \"syntax\": \"auto | none | visiblePainted | visibleFill | visibleStroke | visible | painted | fill | stroke | all | inherit\",\n \"references\": [\n {\n \"name\": \"MDN Reference\",\n \"url\": \"https://developer.mozilla.org/docs/Web/CSS/pointer-events\"\n }\n ],\n \"description\": \"Specifies under what circumstances a given element can be the target element for a pointer event.\",\n \"restrictions\": [\n \"enum\"\n ]\n },\n {\n \"name\": \"letter-spacing\",\n \"values\": [\n {\n \"name\": \"normal\",\n \"description\": \"The spacing is the normal spacing for the current font. It is typically zero-length.\"\n }\n ],\n \"syntax\": \"normal | \",\n \"references\": [\n {\n \"name\": \"MDN Reference\",\n \"url\": \"https://developer.mozilla.org/docs/Web/CSS/letter-spacing\"\n }\n ],\n \"description\": \"Specifies the minimum, maximum, and optimal spacing between grapheme clusters.\",\n \"restrictions\": [\n \"length\"\n ]\n },\n {\n \"name\": \"border-style\",\n \"values\": [],\n \"syntax\": \"{1,4}\",\n \"references\": [\n {\n \"name\": \"MDN Reference\",\n \"url\": \"https://developer.mozilla.org/docs/Web/CSS/border-style\"\n }\n ],\n \"description\": \"The style of the border around edges of an element.\",\n \"restrictions\": [\n \"line-style\"\n ]\n },\n {\n \"name\": \"animation\",\n \"values\": [\n {\n \"name\": \"alternate\",\n \"description\": \"The animation cycle iterations that are odd counts are played in the normal direction, and the animation cycle iterations that are even counts are played in a reverse direction.\"\n },\n {\n \"name\": \"alternate-reverse\",\n \"description\": \"The animation cycle iterations that are odd counts are played in the reverse direction, and the animation cycle iterations that are even counts are played in a normal direction.\"\n },\n {\n \"name\": \"backwards\",\n \"description\": \"The beginning property value (as defined in the first @keyframes at-rule) is applied before the animation is displayed, during the period defined by 'animation-delay'.\"\n },\n {\n \"name\": \"both\",\n \"description\": \"Both forwards and backwards fill modes are applied.\"\n },\n {\n \"name\": \"forwards\",\n \"description\": \"The final property value (as defined in the last @keyframes at-rule) is maintained after the animation completes.\"\n },\n {\n \"name\": \"infinite\",\n \"description\": \"Causes the animation to repeat forever.\"\n },\n {\n \"name\": \"none\",\n \"description\": \"No animation is performed\"\n },\n {\n \"name\": \"normal\",\n \"description\": \"Normal playback.\"\n },\n {\n \"name\": \"reverse\",\n \"description\": \"All iterations of the animation are played in the reverse direction from the way they were specified.\"\n }\n ],\n \"syntax\": \"#\",\n \"references\": [\n {\n \"name\": \"MDN Reference\",\n \"url\": \"https://developer.mozilla.org/docs/Web/CSS/animation\"\n }\n ],\n \"description\": \"Shorthand property combines six of the animation properties into a single property.\",\n \"restrictions\": [\n \"time\",\n \"timing-function\",\n \"enum\",\n \"identifier\",\n \"number\"\n ]\n },\n {\n \"name\": \"overflow-x\",\n \"values\": [\n {\n \"name\": \"auto\",\n \"description\": \"The behavior of the 'auto' value is UA-dependent, but should cause a scrolling mechanism to be provided for overflowing boxes.\"\n },\n {\n \"name\": \"hidden\",\n \"description\": \"Content is clipped and no scrolling mechanism should be provided to view the content outside the clipping region.\"\n },\n {\n \"name\": \"scroll\",\n \"description\": \"Content is clipped and if the user agent uses a scrolling mechanism that is visible on the screen (such as a scroll bar or a panner), that mechanism should be displayed for a box whether or not any of its content is clipped.\"\n },\n {\n \"name\": \"visible\",\n \"description\": \"Content is not clipped, i.e., it may be rendered outside the content box.\"\n }\n ],\n \"syntax\": \"visible | hidden | clip | scroll | auto\",\n \"references\": [\n {\n \"name\": \"MDN Reference\",\n \"url\": \"https://developer.mozilla.org/docs/Web/CSS/overflow-x\"\n }\n ],\n \"description\": \"Specifies the handling of overflow in the horizontal direction.\",\n \"restrictions\": [\n \"enum\"\n ]\n },\n {\n \"name\": \"word-wrap\",\n \"values\": [\n {\n \"name\": \"break-word\",\n \"description\": \"An otherwise unbreakable sequence of characters may be broken at an arbitrary point if there are no otherwise-acceptable break points in the line.\"\n },\n {\n \"name\": \"normal\",\n \"description\": \"Lines may break only at allowed break points.\"\n }\n ],\n \"syntax\": \"normal | break-word\",\n \"references\": [\n {\n \"name\": \"MDN Reference\",\n \"url\": \"https://developer.mozilla.org/docs/Web/CSS/overflow-wrap\"\n }\n ],\n \"description\": \"Specifies whether the UA may break within a word to prevent overflow when an otherwise-unbreakable string is too long to fit.\",\n \"restrictions\": [\n \"enum\"\n ]\n },\n {\n \"name\": \"border-collapse\",\n \"values\": [\n {\n \"name\": \"collapse\",\n \"description\": \"Selects the collapsing borders model.\"\n },\n {\n \"name\": \"separate\",\n \"description\": \"Selects the separated borders border model.\"\n }\n ],\n \"syntax\": \"collapse | separate\",\n \"references\": [\n {\n \"name\": \"MDN Reference\",\n \"url\": \"https://developer.mozilla.org/docs/Web/CSS/border-collapse\"\n }\n ],\n \"description\": \"Selects a table's border model.\",\n \"restrictions\": [\n \"enum\"\n ]\n },\n {\n \"name\": \"flex-direction\",\n \"values\": [\n {\n \"name\": \"column\",\n \"description\": \"The flex container’s main axis has the same orientation as the block axis of the current writing mode.\"\n },\n {\n \"name\": \"column-reverse\",\n \"description\": \"Same as 'column', except the main-start and main-end directions are swapped.\"\n },\n {\n \"name\": \"row\",\n \"description\": \"The flex container’s main axis has the same orientation as the inline axis of the current writing mode.\"\n },\n {\n \"name\": \"row-reverse\",\n \"description\": \"Same as 'row', except the main-start and main-end directions are swapped.\"\n }\n ],\n \"syntax\": \"row | row-reverse | column | column-reverse\",\n \"references\": [\n {\n \"name\": \"MDN Reference\",\n \"url\": \"https://developer.mozilla.org/docs/Web/CSS/flex-direction\"\n }\n ],\n \"description\": \"Specifies how flex items are placed in the flex container, by setting the direction of the flex container’s main axis.\",\n \"restrictions\": [\n \"enum\"\n ]\n },\n {\n \"name\": \"zoom\",\n \"browsers\": [\n \"E12\",\n \"S3.1\",\n \"C1\",\n \"IE5.5\",\n \"O15\"\n ],\n \"values\": [\n {\n \"name\": \"normal\"\n }\n ],\n \"syntax\": \"auto | | \",\n \"references\": [\n {\n \"name\": \"MDN Reference\",\n \"url\": \"https://developer.mozilla.org/docs/Web/CSS/zoom\"\n }\n ],\n \"description\": \"Non-standard. Specifies the magnification scale of the object. See 'transform: scale()' for a standards-based alternative.\",\n \"restrictions\": [\n \"enum\",\n \"integer\",\n \"number\",\n \"percentage\"\n ]\n },\n {\n \"name\": \"flex\",\n \"values\": [\n {\n \"name\": \"auto\",\n \"description\": \"Retrieves the value of the main size property as the used 'flex-basis'.\"\n },\n {\n \"name\": \"content\",\n \"description\": \"Indicates automatic sizing, based on the flex item’s content.\"\n },\n {\n \"name\": \"none\",\n \"description\": \"Expands to '0 0 auto'.\"\n }\n ],\n \"syntax\": \"none | [ <'flex-grow'> <'flex-shrink'>? || <'flex-basis'> ]\",\n \"references\": [\n {\n \"name\": \"MDN Reference\",\n \"url\": \"https://developer.mozilla.org/docs/Web/CSS/flex\"\n }\n ],\n \"description\": \"Specifies the components of a flexible length: the flex grow factor and flex shrink factor, and the flex basis.\",\n \"restrictions\": [\n \"length\",\n \"number\",\n \"percentage\"\n ]\n },\n {\n \"name\": \"text-shadow\",\n \"values\": [\n {\n \"name\": \"none\",\n \"description\": \"No shadow.\"\n }\n ],\n \"syntax\": \"none | #\",\n \"references\": [\n {\n \"name\": \"MDN Reference\",\n \"url\": \"https://developer.mozilla.org/docs/Web/CSS/text-shadow\"\n }\n ],\n \"description\": \"Enables shadow effects to be applied to the text of the element.\",\n \"restrictions\": [\n \"length\",\n \"color\"\n ]\n },\n {\n \"name\": \"list-style-type\",\n \"values\": [\n {\n \"name\": \"armenian\",\n \"description\": \"Traditional uppercase Armenian numbering.\"\n },\n {\n \"name\": \"circle\",\n \"description\": \"A hollow circle.\"\n },\n {\n \"name\": \"decimal\",\n \"description\": \"Western decimal numbers.\"\n },\n {\n \"name\": \"decimal-leading-zero\",\n \"description\": \"Decimal numbers padded by initial zeros.\"\n },\n {\n \"name\": \"disc\",\n \"description\": \"A filled circle.\"\n },\n {\n \"name\": \"georgian\",\n \"description\": \"Traditional Georgian numbering.\"\n },\n {\n \"name\": \"lower-alpha\",\n \"description\": \"Lowercase ASCII letters.\"\n },\n {\n \"name\": \"lower-greek\",\n \"description\": \"Lowercase classical Greek.\"\n },\n {\n \"name\": \"lower-latin\",\n \"description\": \"Lowercase ASCII letters.\"\n },\n {\n \"name\": \"lower-roman\",\n \"description\": \"Lowercase ASCII Roman numerals.\"\n },\n {\n \"name\": \"none\",\n \"description\": \"No marker\"\n },\n {\n \"name\": \"square\",\n \"description\": \"A filled square.\"\n },\n {\n \"name\": \"symbols()\",\n \"description\": \"Allows a counter style to be defined inline.\"\n },\n {\n \"name\": \"upper-alpha\",\n \"description\": \"Uppercase ASCII letters.\"\n },\n {\n \"name\": \"upper-latin\",\n \"description\": \"Uppercase ASCII letters.\"\n },\n {\n \"name\": \"upper-roman\",\n \"description\": \"Uppercase ASCII Roman numerals.\"\n }\n ],\n \"syntax\": \" | | none\",\n \"references\": [\n {\n \"name\": \"MDN Reference\",\n \"url\": \"https://developer.mozilla.org/docs/Web/CSS/list-style-type\"\n }\n ],\n \"description\": \"Used to construct the default contents of a list item’s marker\",\n \"restrictions\": [\n \"enum\",\n \"string\"\n ]\n },\n {\n \"name\": \"border-bottom-left-radius\",\n \"syntax\": \"{1,2}\",\n \"references\": [\n {\n \"name\": \"MDN Reference\",\n \"url\": \"https://developer.mozilla.org/docs/Web/CSS/border-bottom-left-radius\"\n }\n ],\n \"description\": \"Defines the radii of the bottom left outer border edge.\",\n \"restrictions\": [\n \"length\",\n \"percentage\"\n ]\n },\n {\n \"name\": \"user-select\",\n \"values\": [\n {\n \"name\": \"all\",\n \"description\": \"The content of the element must be selected atomically\"\n },\n {\n \"name\": \"auto\"\n },\n {\n \"name\": \"contain\",\n \"description\": \"UAs must not allow a selection which is started in this element to be extended outside of this element.\"\n },\n {\n \"name\": \"none\",\n \"description\": \"The UA must not allow selections to be started in this element.\"\n },\n {\n \"name\": \"text\",\n \"description\": \"The element imposes no constraint on the selection.\"\n }\n ],\n \"status\": \"nonstandard\",\n \"syntax\": \"auto | text | none | contain | all\",\n \"references\": [\n {\n \"name\": \"MDN Reference\",\n \"url\": \"https://developer.mozilla.org/docs/Web/CSS/user-select\"\n }\n ],\n \"description\": \"Controls the appearance of selection.\",\n \"restrictions\": [\n \"enum\"\n ]\n },\n {\n \"name\": \"fill\",\n \"values\": [\n {\n \"name\": \"url()\",\n \"description\": \"A URL reference to a paint server element, which is an element that defines a paint server: ‘hatch’, ‘linearGradient’, ‘mesh’, ‘pattern’, ‘radialGradient’ and ‘solidcolor’.\"\n },\n {\n \"name\": \"none\",\n \"description\": \"No paint is applied in this layer.\"\n }\n ],\n \"description\": \"Paints the interior of the given graphical element.\",\n \"restrictions\": [\n \"color\",\n \"enum\",\n \"url\"\n ]\n },\n {\n \"name\": \"transform-origin\",\n \"syntax\": \"[ | left | center | right | top | bottom ] | [ [ | left | center | right ] && [ | top | center | bottom ] ] ?\",\n \"references\": [\n {\n \"name\": \"MDN Reference\",\n \"url\": \"https://developer.mozilla.org/docs/Web/CSS/transform-origin\"\n }\n ],\n \"description\": \"Establishes the origin of transformation for an element.\",\n \"restrictions\": [\n \"position\",\n \"length\",\n \"percentage\"\n ]\n },\n {\n \"name\": \"border-top-left-radius\",\n \"syntax\": \"{1,2}\",\n \"references\": [\n {\n \"name\": \"MDN Reference\",\n \"url\": \"https://developer.mozilla.org/docs/Web/CSS/border-top-left-radius\"\n }\n ],\n \"description\": \"Defines the radii of the top left outer border edge.\",\n \"restrictions\": [\n \"length\",\n \"percentage\"\n ]\n },\n {\n \"name\": \"text-indent\",\n \"values\": [],\n \"syntax\": \" && hanging? && each-line?\",\n \"references\": [\n {\n \"name\": \"MDN Reference\",\n \"url\": \"https://developer.mozilla.org/docs/Web/CSS/text-indent\"\n }\n ],\n \"description\": \"Specifies the indentation applied to lines of inline content in a block. The indentation only affects the first line of inline content in the block unless the 'hanging' keyword is specified, in which case it affects all lines except the first.\",\n \"restrictions\": [\n \"percentage\",\n \"length\"\n ]\n },\n {\n \"name\": \"border-bottom-right-radius\",\n \"syntax\": \"{1,2}\",\n \"references\": [\n {\n \"name\": \"MDN Reference\",\n \"url\": \"https://developer.mozilla.org/docs/Web/CSS/border-bottom-right-radius\"\n }\n ],\n \"description\": \"Defines the radii of the bottom right outer border edge.\",\n \"restrictions\": [\n \"length\",\n \"percentage\"\n ]\n },\n {\n \"name\": \"flex-wrap\",\n \"values\": [\n {\n \"name\": \"nowrap\",\n \"description\": \"The flex container is single-line.\"\n },\n {\n \"name\": \"wrap\",\n \"description\": \"The flexbox is multi-line.\"\n },\n {\n \"name\": \"wrap-reverse\",\n \"description\": \"Same as 'wrap', except the cross-start and cross-end directions are swapped.\"\n }\n ],\n \"syntax\": \"nowrap | wrap | wrap-reverse\",\n \"references\": [\n {\n \"name\": \"MDN Reference\",\n \"url\": \"https://developer.mozilla.org/docs/Web/CSS/flex-wrap\"\n }\n ],\n \"description\": \"Controls whether the flex container is single-line or multi-line, and the direction of the cross-axis, which determines the direction new lines are stacked in.\",\n \"restrictions\": [\n \"enum\"\n ]\n },\n {\n \"name\": \"border-spacing\",\n \"syntax\": \" ?\",\n \"references\": [\n {\n \"name\": \"MDN Reference\",\n \"url\": \"https://developer.mozilla.org/docs/Web/CSS/border-spacing\"\n }\n ],\n \"description\": \"The lengths specify the distance that separates adjoining cell borders. If one length is specified, it gives both the horizontal and vertical spacing. If two are specified, the first gives the horizontal spacing and the second the vertical spacing. Lengths may not be negative.\",\n \"restrictions\": [\n \"length\"\n ]\n },\n {\n \"name\": \"border-top-right-radius\",\n \"syntax\": \"{1,2}\",\n \"references\": [\n {\n \"name\": \"MDN Reference\",\n \"url\": \"https://developer.mozilla.org/docs/Web/CSS/border-top-right-radius\"\n }\n ],\n \"description\": \"Defines the radii of the top right outer border edge.\",\n \"restrictions\": [\n \"length\",\n \"percentage\"\n ]\n },\n {\n \"name\": \"clip\",\n \"values\": [\n {\n \"name\": \"auto\",\n \"description\": \"The element does not clip.\"\n },\n {\n \"name\": \"rect()\",\n \"description\": \"Specifies offsets from the edges of the border box.\"\n }\n ],\n \"syntax\": \" | auto\",\n \"references\": [\n {\n \"name\": \"MDN Reference\",\n \"url\": \"https://developer.mozilla.org/docs/Web/CSS/clip\"\n }\n ],\n \"description\": \"Deprecated. Use the 'clip-path' property when support allows. Defines the visible portion of an element’s box.\",\n \"restrictions\": [\n \"enum\"\n ]\n },\n {\n \"name\": \"border-top-color\",\n \"syntax\": \"\",\n \"references\": [\n {\n \"name\": \"MDN Reference\",\n \"url\": \"https://developer.mozilla.org/docs/Web/CSS/border-top-color\"\n }\n ],\n \"description\": \"Sets the color of the top border.\",\n \"restrictions\": [\n \"color\"\n ]\n },\n {\n \"name\": \"word-break\",\n \"values\": [\n {\n \"name\": \"break-all\",\n \"description\": \"Lines may break between any two grapheme clusters for non-CJK scripts.\"\n },\n {\n \"name\": \"keep-all\",\n \"description\": \"Block characters can no longer create implied break points.\"\n },\n {\n \"name\": \"normal\",\n \"description\": \"Breaks non-CJK scripts according to their own rules.\"\n }\n ],\n \"syntax\": \"normal | break-all | keep-all | break-word\",\n \"references\": [\n {\n \"name\": \"MDN Reference\",\n \"url\": \"https://developer.mozilla.org/docs/Web/CSS/word-break\"\n }\n ],\n \"description\": \"Specifies line break opportunities for non-CJK scripts.\",\n \"restrictions\": [\n \"enum\"\n ]\n },\n {\n \"name\": \"border-bottom-color\",\n \"syntax\": \"<'border-top-color'>\",\n \"references\": [\n {\n \"name\": \"MDN Reference\",\n \"url\": \"https://developer.mozilla.org/docs/Web/CSS/border-bottom-color\"\n }\n ],\n \"description\": \"Sets the color of the bottom border.\",\n \"restrictions\": [\n \"color\"\n ]\n },\n {\n \"name\": \"flex-grow\",\n \"syntax\": \"\",\n \"references\": [\n {\n \"name\": \"MDN Reference\",\n \"url\": \"https://developer.mozilla.org/docs/Web/CSS/flex-grow\"\n }\n ],\n \"description\": \"Sets the flex grow factor. Negative numbers are invalid.\",\n \"restrictions\": [\n \"number\"\n ]\n },\n {\n \"name\": \"direction\",\n \"values\": [\n {\n \"name\": \"ltr\",\n \"description\": \"Left-to-right direction.\"\n },\n {\n \"name\": \"rtl\",\n \"description\": \"Right-to-left direction.\"\n }\n ],\n \"syntax\": \"ltr | rtl\",\n \"references\": [\n {\n \"name\": \"MDN Reference\",\n \"url\": \"https://developer.mozilla.org/docs/Web/CSS/direction\"\n }\n ],\n \"description\": \"Specifies the inline base direction or directionality of any bidi paragraph, embedding, isolate, or override established by the box. Note: for HTML content use the 'dir' attribute and 'bdo' element rather than this property.\",\n \"restrictions\": [\n \"enum\"\n ]\n },\n {\n \"name\": \"align-self\",\n \"values\": [\n {\n \"name\": \"auto\",\n \"description\": \"Computes to the value of 'align-items' on the element’s parent, or 'stretch' if the element has no parent. On absolutely positioned elements, it computes to itself.\"\n },\n {\n \"name\": \"baseline\",\n \"description\": \"If the flex item’s inline axis is the same as the cross axis, this value is identical to 'flex-start'. Otherwise, it participates in baseline alignment.\"\n },\n {\n \"name\": \"center\",\n \"description\": \"The flex item’s margin box is centered in the cross axis within the line.\"\n },\n {\n \"name\": \"flex-end\",\n \"description\": \"The cross-end margin edge of the flex item is placed flush with the cross-end edge of the line.\"\n },\n {\n \"name\": \"flex-start\",\n \"description\": \"The cross-start margin edge of the flex item is placed flush with the cross-start edge of the line.\"\n },\n {\n \"name\": \"stretch\",\n \"description\": \"If the cross size property of the flex item computes to auto, and neither of the cross-axis margins are auto, the flex item is stretched.\"\n }\n ],\n \"syntax\": \"auto | normal | stretch | | ? \",\n \"description\": \"Allows the default alignment along the cross axis to be overridden for individual flex items.\",\n \"restrictions\": [\n \"enum\"\n ]\n },\n {\n \"name\": \"flex-shrink\",\n \"syntax\": \"\",\n \"references\": [\n {\n \"name\": \"MDN Reference\",\n \"url\": \"https://developer.mozilla.org/docs/Web/CSS/flex-shrink\"\n }\n ],\n \"description\": \"Sets the flex shrink factor. Negative numbers are invalid.\",\n \"restrictions\": [\n \"number\"\n ]\n },\n {\n \"name\": \"text-rendering\",\n \"browsers\": [\n \"FF1\",\n \"S5\",\n \"C4\",\n \"O15\"\n ],\n \"values\": [\n {\n \"name\": \"auto\"\n },\n {\n \"name\": \"geometricPrecision\",\n \"description\": \"Indicates that the user agent shall emphasize geometric precision over legibility and rendering speed.\"\n },\n {\n \"name\": \"optimizeLegibility\",\n \"description\": \"Indicates that the user agent shall emphasize legibility over rendering speed and geometric precision.\"\n },\n {\n \"name\": \"optimizeSpeed\",\n \"description\": \"Indicates that the user agent shall emphasize rendering speed over legibility and geometric precision.\"\n }\n ],\n \"syntax\": \"auto | optimizeSpeed | optimizeLegibility | geometricPrecision\",\n \"references\": [\n {\n \"name\": \"MDN Reference\",\n \"url\": \"https://developer.mozilla.org/docs/Web/CSS/text-rendering\"\n }\n ],\n \"description\": \"The creator of SVG content might want to provide a hint to the implementation about what tradeoffs to make as it renders text. The ‘text-rendering’ property provides these hints.\",\n \"restrictions\": [\n \"enum\"\n ]\n },\n {\n \"name\": \"touch-action\",\n \"values\": [\n {\n \"name\": \"auto\",\n \"description\": \"The user agent may determine any permitted touch behaviors for touches that begin on the element.\"\n },\n {\n \"name\": \"cross-slide-x\"\n },\n {\n \"name\": \"cross-slide-y\"\n },\n {\n \"name\": \"double-tap-zoom\"\n },\n {\n \"name\": \"manipulation\",\n \"description\": \"The user agent may consider touches that begin on the element only for the purposes of scrolling and continuous zooming.\"\n },\n {\n \"name\": \"none\",\n \"description\": \"Touches that begin on the element must not trigger default touch behaviors.\"\n },\n {\n \"name\": \"pan-x\",\n \"description\": \"The user agent may consider touches that begin on the element only for the purposes of horizontally scrolling the element’s nearest ancestor with horizontally scrollable content.\"\n },\n {\n \"name\": \"pan-y\",\n \"description\": \"The user agent may consider touches that begin on the element only for the purposes of vertically scrolling the element’s nearest ancestor with vertically scrollable content.\"\n },\n {\n \"name\": \"pinch-zoom\"\n }\n ],\n \"syntax\": \"auto | none | [ [ pan-x | pan-left | pan-right ] || [ pan-y | pan-up | pan-down ] || pinch-zoom ] | manipulation\",\n \"references\": [\n {\n \"name\": \"MDN Reference\",\n \"url\": \"https://developer.mozilla.org/docs/Web/CSS/touch-action\"\n }\n ],\n \"description\": \"Determines whether touch input may trigger default behavior supplied by user agent.\",\n \"restrictions\": [\n \"enum\"\n ]\n },\n {\n \"name\": \"background-clip\",\n \"syntax\": \"#\",\n \"references\": [\n {\n \"name\": \"MDN Reference\",\n \"url\": \"https://developer.mozilla.org/docs/Web/CSS/background-clip\"\n }\n ],\n \"description\": \"Determines the background painting area.\",\n \"restrictions\": [\n \"box\"\n ]\n },\n {\n \"name\": \"filter\",\n \"browsers\": [\n \"E12\",\n \"FF35\",\n \"S9.1\",\n \"C53\",\n \"O40\"\n ],\n \"values\": [\n {\n \"name\": \"none\",\n \"description\": \"No filter effects are applied.\"\n },\n {\n \"name\": \"blur()\",\n \"description\": \"Applies a Gaussian blur to the input image.\"\n },\n {\n \"name\": \"brightness()\",\n \"description\": \"Applies a linear multiplier to input image, making it appear more or less bright.\"\n },\n {\n \"name\": \"contrast()\",\n \"description\": \"Adjusts the contrast of the input.\"\n },\n {\n \"name\": \"drop-shadow()\",\n \"description\": \"Applies a drop shadow effect to the input image.\"\n },\n {\n \"name\": \"grayscale()\",\n \"description\": \"Converts the input image to grayscale.\"\n },\n {\n \"name\": \"hue-rotate()\",\n \"description\": \"Applies a hue rotation on the input image. \"\n },\n {\n \"name\": \"invert()\",\n \"description\": \"Inverts the samples in the input image.\"\n },\n {\n \"name\": \"opacity()\",\n \"description\": \"Applies transparency to the samples in the input image.\"\n },\n {\n \"name\": \"saturate()\",\n \"description\": \"Saturates the input image.\"\n },\n {\n \"name\": \"sepia()\",\n \"description\": \"Converts the input image to sepia.\"\n },\n {\n \"name\": \"url()\",\n \"browsers\": [\n \"E12\",\n \"FF35\",\n \"S9.1\",\n \"C53\",\n \"O40\"\n ],\n \"description\": \"A filter reference to a element.\"\n }\n ],\n \"syntax\": \"none | \",\n \"references\": [\n {\n \"name\": \"MDN Reference\",\n \"url\": \"https://developer.mozilla.org/docs/Web/CSS/filter\"\n }\n ],\n \"description\": \"Processes an element’s rendering before it is displayed in the document, by applying one or more filter effects.\",\n \"restrictions\": [\n \"enum\",\n \"url\"\n ]\n },\n {\n \"name\": \"src\",\n \"values\": [\n {\n \"name\": \"url()\",\n \"description\": \"Reference font by URL\"\n },\n {\n \"name\": \"format()\",\n \"description\": \"Optional hint describing the format of the font resource.\"\n },\n {\n \"name\": \"local()\",\n \"description\": \"Format-specific string that identifies a locally available copy of a given font.\"\n }\n ],\n \"syntax\": \"[ [ format( # ) ]? | local( ) ]#\",\n \"description\": \"@font-face descriptor. Specifies the resource containing font data. It is required, whether the font is downloadable or locally installed.\",\n \"restrictions\": [\n \"enum\",\n \"url\",\n \"identifier\"\n ]\n },\n {\n \"name\": \"animation-timing-function\",\n \"syntax\": \"#\",\n \"references\": [\n {\n \"name\": \"MDN Reference\",\n \"url\": \"https://developer.mozilla.org/docs/Web/CSS/animation-timing-function\"\n }\n ],\n \"description\": \"Describes how the animation will progress over one cycle of its duration.\",\n \"restrictions\": [\n \"timing-function\"\n ]\n },\n {\n \"name\": \"border-right-color\",\n \"syntax\": \"\",\n \"references\": [\n {\n \"name\": \"MDN Reference\",\n \"url\": \"https://developer.mozilla.org/docs/Web/CSS/border-right-color\"\n }\n ],\n \"description\": \"Sets the color of the right border.\",\n \"restrictions\": [\n \"color\"\n ]\n },\n {\n \"name\": \"font-variant\",\n \"values\": [\n {\n \"name\": \"normal\",\n \"description\": \"Specifies a face that is not labeled as a small-caps font.\"\n },\n {\n \"name\": \"small-caps\",\n \"description\": \"Specifies a font that is labeled as a small-caps font. If a genuine small-caps font is not available, user agents should simulate a small-caps font.\"\n }\n ],\n \"syntax\": \"normal | none | [ || || || || stylistic() || historical-forms || styleset(#) || character-variant(#) || swash() || ornaments() || annotation() || [ small-caps | all-small-caps | petite-caps | all-petite-caps | unicase | titling-caps ] || || || || ordinal || slashed-zero || || || ruby ]\",\n \"references\": [\n {\n \"name\": \"MDN Reference\",\n \"url\": \"https://developer.mozilla.org/docs/Web/CSS/font-variant\"\n }\n ],\n \"description\": \"Specifies variant representations of the font\",\n \"restrictions\": [\n \"enum\"\n ]\n },\n {\n \"name\": \"border-left-color\",\n \"syntax\": \"\",\n \"references\": [\n {\n \"name\": \"MDN Reference\",\n \"url\": \"https://developer.mozilla.org/docs/Web/CSS/border-left-color\"\n }\n ],\n \"description\": \"Sets the color of the left border.\",\n \"restrictions\": [\n \"color\"\n ]\n },\n {\n \"name\": \"animation-name\",\n \"values\": [\n {\n \"name\": \"none\",\n \"description\": \"No animation is performed\"\n }\n ],\n \"syntax\": \"[ none | ]#\",\n \"references\": [\n {\n \"name\": \"MDN Reference\",\n \"url\": \"https://developer.mozilla.org/docs/Web/CSS/animation-name\"\n }\n ],\n \"description\": \"Defines a list of animations that apply. Each name is used to select the keyframe at-rule that provides the property values for the animation.\",\n \"restrictions\": [\n \"identifier\",\n \"enum\"\n ]\n },\n {\n \"name\": \"animation-duration\",\n \"syntax\": \"