diff options
| -rw-r--r-- | extension/react-app/package-lock.json | 402 | ||||
| -rw-r--r-- | extension/react-app/package.json | 3 | ||||
| -rw-r--r-- | extension/react-app/src/components/CodeBlock.tsx | 4 | ||||
| -rw-r--r-- | extension/react-app/src/components/StyledCode.tsx | 14 | 
4 files changed, 418 insertions, 5 deletions
| diff --git a/extension/react-app/package-lock.json b/extension/react-app/package-lock.json index 64440da6..18ef3ee6 100644 --- a/extension/react-app/package-lock.json +++ b/extension/react-app/package-lock.json @@ -12,16 +12,19 @@          "@types/vscode-webview": "^1.57.1",          "downshift": "^7.6.0",          "posthog-js": "^1.58.0", +        "prismjs": "^1.29.0",          "react": "^18.2.0",          "react-dom": "^18.2.0",          "react-markdown": "^8.0.5",          "react-redux": "^8.0.5", +        "react-syntax-highlighter": "^15.5.0",          "styled-components": "^5.3.6",          "vscode-webview": "^1.0.1-beta.1"        },        "devDependencies": {          "@types/react": "^18.0.27",          "@types/react-dom": "^18.0.10", +        "@types/react-syntax-highlighter": "^15.5.7",          "@types/styled-components": "^5.1.26",          "@vitejs/plugin-react-swc": "^3.0.0",          "autoprefixer": "^10.4.13", @@ -951,6 +954,15 @@          "@types/react": "*"        }      }, +    "node_modules/@types/react-syntax-highlighter": { +      "version": "15.5.7", +      "resolved": "https://registry.npmjs.org/@types/react-syntax-highlighter/-/react-syntax-highlighter-15.5.7.tgz", +      "integrity": "sha512-bo5fEO5toQeyCp0zVHBeggclqf5SQ/Z5blfFmjwO5dkMVGPgmiwZsJh9nu/Bo5L7IHTuGWrja6LxJVE2uB5ZrQ==", +      "dev": true, +      "dependencies": { +        "@types/react": "*" +      } +    },      "node_modules/@types/scheduler": {        "version": "0.16.2",        "resolved": "https://registry.npmjs.org/@types/scheduler/-/scheduler-0.16.2.tgz", @@ -1222,6 +1234,24 @@          "url": "https://github.com/sponsors/wooorm"        }      }, +    "node_modules/character-entities-legacy": { +      "version": "1.1.4", +      "resolved": "https://registry.npmjs.org/character-entities-legacy/-/character-entities-legacy-1.1.4.tgz", +      "integrity": "sha512-3Xnr+7ZFS1uxeiUDvV02wQ+QDbc55o97tIV5zHScSPJpcLm/r0DFPcoY3tYRp+VZukxuMeKgXYmsXQHO05zQeA==", +      "funding": { +        "type": "github", +        "url": "https://github.com/sponsors/wooorm" +      } +    }, +    "node_modules/character-reference-invalid": { +      "version": "1.1.4", +      "resolved": "https://registry.npmjs.org/character-reference-invalid/-/character-reference-invalid-1.1.4.tgz", +      "integrity": "sha512-mKKUkUbhPpQlCOfIuZkvSEgktjPFIsZKRRbC6KWVEMvlzblj3i3asQv5ODsrwt0N3pHAEvjP8KTQPHkp0+6jOg==", +      "funding": { +        "type": "github", +        "url": "https://github.com/sponsors/wooorm" +      } +    },      "node_modules/chokidar": {        "version": "3.5.3",        "resolved": "https://registry.npmjs.org/chokidar/-/chokidar-3.5.3.tgz", @@ -1533,6 +1563,18 @@          "reusify": "^1.0.4"        }      }, +    "node_modules/fault": { +      "version": "1.0.4", +      "resolved": "https://registry.npmjs.org/fault/-/fault-1.0.4.tgz", +      "integrity": "sha512-CJ0HCB5tL5fYTEA7ToAq5+kTwd++Borf1/bifxd9iT70QcXr4MRrO3Llf8Ifs70q+SJcGHFtnIE/Nw6giCtECA==", +      "dependencies": { +        "format": "^0.2.0" +      }, +      "funding": { +        "type": "github", +        "url": "https://github.com/sponsors/wooorm" +      } +    },      "node_modules/fflate": {        "version": "0.4.8",        "resolved": "https://registry.npmjs.org/fflate/-/fflate-0.4.8.tgz", @@ -1550,6 +1592,14 @@          "node": ">=8"        }      }, +    "node_modules/format": { +      "version": "0.2.2", +      "resolved": "https://registry.npmjs.org/format/-/format-0.2.2.tgz", +      "integrity": "sha512-wzsgA6WOq+09wrU1tsJ09udeR/YZRaeArL9e1wPbFg3GG2yDnC2ldKpxs4xunpFF9DgqCqOIra3bc1HWrJ37Ww==", +      "engines": { +        "node": ">=0.4.x" +      } +    },      "node_modules/fraction.js": {        "version": "4.2.0",        "resolved": "https://registry.npmjs.org/fraction.js/-/fraction.js-4.2.0.tgz", @@ -1641,6 +1691,15 @@          "node": ">=4"        }      }, +    "node_modules/hast-util-parse-selector": { +      "version": "2.2.5", +      "resolved": "https://registry.npmjs.org/hast-util-parse-selector/-/hast-util-parse-selector-2.2.5.tgz", +      "integrity": "sha512-7j6mrk/qqkSehsM92wQjdIgWM2/BW61u/53G6xmC8i1OmEdKLHbk419QKQUjz6LglWsfqoiHmyMRkP1BGjecNQ==", +      "funding": { +        "type": "opencollective", +        "url": "https://opencollective.com/unified" +      } +    },      "node_modules/hast-util-whitespace": {        "version": "2.0.1",        "resolved": "https://registry.npmjs.org/hast-util-whitespace/-/hast-util-whitespace-2.0.1.tgz", @@ -1650,6 +1709,60 @@          "url": "https://opencollective.com/unified"        }      }, +    "node_modules/hastscript": { +      "version": "6.0.0", +      "resolved": "https://registry.npmjs.org/hastscript/-/hastscript-6.0.0.tgz", +      "integrity": "sha512-nDM6bvd7lIqDUiYEiu5Sl/+6ReP0BMk/2f4U/Rooccxkj0P5nm+acM5PrGJ/t5I8qPGiqZSE6hVAwZEdZIvP4w==", +      "dependencies": { +        "@types/hast": "^2.0.0", +        "comma-separated-tokens": "^1.0.0", +        "hast-util-parse-selector": "^2.0.0", +        "property-information": "^5.0.0", +        "space-separated-tokens": "^1.0.0" +      }, +      "funding": { +        "type": "opencollective", +        "url": "https://opencollective.com/unified" +      } +    }, +    "node_modules/hastscript/node_modules/comma-separated-tokens": { +      "version": "1.0.8", +      "resolved": "https://registry.npmjs.org/comma-separated-tokens/-/comma-separated-tokens-1.0.8.tgz", +      "integrity": "sha512-GHuDRO12Sypu2cV70d1dkA2EUmXHgntrzbpvOB+Qy+49ypNfGgFQIC2fhhXbnyrJRynDCAARsT7Ou0M6hirpfw==", +      "funding": { +        "type": "github", +        "url": "https://github.com/sponsors/wooorm" +      } +    }, +    "node_modules/hastscript/node_modules/property-information": { +      "version": "5.6.0", +      "resolved": "https://registry.npmjs.org/property-information/-/property-information-5.6.0.tgz", +      "integrity": "sha512-YUHSPk+A30YPv+0Qf8i9Mbfe/C0hdPXk1s1jPVToV8pk8BQtpw10ct89Eo7OWkutrwqvT0eicAxlOg3dOAu8JA==", +      "dependencies": { +        "xtend": "^4.0.0" +      }, +      "funding": { +        "type": "github", +        "url": "https://github.com/sponsors/wooorm" +      } +    }, +    "node_modules/hastscript/node_modules/space-separated-tokens": { +      "version": "1.1.5", +      "resolved": "https://registry.npmjs.org/space-separated-tokens/-/space-separated-tokens-1.1.5.tgz", +      "integrity": "sha512-q/JSVd1Lptzhf5bkYm4ob4iWPjx0KiRe3sRFBNrVqbJkFaBm5vbbowy1mymoPNLRa52+oadOhJ+K49wsSeSjTA==", +      "funding": { +        "type": "github", +        "url": "https://github.com/sponsors/wooorm" +      } +    }, +    "node_modules/highlight.js": { +      "version": "10.7.3", +      "resolved": "https://registry.npmjs.org/highlight.js/-/highlight.js-10.7.3.tgz", +      "integrity": "sha512-tzcUFauisWKNHaRkN4Wjl/ZA07gENAjFl3J/c480dprkGTg5EQstgaNFqBfUqCq54kZRIEcreTsAgF/m2quD7A==", +      "engines": { +        "node": "*" +      } +    },      "node_modules/hoist-non-react-statics": {        "version": "3.3.2",        "resolved": "https://registry.npmjs.org/hoist-non-react-statics/-/hoist-non-react-statics-3.3.2.tgz", @@ -1668,6 +1781,28 @@        "resolved": "https://registry.npmjs.org/inline-style-parser/-/inline-style-parser-0.1.1.tgz",        "integrity": "sha512-7NXolsK4CAS5+xvdj5OMMbI962hU/wvwoxk+LWR9Ek9bVtyuuYScDN6eS0rUm6TxApFpw7CX1o4uJzcd4AyD3Q=="      }, +    "node_modules/is-alphabetical": { +      "version": "1.0.4", +      "resolved": "https://registry.npmjs.org/is-alphabetical/-/is-alphabetical-1.0.4.tgz", +      "integrity": "sha512-DwzsA04LQ10FHTZuL0/grVDk4rFoVH1pjAToYwBrHSxcrBIGQuXrQMtD5U1b0U2XVgKZCTLLP8u2Qxqhy3l2Vg==", +      "funding": { +        "type": "github", +        "url": "https://github.com/sponsors/wooorm" +      } +    }, +    "node_modules/is-alphanumerical": { +      "version": "1.0.4", +      "resolved": "https://registry.npmjs.org/is-alphanumerical/-/is-alphanumerical-1.0.4.tgz", +      "integrity": "sha512-UzoZUr+XfVz3t3v4KyGEniVL9BDRoQtY7tOyrRybkVNjDFWyo1yhXNGrrBTQxp3ib9BLAWs7k2YKBQsFRkZG9A==", +      "dependencies": { +        "is-alphabetical": "^1.0.0", +        "is-decimal": "^1.0.0" +      }, +      "funding": { +        "type": "github", +        "url": "https://github.com/sponsors/wooorm" +      } +    },      "node_modules/is-binary-path": {        "version": "2.1.0",        "resolved": "https://registry.npmjs.org/is-binary-path/-/is-binary-path-2.1.0.tgz", @@ -1714,6 +1849,15 @@          "url": "https://github.com/sponsors/ljharb"        }      }, +    "node_modules/is-decimal": { +      "version": "1.0.4", +      "resolved": "https://registry.npmjs.org/is-decimal/-/is-decimal-1.0.4.tgz", +      "integrity": "sha512-RGdriMmQQvZ2aqaQq3awNA6dCGtKpiDFcOzrTWrDAT2MiWrKQVPmxLGHl7Y2nNu6led0kEyoX0enY0qXYsv9zw==", +      "funding": { +        "type": "github", +        "url": "https://github.com/sponsors/wooorm" +      } +    },      "node_modules/is-extglob": {        "version": "2.1.1",        "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz", @@ -1735,6 +1879,15 @@          "node": ">=0.10.0"        }      }, +    "node_modules/is-hexadecimal": { +      "version": "1.0.4", +      "resolved": "https://registry.npmjs.org/is-hexadecimal/-/is-hexadecimal-1.0.4.tgz", +      "integrity": "sha512-gyPJuv83bHMpocVYoqof5VDiZveEoGoFL8m3BXNb2VW8Xs+rz9kqO8LOQ5DH6EsuvilT1ApazU0pyl+ytbPtlw==", +      "funding": { +        "type": "github", +        "url": "https://github.com/sponsors/wooorm" +      } +    },      "node_modules/is-number": {        "version": "7.0.0",        "resolved": "https://registry.npmjs.org/is-number/-/is-number-7.0.0.tgz", @@ -1815,6 +1968,19 @@          "loose-envify": "cli.js"        }      }, +    "node_modules/lowlight": { +      "version": "1.20.0", +      "resolved": "https://registry.npmjs.org/lowlight/-/lowlight-1.20.0.tgz", +      "integrity": "sha512-8Ktj+prEb1RoCPkEOrPMYUN/nCggB7qAWe3a7OpMjWQkh3l2RD5wKRQ+o8Q8YuI9RG/xs95waaI/E6ym/7NsTw==", +      "dependencies": { +        "fault": "^1.0.0", +        "highlight.js": "~10.7.0" +      }, +      "funding": { +        "type": "github", +        "url": "https://github.com/sponsors/wooorm" +      } +    },      "node_modules/mdast-util-definitions": {        "version": "5.1.2",        "resolved": "https://registry.npmjs.org/mdast-util-definitions/-/mdast-util-definitions-5.1.2.tgz", @@ -2402,6 +2568,32 @@          "node": ">= 6"        }      }, +    "node_modules/parse-entities": { +      "version": "2.0.0", +      "resolved": "https://registry.npmjs.org/parse-entities/-/parse-entities-2.0.0.tgz", +      "integrity": "sha512-kkywGpCcRYhqQIchaWqZ875wzpS/bMKhz5HnN3p7wveJTkTtyAB/AlnS0f8DFSqYW1T82t6yEAkEcB+A1I3MbQ==", +      "dependencies": { +        "character-entities": "^1.0.0", +        "character-entities-legacy": "^1.0.0", +        "character-reference-invalid": "^1.0.0", +        "is-alphanumerical": "^1.0.0", +        "is-decimal": "^1.0.0", +        "is-hexadecimal": "^1.0.0" +      }, +      "funding": { +        "type": "github", +        "url": "https://github.com/sponsors/wooorm" +      } +    }, +    "node_modules/parse-entities/node_modules/character-entities": { +      "version": "1.2.4", +      "resolved": "https://registry.npmjs.org/character-entities/-/character-entities-1.2.4.tgz", +      "integrity": "sha512-iBMyeEHxfVnIakwOuDXpVkc54HijNgCyQB2w0VfGQThle6NXn50zU6V/u+LDhxHcDUPojn6Kpga3PTAD8W1bQw==", +      "funding": { +        "type": "github", +        "url": "https://github.com/sponsors/wooorm" +      } +    },      "node_modules/path-parse": {        "version": "1.0.7",        "resolved": "https://registry.npmjs.org/path-parse/-/path-parse-1.0.7.tgz", @@ -2569,6 +2761,14 @@          "rrweb-snapshot": "^1.1.14"        }      }, +    "node_modules/prismjs": { +      "version": "1.29.0", +      "resolved": "https://registry.npmjs.org/prismjs/-/prismjs-1.29.0.tgz", +      "integrity": "sha512-Kx/1w86q/epKcmte75LNrEoT+lX8pBpavuAbvJWRXar7Hz8jrtF+e3vY751p0R8H9HdArwaCTNDDzHg/ScJK1Q==", +      "engines": { +        "node": ">=6" +      } +    },      "node_modules/prop-types": {        "version": "15.8.1",        "resolved": "https://registry.npmjs.org/prop-types/-/prop-types-15.8.1.tgz", @@ -2721,6 +2921,21 @@          }        }      }, +    "node_modules/react-syntax-highlighter": { +      "version": "15.5.0", +      "resolved": "https://registry.npmjs.org/react-syntax-highlighter/-/react-syntax-highlighter-15.5.0.tgz", +      "integrity": "sha512-+zq2myprEnQmH5yw6Gqc8lD55QHnpKaU8TOcFeC/Lg/MQSs8UknEA0JC4nTZGFAXC2J2Hyj/ijJ7NlabyPi2gg==", +      "dependencies": { +        "@babel/runtime": "^7.3.1", +        "highlight.js": "^10.4.1", +        "lowlight": "^1.17.0", +        "prismjs": "^1.27.0", +        "refractor": "^3.6.0" +      }, +      "peerDependencies": { +        "react": ">= 0.14.0" +      } +    },      "node_modules/read-cache": {        "version": "1.0.0",        "resolved": "https://registry.npmjs.org/read-cache/-/read-cache-1.0.0.tgz", @@ -2742,6 +2957,28 @@          "node": ">=8.10.0"        }      }, +    "node_modules/refractor": { +      "version": "3.6.0", +      "resolved": "https://registry.npmjs.org/refractor/-/refractor-3.6.0.tgz", +      "integrity": "sha512-MY9W41IOWxxk31o+YvFCNyNzdkc9M20NoZK5vq6jkv4I/uh2zkWcfudj0Q1fovjUQJrNewS9NMzeTtqPf+n5EA==", +      "dependencies": { +        "hastscript": "^6.0.0", +        "parse-entities": "^2.0.0", +        "prismjs": "~1.27.0" +      }, +      "funding": { +        "type": "github", +        "url": "https://github.com/sponsors/wooorm" +      } +    }, +    "node_modules/refractor/node_modules/prismjs": { +      "version": "1.27.0", +      "resolved": "https://registry.npmjs.org/prismjs/-/prismjs-1.27.0.tgz", +      "integrity": "sha512-t13BGPUlFDR7wRB5kQDG4jjl7XeuH6jbJGt11JHPL96qwsEHNX2+68tFXqc1/k+/jALsbSWJKUOT/hcYAZ5LkA==", +      "engines": { +        "node": ">=6" +      } +    },      "node_modules/regenerator-runtime": {        "version": "0.13.11",        "resolved": "https://registry.npmjs.org/regenerator-runtime/-/regenerator-runtime-0.13.11.tgz", @@ -3291,7 +3528,6 @@        "version": "4.0.2",        "resolved": "https://registry.npmjs.org/xtend/-/xtend-4.0.2.tgz",        "integrity": "sha512-LKYU1iAXJXUgAXn9URjiu+MWhyUXHsvfp7mcuYm9dSUKK0/CjtrUwFAxD82/mCWbtLsGjFIad0wIsod4zrTAEQ==", -      "dev": true,        "engines": {          "node": ">=0.4"        } @@ -3846,6 +4082,15 @@          "@types/react": "*"        }      }, +    "@types/react-syntax-highlighter": { +      "version": "15.5.7", +      "resolved": "https://registry.npmjs.org/@types/react-syntax-highlighter/-/react-syntax-highlighter-15.5.7.tgz", +      "integrity": "sha512-bo5fEO5toQeyCp0zVHBeggclqf5SQ/Z5blfFmjwO5dkMVGPgmiwZsJh9nu/Bo5L7IHTuGWrja6LxJVE2uB5ZrQ==", +      "dev": true, +      "requires": { +        "@types/react": "*" +      } +    },      "@types/scheduler": {        "version": "0.16.2",        "resolved": "https://registry.npmjs.org/@types/scheduler/-/scheduler-0.16.2.tgz", @@ -4028,6 +4273,16 @@        "resolved": "https://registry.npmjs.org/character-entities/-/character-entities-2.0.2.tgz",        "integrity": "sha512-shx7oQ0Awen/BRIdkjkvz54PnEEI/EjwXDSIZp86/KKdbafHh1Df/RYGBhn4hbe2+uKC9FnT5UCEdyPz3ai9hQ=="      }, +    "character-entities-legacy": { +      "version": "1.1.4", +      "resolved": "https://registry.npmjs.org/character-entities-legacy/-/character-entities-legacy-1.1.4.tgz", +      "integrity": "sha512-3Xnr+7ZFS1uxeiUDvV02wQ+QDbc55o97tIV5zHScSPJpcLm/r0DFPcoY3tYRp+VZukxuMeKgXYmsXQHO05zQeA==" +    }, +    "character-reference-invalid": { +      "version": "1.1.4", +      "resolved": "https://registry.npmjs.org/character-reference-invalid/-/character-reference-invalid-1.1.4.tgz", +      "integrity": "sha512-mKKUkUbhPpQlCOfIuZkvSEgktjPFIsZKRRbC6KWVEMvlzblj3i3asQv5ODsrwt0N3pHAEvjP8KTQPHkp0+6jOg==" +    },      "chokidar": {        "version": "3.5.3",        "resolved": "https://registry.npmjs.org/chokidar/-/chokidar-3.5.3.tgz", @@ -4271,6 +4526,14 @@          "reusify": "^1.0.4"        }      }, +    "fault": { +      "version": "1.0.4", +      "resolved": "https://registry.npmjs.org/fault/-/fault-1.0.4.tgz", +      "integrity": "sha512-CJ0HCB5tL5fYTEA7ToAq5+kTwd++Borf1/bifxd9iT70QcXr4MRrO3Llf8Ifs70q+SJcGHFtnIE/Nw6giCtECA==", +      "requires": { +        "format": "^0.2.0" +      } +    },      "fflate": {        "version": "0.4.8",        "resolved": "https://registry.npmjs.org/fflate/-/fflate-0.4.8.tgz", @@ -4285,6 +4548,11 @@          "to-regex-range": "^5.0.1"        }      }, +    "format": { +      "version": "0.2.2", +      "resolved": "https://registry.npmjs.org/format/-/format-0.2.2.tgz", +      "integrity": "sha512-wzsgA6WOq+09wrU1tsJ09udeR/YZRaeArL9e1wPbFg3GG2yDnC2ldKpxs4xunpFF9DgqCqOIra3bc1HWrJ37Ww==" +    },      "fraction.js": {        "version": "4.2.0",        "resolved": "https://registry.npmjs.org/fraction.js/-/fraction.js-4.2.0.tgz", @@ -4347,11 +4615,53 @@        "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz",        "integrity": "sha512-sKJf1+ceQBr4SMkvQnBDNDtf4TXpVhVGateu0t918bl30FnbE2m4vNLX+VWe/dpjlb+HugGYzW7uQXH98HPEYw=="      }, +    "hast-util-parse-selector": { +      "version": "2.2.5", +      "resolved": "https://registry.npmjs.org/hast-util-parse-selector/-/hast-util-parse-selector-2.2.5.tgz", +      "integrity": "sha512-7j6mrk/qqkSehsM92wQjdIgWM2/BW61u/53G6xmC8i1OmEdKLHbk419QKQUjz6LglWsfqoiHmyMRkP1BGjecNQ==" +    },      "hast-util-whitespace": {        "version": "2.0.1",        "resolved": "https://registry.npmjs.org/hast-util-whitespace/-/hast-util-whitespace-2.0.1.tgz",        "integrity": "sha512-nAxA0v8+vXSBDt3AnRUNjyRIQ0rD+ntpbAp4LnPkumc5M9yUbSMa4XDU9Q6etY4f1Wp4bNgvc1yjiZtsTTrSng=="      }, +    "hastscript": { +      "version": "6.0.0", +      "resolved": "https://registry.npmjs.org/hastscript/-/hastscript-6.0.0.tgz", +      "integrity": "sha512-nDM6bvd7lIqDUiYEiu5Sl/+6ReP0BMk/2f4U/Rooccxkj0P5nm+acM5PrGJ/t5I8qPGiqZSE6hVAwZEdZIvP4w==", +      "requires": { +        "@types/hast": "^2.0.0", +        "comma-separated-tokens": "^1.0.0", +        "hast-util-parse-selector": "^2.0.0", +        "property-information": "^5.0.0", +        "space-separated-tokens": "^1.0.0" +      }, +      "dependencies": { +        "comma-separated-tokens": { +          "version": "1.0.8", +          "resolved": "https://registry.npmjs.org/comma-separated-tokens/-/comma-separated-tokens-1.0.8.tgz", +          "integrity": "sha512-GHuDRO12Sypu2cV70d1dkA2EUmXHgntrzbpvOB+Qy+49ypNfGgFQIC2fhhXbnyrJRynDCAARsT7Ou0M6hirpfw==" +        }, +        "property-information": { +          "version": "5.6.0", +          "resolved": "https://registry.npmjs.org/property-information/-/property-information-5.6.0.tgz", +          "integrity": "sha512-YUHSPk+A30YPv+0Qf8i9Mbfe/C0hdPXk1s1jPVToV8pk8BQtpw10ct89Eo7OWkutrwqvT0eicAxlOg3dOAu8JA==", +          "requires": { +            "xtend": "^4.0.0" +          } +        }, +        "space-separated-tokens": { +          "version": "1.1.5", +          "resolved": "https://registry.npmjs.org/space-separated-tokens/-/space-separated-tokens-1.1.5.tgz", +          "integrity": "sha512-q/JSVd1Lptzhf5bkYm4ob4iWPjx0KiRe3sRFBNrVqbJkFaBm5vbbowy1mymoPNLRa52+oadOhJ+K49wsSeSjTA==" +        } +      } +    }, +    "highlight.js": { +      "version": "10.7.3", +      "resolved": "https://registry.npmjs.org/highlight.js/-/highlight.js-10.7.3.tgz", +      "integrity": "sha512-tzcUFauisWKNHaRkN4Wjl/ZA07gENAjFl3J/c480dprkGTg5EQstgaNFqBfUqCq54kZRIEcreTsAgF/m2quD7A==" +    },      "hoist-non-react-statics": {        "version": "3.3.2",        "resolved": "https://registry.npmjs.org/hoist-non-react-statics/-/hoist-non-react-statics-3.3.2.tgz", @@ -4372,6 +4682,20 @@        "resolved": "https://registry.npmjs.org/inline-style-parser/-/inline-style-parser-0.1.1.tgz",        "integrity": "sha512-7NXolsK4CAS5+xvdj5OMMbI962hU/wvwoxk+LWR9Ek9bVtyuuYScDN6eS0rUm6TxApFpw7CX1o4uJzcd4AyD3Q=="      }, +    "is-alphabetical": { +      "version": "1.0.4", +      "resolved": "https://registry.npmjs.org/is-alphabetical/-/is-alphabetical-1.0.4.tgz", +      "integrity": "sha512-DwzsA04LQ10FHTZuL0/grVDk4rFoVH1pjAToYwBrHSxcrBIGQuXrQMtD5U1b0U2XVgKZCTLLP8u2Qxqhy3l2Vg==" +    }, +    "is-alphanumerical": { +      "version": "1.0.4", +      "resolved": "https://registry.npmjs.org/is-alphanumerical/-/is-alphanumerical-1.0.4.tgz", +      "integrity": "sha512-UzoZUr+XfVz3t3v4KyGEniVL9BDRoQtY7tOyrRybkVNjDFWyo1yhXNGrrBTQxp3ib9BLAWs7k2YKBQsFRkZG9A==", +      "requires": { +        "is-alphabetical": "^1.0.0", +        "is-decimal": "^1.0.0" +      } +    },      "is-binary-path": {        "version": "2.1.0",        "resolved": "https://registry.npmjs.org/is-binary-path/-/is-binary-path-2.1.0.tgz", @@ -4395,6 +4719,11 @@          "has": "^1.0.3"        }      }, +    "is-decimal": { +      "version": "1.0.4", +      "resolved": "https://registry.npmjs.org/is-decimal/-/is-decimal-1.0.4.tgz", +      "integrity": "sha512-RGdriMmQQvZ2aqaQq3awNA6dCGtKpiDFcOzrTWrDAT2MiWrKQVPmxLGHl7Y2nNu6led0kEyoX0enY0qXYsv9zw==" +    },      "is-extglob": {        "version": "2.1.1",        "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz", @@ -4410,6 +4739,11 @@          "is-extglob": "^2.1.1"        }      }, +    "is-hexadecimal": { +      "version": "1.0.4", +      "resolved": "https://registry.npmjs.org/is-hexadecimal/-/is-hexadecimal-1.0.4.tgz", +      "integrity": "sha512-gyPJuv83bHMpocVYoqof5VDiZveEoGoFL8m3BXNb2VW8Xs+rz9kqO8LOQ5DH6EsuvilT1ApazU0pyl+ytbPtlw==" +    },      "is-number": {        "version": "7.0.0",        "resolved": "https://registry.npmjs.org/is-number/-/is-number-7.0.0.tgz", @@ -4464,6 +4798,15 @@          "js-tokens": "^3.0.0 || ^4.0.0"        }      }, +    "lowlight": { +      "version": "1.20.0", +      "resolved": "https://registry.npmjs.org/lowlight/-/lowlight-1.20.0.tgz", +      "integrity": "sha512-8Ktj+prEb1RoCPkEOrPMYUN/nCggB7qAWe3a7OpMjWQkh3l2RD5wKRQ+o8Q8YuI9RG/xs95waaI/E6ym/7NsTw==", +      "requires": { +        "fault": "^1.0.0", +        "highlight.js": "~10.7.0" +      } +    },      "mdast-util-definitions": {        "version": "5.1.2",        "resolved": "https://registry.npmjs.org/mdast-util-definitions/-/mdast-util-definitions-5.1.2.tgz", @@ -4795,6 +5138,26 @@        "integrity": "sha512-RSn9F68PjH9HqtltsSnqYC1XXoWe9Bju5+213R98cNGttag9q9yAOTzdbsqvIa7aNm5WffBZFpWYr2aWrklWAw==",        "dev": true      }, +    "parse-entities": { +      "version": "2.0.0", +      "resolved": "https://registry.npmjs.org/parse-entities/-/parse-entities-2.0.0.tgz", +      "integrity": "sha512-kkywGpCcRYhqQIchaWqZ875wzpS/bMKhz5HnN3p7wveJTkTtyAB/AlnS0f8DFSqYW1T82t6yEAkEcB+A1I3MbQ==", +      "requires": { +        "character-entities": "^1.0.0", +        "character-entities-legacy": "^1.0.0", +        "character-reference-invalid": "^1.0.0", +        "is-alphanumerical": "^1.0.0", +        "is-decimal": "^1.0.0", +        "is-hexadecimal": "^1.0.0" +      }, +      "dependencies": { +        "character-entities": { +          "version": "1.2.4", +          "resolved": "https://registry.npmjs.org/character-entities/-/character-entities-1.2.4.tgz", +          "integrity": "sha512-iBMyeEHxfVnIakwOuDXpVkc54HijNgCyQB2w0VfGQThle6NXn50zU6V/u+LDhxHcDUPojn6Kpga3PTAD8W1bQw==" +        } +      } +    },      "path-parse": {        "version": "1.0.7",        "resolved": "https://registry.npmjs.org/path-parse/-/path-parse-1.0.7.tgz", @@ -4892,6 +5255,11 @@          "rrweb-snapshot": "^1.1.14"        }      }, +    "prismjs": { +      "version": "1.29.0", +      "resolved": "https://registry.npmjs.org/prismjs/-/prismjs-1.29.0.tgz", +      "integrity": "sha512-Kx/1w86q/epKcmte75LNrEoT+lX8pBpavuAbvJWRXar7Hz8jrtF+e3vY751p0R8H9HdArwaCTNDDzHg/ScJK1Q==" +    },      "prop-types": {        "version": "15.8.1",        "resolved": "https://registry.npmjs.org/prop-types/-/prop-types-15.8.1.tgz", @@ -4983,6 +5351,18 @@          "use-sync-external-store": "^1.0.0"        }      }, +    "react-syntax-highlighter": { +      "version": "15.5.0", +      "resolved": "https://registry.npmjs.org/react-syntax-highlighter/-/react-syntax-highlighter-15.5.0.tgz", +      "integrity": "sha512-+zq2myprEnQmH5yw6Gqc8lD55QHnpKaU8TOcFeC/Lg/MQSs8UknEA0JC4nTZGFAXC2J2Hyj/ijJ7NlabyPi2gg==", +      "requires": { +        "@babel/runtime": "^7.3.1", +        "highlight.js": "^10.4.1", +        "lowlight": "^1.17.0", +        "prismjs": "^1.27.0", +        "refractor": "^3.6.0" +      } +    },      "read-cache": {        "version": "1.0.0",        "resolved": "https://registry.npmjs.org/read-cache/-/read-cache-1.0.0.tgz", @@ -5001,6 +5381,23 @@          "picomatch": "^2.2.1"        }      }, +    "refractor": { +      "version": "3.6.0", +      "resolved": "https://registry.npmjs.org/refractor/-/refractor-3.6.0.tgz", +      "integrity": "sha512-MY9W41IOWxxk31o+YvFCNyNzdkc9M20NoZK5vq6jkv4I/uh2zkWcfudj0Q1fovjUQJrNewS9NMzeTtqPf+n5EA==", +      "requires": { +        "hastscript": "^6.0.0", +        "parse-entities": "^2.0.0", +        "prismjs": "~1.27.0" +      }, +      "dependencies": { +        "prismjs": { +          "version": "1.27.0", +          "resolved": "https://registry.npmjs.org/prismjs/-/prismjs-1.27.0.tgz", +          "integrity": "sha512-t13BGPUlFDR7wRB5kQDG4jjl7XeuH6jbJGt11JHPL96qwsEHNX2+68tFXqc1/k+/jALsbSWJKUOT/hcYAZ5LkA==" +        } +      } +    },      "regenerator-runtime": {        "version": "0.13.11",        "resolved": "https://registry.npmjs.org/regenerator-runtime/-/regenerator-runtime-0.13.11.tgz", @@ -5348,8 +5745,7 @@      "xtend": {        "version": "4.0.2",        "resolved": "https://registry.npmjs.org/xtend/-/xtend-4.0.2.tgz", -      "integrity": "sha512-LKYU1iAXJXUgAXn9URjiu+MWhyUXHsvfp7mcuYm9dSUKK0/CjtrUwFAxD82/mCWbtLsGjFIad0wIsod4zrTAEQ==", -      "dev": true +      "integrity": "sha512-LKYU1iAXJXUgAXn9URjiu+MWhyUXHsvfp7mcuYm9dSUKK0/CjtrUwFAxD82/mCWbtLsGjFIad0wIsod4zrTAEQ=="      },      "yaml": {        "version": "1.10.2", diff --git a/extension/react-app/package.json b/extension/react-app/package.json index a53fbec8..d43ec55e 100644 --- a/extension/react-app/package.json +++ b/extension/react-app/package.json @@ -13,16 +13,19 @@      "@types/vscode-webview": "^1.57.1",      "downshift": "^7.6.0",      "posthog-js": "^1.58.0", +    "prismjs": "^1.29.0",      "react": "^18.2.0",      "react-dom": "^18.2.0",      "react-markdown": "^8.0.5",      "react-redux": "^8.0.5", +    "react-syntax-highlighter": "^15.5.0",      "styled-components": "^5.3.6",      "vscode-webview": "^1.0.1-beta.1"    },    "devDependencies": {      "@types/react": "^18.0.27",      "@types/react-dom": "^18.0.10", +    "@types/react-syntax-highlighter": "^15.5.7",      "@types/styled-components": "^5.1.26",      "@vitejs/plugin-react-swc": "^3.0.0",      "autoprefixer": "^10.4.13", diff --git a/extension/react-app/src/components/CodeBlock.tsx b/extension/react-app/src/components/CodeBlock.tsx index c4524a51..a720a6ce 100644 --- a/extension/react-app/src/components/CodeBlock.tsx +++ b/extension/react-app/src/components/CodeBlock.tsx @@ -5,6 +5,8 @@ import { defaultBorderRadius, secondaryDark, vscBackground } from ".";  import { Clipboard, CheckCircle } from "@styled-icons/heroicons-outline"; +import StyledCode from "./StyledCode"; +  const StyledPre = styled.pre`    overflow-y: scroll;    word-wrap: normal; @@ -16,8 +18,6 @@ const StyledPre = styled.pre`    padding-bottom: 16px;  `; -const StyledCode = styled.code``; -  const StyledCopyButton = styled.button<{ visible: boolean }>`    /* position: relative; */    float: right; diff --git a/extension/react-app/src/components/StyledCode.tsx b/extension/react-app/src/components/StyledCode.tsx new file mode 100644 index 00000000..16183e7f --- /dev/null +++ b/extension/react-app/src/components/StyledCode.tsx @@ -0,0 +1,14 @@ +import { Prism as SyntaxHighlighter } from "react-syntax-highlighter"; +import { synthwave84 } from "react-syntax-highlighter/dist/esm/styles/prism"; + +interface StyledCodeProps { +    children: string; +} + +const StyledCode = (props: (StyledCodeProps)) => ( +  <SyntaxHighlighter language="auto" style={synthwave84}> +    {props.children} +  </SyntaxHighlighter> +); + +export default StyledCode;
\ No newline at end of file | 
