├── .github ├── dependabot.yml └── workflows │ └── build.yml ├── .gitignore ├── .npmignore ├── .prettierrc ├── LICENSE ├── README.md ├── example ├── .DS_Store ├── index.html ├── package.json ├── scripts │ └── demo.js ├── src │ ├── App.module.css │ ├── App.tsx │ ├── Demo.tsx │ ├── index.tsx │ ├── prism-themes │ │ ├── a11y-dark.css │ │ ├── atom-dark.css │ │ ├── base16-ateliersulphurpool.light.css │ │ ├── cb.css │ │ ├── coldark-cold.css │ │ ├── coldark-dark.css │ │ ├── coy-without-shadows.css │ │ ├── darcula.css │ │ ├── dracula.css │ │ ├── duotone-dark.css │ │ ├── duotone-earth.css │ │ ├── duotone-forest.css │ │ ├── duotone-light.css │ │ ├── duotone-sea.css │ │ ├── duotone-space.css │ │ ├── ghcolors.css │ │ ├── gruvbox-dark.css │ │ ├── gruvbox-light.css │ │ ├── holi-theme.css │ │ ├── hopscotch.css │ │ ├── laserwave.css │ │ ├── lucario.css │ │ ├── material-dark.css │ │ ├── material-light.css │ │ ├── material-oceanic.css │ │ ├── night-owl.css │ │ ├── nord.css │ │ ├── one-dark.css │ │ ├── one-light.css │ │ ├── pojoaque.css │ │ ├── prism-one-dark.css │ │ ├── prism-shades-of-purple.css │ │ ├── shades-of-purple.css │ │ ├── solarized-dark-atom.css │ │ ├── synthwave84.css │ │ ├── vs.css │ │ ├── vsc-dark-plus.css │ │ ├── xonokai.css │ │ └── z-touch.css │ ├── styles.css │ ├── themes │ │ ├── nord-highlight.css │ │ └── nord-prism.css │ └── utils.ts ├── tsconfig.json ├── tsconfig.node.json ├── vite.config.ts └── yarn.lock ├── package.json ├── resources ├── demo.gif ├── demo.mkv └── example.png ├── rollup.config.js ├── scripts └── copy.js ├── src ├── components │ └── CodeInput │ │ ├── CodeInput.tsx │ │ └── styles.module.css ├── index.tsx ├── types.ts └── utils.ts ├── tsconfig.json ├── tsconfig.node.json └── yarn.lock /.github/dependabot.yml: -------------------------------------------------------------------------------- 1 | # To get started with Dependabot version updates, you'll need to specify which 2 | # package ecosystems to update and where the package manifests are located. 3 | # Please see the documentation for all configuration options: 4 | # https://docs.github.com/github/administering-a-repository/configuration-options-for-dependency-updates 5 | 6 | version: 2 7 | updates: 8 | - package-ecosystem: "npm" # See documentation for possible values 9 | directory: "/" # Location of package manifests 10 | schedule: 11 | interval: "weekly" 12 | -------------------------------------------------------------------------------- /.github/workflows/build.yml: -------------------------------------------------------------------------------- 1 | name: build 2 | on: 3 | push: 4 | branches: 5 | - main 6 | jobs: 7 | build: 8 | name: build 9 | runs-on: ubuntu-latest 10 | 11 | steps: 12 | # TODO: Publish to Node Package Manager 13 | - name: Checkout Repo 14 | uses: actions/checkout@main 15 | 16 | - name: Use Node ${{ matrix.node }} 17 | uses: actions/setup-node@v1 18 | with: 19 | node-version: ${{ matrix.node }} 20 | 21 | - name: Install deps and build (with cache) 22 | uses: bahmutov/npm-install@v1 23 | 24 | - name: Build 25 | run: yarn build 26 | -------------------------------------------------------------------------------- /.gitignore: -------------------------------------------------------------------------------- 1 | .DS_Store 2 | # Logs 3 | logs 4 | *.log 5 | npm-debug.log* 6 | yarn-debug.log* 7 | yarn-error.log* 8 | lerna-debug.log* 9 | 10 | # Diagnostic reports (https://nodejs.org/api/report.html) 11 | report.[0-9]*.[0-9]*.[0-9]*.[0-9]*.json 12 | 13 | # Runtime data 14 | pids 15 | *.pid 16 | *.seed 17 | *.pid.lock 18 | 19 | # Directory for instrumented libs generated by jscoverage/JSCover 20 | lib-cov 21 | 22 | # Coverage directory used by tools like istanbul 23 | coverage 24 | *.lcov 25 | 26 | # nyc test coverage 27 | .nyc_output 28 | 29 | # Grunt intermediate storage (https://gruntjs.com/creating-plugins#storing-task-files) 30 | .grunt 31 | 32 | # Bower dependency directory (https://bower.io/) 33 | bower_components 34 | 35 | # node-waf configuration 36 | .lock-wscript 37 | 38 | # Compiled binary addons (https://nodejs.org/api/addons.html) 39 | build/Release 40 | 41 | # Dependency directories 42 | node_modules/ 43 | jspm_packages/ 44 | 45 | # TypeScript v1 declaration files 46 | typings/ 47 | 48 | # TypeScript cache 49 | *.tsbuildinfo 50 | 51 | # Optional npm cache directory 52 | .npm 53 | 54 | # Optional eslint cache 55 | .eslintcache 56 | 57 | # Microbundle cache 58 | .rpt2_cache/ 59 | .rts2_cache_cjs/ 60 | .rts2_cache_es/ 61 | .rts2_cache_umd/ 62 | 63 | # Optional REPL history 64 | .node_repl_history 65 | 66 | # Output of 'npm pack' 67 | *.tgz 68 | 69 | # Yarn Integrity file 70 | .yarn-integrity 71 | 72 | # dotenv environment variables file 73 | .env 74 | .env.test 75 | 76 | # parcel-bundler cache (https://parceljs.org/) 77 | .cache 78 | 79 | # Next.js build output 80 | .next 81 | 82 | # Nuxt.js build / generate output 83 | .nuxt 84 | dist 85 | 86 | # Gatsby files 87 | .cache/ 88 | # Comment in the public line in if your project uses Gatsby and *not* Next.js 89 | # https://nextjs.org/blog/next-9-1#public-directory-support 90 | # public 91 | 92 | # vuepress build output 93 | .vuepress/dist 94 | 95 | # Serverless directories 96 | .serverless/ 97 | 98 | # FuseBox cache 99 | .fusebox/ 100 | 101 | # DynamoDB Local files 102 | .dynamodb/ 103 | 104 | # TernJS port file 105 | .tern-port 106 | -------------------------------------------------------------------------------- /.npmignore: -------------------------------------------------------------------------------- 1 | src 2 | esbuild 3 | resources 4 | example 5 | node_modules 6 | .gitignore 7 | tsconfig.json 8 | tsconfig.node.json 9 | yarn.lock 10 | rollup.config.js 11 | yarn.lock 12 | ./src/**/* -------------------------------------------------------------------------------- /.prettierrc: -------------------------------------------------------------------------------- 1 | { 2 | "trailingComma": "all", 3 | "singleQuote": true 4 | } 5 | -------------------------------------------------------------------------------- /LICENSE: -------------------------------------------------------------------------------- 1 | MIT License 2 | 3 | Copyright (c) 2023 Simon Holmes 4 | 5 | Permission is hereby granted, free of charge, to any person obtaining a copy 6 | of this software and associated documentation files (the "Software"), to deal 7 | in the Software without restriction, including without limitation the rights 8 | to use, copy, modify, merge, publish, distribute, sublicense, and/or sell 9 | copies of the Software, and to permit persons to whom the Software is 10 | furnished to do so, subject to the following conditions: 11 | 12 | The above copyright notice and this permission notice shall be included in all 13 | copies or substantial portions of the Software. 14 | 15 | THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR 16 | IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, 17 | FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE 18 | AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER 19 | LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, 20 | OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE 21 | SOFTWARE. 22 | -------------------------------------------------------------------------------- /README.md: -------------------------------------------------------------------------------- 1 | # Solid Code Input 2 | 3 | Solid Code Input is a small component for SolidJS that allows you to create a lightweight text area component which will automatically syntax highlight the code you type in it. It is designed for basic use cases where you want to display code to the user, and allow them to edit it, without all the overhead of a full blown code editor. 4 | 5 | https://user-images.githubusercontent.com/3579905/222016141-0f6e9225-8dda-484e-a712-8af2caf1bf99.mp4 6 | 7 | It supports both [PrismJS](https://prismjs.com/) and [HighlightJS](https://highlightjs.org/) to do the syntax highlighting, and will use either depending on which library you pass in as a prop. 8 | 9 | ## Features 10 | 11 | - Very Lightweight 12 | - Easier to use than CodeMirror, Ace, and Monaco 13 | - Supports both PrismJS and HighlightJS 14 | - Auto Indentation 15 | - Tab to indent 16 | - Auto resize to fit content 17 | - Resizable 18 | - Placeholders 19 | 20 | ## Installation 21 | 22 | ```bash 23 | npm install @srsholmes/solid-code-input 24 | # or 25 | yarn add @srsholmes/solid-code-input 26 | ``` 27 | 28 | ## Usage 29 | 30 | ```jsx 31 | import { CodeInput } from '@srsholmes/solid-code-input'; 32 | 33 | ; 42 | ``` 43 | 44 | ## API 45 | 46 | CodeInput takes the following props: 47 | | Name | Type | Description | 48 | |---------------|-----------------------------------------------------|-----------------------------------------------------------------------------------| 49 | | `prismJS` | `typeof Prism` | Optional. An instance of the Prism library for syntax highlighting. | 50 | | `highlightjs` | `typeof highlightjs` | Optional. An instance of the Highlight.js library for syntax highlighting. | 51 | | `value` | `string` | Required. The value of the code input. | 52 | | `language` | `string` | Required. The language of the code input. | 53 | | `onChange` | `(value: string) => void` | Required. A callback function that is called when the value of the input changes. | 54 | | `placeholder` | `string` | Optional. Placeholder text for the input. | 55 | | `resize` | `'both'` \| `'horizontal'` \| `'vertical'` | Optional. Specifies whether the input can be resized, and in which direction. | 56 | | `autoHeight` | `boolean` | Optional. Specifies whether the input height should adjust automatically. | 57 | 58 | ## Types 59 | 60 | ```ts 61 | export type CodeInputProps = { 62 | prismJS?: typeof Prism; 63 | highlightjs?: typeof highlightjs; 64 | value: string; 65 | language: string; 66 | onChange: (value: string) => void; 67 | placeholder?: string; 68 | resize?: 'both' | 'horizontal' | 'vertical'; 69 | autoHeight?: boolean; 70 | }; 71 | ``` 72 | 73 | ## Example App 74 | 75 | ![solid-code-input](./resources/example.png 'solid-code-input') 76 | 77 | To run the example app, clone the repo and run the following commands: 78 | 79 | ```bash 80 | git clone https://github.com/srsholmes/solid-code-input 81 | yarn # Install dependencies 82 | yarn build # Build the component from source 83 | cd example 84 | yarn 85 | yarn dev 86 | ``` 87 | 88 | ## Shout outs 89 | 90 | Shout out to Oliver Geer (WebCoder49) for this awesome article which inspired this component [Creating an Editable Textarea That Supports Syntax-Highlighted Code](https://css-tricks.com/creating-an-editable-textarea-that-supports-syntax-highlighted-code/). 91 | 92 | The method used was heavily inspired by this repo [code-input](https://github.com/WebCoder49/code-input), and the auto indent was taken directly from his indent plugin. 93 | 94 | ## License 95 | 96 | MIT 97 | -------------------------------------------------------------------------------- /example/.DS_Store: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/srsholmes/solid-code-input/b8ece72ebdec0a6d346846a874a337ead90b6767/example/.DS_Store -------------------------------------------------------------------------------- /example/index.html: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | 6 | 7 | Solid App 8 | 9 | 10 | 11 |
12 | 13 | 14 | 15 | 16 | -------------------------------------------------------------------------------- /example/package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "solid-code-input-example", 3 | "version": "1.0.0", 4 | "description": "Solid Code Example ", 5 | "main": "index.js", 6 | "scripts": { 7 | "dev": "vite" 8 | }, 9 | "author": "", 10 | "license": "MIT", 11 | "devDependencies": { 12 | "@types/highlight.js": "9.12.2", 13 | "@types/prismjs": "1.26.0", 14 | "typescript": "^4.9.5", 15 | "vite": "^4.1.1", 16 | "vite-plugin-solid": "^2.5.0", 17 | "vite-plugin-dts": "2.0.2" 18 | }, 19 | "dependencies": { 20 | "highlight.js": "^11.7.0", 21 | "prismjs": "^1.28.0", 22 | "solid-js": "^1.6.10" 23 | } 24 | } 25 | -------------------------------------------------------------------------------- /example/scripts/demo.js: -------------------------------------------------------------------------------- 1 | // Put this in the chrome console to simulate typing in the textarea 2 | // to record the demo 3 | function simulateTyping(selector, text, delay) { 4 | // Get the input element 5 | const input = document.querySelector(selector); 6 | 7 | // Make sure the input element exists 8 | if (!input) { 9 | console.error(`Input element with selector ${selector} not found`); 10 | return; 11 | } 12 | const randomDelay = delay * (1 + Math.random() - 0.5); 13 | 14 | // Loop through each character in the text 15 | for (let i = 0; i < text.length; i++) { 16 | // Set a timeout to simulate typing delay 17 | setTimeout(() => { 18 | // Get the current value of the input element 19 | const currentValue = input.value; 20 | 21 | // Append the current character to the input element value 22 | input.value = currentValue + text[i]; 23 | 24 | // Dispatch an input event to trigger any listeners 25 | const inputEvent = new Event('input', { bubbles: true }); 26 | input.dispatchEvent(inputEvent); 27 | }, randomDelay * i); 28 | } 29 | } 30 | 31 | const exampleCode = `import { render } from 'solid-js/web'; 32 | import { createSignal, createEffect } from 'solid-js'; 33 | import Prism from 'prismjs'; 34 | import { CodeInput } from '@srsholmes/solid-code-input'; 35 | 36 | function App() { 37 | const [input, setInput] = createSignal(''); 38 | 39 | return ( 40 | 49 | ); 50 | } 51 | 52 | render(() => , document.getElementById('app')); 53 | `; 54 | 55 | simulateTyping('textarea', exampleCode, 100); 56 | -------------------------------------------------------------------------------- /example/src/App.module.css: -------------------------------------------------------------------------------- 1 | .app { 2 | padding: 5rem;; 3 | width: 90%; 4 | margin: auto; 5 | } 6 | 7 | .select { 8 | margin-top: 1rem; 9 | width: 100%; 10 | min-width: 15ch; 11 | max-width: 30ch; 12 | border: 1px solid var(--select-border); 13 | border-radius: 0.25em; 14 | padding: 0.5em 0.5em; 15 | font-size: 1rem; 16 | cursor: pointer; 17 | line-height: 1.1; 18 | background-color: rgb(46, 52, 64); 19 | color: rgb(255, 255, 255); 20 | } 21 | 22 | /* Original CSS written by Oliver Geer (WebCoder49) */ 23 | /* https://css-tricks.com/creating-an-editable-textarea-that-supports-syntax-highlighted-code/ */ 24 | /* Updated for solid-code-input */ 25 | -------------------------------------------------------------------------------- /example/src/App.tsx: -------------------------------------------------------------------------------- 1 | import highlightjs from 'highlight.js'; 2 | import Prism from 'prismjs'; 3 | import { createSignal, onMount, Show } from 'solid-js'; 4 | import { CodeInput } from '../../dist/esm'; 5 | import styles from './App.module.css'; 6 | 7 | import './themes/nord-highlight.css'; 8 | import './themes/nord-prism.css'; 9 | 10 | const exampleCode = `import { render } from 'solid-js/web'; 11 | import { createSignal, createEffect } from 'solid-js'; 12 | import Prism from 'prismjs'; 13 | import { CodeInput } from '@srsholmes/solid-code-input'; 14 | 15 | function App() { 16 | const [input, setInput] = createSignal(''); 17 | 18 | return ( 19 | 28 | ); 29 | } 30 | 31 | render(() => , document.getElementById('app')); 32 | `; 33 | 34 | // Syntax Highlight libraries to generate the tokens. 35 | // It's up to you to import them. 36 | const libs = [ 37 | import('prismjs/components/prism-markup'), 38 | import('prismjs/components/prism-typescript'), 39 | import('prismjs/components/prism-javascript'), 40 | import('prismjs/components/prism-jsx'), 41 | import('prismjs/components/prism-markup'), 42 | import('prismjs/components/prism-css'), 43 | import('highlight.js/lib/languages/typescript'), 44 | import('highlight.js/lib/languages/javascript'), 45 | import('highlight.js/lib/languages/css'), 46 | ]; 47 | 48 | export function App() { 49 | // Our code input 50 | const [input, setInput] = createSignal(exampleCode); 51 | 52 | // Syntax Highlight libraries. It's up to you to import them. 53 | // CodeInput will use either library if you pass it in. 54 | const [loadedPrism, setLoadedPrism] = createSignal(false); 55 | const [loadedHighlight, setLoadedHighlight] = createSignal(true); 56 | const [languagePrism, setLanguagePrism] = createSignal('jsx'); 57 | const [languageHighlight, setLanguageHighlight] = createSignal('typescript'); 58 | 59 | onMount(async () => { 60 | await Promise.all(libs); 61 | setLoadedPrism(true); 62 | setLoadedHighlight(true); 63 | }); 64 | 65 | return ( 66 |
67 |

Solid Code Input Demo

68 |
69 |

PrismJS

70 | 71 | 80 | 81 | 82 | 83 |
84 |
85 |

Highlight.js

86 | 87 | 96 | 97 | 101 |
102 |
103 | ); 104 | 105 | function LanguageSelect(props: { 106 | setLanguage: (language: string) => void; 107 | value: () => string; 108 | }) { 109 | return ( 110 | 122 | ); 123 | } 124 | } 125 | -------------------------------------------------------------------------------- /example/src/Demo.tsx: -------------------------------------------------------------------------------- 1 | import Prism from 'prismjs'; 2 | import { createEffect, createSignal, onMount, Show } from 'solid-js'; 3 | import { CodeInput } from '../../dist/esm'; 4 | import styles from './App.module.css'; 5 | 6 | const libs = [ 7 | import('prismjs/components/prism-markup'), 8 | import('prismjs/components/prism-typescript'), 9 | import('prismjs/components/prism-javascript'), 10 | import('prismjs/components/prism-jsx'), 11 | ]; 12 | 13 | const BEST_THEMES = [ 14 | 'atom-dark', 15 | 'xonokai', 16 | 'nord', 17 | 'vsc-dark-plus', 18 | 'synthwave84', 19 | 'one-dark', 20 | 'one-light', 21 | 'material-dark', 22 | 'material-light', 23 | 'material-oceanic', 24 | 'prism-one-dark', 25 | 'darcula', 26 | 'dracula', 27 | 'duotone-dark', 28 | 'duotone-earth', 29 | 'duotone-forest', 30 | 'duotone-light', 31 | 'duotone-sea', 32 | 'duotone-space', 33 | ]; 34 | 35 | const exampleCode = `import { render } from 'solid-js/web'; 36 | import { createSignal, createEffect } from 'solid-js'; 37 | import Prism from 'prismjs'; 38 | import { CodeInput } from '@srsholmes/solid-code-input'; 39 | 40 | function App() { 41 | const [input, setInput] = createSignal(''); 42 | 43 | return ( 44 | 52 | ); 53 | } 54 | 55 | render(() => , document.getElementById('app'));`; 56 | 57 | export function Demo() { 58 | const [input, setInput] = createSignal(''); 59 | // Syntax Highlight libraries. It's up to you to import them. 60 | // CodeInput will use either library if you pass it in. 61 | const [loadedPrism, setLoadedPrism] = createSignal(false); 62 | const [languagePrism, setLanguagePrism] = createSignal('jsx'); 63 | 64 | createEffect(async () => { 65 | await Promise.all(libs); 66 | setLoadedPrism(true); 67 | // sleep 5 seconds to load 68 | await new Promise((resolve) => setTimeout(resolve, 5000)); 69 | 70 | // setInterval(async () => { 71 | const oldStyle = document.getElementById('theme'); 72 | if (oldStyle) { 73 | document.head.removeChild(oldStyle); 74 | } 75 | const theme = BEST_THEMES[Math.floor(Math.random() * BEST_THEMES.length)]; 76 | const res = await import(`./prism-themes/${theme}.css?raw`); 77 | const style = document.createElement('style'); 78 | style.textContent = res.default; 79 | style.id = `theme`; 80 | document.head.appendChild(style); 81 | document.body.dataset.theme = theme; 82 | // }, 500); 83 | }); 84 | 85 | return ( 86 |
87 |
88 | 89 |
90 | 99 |
100 |
101 |
102 |
103 | ); 104 | } 105 | -------------------------------------------------------------------------------- /example/src/index.tsx: -------------------------------------------------------------------------------- 1 | import { render } from 'solid-js/web'; 2 | import { App } from './App'; 3 | import { Demo } from './Demo'; 4 | import './styles.css'; 5 | render(() => , document.querySelector('#root')!); 6 | -------------------------------------------------------------------------------- /example/src/prism-themes/a11y-dark.css: -------------------------------------------------------------------------------- 1 | /** 2 | * a11y-dark theme for JavaScript, CSS, and HTML 3 | * Based on the okaidia theme: https://github.com/PrismJS/prism/blob/gh-pages/themes/prism-okaidia.css 4 | * @author ericwbailey 5 | */ 6 | 7 | code[class*="language-"], 8 | pre[class*="language-"] { 9 | color: #f8f8f2; 10 | background: none; 11 | font-family: Consolas, Monaco, 'Andale Mono', 'Ubuntu Mono', monospace; 12 | text-align: left; 13 | white-space: pre; 14 | word-spacing: normal; 15 | word-break: normal; 16 | word-wrap: normal; 17 | line-height: 1.5; 18 | 19 | -moz-tab-size: 4; 20 | -o-tab-size: 4; 21 | tab-size: 4; 22 | 23 | -webkit-hyphens: none; 24 | -moz-hyphens: none; 25 | -ms-hyphens: none; 26 | hyphens: none; 27 | } 28 | 29 | /* Code blocks */ 30 | pre[class*="language-"] { 31 | padding: 1em; 32 | margin: 0.5em 0; 33 | overflow: auto; 34 | border-radius: 0.3em; 35 | } 36 | 37 | :not(pre) > code[class*="language-"], 38 | pre[class*="language-"] { 39 | background: #2b2b2b; 40 | } 41 | 42 | /* Inline code */ 43 | :not(pre) > code[class*="language-"] { 44 | padding: 0.1em; 45 | border-radius: 0.3em; 46 | white-space: normal; 47 | } 48 | 49 | .token.comment, 50 | .token.prolog, 51 | .token.doctype, 52 | .token.cdata { 53 | color: #d4d0ab; 54 | } 55 | 56 | .token.punctuation { 57 | color: #fefefe; 58 | } 59 | 60 | .token.property, 61 | .token.tag, 62 | .token.constant, 63 | .token.symbol, 64 | .token.deleted { 65 | color: #ffa07a; 66 | } 67 | 68 | .token.boolean, 69 | .token.number { 70 | color: #00e0e0; 71 | } 72 | 73 | .token.selector, 74 | .token.attr-name, 75 | .token.string, 76 | .token.char, 77 | .token.builtin, 78 | .token.inserted { 79 | color: #abe338; 80 | } 81 | 82 | .token.operator, 83 | .token.entity, 84 | .token.url, 85 | .language-css .token.string, 86 | .style .token.string, 87 | .token.variable { 88 | color: #00e0e0; 89 | } 90 | 91 | .token.atrule, 92 | .token.attr-value, 93 | .token.function { 94 | color: #ffd700; 95 | } 96 | 97 | .token.keyword { 98 | color: #00e0e0; 99 | } 100 | 101 | .token.regex, 102 | .token.important { 103 | color: #ffd700; 104 | } 105 | 106 | .token.important, 107 | .token.bold { 108 | font-weight: bold; 109 | } 110 | 111 | .token.italic { 112 | font-style: italic; 113 | } 114 | 115 | .token.entity { 116 | cursor: help; 117 | } 118 | 119 | @media screen and (-ms-high-contrast: active) { 120 | code[class*="language-"], 121 | pre[class*="language-"] { 122 | color: windowText; 123 | background: window; 124 | } 125 | 126 | :not(pre) > code[class*="language-"], 127 | pre[class*="language-"] { 128 | background: window; 129 | } 130 | 131 | .token.important { 132 | background: highlight; 133 | color: window; 134 | font-weight: normal; 135 | } 136 | 137 | .token.atrule, 138 | .token.attr-value, 139 | .token.function, 140 | .token.keyword, 141 | .token.operator, 142 | .token.selector { 143 | font-weight: bold; 144 | } 145 | 146 | .token.attr-value, 147 | .token.comment, 148 | .token.doctype, 149 | .token.function, 150 | .token.keyword, 151 | .token.operator, 152 | .token.property, 153 | .token.string { 154 | color: highlight; 155 | } 156 | 157 | .token.attr-value, 158 | .token.url { 159 | font-weight: normal; 160 | } 161 | } 162 | -------------------------------------------------------------------------------- /example/src/prism-themes/atom-dark.css: -------------------------------------------------------------------------------- 1 | /** 2 | * atom-dark theme for `prism.js` 3 | * Based on Atom's `atom-dark` theme: https://github.com/atom/atom-dark-syntax 4 | * @author Joe Gibson (@gibsjose) 5 | */ 6 | 7 | code[class*="language-"], 8 | pre[class*="language-"] { 9 | color: #c5c8c6; 10 | text-shadow: 0 1px rgba(0, 0, 0, 0.3); 11 | font-family: Inconsolata, Monaco, Consolas, 'Courier New', Courier, monospace; 12 | direction: ltr; 13 | text-align: left; 14 | white-space: pre; 15 | word-spacing: normal; 16 | word-break: normal; 17 | line-height: 1.5; 18 | 19 | -moz-tab-size: 4; 20 | -o-tab-size: 4; 21 | tab-size: 4; 22 | 23 | -webkit-hyphens: none; 24 | -moz-hyphens: none; 25 | -ms-hyphens: none; 26 | hyphens: none; 27 | } 28 | 29 | /* Code blocks */ 30 | pre[class*="language-"] { 31 | padding: 1em; 32 | margin: .5em 0; 33 | overflow: auto; 34 | border-radius: 0.3em; 35 | } 36 | 37 | :not(pre) > code[class*="language-"], 38 | pre[class*="language-"] { 39 | background: #1d1f21; 40 | } 41 | 42 | /* Inline code */ 43 | :not(pre) > code[class*="language-"] { 44 | padding: .1em; 45 | border-radius: .3em; 46 | } 47 | 48 | .token.comment, 49 | .token.prolog, 50 | .token.doctype, 51 | .token.cdata { 52 | color: #7C7C7C; 53 | } 54 | 55 | .token.punctuation { 56 | color: #c5c8c6; 57 | } 58 | 59 | .namespace { 60 | opacity: .7; 61 | } 62 | 63 | .token.property, 64 | .token.keyword, 65 | .token.tag { 66 | color: #96CBFE; 67 | } 68 | 69 | .token.class-name { 70 | color: #FFFFB6; 71 | text-decoration: underline; 72 | } 73 | 74 | .token.boolean, 75 | .token.constant { 76 | color: #99CC99; 77 | } 78 | 79 | .token.symbol, 80 | .token.deleted { 81 | color: #f92672; 82 | } 83 | 84 | .token.number { 85 | color: #FF73FD; 86 | } 87 | 88 | .token.selector, 89 | .token.attr-name, 90 | .token.string, 91 | .token.char, 92 | .token.builtin, 93 | .token.inserted { 94 | color: #A8FF60; 95 | } 96 | 97 | .token.variable { 98 | color: #C6C5FE; 99 | } 100 | 101 | .token.operator { 102 | color: #EDEDED; 103 | } 104 | 105 | .token.entity { 106 | color: #FFFFB6; 107 | cursor: help; 108 | } 109 | 110 | .token.url { 111 | color: #96CBFE; 112 | } 113 | 114 | .language-css .token.string, 115 | .style .token.string { 116 | color: #87C38A; 117 | } 118 | 119 | .token.atrule, 120 | .token.attr-value { 121 | color: #F9EE98; 122 | } 123 | 124 | .token.function { 125 | color: #DAD085; 126 | } 127 | 128 | .token.regex { 129 | color: #E9C062; 130 | } 131 | 132 | .token.important { 133 | color: #fd971f; 134 | } 135 | 136 | .token.important, 137 | .token.bold { 138 | font-weight: bold; 139 | } 140 | 141 | .token.italic { 142 | font-style: italic; 143 | } 144 | -------------------------------------------------------------------------------- /example/src/prism-themes/base16-ateliersulphurpool.light.css: -------------------------------------------------------------------------------- 1 | /* 2 | 3 | Name: Base16 Atelier Sulphurpool Light 4 | Author: Bram de Haan (http://atelierbram.github.io/syntax-highlighting/atelier-schemes/sulphurpool) 5 | 6 | Prism template by Bram de Haan (http://atelierbram.github.io/syntax-highlighting/prism/) 7 | Original Base16 color scheme by Chris Kempson (https://github.com/chriskempson/base16) 8 | 9 | */ 10 | code[class*="language-"], 11 | pre[class*="language-"] { 12 | font-family: Consolas, Menlo, Monaco, "Andale Mono WT", "Andale Mono", "Lucida Console", "Lucida Sans Typewriter", "DejaVu Sans Mono", "Bitstream Vera Sans Mono", "Liberation Mono", "Nimbus Mono L", "Courier New", Courier, monospace; 13 | font-size: 14px; 14 | line-height: 1.375; 15 | direction: ltr; 16 | text-align: left; 17 | white-space: pre; 18 | word-spacing: normal; 19 | word-break: normal; 20 | -moz-tab-size: 4; 21 | -o-tab-size: 4; 22 | tab-size: 4; 23 | -webkit-hyphens: none; 24 | -moz-hyphens: none; 25 | -ms-hyphens: none; 26 | hyphens: none; 27 | background: #f5f7ff; 28 | color: #5e6687; 29 | } 30 | 31 | pre > code[class*="language-"] { 32 | font-size: 1em; 33 | } 34 | 35 | pre[class*="language-"]::-moz-selection, pre[class*="language-"] ::-moz-selection, 36 | code[class*="language-"]::-moz-selection, code[class*="language-"] ::-moz-selection { 37 | text-shadow: none; 38 | background: #dfe2f1; 39 | } 40 | 41 | pre[class*="language-"]::selection, pre[class*="language-"] ::selection, 42 | code[class*="language-"]::selection, code[class*="language-"] ::selection { 43 | text-shadow: none; 44 | background: #dfe2f1; 45 | } 46 | 47 | /* Code blocks */ 48 | pre[class*="language-"] { 49 | padding: 1em; 50 | margin: .5em 0; 51 | overflow: auto; 52 | } 53 | 54 | /* Inline code */ 55 | :not(pre) > code[class*="language-"] { 56 | padding: .1em; 57 | border-radius: .3em; 58 | } 59 | 60 | .token.comment, 61 | .token.prolog, 62 | .token.doctype, 63 | .token.cdata { 64 | color: #898ea4; 65 | } 66 | 67 | .token.punctuation { 68 | color: #5e6687; 69 | } 70 | 71 | .token.namespace { 72 | opacity: .7; 73 | } 74 | 75 | .token.operator, 76 | .token.boolean, 77 | .token.number { 78 | color: #c76b29; 79 | } 80 | 81 | .token.property { 82 | color: #c08b30; 83 | } 84 | 85 | .token.tag { 86 | color: #3d8fd1; 87 | } 88 | 89 | .token.string { 90 | color: #22a2c9; 91 | } 92 | 93 | .token.selector { 94 | color: #6679cc; 95 | } 96 | 97 | .token.attr-name { 98 | color: #c76b29; 99 | } 100 | 101 | .token.entity, 102 | .token.url, 103 | .language-css .token.string, 104 | .style .token.string { 105 | color: #22a2c9; 106 | } 107 | 108 | .token.attr-value, 109 | .token.keyword, 110 | .token.control, 111 | .token.directive, 112 | .token.unit { 113 | color: #ac9739; 114 | } 115 | 116 | .token.statement, 117 | .token.regex, 118 | .token.atrule { 119 | color: #22a2c9; 120 | } 121 | 122 | .token.placeholder, 123 | .token.variable { 124 | color: #3d8fd1; 125 | } 126 | 127 | .token.deleted { 128 | text-decoration: line-through; 129 | } 130 | 131 | .token.inserted { 132 | border-bottom: 1px dotted #202746; 133 | text-decoration: none; 134 | } 135 | 136 | .token.italic { 137 | font-style: italic; 138 | } 139 | 140 | .token.important, 141 | .token.bold { 142 | font-weight: bold; 143 | } 144 | 145 | .token.important { 146 | color: #c94922; 147 | } 148 | 149 | .token.entity { 150 | cursor: help; 151 | } 152 | 153 | pre > code.highlight { 154 | outline: 0.4em solid #c94922; 155 | outline-offset: .4em; 156 | } 157 | 158 | /* overrides color-values for the Line Numbers plugin 159 | * http://prismjs.com/plugins/line-numbers/ 160 | */ 161 | .line-numbers.line-numbers .line-numbers-rows { 162 | border-right-color: #dfe2f1; 163 | } 164 | 165 | .line-numbers .line-numbers-rows > span:before { 166 | color: #979db4; 167 | } 168 | 169 | /* overrides color-values for the Line Highlight plugin 170 | * http://prismjs.com/plugins/line-highlight/ 171 | */ 172 | .line-highlight.line-highlight { 173 | background: rgba(107, 115, 148, 0.2); 174 | background: -webkit-linear-gradient(left, rgba(107, 115, 148, 0.2) 70%, rgba(107, 115, 148, 0)); 175 | background: linear-gradient(to right, rgba(107, 115, 148, 0.2) 70%, rgba(107, 115, 148, 0)); 176 | } 177 | -------------------------------------------------------------------------------- /example/src/prism-themes/cb.css: -------------------------------------------------------------------------------- 1 | /* 2 | * Based on Plugin: Syntax Highlighter CB 3 | * Plugin URI: http://wp.tutsplus.com/tutorials/plugins/adding-a-syntax-highlighter-shortcode-using-prism-js 4 | * Description: Highlight your code snippets with an easy to use shortcode based on Lea Verou's Prism.js. 5 | * Version: 1.0.0 6 | * Author: c.bavota 7 | * Author URI: http://bavotasan.comhttp://wp.tutsplus.com/tutorials/plugins/adding-a-syntax-highlighter-shortcode-using-prism-js/ */ 8 | /* http://cbavota.bitbucket.org/syntax-highlighter/ */ 9 | 10 | /* ===== ===== */ 11 | code[class*="language-"], 12 | pre[class*="language-"] { 13 | color: #fff; 14 | text-shadow: 0 1px 1px #000; 15 | font-family: Menlo, Monaco, "Courier New", monospace; 16 | direction: ltr; 17 | text-align: left; 18 | word-spacing: normal; 19 | white-space: pre; 20 | word-wrap: normal; 21 | line-height: 1.4; 22 | background: none; 23 | border: 0; 24 | 25 | -moz-tab-size: 4; 26 | -o-tab-size: 4; 27 | tab-size: 4; 28 | 29 | -webkit-hyphens: none; 30 | -moz-hyphens: none; 31 | -ms-hyphens: none; 32 | hyphens: none; 33 | } 34 | 35 | pre[class*="language-"] code { 36 | float: left; 37 | padding: 0 15px 0 0; 38 | } 39 | 40 | pre[class*="language-"], 41 | :not(pre) > code[class*="language-"] { 42 | background: #222; 43 | } 44 | 45 | /* Code blocks */ 46 | pre[class*="language-"] { 47 | padding: 15px; 48 | margin: 1em 0; 49 | overflow: auto; 50 | -moz-border-radius: 8px; 51 | -webkit-border-radius: 8px; 52 | border-radius: 8px; 53 | } 54 | 55 | /* Inline code */ 56 | :not(pre) > code[class*="language-"] { 57 | padding: 5px 10px; 58 | line-height: 1; 59 | -moz-border-radius: 3px; 60 | -webkit-border-radius: 3px; 61 | border-radius: 3px; 62 | } 63 | 64 | .token.comment, 65 | .token.prolog, 66 | .token.doctype, 67 | .token.cdata { 68 | color: #797979; 69 | } 70 | 71 | .token.selector, 72 | .token.operator, 73 | .token.punctuation { 74 | color: #fff; 75 | } 76 | 77 | .token.namespace { 78 | opacity: .7; 79 | } 80 | 81 | .token.tag, 82 | .token.boolean { 83 | color: #ffd893; 84 | } 85 | 86 | .token.atrule, 87 | .token.attr-value, 88 | .token.hex, 89 | .token.string { 90 | color: #B0C975; 91 | } 92 | 93 | .token.property, 94 | .token.entity, 95 | .token.url, 96 | .token.attr-name, 97 | .token.keyword { 98 | color: #c27628; 99 | } 100 | 101 | .token.regex { 102 | color: #9B71C6; 103 | } 104 | 105 | .token.entity { 106 | cursor: help; 107 | } 108 | 109 | .token.function, 110 | .token.constant { 111 | color: #e5a638; 112 | } 113 | 114 | .token.variable { 115 | color: #fdfba8; 116 | } 117 | 118 | .token.number { 119 | color: #8799B0; 120 | } 121 | 122 | .token.important, 123 | .token.deliminator { 124 | color: #E45734; 125 | } 126 | 127 | /* Line highlight plugin */ 128 | .line-highlight.line-highlight { 129 | background: rgba(255, 255, 255, .2); 130 | } 131 | 132 | .line-highlight.line-highlight:before, 133 | .line-highlight.line-highlight[data-end]:after { 134 | top: .3em; 135 | background-color: rgba(255, 255, 255, .3); 136 | color: #fff; 137 | -moz-border-radius: 8px; 138 | -webkit-border-radius: 8px; 139 | border-radius: 8px; 140 | } 141 | 142 | /* for line numbers */ 143 | /* span instead of span:before for a two-toned border */ 144 | .line-numbers .line-numbers-rows > span { 145 | border-right: 3px #d9d336 solid; 146 | } 147 | -------------------------------------------------------------------------------- /example/src/prism-themes/coldark-cold.css: -------------------------------------------------------------------------------- 1 | /** 2 | * Coldark Theme for Prism.js 3 | * Theme variation: Cold 4 | * Tested with HTML, CSS, JS, JSON, PHP, YAML, Bash script 5 | * @author Armand Philippot 6 | * @homepage https://github.com/ArmandPhilippot/coldark-prism 7 | * @license MIT 8 | */ 9 | code[class*="language-"], 10 | pre[class*="language-"] { 11 | color: #111b27; 12 | background: none; 13 | font-family: Consolas, Monaco, "Andale Mono", "Ubuntu Mono", monospace; 14 | text-align: left; 15 | white-space: pre; 16 | word-spacing: normal; 17 | word-break: normal; 18 | word-wrap: normal; 19 | line-height: 1.5; 20 | -moz-tab-size: 4; 21 | -o-tab-size: 4; 22 | tab-size: 4; 23 | -webkit-hyphens: none; 24 | -moz-hyphens: none; 25 | -ms-hyphens: none; 26 | hyphens: none; 27 | } 28 | 29 | pre[class*="language-"]::-moz-selection, 30 | pre[class*="language-"] ::-moz-selection, 31 | code[class*="language-"]::-moz-selection, 32 | code[class*="language-"] ::-moz-selection { 33 | background: #8da1b9; 34 | } 35 | 36 | pre[class*="language-"]::selection, 37 | pre[class*="language-"] ::selection, 38 | code[class*="language-"]::selection, 39 | code[class*="language-"] ::selection { 40 | background: #8da1b9; 41 | } 42 | 43 | /* Code blocks */ 44 | pre[class*="language-"] { 45 | padding: 1em; 46 | margin: 0.5em 0; 47 | overflow: auto; 48 | } 49 | 50 | :not(pre) > code[class*="language-"], 51 | pre[class*="language-"] { 52 | background: #e3eaf2; 53 | } 54 | 55 | /* Inline code */ 56 | :not(pre) > code[class*="language-"] { 57 | padding: 0.1em 0.3em; 58 | border-radius: 0.3em; 59 | white-space: normal; 60 | } 61 | 62 | .token.comment, 63 | .token.prolog, 64 | .token.doctype, 65 | .token.cdata { 66 | color: #3c526d; 67 | } 68 | 69 | .token.punctuation { 70 | color: #111b27; 71 | } 72 | 73 | .token.delimiter.important, 74 | .token.selector .parent, 75 | .token.tag, 76 | .token.tag .token.punctuation { 77 | color: #006d6d; 78 | } 79 | 80 | .token.attr-name, 81 | .token.boolean, 82 | .token.boolean.important, 83 | .token.number, 84 | .token.constant, 85 | .token.selector .token.attribute { 86 | color: #755f00; 87 | } 88 | 89 | .token.class-name, 90 | .token.key, 91 | .token.parameter, 92 | .token.property, 93 | .token.property-access, 94 | .token.variable { 95 | color: #005a8e; 96 | } 97 | 98 | .token.attr-value, 99 | .token.inserted, 100 | .token.color, 101 | .token.selector .token.value, 102 | .token.string, 103 | .token.string .token.url-link { 104 | color: #116b00; 105 | } 106 | 107 | .token.builtin, 108 | .token.keyword-array, 109 | .token.package, 110 | .token.regex { 111 | color: #af00af; 112 | } 113 | 114 | .token.function, 115 | .token.selector .token.class, 116 | .token.selector .token.id { 117 | color: #7c00aa; 118 | } 119 | 120 | .token.atrule .token.rule, 121 | .token.combinator, 122 | .token.keyword, 123 | .token.operator, 124 | .token.pseudo-class, 125 | .token.pseudo-element, 126 | .token.selector, 127 | .token.unit { 128 | color: #a04900; 129 | } 130 | 131 | .token.deleted, 132 | .token.important { 133 | color: #c22f2e; 134 | } 135 | 136 | .token.keyword-this, 137 | .token.this { 138 | color: #005a8e; 139 | } 140 | 141 | .token.important, 142 | .token.keyword-this, 143 | .token.this, 144 | .token.bold { 145 | font-weight: bold; 146 | } 147 | 148 | .token.delimiter.important { 149 | font-weight: inherit; 150 | } 151 | 152 | .token.italic { 153 | font-style: italic; 154 | } 155 | 156 | .token.entity { 157 | cursor: help; 158 | } 159 | 160 | .language-markdown .token.title, 161 | .language-markdown .token.title .token.punctuation { 162 | color: #005a8e; 163 | font-weight: bold; 164 | } 165 | 166 | .language-markdown .token.blockquote.punctuation { 167 | color: #af00af; 168 | } 169 | 170 | .language-markdown .token.code { 171 | color: #006d6d; 172 | } 173 | 174 | .language-markdown .token.hr.punctuation { 175 | color: #005a8e; 176 | } 177 | 178 | .language-markdown .token.url > .token.content { 179 | color: #116b00; 180 | } 181 | 182 | .language-markdown .token.url-link { 183 | color: #755f00; 184 | } 185 | 186 | .language-markdown .token.list.punctuation { 187 | color: #af00af; 188 | } 189 | 190 | .language-markdown .token.table-header { 191 | color: #111b27; 192 | } 193 | 194 | .language-json .token.operator { 195 | color: #111b27; 196 | } 197 | 198 | .language-scss .token.variable { 199 | color: #006d6d; 200 | } 201 | 202 | /* overrides color-values for the Show Invisibles plugin 203 | * https://prismjs.com/plugins/show-invisibles/ 204 | */ 205 | .token.token.tab:not(:empty):before, 206 | .token.token.cr:before, 207 | .token.token.lf:before, 208 | .token.token.space:before { 209 | color: #3c526d; 210 | } 211 | 212 | /* overrides color-values for the Toolbar plugin 213 | * https://prismjs.com/plugins/toolbar/ 214 | */ 215 | div.code-toolbar > .toolbar.toolbar > .toolbar-item > a, 216 | div.code-toolbar > .toolbar.toolbar > .toolbar-item > button { 217 | color: #e3eaf2; 218 | background: #005a8e; 219 | } 220 | 221 | div.code-toolbar > .toolbar.toolbar > .toolbar-item > a:hover, 222 | div.code-toolbar > .toolbar.toolbar > .toolbar-item > a:focus, 223 | div.code-toolbar > .toolbar.toolbar > .toolbar-item > button:hover, 224 | div.code-toolbar > .toolbar.toolbar > .toolbar-item > button:focus { 225 | color: #e3eaf2; 226 | background: #005a8eda; 227 | text-decoration: none; 228 | } 229 | 230 | div.code-toolbar > .toolbar.toolbar > .toolbar-item > span, 231 | div.code-toolbar > .toolbar.toolbar > .toolbar-item > span:hover, 232 | div.code-toolbar > .toolbar.toolbar > .toolbar-item > span:focus { 233 | color: #e3eaf2; 234 | background: #3c526d; 235 | } 236 | 237 | /* overrides color-values for the Line Highlight plugin 238 | * http://prismjs.com/plugins/line-highlight/ 239 | */ 240 | .line-highlight.line-highlight { 241 | background: #8da1b92f; 242 | background: linear-gradient(to right, #8da1b92f 70%, #8da1b925); 243 | } 244 | 245 | .line-highlight.line-highlight:before, 246 | .line-highlight.line-highlight[data-end]:after { 247 | background-color: #3c526d; 248 | color: #e3eaf2; 249 | box-shadow: 0 1px #8da1b9; 250 | } 251 | 252 | pre[id].linkable-line-numbers.linkable-line-numbers span.line-numbers-rows > span:hover:before { 253 | background-color: #3c526d1f; 254 | } 255 | 256 | /* overrides color-values for the Line Numbers plugin 257 | * http://prismjs.com/plugins/line-numbers/ 258 | */ 259 | .line-numbers.line-numbers .line-numbers-rows { 260 | border-right: 1px solid #8da1b97a; 261 | background: #d0dae77a; 262 | } 263 | 264 | .line-numbers .line-numbers-rows > span:before { 265 | color: #3c526dda; 266 | } 267 | 268 | /* overrides color-values for the Match Braces plugin 269 | * https://prismjs.com/plugins/match-braces/ 270 | */ 271 | .rainbow-braces .token.token.punctuation.brace-level-1, 272 | .rainbow-braces .token.token.punctuation.brace-level-5, 273 | .rainbow-braces .token.token.punctuation.brace-level-9 { 274 | color: #755f00; 275 | } 276 | 277 | .rainbow-braces .token.token.punctuation.brace-level-2, 278 | .rainbow-braces .token.token.punctuation.brace-level-6, 279 | .rainbow-braces .token.token.punctuation.brace-level-10 { 280 | color: #af00af; 281 | } 282 | 283 | .rainbow-braces .token.token.punctuation.brace-level-3, 284 | .rainbow-braces .token.token.punctuation.brace-level-7, 285 | .rainbow-braces .token.token.punctuation.brace-level-11 { 286 | color: #005a8e; 287 | } 288 | 289 | .rainbow-braces .token.token.punctuation.brace-level-4, 290 | .rainbow-braces .token.token.punctuation.brace-level-8, 291 | .rainbow-braces .token.token.punctuation.brace-level-12 { 292 | color: #7c00aa; 293 | } 294 | 295 | /* overrides color-values for the Diff Highlight plugin 296 | * https://prismjs.com/plugins/diff-highlight/ 297 | */ 298 | pre.diff-highlight > code .token.token.deleted:not(.prefix), 299 | pre > code.diff-highlight .token.token.deleted:not(.prefix) { 300 | background-color: #c22f2e1f; 301 | } 302 | 303 | pre.diff-highlight > code .token.token.inserted:not(.prefix), 304 | pre > code.diff-highlight .token.token.inserted:not(.prefix) { 305 | background-color: #116b001f; 306 | } 307 | 308 | /* overrides color-values for the Command Line plugin 309 | * https://prismjs.com/plugins/command-line/ 310 | */ 311 | .command-line .command-line-prompt { 312 | border-right: 1px solid #8da1b97a; 313 | } 314 | 315 | .command-line .command-line-prompt > span:before { 316 | color: #3c526dda; 317 | } 318 | -------------------------------------------------------------------------------- /example/src/prism-themes/coldark-dark.css: -------------------------------------------------------------------------------- 1 | /** 2 | * Coldark Theme for Prism.js 3 | * Theme variation: Dark 4 | * Tested with HTML, CSS, JS, JSON, PHP, YAML, Bash script 5 | * @author Armand Philippot 6 | * @homepage https://github.com/ArmandPhilippot/coldark-prism 7 | * @license MIT 8 | */ 9 | code[class*="language-"], 10 | pre[class*="language-"] { 11 | color: #e3eaf2; 12 | background: none; 13 | font-family: Consolas, Monaco, "Andale Mono", "Ubuntu Mono", monospace; 14 | text-align: left; 15 | white-space: pre; 16 | word-spacing: normal; 17 | word-break: normal; 18 | word-wrap: normal; 19 | line-height: 1.5; 20 | -moz-tab-size: 4; 21 | -o-tab-size: 4; 22 | tab-size: 4; 23 | -webkit-hyphens: none; 24 | -moz-hyphens: none; 25 | -ms-hyphens: none; 26 | hyphens: none; 27 | } 28 | 29 | pre[class*="language-"]::-moz-selection, 30 | pre[class*="language-"] ::-moz-selection, 31 | code[class*="language-"]::-moz-selection, 32 | code[class*="language-"] ::-moz-selection { 33 | background: #3c526d; 34 | } 35 | 36 | pre[class*="language-"]::selection, 37 | pre[class*="language-"] ::selection, 38 | code[class*="language-"]::selection, 39 | code[class*="language-"] ::selection { 40 | background: #3c526d; 41 | } 42 | 43 | /* Code blocks */ 44 | pre[class*="language-"] { 45 | padding: 1em; 46 | margin: 0.5em 0; 47 | overflow: auto; 48 | } 49 | 50 | :not(pre) > code[class*="language-"], 51 | pre[class*="language-"] { 52 | background: #111b27; 53 | } 54 | 55 | /* Inline code */ 56 | :not(pre) > code[class*="language-"] { 57 | padding: 0.1em 0.3em; 58 | border-radius: 0.3em; 59 | white-space: normal; 60 | } 61 | 62 | .token.comment, 63 | .token.prolog, 64 | .token.doctype, 65 | .token.cdata { 66 | color: #8da1b9; 67 | } 68 | 69 | .token.punctuation { 70 | color: #e3eaf2; 71 | } 72 | 73 | .token.delimiter.important, 74 | .token.selector .parent, 75 | .token.tag, 76 | .token.tag .token.punctuation { 77 | color: #66cccc; 78 | } 79 | 80 | .token.attr-name, 81 | .token.boolean, 82 | .token.boolean.important, 83 | .token.number, 84 | .token.constant, 85 | .token.selector .token.attribute { 86 | color: #e6d37a; 87 | } 88 | 89 | .token.class-name, 90 | .token.key, 91 | .token.parameter, 92 | .token.property, 93 | .token.property-access, 94 | .token.variable { 95 | color: #6cb8e6; 96 | } 97 | 98 | .token.attr-value, 99 | .token.inserted, 100 | .token.color, 101 | .token.selector .token.value, 102 | .token.string, 103 | .token.string .token.url-link { 104 | color: #91d076; 105 | } 106 | 107 | .token.builtin, 108 | .token.keyword-array, 109 | .token.package, 110 | .token.regex { 111 | color: #f4adf4; 112 | } 113 | 114 | .token.function, 115 | .token.selector .token.class, 116 | .token.selector .token.id { 117 | color: #c699e3; 118 | } 119 | 120 | .token.atrule .token.rule, 121 | .token.combinator, 122 | .token.keyword, 123 | .token.operator, 124 | .token.pseudo-class, 125 | .token.pseudo-element, 126 | .token.selector, 127 | .token.unit { 128 | color: #e9ae7e; 129 | } 130 | 131 | .token.deleted, 132 | .token.important { 133 | color: #cd6660; 134 | } 135 | 136 | .token.keyword-this, 137 | .token.this { 138 | color: #6cb8e6; 139 | } 140 | 141 | .token.important, 142 | .token.keyword-this, 143 | .token.this, 144 | .token.bold { 145 | font-weight: bold; 146 | } 147 | 148 | .token.delimiter.important { 149 | font-weight: inherit; 150 | } 151 | 152 | .token.italic { 153 | font-style: italic; 154 | } 155 | 156 | .token.entity { 157 | cursor: help; 158 | } 159 | 160 | .language-markdown .token.title, 161 | .language-markdown .token.title .token.punctuation { 162 | color: #6cb8e6; 163 | font-weight: bold; 164 | } 165 | 166 | .language-markdown .token.blockquote.punctuation { 167 | color: #f4adf4; 168 | } 169 | 170 | .language-markdown .token.code { 171 | color: #66cccc; 172 | } 173 | 174 | .language-markdown .token.hr.punctuation { 175 | color: #6cb8e6; 176 | } 177 | 178 | .language-markdown .token.url .token.content { 179 | color: #91d076; 180 | } 181 | 182 | .language-markdown .token.url-link { 183 | color: #e6d37a; 184 | } 185 | 186 | .language-markdown .token.list.punctuation { 187 | color: #f4adf4; 188 | } 189 | 190 | .language-markdown .token.table-header { 191 | color: #e3eaf2; 192 | } 193 | 194 | .language-json .token.operator { 195 | color: #e3eaf2; 196 | } 197 | 198 | .language-scss .token.variable { 199 | color: #66cccc; 200 | } 201 | 202 | /* overrides color-values for the Show Invisibles plugin 203 | * https://prismjs.com/plugins/show-invisibles/ 204 | */ 205 | .token.token.tab:not(:empty):before, 206 | .token.token.cr:before, 207 | .token.token.lf:before, 208 | .token.token.space:before { 209 | color: #8da1b9; 210 | } 211 | 212 | /* overrides color-values for the Toolbar plugin 213 | * https://prismjs.com/plugins/toolbar/ 214 | */ 215 | div.code-toolbar > .toolbar.toolbar > .toolbar-item > a, 216 | div.code-toolbar > .toolbar.toolbar > .toolbar-item > button { 217 | color: #111b27; 218 | background: #6cb8e6; 219 | } 220 | 221 | div.code-toolbar > .toolbar.toolbar > .toolbar-item > a:hover, 222 | div.code-toolbar > .toolbar.toolbar > .toolbar-item > a:focus, 223 | div.code-toolbar > .toolbar.toolbar > .toolbar-item > button:hover, 224 | div.code-toolbar > .toolbar.toolbar > .toolbar-item > button:focus { 225 | color: #111b27; 226 | background: #6cb8e6da; 227 | text-decoration: none; 228 | } 229 | 230 | div.code-toolbar > .toolbar.toolbar > .toolbar-item > span, 231 | div.code-toolbar > .toolbar.toolbar > .toolbar-item > span:hover, 232 | div.code-toolbar > .toolbar.toolbar > .toolbar-item > span:focus { 233 | color: #111b27; 234 | background: #8da1b9; 235 | } 236 | 237 | /* overrides color-values for the Line Highlight plugin 238 | * http://prismjs.com/plugins/line-highlight/ 239 | */ 240 | .line-highlight.line-highlight { 241 | background: #3c526d5f; 242 | background: linear-gradient(to right, #3c526d5f 70%, #3c526d55); 243 | } 244 | 245 | .line-highlight.line-highlight:before, 246 | .line-highlight.line-highlight[data-end]:after { 247 | background-color: #8da1b9; 248 | color: #111b27; 249 | box-shadow: 0 1px #3c526d; 250 | } 251 | 252 | pre[id].linkable-line-numbers.linkable-line-numbers span.line-numbers-rows > span:hover:before { 253 | background-color: #8da1b918; 254 | } 255 | 256 | /* overrides color-values for the Line Numbers plugin 257 | * http://prismjs.com/plugins/line-numbers/ 258 | */ 259 | .line-numbers.line-numbers .line-numbers-rows { 260 | border-right: 1px solid #0b121b; 261 | background: #0b121b7a; 262 | } 263 | 264 | .line-numbers .line-numbers-rows > span:before { 265 | color: #8da1b9da; 266 | } 267 | 268 | /* overrides color-values for the Match Braces plugin 269 | * https://prismjs.com/plugins/match-braces/ 270 | */ 271 | .rainbow-braces .token.token.punctuation.brace-level-1, 272 | .rainbow-braces .token.token.punctuation.brace-level-5, 273 | .rainbow-braces .token.token.punctuation.brace-level-9 { 274 | color: #e6d37a; 275 | } 276 | 277 | .rainbow-braces .token.token.punctuation.brace-level-2, 278 | .rainbow-braces .token.token.punctuation.brace-level-6, 279 | .rainbow-braces .token.token.punctuation.brace-level-10 { 280 | color: #f4adf4; 281 | } 282 | 283 | .rainbow-braces .token.token.punctuation.brace-level-3, 284 | .rainbow-braces .token.token.punctuation.brace-level-7, 285 | .rainbow-braces .token.token.punctuation.brace-level-11 { 286 | color: #6cb8e6; 287 | } 288 | 289 | .rainbow-braces .token.token.punctuation.brace-level-4, 290 | .rainbow-braces .token.token.punctuation.brace-level-8, 291 | .rainbow-braces .token.token.punctuation.brace-level-12 { 292 | color: #c699e3; 293 | } 294 | 295 | /* overrides color-values for the Diff Highlight plugin 296 | * https://prismjs.com/plugins/diff-highlight/ 297 | */ 298 | pre.diff-highlight > code .token.token.deleted:not(.prefix), 299 | pre > code.diff-highlight .token.token.deleted:not(.prefix) { 300 | background-color: #cd66601f; 301 | } 302 | 303 | pre.diff-highlight > code .token.token.inserted:not(.prefix), 304 | pre > code.diff-highlight .token.token.inserted:not(.prefix) { 305 | background-color: #91d0761f; 306 | } 307 | 308 | /* overrides color-values for the Command Line plugin 309 | * https://prismjs.com/plugins/command-line/ 310 | */ 311 | .command-line .command-line-prompt { 312 | border-right: 1px solid #0b121b; 313 | } 314 | 315 | .command-line .command-line-prompt > span:before { 316 | color: #8da1b9da; 317 | } 318 | -------------------------------------------------------------------------------- /example/src/prism-themes/coy-without-shadows.css: -------------------------------------------------------------------------------- 1 | /** 2 | * Coy without shadows 3 | * Based on Tim Shedor's Coy theme for prism.js 4 | * Author: RunDevelopment 5 | */ 6 | 7 | code[class*="language-"], 8 | pre[class*="language-"] { 9 | color: black; 10 | background: none; 11 | font-family: Consolas, Monaco, 'Andale Mono', 'Ubuntu Mono', monospace; 12 | font-size: 1em; 13 | text-align: left; 14 | white-space: pre; 15 | word-spacing: normal; 16 | word-break: normal; 17 | word-wrap: normal; 18 | line-height: 1.5; 19 | 20 | -moz-tab-size: 4; 21 | -o-tab-size: 4; 22 | tab-size: 4; 23 | 24 | -webkit-hyphens: none; 25 | -moz-hyphens: none; 26 | -ms-hyphens: none; 27 | hyphens: none; 28 | } 29 | 30 | /* Code blocks */ 31 | pre[class*="language-"] { 32 | position: relative; 33 | border-left: 10px solid #358ccb; 34 | box-shadow: -1px 0 0 0 #358ccb, 0 0 0 1px #dfdfdf; 35 | background-color: #fdfdfd; 36 | background-image: linear-gradient(transparent 50%, rgba(69, 142, 209, 0.04) 50%); 37 | background-size: 3em 3em; 38 | background-origin: content-box; 39 | background-attachment: local; 40 | margin: .5em 0; 41 | padding: 0 1em; 42 | } 43 | 44 | pre[class*="language-"] > code { 45 | display: block; 46 | } 47 | 48 | /* Inline code */ 49 | :not(pre) > code[class*="language-"] { 50 | position: relative; 51 | padding: .2em; 52 | border-radius: 0.3em; 53 | color: #c92c2c; 54 | border: 1px solid rgba(0, 0, 0, 0.1); 55 | display: inline; 56 | white-space: normal; 57 | background-color: #fdfdfd; 58 | -webkit-box-sizing: border-box; 59 | -moz-box-sizing: border-box; 60 | box-sizing: border-box; 61 | } 62 | 63 | .token.comment, 64 | .token.block-comment, 65 | .token.prolog, 66 | .token.doctype, 67 | .token.cdata { 68 | color: #7D8B99; 69 | } 70 | 71 | .token.punctuation { 72 | color: #5F6364; 73 | } 74 | 75 | .token.property, 76 | .token.tag, 77 | .token.boolean, 78 | .token.number, 79 | .token.function-name, 80 | .token.constant, 81 | .token.symbol, 82 | .token.deleted { 83 | color: #c92c2c; 84 | } 85 | 86 | .token.selector, 87 | .token.attr-name, 88 | .token.string, 89 | .token.char, 90 | .token.function, 91 | .token.builtin, 92 | .token.inserted { 93 | color: #2f9c0a; 94 | } 95 | 96 | .token.operator, 97 | .token.entity, 98 | .token.url, 99 | .token.variable { 100 | color: #a67f59; 101 | background: rgba(255, 255, 255, 0.5); 102 | } 103 | 104 | .token.atrule, 105 | .token.attr-value, 106 | .token.keyword, 107 | .token.class-name { 108 | color: #1990b8; 109 | } 110 | 111 | .token.regex, 112 | .token.important { 113 | color: #e90; 114 | } 115 | 116 | .language-css .token.string, 117 | .style .token.string { 118 | color: #a67f59; 119 | background: rgba(255, 255, 255, 0.5); 120 | } 121 | 122 | .token.important { 123 | font-weight: normal; 124 | } 125 | 126 | .token.bold { 127 | font-weight: bold; 128 | } 129 | 130 | .token.italic { 131 | font-style: italic; 132 | } 133 | 134 | .token.entity { 135 | cursor: help; 136 | } 137 | 138 | .token.namespace { 139 | opacity: .7; 140 | } 141 | -------------------------------------------------------------------------------- /example/src/prism-themes/darcula.css: -------------------------------------------------------------------------------- 1 | /** 2 | * Darcula theme 3 | * 4 | * Adapted from a theme based on: 5 | * IntelliJ Darcula Theme (https://github.com/bulenkov/Darcula) 6 | * 7 | * @author Alexandre Paradis 8 | * @version 1.0 9 | */ 10 | 11 | code[class*="language-"], 12 | pre[class*="language-"] { 13 | color: #a9b7c6; 14 | font-family: Consolas, Monaco, 'Andale Mono', monospace; 15 | direction: ltr; 16 | text-align: left; 17 | white-space: pre; 18 | word-spacing: normal; 19 | word-break: normal; 20 | line-height: 1.5; 21 | 22 | -moz-tab-size: 4; 23 | -o-tab-size: 4; 24 | tab-size: 4; 25 | 26 | -webkit-hyphens: none; 27 | -moz-hyphens: none; 28 | -ms-hyphens: none; 29 | hyphens: none; 30 | } 31 | 32 | pre[class*="language-"]::-moz-selection, pre[class*="language-"] ::-moz-selection, 33 | code[class*="language-"]::-moz-selection, code[class*="language-"] ::-moz-selection { 34 | color: inherit; 35 | background: rgba(33, 66, 131, .85); 36 | } 37 | 38 | pre[class*="language-"]::selection, pre[class*="language-"] ::selection, 39 | code[class*="language-"]::selection, code[class*="language-"] ::selection { 40 | color: inherit; 41 | background: rgba(33, 66, 131, .85); 42 | } 43 | 44 | /* Code blocks */ 45 | pre[class*="language-"] { 46 | padding: 1em; 47 | margin: .5em 0; 48 | overflow: auto; 49 | } 50 | 51 | :not(pre) > code[class*="language-"], 52 | pre[class*="language-"] { 53 | background: #2b2b2b; 54 | } 55 | 56 | /* Inline code */ 57 | :not(pre) > code[class*="language-"] { 58 | padding: .1em; 59 | border-radius: .3em; 60 | } 61 | 62 | .token.comment, 63 | .token.prolog, 64 | .token.cdata { 65 | color: #808080; 66 | } 67 | 68 | .token.delimiter, 69 | .token.boolean, 70 | .token.keyword, 71 | .token.selector, 72 | .token.important, 73 | .token.atrule { 74 | color: #cc7832; 75 | } 76 | 77 | .token.operator, 78 | .token.punctuation, 79 | .token.attr-name { 80 | color: #a9b7c6; 81 | } 82 | 83 | .token.tag, 84 | .token.tag .punctuation, 85 | .token.doctype, 86 | .token.builtin { 87 | color: #e8bf6a; 88 | } 89 | 90 | .token.entity, 91 | .token.number, 92 | .token.symbol { 93 | color: #6897bb; 94 | } 95 | 96 | .token.property, 97 | .token.constant, 98 | .token.variable { 99 | color: #9876aa; 100 | } 101 | 102 | .token.string, 103 | .token.char { 104 | color: #6a8759; 105 | } 106 | 107 | .token.attr-value, 108 | .token.attr-value .punctuation { 109 | color: #a5c261; 110 | } 111 | 112 | .token.attr-value .punctuation:first-child { 113 | color: #a9b7c6; 114 | } 115 | 116 | .token.url { 117 | color: #287bde; 118 | text-decoration: underline; 119 | } 120 | 121 | .token.function { 122 | color: #ffc66d; 123 | } 124 | 125 | .token.regex { 126 | background: #364135; 127 | } 128 | 129 | .token.bold { 130 | font-weight: bold; 131 | } 132 | 133 | .token.italic { 134 | font-style: italic; 135 | } 136 | 137 | .token.inserted { 138 | background: #294436; 139 | } 140 | 141 | .token.deleted { 142 | background: #484a4a; 143 | } 144 | 145 | code.language-css .token.property, 146 | code.language-css .token.property + .token.punctuation { 147 | color: #a9b7c6; 148 | } 149 | 150 | code.language-css .token.id { 151 | color: #ffc66d; 152 | } 153 | 154 | code.language-css .token.selector > .token.class, 155 | code.language-css .token.selector > .token.attribute, 156 | code.language-css .token.selector > .token.pseudo-class, 157 | code.language-css .token.selector > .token.pseudo-element { 158 | color: #ffc66d; 159 | } 160 | -------------------------------------------------------------------------------- /example/src/prism-themes/dracula.css: -------------------------------------------------------------------------------- 1 | /** 2 | * Dracula Theme originally by Zeno Rocha [@zenorocha] 3 | * https://draculatheme.com/ 4 | * 5 | * Ported for PrismJS by Albert Vallverdu [@byverdu] 6 | */ 7 | 8 | code[class*="language-"], 9 | pre[class*="language-"] { 10 | color: #f8f8f2; 11 | background: none; 12 | text-shadow: 0 1px rgba(0, 0, 0, 0.3); 13 | font-family: Consolas, Monaco, 'Andale Mono', 'Ubuntu Mono', monospace; 14 | text-align: left; 15 | white-space: pre; 16 | word-spacing: normal; 17 | word-break: normal; 18 | word-wrap: normal; 19 | line-height: 1.5; 20 | -moz-tab-size: 4; 21 | -o-tab-size: 4; 22 | tab-size: 4; 23 | -webkit-hyphens: none; 24 | -moz-hyphens: none; 25 | -ms-hyphens: none; 26 | hyphens: none; 27 | } 28 | 29 | /* Code blocks */ 30 | pre[class*="language-"] { 31 | padding: 1em; 32 | margin: .5em 0; 33 | overflow: auto; 34 | border-radius: 0.3em; 35 | } 36 | 37 | :not(pre) > code[class*="language-"], 38 | pre[class*="language-"] { 39 | background: #282a36; 40 | } 41 | 42 | /* Inline code */ 43 | :not(pre) > code[class*="language-"] { 44 | padding: .1em; 45 | border-radius: .3em; 46 | white-space: normal; 47 | } 48 | 49 | .token.comment, 50 | .token.prolog, 51 | .token.doctype, 52 | .token.cdata { 53 | color: #6272a4; 54 | } 55 | 56 | .token.punctuation { 57 | color: #f8f8f2; 58 | } 59 | 60 | .namespace { 61 | opacity: .7; 62 | } 63 | 64 | .token.property, 65 | .token.tag, 66 | .token.constant, 67 | .token.symbol, 68 | .token.deleted { 69 | color: #ff79c6; 70 | } 71 | 72 | .token.boolean, 73 | .token.number { 74 | color: #bd93f9; 75 | } 76 | 77 | .token.selector, 78 | .token.attr-name, 79 | .token.string, 80 | .token.char, 81 | .token.builtin, 82 | .token.inserted { 83 | color: #50fa7b; 84 | } 85 | 86 | .token.operator, 87 | .token.entity, 88 | .token.url, 89 | .language-css .token.string, 90 | .style .token.string, 91 | .token.variable { 92 | color: #f8f8f2; 93 | } 94 | 95 | .token.atrule, 96 | .token.attr-value, 97 | .token.function, 98 | .token.class-name { 99 | color: #f1fa8c; 100 | } 101 | 102 | .token.keyword { 103 | color: #8be9fd; 104 | } 105 | 106 | .token.regex, 107 | .token.important { 108 | color: #ffb86c; 109 | } 110 | 111 | .token.important, 112 | .token.bold { 113 | font-weight: bold; 114 | } 115 | 116 | .token.italic { 117 | font-style: italic; 118 | } 119 | 120 | .token.entity { 121 | cursor: help; 122 | } 123 | -------------------------------------------------------------------------------- /example/src/prism-themes/duotone-dark.css: -------------------------------------------------------------------------------- 1 | /* 2 | Name: Duotone Dark 3 | Author: Simurai, adapted from DuoTone themes for Atom (http://simurai.com/projects/2016/01/01/duotone-themes) 4 | 5 | Conversion: Bram de Haan (http://atelierbram.github.io/Base2Tone-prism/output/prism/prism-base2tone-evening-dark.css) 6 | Generated with Base16 Builder (https://github.com/base16-builder/base16-builder) 7 | */ 8 | 9 | code[class*="language-"], 10 | pre[class*="language-"] { 11 | font-family: Consolas, Menlo, Monaco, "Andale Mono WT", "Andale Mono", "Lucida Console", "Lucida Sans Typewriter", "DejaVu Sans Mono", "Bitstream Vera Sans Mono", "Liberation Mono", "Nimbus Mono L", "Courier New", Courier, monospace; 12 | font-size: 14px; 13 | line-height: 1.375; 14 | direction: ltr; 15 | text-align: left; 16 | white-space: pre; 17 | word-spacing: normal; 18 | word-break: normal; 19 | 20 | -moz-tab-size: 4; 21 | -o-tab-size: 4; 22 | tab-size: 4; 23 | 24 | -webkit-hyphens: none; 25 | -moz-hyphens: none; 26 | -ms-hyphens: none; 27 | hyphens: none; 28 | background: #2a2734; 29 | color: #9a86fd; 30 | } 31 | 32 | pre > code[class*="language-"] { 33 | font-size: 1em; 34 | } 35 | 36 | pre[class*="language-"]::-moz-selection, pre[class*="language-"] ::-moz-selection, 37 | code[class*="language-"]::-moz-selection, code[class*="language-"] ::-moz-selection { 38 | text-shadow: none; 39 | background: #6a51e6; 40 | } 41 | 42 | pre[class*="language-"]::selection, pre[class*="language-"] ::selection, 43 | code[class*="language-"]::selection, code[class*="language-"] ::selection { 44 | text-shadow: none; 45 | background: #6a51e6; 46 | } 47 | 48 | /* Code blocks */ 49 | pre[class*="language-"] { 50 | padding: 1em; 51 | margin: .5em 0; 52 | overflow: auto; 53 | } 54 | 55 | /* Inline code */ 56 | :not(pre) > code[class*="language-"] { 57 | padding: .1em; 58 | border-radius: .3em; 59 | } 60 | 61 | .token.comment, 62 | .token.prolog, 63 | .token.doctype, 64 | .token.cdata { 65 | color: #6c6783; 66 | } 67 | 68 | .token.punctuation { 69 | color: #6c6783; 70 | } 71 | 72 | .token.namespace { 73 | opacity: .7; 74 | } 75 | 76 | .token.tag, 77 | .token.operator, 78 | .token.number { 79 | color: #e09142; 80 | } 81 | 82 | .token.property, 83 | .token.function { 84 | color: #9a86fd; 85 | } 86 | 87 | .token.tag-id, 88 | .token.selector, 89 | .token.atrule-id { 90 | color: #eeebff; 91 | } 92 | 93 | code.language-javascript, 94 | .token.attr-name { 95 | color: #c4b9fe; 96 | } 97 | 98 | code.language-css, 99 | code.language-scss, 100 | .token.boolean, 101 | .token.string, 102 | .token.entity, 103 | .token.url, 104 | .language-css .token.string, 105 | .language-scss .token.string, 106 | .style .token.string, 107 | .token.attr-value, 108 | .token.keyword, 109 | .token.control, 110 | .token.directive, 111 | .token.unit, 112 | .token.statement, 113 | .token.regex, 114 | .token.atrule { 115 | color: #ffcc99; 116 | } 117 | 118 | .token.placeholder, 119 | .token.variable { 120 | color: #ffcc99; 121 | } 122 | 123 | .token.deleted { 124 | text-decoration: line-through; 125 | } 126 | 127 | .token.inserted { 128 | border-bottom: 1px dotted #eeebff; 129 | text-decoration: none; 130 | } 131 | 132 | .token.italic { 133 | font-style: italic; 134 | } 135 | 136 | .token.important, 137 | .token.bold { 138 | font-weight: bold; 139 | } 140 | 141 | .token.important { 142 | color: #c4b9fe; 143 | } 144 | 145 | .token.entity { 146 | cursor: help; 147 | } 148 | 149 | pre > code.highlight { 150 | outline: .4em solid #8a75f5; 151 | outline-offset: .4em; 152 | } 153 | 154 | /* overrides color-values for the Line Numbers plugin 155 | * http://prismjs.com/plugins/line-numbers/ 156 | */ 157 | .line-numbers.line-numbers .line-numbers-rows { 158 | border-right-color: #2c2937; 159 | } 160 | 161 | .line-numbers .line-numbers-rows > span:before { 162 | color: #3c3949; 163 | } 164 | 165 | /* overrides color-values for the Line Highlight plugin 166 | * http://prismjs.com/plugins/line-highlight/ 167 | */ 168 | .line-highlight.line-highlight { 169 | background: rgba(224, 145, 66, 0.2); 170 | background: -webkit-linear-gradient(left, rgba(224, 145, 66, 0.2) 70%, rgba(224, 145, 66, 0)); 171 | background: linear-gradient(to right, rgba(224, 145, 66, 0.2) 70%, rgba(224, 145, 66, 0)); 172 | } 173 | -------------------------------------------------------------------------------- /example/src/prism-themes/duotone-earth.css: -------------------------------------------------------------------------------- 1 | /* 2 | Name: Duotone Earth 3 | Author: Simurai, adapted from DuoTone themes for Atom (http://simurai.com/projects/2016/01/01/duotone-themes) 4 | 5 | Conversion: Bram de Haan (http://atelierbram.github.io/Base2Tone-prism/output/prism/prism-base2tone-earth-dark.css) 6 | Generated with Base16 Builder (https://github.com/base16-builder/base16-builder) 7 | */ 8 | 9 | code[class*="language-"], 10 | pre[class*="language-"] { 11 | font-family: Consolas, Menlo, Monaco, "Andale Mono WT", "Andale Mono", "Lucida Console", "Lucida Sans Typewriter", "DejaVu Sans Mono", "Bitstream Vera Sans Mono", "Liberation Mono", "Nimbus Mono L", "Courier New", Courier, monospace; 12 | font-size: 14px; 13 | line-height: 1.375; 14 | direction: ltr; 15 | text-align: left; 16 | white-space: pre; 17 | word-spacing: normal; 18 | word-break: normal; 19 | 20 | -moz-tab-size: 4; 21 | -o-tab-size: 4; 22 | tab-size: 4; 23 | 24 | -webkit-hyphens: none; 25 | -moz-hyphens: none; 26 | -ms-hyphens: none; 27 | hyphens: none; 28 | background: #322d29; 29 | color: #88786d; 30 | } 31 | 32 | pre > code[class*="language-"] { 33 | font-size: 1em; 34 | } 35 | 36 | pre[class*="language-"]::-moz-selection, pre[class*="language-"] ::-moz-selection, 37 | code[class*="language-"]::-moz-selection, code[class*="language-"] ::-moz-selection { 38 | text-shadow: none; 39 | background: #6f5849; 40 | } 41 | 42 | pre[class*="language-"]::selection, pre[class*="language-"] ::selection, 43 | code[class*="language-"]::selection, code[class*="language-"] ::selection { 44 | text-shadow: none; 45 | background: #6f5849; 46 | } 47 | 48 | /* Code blocks */ 49 | pre[class*="language-"] { 50 | padding: 1em; 51 | margin: .5em 0; 52 | overflow: auto; 53 | } 54 | 55 | /* Inline code */ 56 | :not(pre) > code[class*="language-"] { 57 | padding: .1em; 58 | border-radius: .3em; 59 | } 60 | 61 | .token.comment, 62 | .token.prolog, 63 | .token.doctype, 64 | .token.cdata { 65 | color: #6a5f58; 66 | } 67 | 68 | .token.punctuation { 69 | color: #6a5f58; 70 | } 71 | 72 | .token.namespace { 73 | opacity: .7; 74 | } 75 | 76 | .token.tag, 77 | .token.operator, 78 | .token.number { 79 | color: #bfa05a; 80 | } 81 | 82 | .token.property, 83 | .token.function { 84 | color: #88786d; 85 | } 86 | 87 | .token.tag-id, 88 | .token.selector, 89 | .token.atrule-id { 90 | color: #fff3eb; 91 | } 92 | 93 | code.language-javascript, 94 | .token.attr-name { 95 | color: #a48774; 96 | } 97 | 98 | code.language-css, 99 | code.language-scss, 100 | .token.boolean, 101 | .token.string, 102 | .token.entity, 103 | .token.url, 104 | .language-css .token.string, 105 | .language-scss .token.string, 106 | .style .token.string, 107 | .token.attr-value, 108 | .token.keyword, 109 | .token.control, 110 | .token.directive, 111 | .token.unit, 112 | .token.statement, 113 | .token.regex, 114 | .token.atrule { 115 | color: #fcc440; 116 | } 117 | 118 | .token.placeholder, 119 | .token.variable { 120 | color: #fcc440; 121 | } 122 | 123 | .token.deleted { 124 | text-decoration: line-through; 125 | } 126 | 127 | .token.inserted { 128 | border-bottom: 1px dotted #fff3eb; 129 | text-decoration: none; 130 | } 131 | 132 | .token.italic { 133 | font-style: italic; 134 | } 135 | 136 | .token.important, 137 | .token.bold { 138 | font-weight: bold; 139 | } 140 | 141 | .token.important { 142 | color: #a48774; 143 | } 144 | 145 | .token.entity { 146 | cursor: help; 147 | } 148 | 149 | pre > code.highlight { 150 | outline: .4em solid #816d5f; 151 | outline-offset: .4em; 152 | } 153 | 154 | /* overrides color-values for the Line Numbers plugin 155 | * http://prismjs.com/plugins/line-numbers/ 156 | */ 157 | .line-numbers.line-numbers .line-numbers-rows { 158 | border-right-color: #35302b; 159 | } 160 | 161 | .line-numbers .line-numbers-rows > span:before { 162 | color: #46403d; 163 | } 164 | 165 | /* overrides color-values for the Line Highlight plugin 166 | * http://prismjs.com/plugins/line-highlight/ 167 | */ 168 | .line-highlight.line-highlight { 169 | background: rgba(191, 160, 90, 0.2); 170 | background: -webkit-linear-gradient(left, rgba(191, 160, 90, 0.2) 70%, rgba(191, 160, 90, 0)); 171 | background: linear-gradient(to right, rgba(191, 160, 90, 0.2) 70%, rgba(191, 160, 90, 0)); 172 | } 173 | -------------------------------------------------------------------------------- /example/src/prism-themes/duotone-forest.css: -------------------------------------------------------------------------------- 1 | /* 2 | Name: Duotone Forest 3 | Author: by Simurai, adapted from DuoTone themes for Atom (http://simurai.com/projects/2016/01/01/duotone-themes) 4 | 5 | Conversion: Bram de Haan (http://atelierbram.github.io/Base2Tone-prism/output/prism/prism-base2tone-forest-dark.css) 6 | Generated with Base16 Builder (https://github.com/base16-builder/base16-builder) 7 | */ 8 | 9 | code[class*="language-"], 10 | pre[class*="language-"] { 11 | font-family: Consolas, Menlo, Monaco, "Andale Mono WT", "Andale Mono", "Lucida Console", "Lucida Sans Typewriter", "DejaVu Sans Mono", "Bitstream Vera Sans Mono", "Liberation Mono", "Nimbus Mono L", "Courier New", Courier, monospace; 12 | font-size: 14px; 13 | line-height: 1.375; 14 | direction: ltr; 15 | text-align: left; 16 | white-space: pre; 17 | word-spacing: normal; 18 | word-break: normal; 19 | 20 | -moz-tab-size: 4; 21 | -o-tab-size: 4; 22 | tab-size: 4; 23 | 24 | -webkit-hyphens: none; 25 | -moz-hyphens: none; 26 | -ms-hyphens: none; 27 | hyphens: none; 28 | background: #2a2d2a; 29 | color: #687d68; 30 | } 31 | 32 | pre > code[class*="language-"] { 33 | font-size: 1em; 34 | } 35 | 36 | pre[class*="language-"]::-moz-selection, pre[class*="language-"] ::-moz-selection, 37 | code[class*="language-"]::-moz-selection, code[class*="language-"] ::-moz-selection { 38 | text-shadow: none; 39 | background: #435643; 40 | } 41 | 42 | pre[class*="language-"]::selection, pre[class*="language-"] ::selection, 43 | code[class*="language-"]::selection, code[class*="language-"] ::selection { 44 | text-shadow: none; 45 | background: #435643; 46 | } 47 | 48 | /* Code blocks */ 49 | pre[class*="language-"] { 50 | padding: 1em; 51 | margin: .5em 0; 52 | overflow: auto; 53 | } 54 | 55 | /* Inline code */ 56 | :not(pre) > code[class*="language-"] { 57 | padding: .1em; 58 | border-radius: .3em; 59 | } 60 | 61 | .token.comment, 62 | .token.prolog, 63 | .token.doctype, 64 | .token.cdata { 65 | color: #535f53; 66 | } 67 | 68 | .token.punctuation { 69 | color: #535f53; 70 | } 71 | 72 | .token.namespace { 73 | opacity: .7; 74 | } 75 | 76 | .token.tag, 77 | .token.operator, 78 | .token.number { 79 | color: #a2b34d; 80 | } 81 | 82 | .token.property, 83 | .token.function { 84 | color: #687d68; 85 | } 86 | 87 | .token.tag-id, 88 | .token.selector, 89 | .token.atrule-id { 90 | color: #f0fff0; 91 | } 92 | 93 | code.language-javascript, 94 | .token.attr-name { 95 | color: #b3d6b3; 96 | } 97 | 98 | code.language-css, 99 | code.language-scss, 100 | .token.boolean, 101 | .token.string, 102 | .token.entity, 103 | .token.url, 104 | .language-css .token.string, 105 | .language-scss .token.string, 106 | .style .token.string, 107 | .token.attr-value, 108 | .token.keyword, 109 | .token.control, 110 | .token.directive, 111 | .token.unit, 112 | .token.statement, 113 | .token.regex, 114 | .token.atrule { 115 | color: #e5fb79; 116 | } 117 | 118 | .token.placeholder, 119 | .token.variable { 120 | color: #e5fb79; 121 | } 122 | 123 | .token.deleted { 124 | text-decoration: line-through; 125 | } 126 | 127 | .token.inserted { 128 | border-bottom: 1px dotted #f0fff0; 129 | text-decoration: none; 130 | } 131 | 132 | .token.italic { 133 | font-style: italic; 134 | } 135 | 136 | .token.important, 137 | .token.bold { 138 | font-weight: bold; 139 | } 140 | 141 | .token.important { 142 | color: #b3d6b3; 143 | } 144 | 145 | .token.entity { 146 | cursor: help; 147 | } 148 | 149 | pre > code.highlight { 150 | outline: .4em solid #5c705c; 151 | outline-offset: .4em; 152 | } 153 | 154 | /* overrides color-values for the Line Numbers plugin 155 | * http://prismjs.com/plugins/line-numbers/ 156 | */ 157 | .line-numbers.line-numbers .line-numbers-rows { 158 | border-right-color: #2c302c; 159 | } 160 | 161 | .line-numbers .line-numbers-rows > span:before { 162 | color: #3b423b; 163 | } 164 | 165 | /* overrides color-values for the Line Highlight plugin 166 | * http://prismjs.com/plugins/line-highlight/ 167 | */ 168 | .line-highlight.line-highlight { 169 | background: rgba(162, 179, 77, 0.2); 170 | background: -webkit-linear-gradient(left, rgba(162, 179, 77, 0.2) 70%, rgba(162, 179, 77, 0)); 171 | background: linear-gradient(to right, rgba(162, 179, 77, 0.2) 70%, rgba(162, 179, 77, 0)); 172 | } 173 | -------------------------------------------------------------------------------- /example/src/prism-themes/duotone-light.css: -------------------------------------------------------------------------------- 1 | /* 2 | Name: Duotone Light 3 | Author: Simurai, adapted from DuoTone themes for Atom (http://simurai.com/projects/2016/01/01/duotone-themes) 4 | 5 | Conversion: Bram de Haan (http://atelierbram.github.io/Base2Tone-prism/output/prism/prism-base2tone-morning-light.css) 6 | Generated with Base16 Builder (https://github.com/base16-builder/base16-builder) 7 | */ 8 | 9 | code[class*="language-"], 10 | pre[class*="language-"] { 11 | font-family: Consolas, Menlo, Monaco, "Andale Mono WT", "Andale Mono", "Lucida Console", "Lucida Sans Typewriter", "DejaVu Sans Mono", "Bitstream Vera Sans Mono", "Liberation Mono", "Nimbus Mono L", "Courier New", Courier, monospace; 12 | font-size: 14px; 13 | line-height: 1.375; 14 | direction: ltr; 15 | text-align: left; 16 | white-space: pre; 17 | word-spacing: normal; 18 | word-break: normal; 19 | 20 | -moz-tab-size: 4; 21 | -o-tab-size: 4; 22 | tab-size: 4; 23 | 24 | -webkit-hyphens: none; 25 | -moz-hyphens: none; 26 | -ms-hyphens: none; 27 | hyphens: none; 28 | background: #faf8f5; 29 | color: #728fcb; 30 | } 31 | 32 | pre > code[class*="language-"] { 33 | font-size: 1em; 34 | } 35 | 36 | pre[class*="language-"]::-moz-selection, pre[class*="language-"] ::-moz-selection, 37 | code[class*="language-"]::-moz-selection, code[class*="language-"] ::-moz-selection { 38 | text-shadow: none; 39 | background: #faf8f5; 40 | } 41 | 42 | pre[class*="language-"]::selection, pre[class*="language-"] ::selection, 43 | code[class*="language-"]::selection, code[class*="language-"] ::selection { 44 | text-shadow: none; 45 | background: #faf8f5; 46 | } 47 | 48 | /* Code blocks */ 49 | pre[class*="language-"] { 50 | padding: 1em; 51 | margin: .5em 0; 52 | overflow: auto; 53 | } 54 | 55 | /* Inline code */ 56 | :not(pre) > code[class*="language-"] { 57 | padding: .1em; 58 | border-radius: .3em; 59 | } 60 | 61 | .token.comment, 62 | .token.prolog, 63 | .token.doctype, 64 | .token.cdata { 65 | color: #b6ad9a; 66 | } 67 | 68 | .token.punctuation { 69 | color: #b6ad9a; 70 | } 71 | 72 | .token.namespace { 73 | opacity: .7; 74 | } 75 | 76 | .token.tag, 77 | .token.operator, 78 | .token.number { 79 | color: #063289; 80 | } 81 | 82 | .token.property, 83 | .token.function { 84 | color: #b29762; 85 | } 86 | 87 | .token.tag-id, 88 | .token.selector, 89 | .token.atrule-id { 90 | color: #2d2006; 91 | } 92 | 93 | code.language-javascript, 94 | .token.attr-name { 95 | color: #896724; 96 | } 97 | 98 | code.language-css, 99 | code.language-scss, 100 | .token.boolean, 101 | .token.string, 102 | .token.entity, 103 | .token.url, 104 | .language-css .token.string, 105 | .language-scss .token.string, 106 | .style .token.string, 107 | .token.attr-value, 108 | .token.keyword, 109 | .token.control, 110 | .token.directive, 111 | .token.unit, 112 | .token.statement, 113 | .token.regex, 114 | .token.atrule { 115 | color: #728fcb; 116 | } 117 | 118 | .token.placeholder, 119 | .token.variable { 120 | color: #93abdc; 121 | } 122 | 123 | .token.deleted { 124 | text-decoration: line-through; 125 | } 126 | 127 | .token.inserted { 128 | border-bottom: 1px dotted #2d2006; 129 | text-decoration: none; 130 | } 131 | 132 | .token.italic { 133 | font-style: italic; 134 | } 135 | 136 | .token.important, 137 | .token.bold { 138 | font-weight: bold; 139 | } 140 | 141 | .token.important { 142 | color: #896724; 143 | } 144 | 145 | .token.entity { 146 | cursor: help; 147 | } 148 | 149 | pre > code.highlight { 150 | outline: .4em solid #896724; 151 | outline-offset: .4em; 152 | } 153 | 154 | /* overrides color-values for the Line Numbers plugin 155 | * http://prismjs.com/plugins/line-numbers/ 156 | */ 157 | .line-numbers.line-numbers .line-numbers-rows { 158 | border-right-color: #ece8de; 159 | } 160 | 161 | .line-numbers .line-numbers-rows > span:before { 162 | color: #cdc4b1; 163 | } 164 | 165 | /* overrides color-values for the Line Highlight plugin 166 | * http://prismjs.com/plugins/line-highlight/ 167 | */ 168 | .line-highlight.line-highlight { 169 | background: rgba(45, 32, 6, 0.2); 170 | background: -webkit-linear-gradient(left, rgba(45, 32, 6, 0.2) 70%, rgba(45, 32, 6, 0)); 171 | background: linear-gradient(to right, rgba(45, 32, 6, 0.2) 70%, rgba(45, 32, 6, 0)); 172 | } 173 | -------------------------------------------------------------------------------- /example/src/prism-themes/duotone-sea.css: -------------------------------------------------------------------------------- 1 | /* 2 | Name: Duotone Sea 3 | Author: by Simurai, adapted from DuoTone themes by Simurai for Atom (http://simurai.com/projects/2016/01/01/duotone-themes) 4 | 5 | Conversion: Bram de Haan (http://atelierbram.github.io/Base2Tone-prism/output/prism/prism-base2tone-sea-dark.css) 6 | Generated with Base16 Builder (https://github.com/base16-builder/base16-builder) 7 | */ 8 | 9 | code[class*="language-"], 10 | pre[class*="language-"] { 11 | font-family: Consolas, Menlo, Monaco, "Andale Mono WT", "Andale Mono", "Lucida Console", "Lucida Sans Typewriter", "DejaVu Sans Mono", "Bitstream Vera Sans Mono", "Liberation Mono", "Nimbus Mono L", "Courier New", Courier, monospace; 12 | font-size: 14px; 13 | line-height: 1.375; 14 | direction: ltr; 15 | text-align: left; 16 | white-space: pre; 17 | word-spacing: normal; 18 | word-break: normal; 19 | 20 | -moz-tab-size: 4; 21 | -o-tab-size: 4; 22 | tab-size: 4; 23 | 24 | -webkit-hyphens: none; 25 | -moz-hyphens: none; 26 | -ms-hyphens: none; 27 | hyphens: none; 28 | background: #1d262f; 29 | color: #57718e; 30 | } 31 | 32 | pre > code[class*="language-"] { 33 | font-size: 1em; 34 | } 35 | 36 | pre[class*="language-"]::-moz-selection, pre[class*="language-"] ::-moz-selection, 37 | code[class*="language-"]::-moz-selection, code[class*="language-"] ::-moz-selection { 38 | text-shadow: none; 39 | background: #004a9e; 40 | } 41 | 42 | pre[class*="language-"]::selection, pre[class*="language-"] ::selection, 43 | code[class*="language-"]::selection, code[class*="language-"] ::selection { 44 | text-shadow: none; 45 | background: #004a9e; 46 | } 47 | 48 | /* Code blocks */ 49 | pre[class*="language-"] { 50 | padding: 1em; 51 | margin: .5em 0; 52 | overflow: auto; 53 | } 54 | 55 | /* Inline code */ 56 | :not(pre) > code[class*="language-"] { 57 | padding: .1em; 58 | border-radius: .3em; 59 | } 60 | 61 | .token.comment, 62 | .token.prolog, 63 | .token.doctype, 64 | .token.cdata { 65 | color: #4a5f78; 66 | } 67 | 68 | .token.punctuation { 69 | color: #4a5f78; 70 | } 71 | 72 | .token.namespace { 73 | opacity: .7; 74 | } 75 | 76 | .token.tag, 77 | .token.operator, 78 | .token.number { 79 | color: #0aa370; 80 | } 81 | 82 | .token.property, 83 | .token.function { 84 | color: #57718e; 85 | } 86 | 87 | .token.tag-id, 88 | .token.selector, 89 | .token.atrule-id { 90 | color: #ebf4ff; 91 | } 92 | 93 | code.language-javascript, 94 | .token.attr-name { 95 | color: #7eb6f6; 96 | } 97 | 98 | code.language-css, 99 | code.language-scss, 100 | .token.boolean, 101 | .token.string, 102 | .token.entity, 103 | .token.url, 104 | .language-css .token.string, 105 | .language-scss .token.string, 106 | .style .token.string, 107 | .token.attr-value, 108 | .token.keyword, 109 | .token.control, 110 | .token.directive, 111 | .token.unit, 112 | .token.statement, 113 | .token.regex, 114 | .token.atrule { 115 | color: #47ebb4; 116 | } 117 | 118 | .token.placeholder, 119 | .token.variable { 120 | color: #47ebb4; 121 | } 122 | 123 | .token.deleted { 124 | text-decoration: line-through; 125 | } 126 | 127 | .token.inserted { 128 | border-bottom: 1px dotted #ebf4ff; 129 | text-decoration: none; 130 | } 131 | 132 | .token.italic { 133 | font-style: italic; 134 | } 135 | 136 | .token.important, 137 | .token.bold { 138 | font-weight: bold; 139 | } 140 | 141 | .token.important { 142 | color: #7eb6f6; 143 | } 144 | 145 | .token.entity { 146 | cursor: help; 147 | } 148 | 149 | pre > code.highlight { 150 | outline: .4em solid #34659d; 151 | outline-offset: .4em; 152 | } 153 | 154 | /* overrides color-values for the Line Numbers plugin 155 | * http://prismjs.com/plugins/line-numbers/ 156 | */ 157 | .line-numbers.line-numbers .line-numbers-rows { 158 | border-right-color: #1f2932; 159 | } 160 | 161 | .line-numbers .line-numbers-rows > span:before { 162 | color: #2c3847; 163 | } 164 | 165 | /* overrides color-values for the Line Highlight plugin 166 | * http://prismjs.com/plugins/line-highlight/ 167 | */ 168 | .line-highlight.line-highlight { 169 | background: rgba(10, 163, 112, 0.2); 170 | background: -webkit-linear-gradient(left, rgba(10, 163, 112, 0.2) 70%, rgba(10, 163, 112, 0)); 171 | background: linear-gradient(to right, rgba(10, 163, 112, 0.2) 70%, rgba(10, 163, 112, 0)); 172 | } 173 | -------------------------------------------------------------------------------- /example/src/prism-themes/duotone-space.css: -------------------------------------------------------------------------------- 1 | /* 2 | Name: Duotone Space 3 | Author: Simurai, adapted from DuoTone themes for Atom (http://simurai.com/projects/2016/01/01/duotone-themes) 4 | 5 | Conversion: Bram de Haan (http://atelierbram.github.io/Base2Tone-prism/output/prism/prism-base2tone-space-dark.css) 6 | Generated with Base16 Builder (https://github.com/base16-builder/base16-builder) 7 | */ 8 | 9 | code[class*="language-"], 10 | pre[class*="language-"] { 11 | font-family: Consolas, Menlo, Monaco, "Andale Mono WT", "Andale Mono", "Lucida Console", "Lucida Sans Typewriter", "DejaVu Sans Mono", "Bitstream Vera Sans Mono", "Liberation Mono", "Nimbus Mono L", "Courier New", Courier, monospace; 12 | font-size: 14px; 13 | line-height: 1.375; 14 | direction: ltr; 15 | text-align: left; 16 | white-space: pre; 17 | word-spacing: normal; 18 | word-break: normal; 19 | 20 | -moz-tab-size: 4; 21 | -o-tab-size: 4; 22 | tab-size: 4; 23 | 24 | -webkit-hyphens: none; 25 | -moz-hyphens: none; 26 | -ms-hyphens: none; 27 | hyphens: none; 28 | background: #24242e; 29 | color: #767693; 30 | } 31 | 32 | pre > code[class*="language-"] { 33 | font-size: 1em; 34 | } 35 | 36 | pre[class*="language-"]::-moz-selection, pre[class*="language-"] ::-moz-selection, 37 | code[class*="language-"]::-moz-selection, code[class*="language-"] ::-moz-selection { 38 | text-shadow: none; 39 | background: #5151e6; 40 | } 41 | 42 | pre[class*="language-"]::selection, pre[class*="language-"] ::selection, 43 | code[class*="language-"]::selection, code[class*="language-"] ::selection { 44 | text-shadow: none; 45 | background: #5151e6; 46 | } 47 | 48 | /* Code blocks */ 49 | pre[class*="language-"] { 50 | padding: 1em; 51 | margin: .5em 0; 52 | overflow: auto; 53 | } 54 | 55 | /* Inline code */ 56 | :not(pre) > code[class*="language-"] { 57 | padding: .1em; 58 | border-radius: .3em; 59 | } 60 | 61 | .token.comment, 62 | .token.prolog, 63 | .token.doctype, 64 | .token.cdata { 65 | color: #5b5b76; 66 | } 67 | 68 | .token.punctuation { 69 | color: #5b5b76; 70 | } 71 | 72 | .token.namespace { 73 | opacity: .7; 74 | } 75 | 76 | .token.tag, 77 | .token.operator, 78 | .token.number { 79 | color: #dd672c; 80 | } 81 | 82 | .token.property, 83 | .token.function { 84 | color: #767693; 85 | } 86 | 87 | .token.tag-id, 88 | .token.selector, 89 | .token.atrule-id { 90 | color: #ebebff; 91 | } 92 | 93 | code.language-javascript, 94 | .token.attr-name { 95 | color: #aaaaca; 96 | } 97 | 98 | code.language-css, 99 | code.language-scss, 100 | .token.boolean, 101 | .token.string, 102 | .token.entity, 103 | .token.url, 104 | .language-css .token.string, 105 | .language-scss .token.string, 106 | .style .token.string, 107 | .token.attr-value, 108 | .token.keyword, 109 | .token.control, 110 | .token.directive, 111 | .token.unit, 112 | .token.statement, 113 | .token.regex, 114 | .token.atrule { 115 | color: #fe8c52; 116 | } 117 | 118 | .token.placeholder, 119 | .token.variable { 120 | color: #fe8c52; 121 | } 122 | 123 | .token.deleted { 124 | text-decoration: line-through; 125 | } 126 | 127 | .token.inserted { 128 | border-bottom: 1px dotted #ebebff; 129 | text-decoration: none; 130 | } 131 | 132 | .token.italic { 133 | font-style: italic; 134 | } 135 | 136 | .token.important, 137 | .token.bold { 138 | font-weight: bold; 139 | } 140 | 141 | .token.important { 142 | color: #aaaaca; 143 | } 144 | 145 | .token.entity { 146 | cursor: help; 147 | } 148 | 149 | pre > code.highlight { 150 | outline: .4em solid #7676f4; 151 | outline-offset: .4em; 152 | } 153 | 154 | /* overrides color-values for the Line Numbers plugin 155 | * http://prismjs.com/plugins/line-numbers/ 156 | */ 157 | .line-numbers.line-numbers .line-numbers-rows { 158 | border-right-color: #262631; 159 | } 160 | 161 | .line-numbers .line-numbers-rows > span:before { 162 | color: #393949; 163 | } 164 | 165 | /* overrides color-values for the Line Highlight plugin 166 | * http://prismjs.com/plugins/line-highlight/ 167 | */ 168 | .line-highlight.line-highlight { 169 | background: rgba(221, 103, 44, 0.2); 170 | background: -webkit-linear-gradient(left, rgba(221, 103, 44, 0.2) 70%, rgba(221, 103, 44, 0)); 171 | background: linear-gradient(to right, rgba(221, 103, 44, 0.2) 70%, rgba(221, 103, 44, 0)); 172 | } 173 | -------------------------------------------------------------------------------- /example/src/prism-themes/ghcolors.css: -------------------------------------------------------------------------------- 1 | /** 2 | * GHColors theme by Avi Aryan (http://aviaryan.in) 3 | * Inspired by Github syntax coloring 4 | */ 5 | 6 | code[class*="language-"], 7 | pre[class*="language-"] { 8 | color: #393A34; 9 | font-family: "Consolas", "Bitstream Vera Sans Mono", "Courier New", Courier, monospace; 10 | direction: ltr; 11 | text-align: left; 12 | white-space: pre; 13 | word-spacing: normal; 14 | word-break: normal; 15 | font-size: .9em; 16 | line-height: 1.2em; 17 | 18 | -moz-tab-size: 4; 19 | -o-tab-size: 4; 20 | tab-size: 4; 21 | 22 | -webkit-hyphens: none; 23 | -moz-hyphens: none; 24 | -ms-hyphens: none; 25 | hyphens: none; 26 | } 27 | 28 | pre > code[class*="language-"] { 29 | font-size: 1em; 30 | } 31 | 32 | pre[class*="language-"]::-moz-selection, pre[class*="language-"] ::-moz-selection, 33 | code[class*="language-"]::-moz-selection, code[class*="language-"] ::-moz-selection { 34 | background: #b3d4fc; 35 | } 36 | 37 | pre[class*="language-"]::selection, pre[class*="language-"] ::selection, 38 | code[class*="language-"]::selection, code[class*="language-"] ::selection { 39 | background: #b3d4fc; 40 | } 41 | 42 | /* Code blocks */ 43 | pre[class*="language-"] { 44 | padding: 1em; 45 | margin: .5em 0; 46 | overflow: auto; 47 | border: 1px solid #dddddd; 48 | background-color: white; 49 | } 50 | 51 | /* Inline code */ 52 | :not(pre) > code[class*="language-"] { 53 | padding: .2em; 54 | padding-top: 1px; 55 | padding-bottom: 1px; 56 | background: #f8f8f8; 57 | border: 1px solid #dddddd; 58 | } 59 | 60 | .token.comment, 61 | .token.prolog, 62 | .token.doctype, 63 | .token.cdata { 64 | color: #999988; 65 | font-style: italic; 66 | } 67 | 68 | .token.namespace { 69 | opacity: .7; 70 | } 71 | 72 | .token.string, 73 | .token.attr-value { 74 | color: #e3116c; 75 | } 76 | 77 | .token.punctuation, 78 | .token.operator { 79 | color: #393A34; /* no highlight */ 80 | } 81 | 82 | .token.entity, 83 | .token.url, 84 | .token.symbol, 85 | .token.number, 86 | .token.boolean, 87 | .token.variable, 88 | .token.constant, 89 | .token.property, 90 | .token.regex, 91 | .token.inserted { 92 | color: #36acaa; 93 | } 94 | 95 | .token.atrule, 96 | .token.keyword, 97 | .token.attr-name, 98 | .language-autohotkey .token.selector { 99 | color: #00a4db; 100 | } 101 | 102 | .token.function, 103 | .token.deleted, 104 | .language-autohotkey .token.tag { 105 | color: #9a050f; 106 | } 107 | 108 | .token.tag, 109 | .token.selector, 110 | .language-autohotkey .token.keyword { 111 | color: #00009f; 112 | } 113 | 114 | .token.important, 115 | .token.function, 116 | .token.bold { 117 | font-weight: bold; 118 | } 119 | 120 | .token.italic { 121 | font-style: italic; 122 | } 123 | -------------------------------------------------------------------------------- /example/src/prism-themes/gruvbox-dark.css: -------------------------------------------------------------------------------- 1 | /** 2 | * Gruvbox dark theme 3 | * 4 | * Adapted from a theme based on: 5 | * Vim Gruvbox dark Theme (https://github.com/morhetz/gruvbox) 6 | * 7 | * @author Azat S. 8 | * @version 1.0 9 | */ 10 | 11 | code[class*="language-"], 12 | pre[class*="language-"] { 13 | color: #ebdbb2; /* fg1 / fg */ 14 | font-family: Consolas, Monaco, "Andale Mono", monospace; 15 | direction: ltr; 16 | text-align: left; 17 | white-space: pre; 18 | word-spacing: normal; 19 | word-break: normal; 20 | line-height: 1.5; 21 | 22 | -moz-tab-size: 4; 23 | -o-tab-size: 4; 24 | tab-size: 4; 25 | 26 | -webkit-hyphens: none; 27 | -moz-hyphens: none; 28 | -ms-hyphens: none; 29 | hyphens: none; 30 | } 31 | 32 | pre[class*="language-"]::-moz-selection, 33 | pre[class*="language-"] ::-moz-selection, 34 | code[class*="language-"]::-moz-selection, 35 | code[class*="language-"] ::-moz-selection { 36 | color: #fbf1c7; /* fg0 */ 37 | background: #7c6f64; /* bg4 */ 38 | } 39 | 40 | pre[class*="language-"]::selection, 41 | pre[class*="language-"] ::selection, 42 | code[class*="language-"]::selection, 43 | code[class*="language-"] ::selection { 44 | color: #fbf1c7; /* fg0 */ 45 | background: #7c6f64; /* bg4 */ 46 | } 47 | 48 | /* Code blocks */ 49 | pre[class*="language-"] { 50 | padding: 1em; 51 | margin: 0.5em 0; 52 | overflow: auto; 53 | } 54 | 55 | :not(pre) > code[class*="language-"], 56 | pre[class*="language-"] { 57 | background: #1d2021; /* bg0_h */ 58 | } 59 | 60 | /* Inline code */ 61 | :not(pre) > code[class*="language-"] { 62 | padding: 0.1em; 63 | border-radius: 0.3em; 64 | } 65 | 66 | .token.comment, 67 | .token.prolog, 68 | .token.cdata { 69 | color: #a89984; /* fg4 / gray1 */ 70 | } 71 | 72 | .token.delimiter, 73 | .token.boolean, 74 | .token.keyword, 75 | .token.selector, 76 | .token.important, 77 | .token.atrule { 78 | color: #fb4934; /* red2 */ 79 | } 80 | 81 | .token.operator, 82 | .token.punctuation, 83 | .token.attr-name { 84 | color: #a89984; /* fg4 / gray1 */ 85 | } 86 | 87 | .token.tag, 88 | .token.tag .punctuation, 89 | .token.doctype, 90 | .token.builtin { 91 | color: #fabd2f; /* yellow2 */ 92 | } 93 | 94 | .token.entity, 95 | .token.number, 96 | .token.symbol { 97 | color: #d3869b; /* purple2 */ 98 | } 99 | 100 | .token.property, 101 | .token.constant, 102 | .token.variable { 103 | color: #fb4934; /* red2 */ 104 | } 105 | 106 | .token.string, 107 | .token.char { 108 | color: #b8bb26; /* green2 */ 109 | } 110 | 111 | .token.attr-value, 112 | .token.attr-value .punctuation { 113 | color: #a89984; /* fg4 / gray1 */ 114 | } 115 | 116 | .token.url { 117 | color: #b8bb26; /* green2 */ 118 | text-decoration: underline; 119 | } 120 | 121 | .token.function { 122 | color: #fabd2f; /* yellow2 */ 123 | } 124 | 125 | .token.regex { 126 | background: #b8bb26; /* green2 */ 127 | } 128 | 129 | .token.bold { 130 | font-weight: bold; 131 | } 132 | 133 | .token.italic { 134 | font-style: italic; 135 | } 136 | 137 | .token.inserted { 138 | background: #a89984; /* fg4 / gray1 */ 139 | } 140 | 141 | .token.deleted { 142 | background: #fb4934; /* red2 */ 143 | } 144 | 145 | -------------------------------------------------------------------------------- /example/src/prism-themes/gruvbox-light.css: -------------------------------------------------------------------------------- 1 | /** 2 | * Gruvbox light theme 3 | * 4 | * Based on Gruvbox: https://github.com/morhetz/gruvbox 5 | * Adapted from PrismJS gruvbox-dark theme: https://github.com/schnerring/prism-themes/blob/master/themes/prism-gruvbox-dark.css 6 | * 7 | * @author Michael Schnerring (https://schnerring.net) 8 | * @version 1.0 9 | */ 10 | 11 | code[class*="language-"], 12 | pre[class*="language-"] { 13 | color: #3c3836; /* fg1 / fg */ 14 | font-family: Consolas, Monaco, "Andale Mono", monospace; 15 | direction: ltr; 16 | text-align: left; 17 | white-space: pre; 18 | word-spacing: normal; 19 | word-break: normal; 20 | line-height: 1.5; 21 | 22 | -moz-tab-size: 4; 23 | -o-tab-size: 4; 24 | tab-size: 4; 25 | 26 | -webkit-hyphens: none; 27 | -moz-hyphens: none; 28 | -ms-hyphens: none; 29 | hyphens: none; 30 | } 31 | 32 | pre[class*="language-"]::-moz-selection, 33 | pre[class*="language-"] ::-moz-selection, 34 | code[class*="language-"]::-moz-selection, 35 | code[class*="language-"] ::-moz-selection { 36 | color: #282828; /* fg0 */ 37 | background: #a89984; /* bg4 */ 38 | } 39 | 40 | pre[class*="language-"]::selection, 41 | pre[class*="language-"] ::selection, 42 | code[class*="language-"]::selection, 43 | code[class*="language-"] ::selection { 44 | color: #282828; /* fg0 */ 45 | background: #a89984; /* bg4 */ 46 | } 47 | 48 | /* Code blocks */ 49 | pre[class*="language-"] { 50 | padding: 1em; 51 | margin: 0.5em 0; 52 | overflow: auto; 53 | } 54 | 55 | :not(pre) > code[class*="language-"], 56 | pre[class*="language-"] { 57 | background: #f9f5d7; /* bg0_h */ 58 | } 59 | 60 | /* Inline code */ 61 | :not(pre) > code[class*="language-"] { 62 | padding: 0.1em; 63 | border-radius: 0.3em; 64 | } 65 | 66 | .token.comment, 67 | .token.prolog, 68 | .token.cdata { 69 | color: #7c6f64; /* fg4 / gray1 */ 70 | } 71 | 72 | .token.delimiter, 73 | .token.boolean, 74 | .token.keyword, 75 | .token.selector, 76 | .token.important, 77 | .token.atrule { 78 | color: #9d0006; /* red2 */ 79 | } 80 | 81 | .token.operator, 82 | .token.punctuation, 83 | .token.attr-name { 84 | color: #7c6f64; /* fg4 / gray1 */ 85 | } 86 | 87 | .token.tag, 88 | .token.tag .punctuation, 89 | .token.doctype, 90 | .token.builtin { 91 | color: #b57614; /* yellow2 */ 92 | } 93 | 94 | .token.entity, 95 | .token.number, 96 | .token.symbol { 97 | color: #8f3f71; /* purple2 */ 98 | } 99 | 100 | .token.property, 101 | .token.constant, 102 | .token.variable { 103 | color: #9d0006; /* red2 */ 104 | } 105 | 106 | .token.string, 107 | .token.char { 108 | color: #797403; /* green2 */ 109 | } 110 | 111 | .token.attr-value, 112 | .token.attr-value .punctuation { 113 | color: #7c6f64; /* fg4 / gray1 */ 114 | } 115 | 116 | .token.url { 117 | color: #797403; /* green2 */ 118 | text-decoration: underline; 119 | } 120 | 121 | .token.function { 122 | color: #b57614; /* yellow2 */ 123 | } 124 | 125 | .token.regex { 126 | background: #797403; /* green2 */ 127 | } 128 | 129 | .token.bold { 130 | font-weight: bold; 131 | } 132 | 133 | .token.italic { 134 | font-style: italic; 135 | } 136 | 137 | .token.inserted { 138 | background: #7c6f64; /* fg4 / gray1 */ 139 | } 140 | 141 | .token.deleted { 142 | background: #9d0006; /* red2 */ 143 | } 144 | -------------------------------------------------------------------------------- /example/src/prism-themes/holi-theme.css: -------------------------------------------------------------------------------- 1 | /** 2 | * MIT License 3 | * Copyright (c) 2021 Ayush Saini 4 | * Holi Theme for prism.js 5 | * @author Ayush Saini <@AyushCodes on Twitter> 6 | */ 7 | 8 | code[class*='language-'], 9 | pre[class*='language-'] { 10 | color: #d6e7ff; 11 | background: #030314; 12 | text-shadow: none; 13 | font-family: Consolas, Monaco, "Andale Mono", "Ubuntu Mono", monospace; 14 | font-size: 1em; 15 | line-height: 1.5; 16 | letter-spacing: .2px; 17 | white-space: pre; 18 | word-spacing: normal; 19 | word-break: normal; 20 | word-wrap: normal; 21 | text-align: left; 22 | 23 | -moz-tab-size: 4; 24 | -o-tab-size: 4; 25 | tab-size: 4; 26 | 27 | -webkit-hyphens: none; 28 | -moz-hyphens: none; 29 | -ms-hyphens: none; 30 | hyphens: none; 31 | } 32 | 33 | pre[class*='language-']::-moz-selection, 34 | pre[class*='language-'] ::-moz-selection, 35 | code[class*='language-']::-moz-selection, 36 | code[class*='language-'] ::-moz-selection, 37 | pre[class*='language-']::selection, 38 | pre[class*='language-'] ::selection, 39 | code[class*='language-']::selection, 40 | code[class*='language-'] ::selection { 41 | color: inherit; 42 | background: #1d3b54; 43 | text-shadow: none; 44 | } 45 | 46 | pre[class*='language-'] { 47 | border: 1px solid #2a4555; 48 | border-radius: 5px; 49 | padding: 1.5em 1em; 50 | margin: 1em 0; 51 | overflow: auto; 52 | } 53 | 54 | :not(pre) > code[class*='language-'] { 55 | color: #f0f6f6; 56 | background: #2a4555; 57 | padding: 0.2em 0.3em; 58 | border-radius: 0.2em; 59 | box-decoration-break: clone; 60 | } 61 | 62 | .token.comment, 63 | .token.prolog, 64 | .token.doctype, 65 | .token.cdata { 66 | color: #446e69; 67 | } 68 | 69 | .token.punctuation { 70 | color: #d6b007; 71 | } 72 | 73 | .token.property, 74 | .token.tag, 75 | .token.boolean, 76 | .token.number, 77 | .token.constant, 78 | .token.symbol, 79 | .token.deleted { 80 | color: #d6e7ff; 81 | } 82 | 83 | .token.selector, 84 | .token.attr-name, 85 | .token.builtin, 86 | .token.inserted { 87 | color: #e60067; 88 | } 89 | 90 | .token.string, 91 | .token.char { 92 | color: #49c6ec; 93 | } 94 | 95 | .token.operator, 96 | .token.entity, 97 | .token.url, 98 | .language-css .token.string, 99 | .style .token.string { 100 | color: #ec8e01; 101 | background: transparent; 102 | } 103 | 104 | .token.atrule, 105 | .token.attr-value, 106 | .token.keyword { 107 | color: #0fe468; 108 | } 109 | 110 | .token.function, 111 | .token.class-name { 112 | color: #78f3e9; 113 | } 114 | 115 | .token.regex, 116 | .token.important, 117 | .token.variable { 118 | color: #d6e7ff; 119 | } 120 | -------------------------------------------------------------------------------- /example/src/prism-themes/hopscotch.css: -------------------------------------------------------------------------------- 1 | @import url(https://fonts.googleapis.com/css?family=Fira+Mono); 2 | /* 3 | * Hopscotch 4 | * by Jan T. Sott 5 | * https://github.com/idleberg/Hopscotch 6 | * 7 | * This work is licensed under the Creative Commons CC0 1.0 Universal License 8 | */ 9 | 10 | code[class*="language-"], 11 | pre[class*="language-"] { 12 | font-family: "Fira Mono", Menlo, Monaco, "Lucida Console", "Courier New", Courier, monospace; 13 | font-size: 16px; 14 | line-height: 1.375; 15 | direction: ltr; 16 | text-align: left; 17 | word-spacing: normal; 18 | 19 | -moz-tab-size: 4; 20 | -o-tab-size: 4; 21 | tab-size: 4; 22 | 23 | -webkit-hyphens: none; 24 | -moz-hyphens: none; 25 | -ms-hyphens: none; 26 | hyphens: none; 27 | white-space: pre; 28 | white-space: pre-wrap; 29 | word-break: break-all; 30 | word-wrap: break-word; 31 | background: #322931; 32 | color: #b9b5b8; 33 | } 34 | 35 | pre > code[class*="language-"] { 36 | font-size: 1em; 37 | } 38 | 39 | /* Code blocks */ 40 | pre[class*="language-"] { 41 | padding: 1em; 42 | margin: .5em 0; 43 | overflow: auto; 44 | } 45 | 46 | /* Inline code */ 47 | :not(pre) > code[class*="language-"] { 48 | padding: .1em; 49 | border-radius: .3em; 50 | } 51 | 52 | .token.comment, 53 | .token.prolog, 54 | .token.doctype, 55 | .token.cdata { 56 | color: #797379; 57 | } 58 | 59 | .token.punctuation { 60 | color: #b9b5b8; 61 | } 62 | 63 | .namespace { 64 | opacity: .7; 65 | } 66 | 67 | .token.null, 68 | .token.operator, 69 | .token.boolean, 70 | .token.number { 71 | color: #fd8b19; 72 | } 73 | 74 | .token.property { 75 | color: #fdcc59; 76 | } 77 | 78 | .token.tag { 79 | color: #1290bf; 80 | } 81 | 82 | .token.string { 83 | color: #149b93; 84 | } 85 | 86 | .token.selector { 87 | color: #c85e7c; 88 | } 89 | 90 | .token.attr-name { 91 | color: #fd8b19; 92 | } 93 | 94 | .token.entity, 95 | .token.url, 96 | .language-css .token.string, 97 | .style .token.string { 98 | color: #149b93; 99 | } 100 | 101 | .token.attr-value, 102 | .token.keyword, 103 | .token.control, 104 | .token.directive, 105 | .token.unit { 106 | color: #8fc13e; 107 | } 108 | 109 | .token.statement, 110 | .token.regex, 111 | .token.atrule { 112 | color: #149b93; 113 | } 114 | 115 | .token.placeholder, 116 | .token.variable { 117 | color: #1290bf; 118 | } 119 | 120 | .token.important { 121 | color: #dd464c; 122 | font-weight: bold; 123 | } 124 | 125 | .token.entity { 126 | cursor: help; 127 | } 128 | 129 | pre > code.highlight { 130 | outline: .4em solid red; 131 | outline-offset: .4em; 132 | } 133 | -------------------------------------------------------------------------------- /example/src/prism-themes/laserwave.css: -------------------------------------------------------------------------------- 1 | /* 2 | * Laserwave Theme originally by Jared Jones for Visual Studio Code 3 | * https://github.com/Jaredk3nt/laserwave 4 | * 5 | * Ported for PrismJS by Simon Jespersen [https://github.com/simjes] 6 | */ 7 | 8 | code[class*="language-"], 9 | pre[class*="language-"] { 10 | background: #27212e; 11 | color: #ffffff; 12 | font-family: Consolas, Monaco, "Andale Mono", "Ubuntu Mono", monospace; /* this is the default */ 13 | /* The following properties are standard, please leave them as they are */ 14 | font-size: 1em; 15 | direction: ltr; 16 | text-align: left; 17 | white-space: pre; 18 | word-spacing: normal; 19 | word-break: normal; 20 | line-height: 1.5; 21 | -moz-tab-size: 2; 22 | -o-tab-size: 2; 23 | tab-size: 2; 24 | /* The following properties are also standard */ 25 | -webkit-hyphens: none; 26 | -moz-hyphens: none; 27 | -ms-hyphens: none; 28 | hyphens: none; 29 | } 30 | 31 | code[class*="language-"]::-moz-selection, 32 | code[class*="language-"] ::-moz-selection, 33 | pre[class*="language-"]::-moz-selection, 34 | pre[class*="language-"] ::-moz-selection { 35 | background: #eb64b927; 36 | color: inherit; 37 | } 38 | 39 | code[class*="language-"]::selection, 40 | code[class*="language-"] ::selection, 41 | pre[class*="language-"]::selection, 42 | pre[class*="language-"] ::selection { 43 | background: #eb64b927; 44 | color: inherit; 45 | } 46 | 47 | /* Properties specific to code blocks */ 48 | pre[class*="language-"] { 49 | padding: 1em; /* this is standard */ 50 | margin: 0.5em 0; /* this is the default */ 51 | overflow: auto; /* this is standard */ 52 | border-radius: 0.5em; 53 | } 54 | 55 | /* Properties specific to inline code */ 56 | :not(pre) > code[class*="language-"] { 57 | padding: 0.2em 0.3em; 58 | border-radius: 0.5rem; 59 | white-space: normal; /* this is standard */ 60 | } 61 | 62 | .token.comment, 63 | .token.prolog, 64 | .token.cdata { 65 | color: #91889b; 66 | } 67 | 68 | .token.punctuation { 69 | color: #7b6995; 70 | } 71 | 72 | .token.builtin, 73 | .token.constant, 74 | .token.boolean { 75 | color: #ffe261; 76 | } 77 | 78 | .token.number { 79 | color: #b381c5; 80 | } 81 | 82 | .token.important, 83 | .token.atrule, 84 | .token.property, 85 | .token.keyword { 86 | color: #40b4c4; 87 | } 88 | 89 | .token.doctype, 90 | .token.operator, 91 | .token.inserted, 92 | .token.tag, 93 | .token.class-name, 94 | .token.symbol { 95 | color: #74dfc4; 96 | } 97 | 98 | .token.attr-name, 99 | .token.function, 100 | .token.deleted, 101 | .token.selector { 102 | color: #eb64b9; 103 | } 104 | 105 | .token.attr-value, 106 | .token.regex, 107 | .token.char, 108 | .token.string { 109 | color: #b4dce7; 110 | } 111 | 112 | .token.entity, 113 | .token.url, 114 | .token.variable { 115 | color: #ffffff; 116 | } 117 | 118 | /* The following rules are pretty similar across themes, but feel free to adjust them */ 119 | .token.bold { 120 | font-weight: bold; 121 | } 122 | 123 | .token.italic { 124 | font-style: italic; 125 | } 126 | 127 | .token.entity { 128 | cursor: help; 129 | } 130 | 131 | .token.namespace { 132 | opacity: 0.7; 133 | } 134 | -------------------------------------------------------------------------------- /example/src/prism-themes/lucario.css: -------------------------------------------------------------------------------- 1 | /** 2 | * Lucario Theme originally by Raphael Amorim [@raphamorim] 3 | * https://github.com/raphamorim/lucario 4 | * 5 | * Ported for PrismJS by Christopher Kapic [@christopher-kapic] 6 | */ 7 | 8 | code[class*="language-"], 9 | pre[class*="language-"] { 10 | color: #f8f8f2; 11 | background: none; 12 | text-shadow: 0 1px rgba(0, 0, 0, 0.3); 13 | font-family: Monaco, Consolas, 'Andale Mono', 'Ubuntu Mono', monospace; 14 | text-align: left; 15 | white-space: pre; 16 | word-spacing: normal; 17 | word-break: normal; 18 | word-wrap: normal; 19 | line-height: 1.5; 20 | -moz-tab-size: 4; 21 | -o-tab-size: 4; 22 | tab-size: 4; 23 | -webkit-hyphens: none; 24 | -moz-hyphens: none; 25 | -ms-hyphens: none; 26 | hyphens: none; 27 | } 28 | 29 | /* Code blocks */ 30 | pre[class*="language-"] { 31 | padding: 1em; 32 | margin: .5em 0; 33 | overflow: auto; 34 | border-radius: 0.3em; 35 | } 36 | 37 | :not(pre) > code[class*="language-"], 38 | pre[class*="language-"] { 39 | background: #263E52; 40 | } 41 | 42 | /* Inline code */ 43 | :not(pre) > code[class*="language-"] { 44 | padding: .1em; 45 | border-radius: .3em; 46 | white-space: normal; 47 | } 48 | 49 | .token.comment, 50 | .token.prolog, 51 | .token.doctype, 52 | .token.cdata { 53 | color: #5c98cd; 54 | } 55 | 56 | .token.punctuation { 57 | color: #f8f8f2; 58 | } 59 | 60 | .namespace { 61 | opacity: .7; 62 | } 63 | 64 | .token.property, 65 | .token.tag, 66 | .token.constant, 67 | .token.symbol, 68 | .token.deleted { 69 | color: #F05E5D; 70 | } 71 | 72 | .token.boolean, 73 | .token.number { 74 | color: #BC94F9; 75 | } 76 | 77 | .token.selector, 78 | .token.attr-name, 79 | .token.string, 80 | .token.char, 81 | .token.builtin, 82 | .token.inserted { 83 | color: #FCFCD6; 84 | } 85 | 86 | .token.operator, 87 | .token.entity, 88 | .token.url, 89 | .language-css .token.string, 90 | .style .token.string, 91 | .token.variable { 92 | color: #f8f8f2; 93 | } 94 | 95 | .token.atrule, 96 | .token.attr-value, 97 | .token.function, 98 | .token.class-name { 99 | color: #66D8EF; 100 | } 101 | 102 | .token.keyword { 103 | color: #6EB26E; 104 | } 105 | 106 | .token.regex, 107 | .token.important { 108 | color: #F05E5D; 109 | } 110 | 111 | .token.important, 112 | .token.bold { 113 | font-weight: bold; 114 | } 115 | 116 | .token.italic { 117 | font-style: italic; 118 | } 119 | 120 | .token.entity { 121 | cursor: help; 122 | } 123 | -------------------------------------------------------------------------------- /example/src/prism-themes/material-dark.css: -------------------------------------------------------------------------------- 1 | code[class*="language-"], 2 | pre[class*="language-"] { 3 | text-align: left; 4 | white-space: pre; 5 | word-spacing: normal; 6 | word-break: normal; 7 | word-wrap: normal; 8 | color: #eee; 9 | background: #2f2f2f; 10 | font-family: Roboto Mono, monospace; 11 | font-size: 1em; 12 | line-height: 1.5em; 13 | 14 | -moz-tab-size: 4; 15 | -o-tab-size: 4; 16 | tab-size: 4; 17 | 18 | -webkit-hyphens: none; 19 | -moz-hyphens: none; 20 | -ms-hyphens: none; 21 | hyphens: none; 22 | } 23 | 24 | code[class*="language-"]::-moz-selection, 25 | pre[class*="language-"]::-moz-selection, 26 | code[class*="language-"] ::-moz-selection, 27 | pre[class*="language-"] ::-moz-selection { 28 | background: #363636; 29 | } 30 | 31 | code[class*="language-"]::selection, 32 | pre[class*="language-"]::selection, 33 | code[class*="language-"] ::selection, 34 | pre[class*="language-"] ::selection { 35 | background: #363636; 36 | } 37 | 38 | :not(pre) > code[class*="language-"] { 39 | white-space: normal; 40 | border-radius: 0.2em; 41 | padding: 0.1em; 42 | } 43 | 44 | pre[class*="language-"] { 45 | overflow: auto; 46 | position: relative; 47 | margin: 0.5em 0; 48 | padding: 1.25em 1em; 49 | } 50 | 51 | .language-css > code, 52 | .language-sass > code, 53 | .language-scss > code { 54 | color: #fd9170; 55 | } 56 | 57 | [class*="language-"] .namespace { 58 | opacity: 0.7; 59 | } 60 | 61 | .token.atrule { 62 | color: #c792ea; 63 | } 64 | 65 | .token.attr-name { 66 | color: #ffcb6b; 67 | } 68 | 69 | .token.attr-value { 70 | color: #a5e844; 71 | } 72 | 73 | .token.attribute { 74 | color: #a5e844; 75 | } 76 | 77 | .token.boolean { 78 | color: #c792ea; 79 | } 80 | 81 | .token.builtin { 82 | color: #ffcb6b; 83 | } 84 | 85 | .token.cdata { 86 | color: #80cbc4; 87 | } 88 | 89 | .token.char { 90 | color: #80cbc4; 91 | } 92 | 93 | .token.class { 94 | color: #ffcb6b; 95 | } 96 | 97 | .token.class-name { 98 | color: #f2ff00; 99 | } 100 | 101 | .token.comment { 102 | color: #616161; 103 | } 104 | 105 | .token.constant { 106 | color: #c792ea; 107 | } 108 | 109 | .token.deleted { 110 | color: #ff6666; 111 | } 112 | 113 | .token.doctype { 114 | color: #616161; 115 | } 116 | 117 | .token.entity { 118 | color: #ff6666; 119 | } 120 | 121 | .token.function { 122 | color: #c792ea; 123 | } 124 | 125 | .token.hexcode { 126 | color: #f2ff00; 127 | } 128 | 129 | .token.id { 130 | color: #c792ea; 131 | font-weight: bold; 132 | } 133 | 134 | .token.important { 135 | color: #c792ea; 136 | font-weight: bold; 137 | } 138 | 139 | .token.inserted { 140 | color: #80cbc4; 141 | } 142 | 143 | .token.keyword { 144 | color: #c792ea; 145 | } 146 | 147 | .token.number { 148 | color: #fd9170; 149 | } 150 | 151 | .token.operator { 152 | color: #89ddff; 153 | } 154 | 155 | .token.prolog { 156 | color: #616161; 157 | } 158 | 159 | .token.property { 160 | color: #80cbc4; 161 | } 162 | 163 | .token.pseudo-class { 164 | color: #a5e844; 165 | } 166 | 167 | .token.pseudo-element { 168 | color: #a5e844; 169 | } 170 | 171 | .token.punctuation { 172 | color: #89ddff; 173 | } 174 | 175 | .token.regex { 176 | color: #f2ff00; 177 | } 178 | 179 | .token.selector { 180 | color: #ff6666; 181 | } 182 | 183 | .token.string { 184 | color: #a5e844; 185 | } 186 | 187 | .token.symbol { 188 | color: #c792ea; 189 | } 190 | 191 | .token.tag { 192 | color: #ff6666; 193 | } 194 | 195 | .token.unit { 196 | color: #fd9170; 197 | } 198 | 199 | .token.url { 200 | color: #ff6666; 201 | } 202 | 203 | .token.variable { 204 | color: #ff6666; 205 | } 206 | -------------------------------------------------------------------------------- /example/src/prism-themes/material-light.css: -------------------------------------------------------------------------------- 1 | code[class*="language-"], 2 | pre[class*="language-"] { 3 | text-align: left; 4 | white-space: pre; 5 | word-spacing: normal; 6 | word-break: normal; 7 | word-wrap: normal; 8 | color: #90a4ae; 9 | background: #fafafa; 10 | font-family: Roboto Mono, monospace; 11 | font-size: 1em; 12 | line-height: 1.5em; 13 | 14 | -moz-tab-size: 4; 15 | -o-tab-size: 4; 16 | tab-size: 4; 17 | 18 | -webkit-hyphens: none; 19 | -moz-hyphens: none; 20 | -ms-hyphens: none; 21 | hyphens: none; 22 | } 23 | 24 | code[class*="language-"]::-moz-selection, 25 | pre[class*="language-"]::-moz-selection, 26 | code[class*="language-"] ::-moz-selection, 27 | pre[class*="language-"] ::-moz-selection { 28 | background: #cceae7; 29 | color: #263238; 30 | } 31 | 32 | code[class*="language-"]::selection, 33 | pre[class*="language-"]::selection, 34 | code[class*="language-"] ::selection, 35 | pre[class*="language-"] ::selection { 36 | background: #cceae7; 37 | color: #263238; 38 | } 39 | 40 | :not(pre) > code[class*="language-"] { 41 | white-space: normal; 42 | border-radius: 0.2em; 43 | padding: 0.1em; 44 | } 45 | 46 | pre[class*="language-"] { 47 | overflow: auto; 48 | position: relative; 49 | margin: 0.5em 0; 50 | padding: 1.25em 1em; 51 | } 52 | 53 | .language-css > code, 54 | .language-sass > code, 55 | .language-scss > code { 56 | color: #f76d47; 57 | } 58 | 59 | [class*="language-"] .namespace { 60 | opacity: 0.7; 61 | } 62 | 63 | .token.atrule { 64 | color: #7c4dff; 65 | } 66 | 67 | .token.attr-name { 68 | color: #39adb5; 69 | } 70 | 71 | .token.attr-value { 72 | color: #f6a434; 73 | } 74 | 75 | .token.attribute { 76 | color: #f6a434; 77 | } 78 | 79 | .token.boolean { 80 | color: #7c4dff; 81 | } 82 | 83 | .token.builtin { 84 | color: #39adb5; 85 | } 86 | 87 | .token.cdata { 88 | color: #39adb5; 89 | } 90 | 91 | .token.char { 92 | color: #39adb5; 93 | } 94 | 95 | .token.class { 96 | color: #39adb5; 97 | } 98 | 99 | .token.class-name { 100 | color: #6182b8; 101 | } 102 | 103 | .token.comment { 104 | color: #aabfc9; 105 | } 106 | 107 | .token.constant { 108 | color: #7c4dff; 109 | } 110 | 111 | .token.deleted { 112 | color: #e53935; 113 | } 114 | 115 | .token.doctype { 116 | color: #aabfc9; 117 | } 118 | 119 | .token.entity { 120 | color: #e53935; 121 | } 122 | 123 | .token.function { 124 | color: #7c4dff; 125 | } 126 | 127 | .token.hexcode { 128 | color: #f76d47; 129 | } 130 | 131 | .token.id { 132 | color: #7c4dff; 133 | font-weight: bold; 134 | } 135 | 136 | .token.important { 137 | color: #7c4dff; 138 | font-weight: bold; 139 | } 140 | 141 | .token.inserted { 142 | color: #39adb5; 143 | } 144 | 145 | .token.keyword { 146 | color: #7c4dff; 147 | } 148 | 149 | .token.number { 150 | color: #f76d47; 151 | } 152 | 153 | .token.operator { 154 | color: #39adb5; 155 | } 156 | 157 | .token.prolog { 158 | color: #aabfc9; 159 | } 160 | 161 | .token.property { 162 | color: #39adb5; 163 | } 164 | 165 | .token.pseudo-class { 166 | color: #f6a434; 167 | } 168 | 169 | .token.pseudo-element { 170 | color: #f6a434; 171 | } 172 | 173 | .token.punctuation { 174 | color: #39adb5; 175 | } 176 | 177 | .token.regex { 178 | color: #6182b8; 179 | } 180 | 181 | .token.selector { 182 | color: #e53935; 183 | } 184 | 185 | .token.string { 186 | color: #f6a434; 187 | } 188 | 189 | .token.symbol { 190 | color: #7c4dff; 191 | } 192 | 193 | .token.tag { 194 | color: #e53935; 195 | } 196 | 197 | .token.unit { 198 | color: #f76d47; 199 | } 200 | 201 | .token.url { 202 | color: #e53935; 203 | } 204 | 205 | .token.variable { 206 | color: #e53935; 207 | } 208 | -------------------------------------------------------------------------------- /example/src/prism-themes/material-oceanic.css: -------------------------------------------------------------------------------- 1 | code[class*="language-"], 2 | pre[class*="language-"] { 3 | text-align: left; 4 | white-space: pre; 5 | word-spacing: normal; 6 | word-break: normal; 7 | word-wrap: normal; 8 | color: #c3cee3; 9 | background: #263238; 10 | font-family: Roboto Mono, monospace; 11 | font-size: 1em; 12 | line-height: 1.5em; 13 | 14 | -moz-tab-size: 4; 15 | -o-tab-size: 4; 16 | tab-size: 4; 17 | 18 | -webkit-hyphens: none; 19 | -moz-hyphens: none; 20 | -ms-hyphens: none; 21 | hyphens: none; 22 | } 23 | 24 | code[class*="language-"]::-moz-selection, 25 | pre[class*="language-"]::-moz-selection, 26 | code[class*="language-"] ::-moz-selection, 27 | pre[class*="language-"] ::-moz-selection { 28 | background: #363636; 29 | } 30 | 31 | code[class*="language-"]::selection, 32 | pre[class*="language-"]::selection, 33 | code[class*="language-"] ::selection, 34 | pre[class*="language-"] ::selection { 35 | background: #363636; 36 | } 37 | 38 | :not(pre) > code[class*="language-"] { 39 | white-space: normal; 40 | border-radius: 0.2em; 41 | padding: 0.1em; 42 | } 43 | 44 | pre[class*="language-"] { 45 | overflow: auto; 46 | position: relative; 47 | margin: 0.5em 0; 48 | padding: 1.25em 1em; 49 | } 50 | 51 | .language-css > code, 52 | .language-sass > code, 53 | .language-scss > code { 54 | color: #fd9170; 55 | } 56 | 57 | [class*="language-"] .namespace { 58 | opacity: 0.7; 59 | } 60 | 61 | .token.atrule { 62 | color: #c792ea; 63 | } 64 | 65 | .token.attr-name { 66 | color: #ffcb6b; 67 | } 68 | 69 | .token.attr-value { 70 | color: #c3e88d; 71 | } 72 | 73 | .token.attribute { 74 | color: #c3e88d; 75 | } 76 | 77 | .token.boolean { 78 | color: #c792ea; 79 | } 80 | 81 | .token.builtin { 82 | color: #ffcb6b; 83 | } 84 | 85 | .token.cdata { 86 | color: #80cbc4; 87 | } 88 | 89 | .token.char { 90 | color: #80cbc4; 91 | } 92 | 93 | .token.class { 94 | color: #ffcb6b; 95 | } 96 | 97 | .token.class-name { 98 | color: #f2ff00; 99 | } 100 | 101 | .token.color { 102 | color: #f2ff00; 103 | } 104 | 105 | .token.comment { 106 | color: #546e7a; 107 | } 108 | 109 | .token.constant { 110 | color: #c792ea; 111 | } 112 | 113 | .token.deleted { 114 | color: #f07178; 115 | } 116 | 117 | .token.doctype { 118 | color: #546e7a; 119 | } 120 | 121 | .token.entity { 122 | color: #f07178; 123 | } 124 | 125 | .token.function { 126 | color: #c792ea; 127 | } 128 | 129 | .token.hexcode { 130 | color: #f2ff00; 131 | } 132 | 133 | .token.id { 134 | color: #c792ea; 135 | font-weight: bold; 136 | } 137 | 138 | .token.important { 139 | color: #c792ea; 140 | font-weight: bold; 141 | } 142 | 143 | .token.inserted { 144 | color: #80cbc4; 145 | } 146 | 147 | .token.keyword { 148 | color: #c792ea; 149 | font-style: italic; 150 | } 151 | 152 | .token.number { 153 | color: #fd9170; 154 | } 155 | 156 | .token.operator { 157 | color: #89ddff; 158 | } 159 | 160 | .token.prolog { 161 | color: #546e7a; 162 | } 163 | 164 | .token.property { 165 | color: #80cbc4; 166 | } 167 | 168 | .token.pseudo-class { 169 | color: #c3e88d; 170 | } 171 | 172 | .token.pseudo-element { 173 | color: #c3e88d; 174 | } 175 | 176 | .token.punctuation { 177 | color: #89ddff; 178 | } 179 | 180 | .token.regex { 181 | color: #f2ff00; 182 | } 183 | 184 | .token.selector { 185 | color: #f07178; 186 | } 187 | 188 | .token.string { 189 | color: #c3e88d; 190 | } 191 | 192 | .token.symbol { 193 | color: #c792ea; 194 | } 195 | 196 | .token.tag { 197 | color: #f07178; 198 | } 199 | 200 | .token.unit { 201 | color: #f07178; 202 | } 203 | 204 | .token.url { 205 | color: #fd9170; 206 | } 207 | 208 | .token.variable { 209 | color: #f07178; 210 | } 211 | -------------------------------------------------------------------------------- /example/src/prism-themes/night-owl.css: -------------------------------------------------------------------------------- 1 | /** 2 | * MIT License 3 | * Copyright (c) 2018 Sarah Drasner 4 | * Sarah Drasner's[@sdras] Night Owl 5 | * Ported by Sara vieria [@SaraVieira] 6 | * Added by Souvik Mandal [@SimpleIndian] 7 | */ 8 | 9 | code[class*="language-"], 10 | pre[class*="language-"] { 11 | color: #d6deeb; 12 | font-family: Consolas, Monaco, "Andale Mono", "Ubuntu Mono", monospace; 13 | text-align: left; 14 | white-space: pre; 15 | word-spacing: normal; 16 | word-break: normal; 17 | word-wrap: normal; 18 | line-height: 1.5; 19 | font-size: 1em; 20 | 21 | -moz-tab-size: 4; 22 | -o-tab-size: 4; 23 | tab-size: 4; 24 | 25 | -webkit-hyphens: none; 26 | -moz-hyphens: none; 27 | -ms-hyphens: none; 28 | hyphens: none; 29 | } 30 | 31 | pre[class*="language-"]::-moz-selection, 32 | pre[class*="language-"] ::-moz-selection, 33 | code[class*="language-"]::-moz-selection, 34 | code[class*="language-"] ::-moz-selection { 35 | text-shadow: none; 36 | background: rgba(29, 59, 83, 0.99); 37 | } 38 | 39 | pre[class*="language-"]::selection, 40 | pre[class*="language-"] ::selection, 41 | code[class*="language-"]::selection, 42 | code[class*="language-"] ::selection { 43 | text-shadow: none; 44 | background: rgba(29, 59, 83, 0.99); 45 | } 46 | 47 | @media print { 48 | code[class*="language-"], 49 | pre[class*="language-"] { 50 | text-shadow: none; 51 | } 52 | } 53 | 54 | /* Code blocks */ 55 | pre[class*="language-"] { 56 | padding: 1em; 57 | margin: 0.5em 0; 58 | overflow: auto; 59 | } 60 | 61 | :not(pre) > code[class*="language-"], 62 | pre[class*="language-"] { 63 | color: white; 64 | background: #011627; 65 | } 66 | 67 | :not(pre) > code[class*="language-"] { 68 | padding: 0.1em; 69 | border-radius: 0.3em; 70 | white-space: normal; 71 | } 72 | 73 | .token.comment, 74 | .token.prolog, 75 | .token.cdata { 76 | color: rgb(99, 119, 119); 77 | font-style: italic; 78 | } 79 | 80 | .token.punctuation { 81 | color: rgb(199, 146, 234); 82 | } 83 | 84 | .namespace { 85 | color: rgb(178, 204, 214); 86 | } 87 | 88 | .token.deleted { 89 | color: rgba(239, 83, 80, 0.56); 90 | font-style: italic; 91 | } 92 | 93 | .token.symbol, 94 | .token.property { 95 | color: rgb(128, 203, 196); 96 | } 97 | 98 | .token.tag, 99 | .token.operator, 100 | .token.keyword { 101 | color: rgb(127, 219, 202); 102 | } 103 | 104 | .token.boolean { 105 | color: rgb(255, 88, 116); 106 | } 107 | 108 | .token.number { 109 | color: rgb(247, 140, 108); 110 | } 111 | 112 | .token.constant, 113 | .token.function, 114 | .token.builtin, 115 | .token.char { 116 | color: rgb(130, 170, 255); 117 | } 118 | 119 | .token.selector, 120 | .token.doctype { 121 | color: rgb(199, 146, 234); 122 | font-style: italic; 123 | } 124 | 125 | .token.attr-name, 126 | .token.inserted { 127 | color: rgb(173, 219, 103); 128 | font-style: italic; 129 | } 130 | 131 | .token.string, 132 | .token.url, 133 | .token.entity, 134 | .language-css .token.string, 135 | .style .token.string { 136 | color: rgb(173, 219, 103); 137 | } 138 | 139 | .token.class-name, 140 | .token.atrule, 141 | .token.attr-value { 142 | color: rgb(255, 203, 139); 143 | } 144 | 145 | .token.regex, 146 | .token.important, 147 | .token.variable { 148 | color: rgb(214, 222, 235); 149 | } 150 | 151 | .token.important, 152 | .token.bold { 153 | font-weight: bold; 154 | } 155 | 156 | .token.italic { 157 | font-style: italic; 158 | } 159 | -------------------------------------------------------------------------------- /example/src/prism-themes/nord.css: -------------------------------------------------------------------------------- 1 | /** 2 | * Nord Theme Originally by Arctic Ice Studio 3 | * https://nordtheme.com 4 | * 5 | * Ported for PrismJS by Zane Hitchcoxc (@zwhitchcox) and Gabriel Ramos (@gabrieluizramos) 6 | */ 7 | 8 | code[class*="language-"], 9 | pre[class*="language-"] { 10 | color: #f8f8f2; 11 | background: none; 12 | font-family: "Fira Code", Consolas, Monaco, 'Andale Mono', 'Ubuntu Mono', monospace; 13 | text-align: left; 14 | white-space: pre; 15 | word-spacing: normal; 16 | word-break: normal; 17 | word-wrap: normal; 18 | line-height: 1.5; 19 | -moz-tab-size: 4; 20 | -o-tab-size: 4; 21 | tab-size: 4; 22 | -webkit-hyphens: none; 23 | -moz-hyphens: none; 24 | -ms-hyphens: none; 25 | hyphens: none; 26 | } 27 | 28 | /* Code blocks */ 29 | pre[class*="language-"] { 30 | padding: 1em; 31 | margin: .5em 0; 32 | overflow: auto; 33 | border-radius: 0.3em; 34 | } 35 | 36 | :not(pre) > code[class*="language-"], 37 | pre[class*="language-"] { 38 | background: #2E3440; 39 | } 40 | 41 | /* Inline code */ 42 | :not(pre) > code[class*="language-"] { 43 | padding: .1em; 44 | border-radius: .3em; 45 | white-space: normal; 46 | } 47 | 48 | .token.comment, 49 | .token.prolog, 50 | .token.doctype, 51 | .token.cdata { 52 | color: #636f88; 53 | } 54 | 55 | .token.punctuation { 56 | color: #81A1C1; 57 | } 58 | 59 | .namespace { 60 | opacity: .7; 61 | } 62 | 63 | .token.property, 64 | .token.tag, 65 | .token.constant, 66 | .token.symbol, 67 | .token.deleted { 68 | color: #81A1C1; 69 | } 70 | 71 | .token.number { 72 | color: #B48EAD; 73 | } 74 | 75 | .token.boolean { 76 | color: #81A1C1; 77 | } 78 | 79 | .token.selector, 80 | .token.attr-name, 81 | .token.string, 82 | .token.char, 83 | .token.builtin, 84 | .token.inserted { 85 | color: #A3BE8C; 86 | } 87 | 88 | .token.operator, 89 | .token.entity, 90 | .token.url, 91 | .language-css .token.string, 92 | .style .token.string, 93 | .token.variable { 94 | color: #81A1C1; 95 | } 96 | 97 | .token.atrule, 98 | .token.attr-value, 99 | .token.function, 100 | .token.class-name { 101 | color: #88C0D0; 102 | } 103 | 104 | .token.keyword { 105 | color: #81A1C1; 106 | } 107 | 108 | .token.regex, 109 | .token.important { 110 | color: #EBCB8B; 111 | } 112 | 113 | .token.important, 114 | .token.bold { 115 | font-weight: bold; 116 | } 117 | 118 | .token.italic { 119 | font-style: italic; 120 | } 121 | 122 | .token.entity { 123 | cursor: help; 124 | } 125 | -------------------------------------------------------------------------------- /example/src/prism-themes/one-dark.css: -------------------------------------------------------------------------------- 1 | /** 2 | * One Dark theme for prism.js 3 | * Based on Atom's One Dark theme: https://github.com/atom/atom/tree/master/packages/one-dark-syntax 4 | */ 5 | 6 | /** 7 | * One Dark colours (accurate as of commit 8ae45ca on 6 Sep 2018) 8 | * From colors.less 9 | * --mono-1: hsl(220, 14%, 71%); 10 | * --mono-2: hsl(220, 9%, 55%); 11 | * --mono-3: hsl(220, 10%, 40%); 12 | * --hue-1: hsl(187, 47%, 55%); 13 | * --hue-2: hsl(207, 82%, 66%); 14 | * --hue-3: hsl(286, 60%, 67%); 15 | * --hue-4: hsl(95, 38%, 62%); 16 | * --hue-5: hsl(355, 65%, 65%); 17 | * --hue-5-2: hsl(5, 48%, 51%); 18 | * --hue-6: hsl(29, 54%, 61%); 19 | * --hue-6-2: hsl(39, 67%, 69%); 20 | * --syntax-fg: hsl(220, 14%, 71%); 21 | * --syntax-bg: hsl(220, 13%, 18%); 22 | * --syntax-gutter: hsl(220, 14%, 45%); 23 | * --syntax-guide: hsla(220, 14%, 71%, 0.15); 24 | * --syntax-accent: hsl(220, 100%, 66%); 25 | * From syntax-variables.less 26 | * --syntax-selection-color: hsl(220, 13%, 28%); 27 | * --syntax-gutter-background-color-selected: hsl(220, 13%, 26%); 28 | * --syntax-cursor-line: hsla(220, 100%, 80%, 0.04); 29 | */ 30 | 31 | code[class*="language-"], 32 | pre[class*="language-"] { 33 | background: hsl(220, 13%, 18%); 34 | color: hsl(220, 14%, 71%); 35 | text-shadow: 0 1px rgba(0, 0, 0, 0.3); 36 | font-family: "Fira Code", "Fira Mono", Menlo, Consolas, "DejaVu Sans Mono", monospace; 37 | direction: ltr; 38 | text-align: left; 39 | white-space: pre; 40 | word-spacing: normal; 41 | word-break: normal; 42 | line-height: 1.5; 43 | -moz-tab-size: 2; 44 | -o-tab-size: 2; 45 | tab-size: 2; 46 | -webkit-hyphens: none; 47 | -moz-hyphens: none; 48 | -ms-hyphens: none; 49 | hyphens: none; 50 | } 51 | 52 | /* Selection */ 53 | code[class*="language-"]::-moz-selection, 54 | code[class*="language-"] *::-moz-selection, 55 | pre[class*="language-"] *::-moz-selection { 56 | background: hsl(220, 13%, 28%); 57 | color: inherit; 58 | text-shadow: none; 59 | } 60 | 61 | code[class*="language-"]::selection, 62 | code[class*="language-"] *::selection, 63 | pre[class*="language-"] *::selection { 64 | background: hsl(220, 13%, 28%); 65 | color: inherit; 66 | text-shadow: none; 67 | } 68 | 69 | /* Code blocks */ 70 | pre[class*="language-"] { 71 | padding: 1em; 72 | margin: 0.5em 0; 73 | overflow: auto; 74 | border-radius: 0.3em; 75 | } 76 | 77 | /* Inline code */ 78 | :not(pre) > code[class*="language-"] { 79 | padding: 0.2em 0.3em; 80 | border-radius: 0.3em; 81 | white-space: normal; 82 | } 83 | 84 | /* Print */ 85 | @media print { 86 | code[class*="language-"], 87 | pre[class*="language-"] { 88 | text-shadow: none; 89 | } 90 | } 91 | 92 | .token.comment, 93 | .token.prolog, 94 | .token.cdata { 95 | color: hsl(220, 10%, 40%); 96 | } 97 | 98 | .token.doctype, 99 | .token.punctuation, 100 | .token.entity { 101 | color: hsl(220, 14%, 71%); 102 | } 103 | 104 | .token.attr-name, 105 | .token.class-name, 106 | .token.boolean, 107 | .token.constant, 108 | .token.number, 109 | .token.atrule { 110 | color: hsl(29, 54%, 61%); 111 | } 112 | 113 | .token.keyword { 114 | color: hsl(286, 60%, 67%); 115 | } 116 | 117 | .token.property, 118 | .token.tag, 119 | .token.symbol, 120 | .token.deleted, 121 | .token.important { 122 | color: hsl(355, 65%, 65%); 123 | } 124 | 125 | .token.selector, 126 | .token.string, 127 | .token.char, 128 | .token.builtin, 129 | .token.inserted, 130 | .token.regex, 131 | .token.attr-value, 132 | .token.attr-value > .token.punctuation { 133 | color: hsl(95, 38%, 62%); 134 | } 135 | 136 | .token.variable, 137 | .token.operator, 138 | .token.function { 139 | color: hsl(207, 82%, 66%); 140 | } 141 | 142 | .token.url { 143 | color: hsl(187, 47%, 55%); 144 | } 145 | 146 | /* HTML overrides */ 147 | .token.attr-value > .token.punctuation.attr-equals, 148 | .token.special-attr > .token.attr-value > .token.value.css { 149 | color: hsl(220, 14%, 71%); 150 | } 151 | 152 | /* CSS overrides */ 153 | .language-css .token.selector { 154 | color: hsl(355, 65%, 65%); 155 | } 156 | 157 | .language-css .token.property { 158 | color: hsl(220, 14%, 71%); 159 | } 160 | 161 | .language-css .token.function, 162 | .language-css .token.url > .token.function { 163 | color: hsl(187, 47%, 55%); 164 | } 165 | 166 | .language-css .token.url > .token.string.url { 167 | color: hsl(95, 38%, 62%); 168 | } 169 | 170 | .language-css .token.important, 171 | .language-css .token.atrule .token.rule { 172 | color: hsl(286, 60%, 67%); 173 | } 174 | 175 | /* JS overrides */ 176 | .language-javascript .token.operator { 177 | color: hsl(286, 60%, 67%); 178 | } 179 | 180 | .language-javascript .token.template-string > .token.interpolation > .token.interpolation-punctuation.punctuation { 181 | color: hsl(5, 48%, 51%); 182 | } 183 | 184 | /* JSON overrides */ 185 | .language-json .token.operator { 186 | color: hsl(220, 14%, 71%); 187 | } 188 | 189 | .language-json .token.null.keyword { 190 | color: hsl(29, 54%, 61%); 191 | } 192 | 193 | /* MD overrides */ 194 | .language-markdown .token.url, 195 | .language-markdown .token.url > .token.operator, 196 | .language-markdown .token.url-reference.url > .token.string { 197 | color: hsl(220, 14%, 71%); 198 | } 199 | 200 | .language-markdown .token.url > .token.content { 201 | color: hsl(207, 82%, 66%); 202 | } 203 | 204 | .language-markdown .token.url > .token.url, 205 | .language-markdown .token.url-reference.url { 206 | color: hsl(187, 47%, 55%); 207 | } 208 | 209 | .language-markdown .token.blockquote.punctuation, 210 | .language-markdown .token.hr.punctuation { 211 | color: hsl(220, 10%, 40%); 212 | font-style: italic; 213 | } 214 | 215 | .language-markdown .token.code-snippet { 216 | color: hsl(95, 38%, 62%); 217 | } 218 | 219 | .language-markdown .token.bold .token.content { 220 | color: hsl(29, 54%, 61%); 221 | } 222 | 223 | .language-markdown .token.italic .token.content { 224 | color: hsl(286, 60%, 67%); 225 | } 226 | 227 | .language-markdown .token.strike .token.content, 228 | .language-markdown .token.strike .token.punctuation, 229 | .language-markdown .token.list.punctuation, 230 | .language-markdown .token.title.important > .token.punctuation { 231 | color: hsl(355, 65%, 65%); 232 | } 233 | 234 | /* General */ 235 | .token.bold { 236 | font-weight: bold; 237 | } 238 | 239 | .token.comment, 240 | .token.italic { 241 | font-style: italic; 242 | } 243 | 244 | .token.entity { 245 | cursor: help; 246 | } 247 | 248 | .token.namespace { 249 | opacity: 0.8; 250 | } 251 | 252 | /* Plugin overrides */ 253 | /* Selectors should have higher specificity than those in the plugins' default stylesheets */ 254 | 255 | /* Show Invisibles plugin overrides */ 256 | .token.token.tab:not(:empty):before, 257 | .token.token.cr:before, 258 | .token.token.lf:before, 259 | .token.token.space:before { 260 | color: hsla(220, 14%, 71%, 0.15); 261 | text-shadow: none; 262 | } 263 | 264 | /* Toolbar plugin overrides */ 265 | /* Space out all buttons and move them away from the right edge of the code block */ 266 | div.code-toolbar > .toolbar.toolbar > .toolbar-item { 267 | margin-right: 0.4em; 268 | } 269 | 270 | /* Styling the buttons */ 271 | div.code-toolbar > .toolbar.toolbar > .toolbar-item > button, 272 | div.code-toolbar > .toolbar.toolbar > .toolbar-item > a, 273 | div.code-toolbar > .toolbar.toolbar > .toolbar-item > span { 274 | background: hsl(220, 13%, 26%); 275 | color: hsl(220, 9%, 55%); 276 | padding: 0.1em 0.4em; 277 | border-radius: 0.3em; 278 | } 279 | 280 | div.code-toolbar > .toolbar.toolbar > .toolbar-item > button:hover, 281 | div.code-toolbar > .toolbar.toolbar > .toolbar-item > button:focus, 282 | div.code-toolbar > .toolbar.toolbar > .toolbar-item > a:hover, 283 | div.code-toolbar > .toolbar.toolbar > .toolbar-item > a:focus, 284 | div.code-toolbar > .toolbar.toolbar > .toolbar-item > span:hover, 285 | div.code-toolbar > .toolbar.toolbar > .toolbar-item > span:focus { 286 | background: hsl(220, 13%, 28%); 287 | color: hsl(220, 14%, 71%); 288 | } 289 | 290 | /* Line Highlight plugin overrides */ 291 | /* The highlighted line itself */ 292 | .line-highlight.line-highlight { 293 | background: hsla(220, 100%, 80%, 0.04); 294 | } 295 | 296 | /* Default line numbers in Line Highlight plugin */ 297 | .line-highlight.line-highlight:before, 298 | .line-highlight.line-highlight[data-end]:after { 299 | background: hsl(220, 13%, 26%); 300 | color: hsl(220, 14%, 71%); 301 | padding: 0.1em 0.6em; 302 | border-radius: 0.3em; 303 | box-shadow: 0 2px 0 0 rgba(0, 0, 0, 0.2); /* same as Toolbar plugin default */ 304 | } 305 | 306 | /* Hovering over a linkable line number (in the gutter area) */ 307 | /* Requires Line Numbers plugin as well */ 308 | pre[id].linkable-line-numbers.linkable-line-numbers span.line-numbers-rows > span:hover:before { 309 | background-color: hsla(220, 100%, 80%, 0.04); 310 | } 311 | 312 | /* Line Numbers and Command Line plugins overrides */ 313 | /* Line separating gutter from coding area */ 314 | .line-numbers.line-numbers .line-numbers-rows, 315 | .command-line .command-line-prompt { 316 | border-right-color: hsla(220, 14%, 71%, 0.15); 317 | } 318 | 319 | /* Stuff in the gutter */ 320 | .line-numbers .line-numbers-rows > span:before, 321 | .command-line .command-line-prompt > span:before { 322 | color: hsl(220, 14%, 45%); 323 | } 324 | 325 | /* Match Braces plugin overrides */ 326 | /* Note: Outline colour is inherited from the braces */ 327 | .rainbow-braces .token.token.punctuation.brace-level-1, 328 | .rainbow-braces .token.token.punctuation.brace-level-5, 329 | .rainbow-braces .token.token.punctuation.brace-level-9 { 330 | color: hsl(355, 65%, 65%); 331 | } 332 | 333 | .rainbow-braces .token.token.punctuation.brace-level-2, 334 | .rainbow-braces .token.token.punctuation.brace-level-6, 335 | .rainbow-braces .token.token.punctuation.brace-level-10 { 336 | color: hsl(95, 38%, 62%); 337 | } 338 | 339 | .rainbow-braces .token.token.punctuation.brace-level-3, 340 | .rainbow-braces .token.token.punctuation.brace-level-7, 341 | .rainbow-braces .token.token.punctuation.brace-level-11 { 342 | color: hsl(207, 82%, 66%); 343 | } 344 | 345 | .rainbow-braces .token.token.punctuation.brace-level-4, 346 | .rainbow-braces .token.token.punctuation.brace-level-8, 347 | .rainbow-braces .token.token.punctuation.brace-level-12 { 348 | color: hsl(286, 60%, 67%); 349 | } 350 | 351 | /* Diff Highlight plugin overrides */ 352 | /* Taken from https://github.com/atom/github/blob/master/styles/variables.less */ 353 | pre.diff-highlight > code .token.token.deleted:not(.prefix), 354 | pre > code.diff-highlight .token.token.deleted:not(.prefix) { 355 | background-color: hsla(353, 100%, 66%, 0.15); 356 | } 357 | 358 | pre.diff-highlight > code .token.token.deleted:not(.prefix)::-moz-selection, 359 | pre.diff-highlight > code .token.token.deleted:not(.prefix) *::-moz-selection, 360 | pre > code.diff-highlight .token.token.deleted:not(.prefix)::-moz-selection, 361 | pre > code.diff-highlight .token.token.deleted:not(.prefix) *::-moz-selection { 362 | background-color: hsla(353, 95%, 66%, 0.25); 363 | } 364 | 365 | pre.diff-highlight > code .token.token.deleted:not(.prefix)::selection, 366 | pre.diff-highlight > code .token.token.deleted:not(.prefix) *::selection, 367 | pre > code.diff-highlight .token.token.deleted:not(.prefix)::selection, 368 | pre > code.diff-highlight .token.token.deleted:not(.prefix) *::selection { 369 | background-color: hsla(353, 95%, 66%, 0.25); 370 | } 371 | 372 | pre.diff-highlight > code .token.token.inserted:not(.prefix), 373 | pre > code.diff-highlight .token.token.inserted:not(.prefix) { 374 | background-color: hsla(137, 100%, 55%, 0.15); 375 | } 376 | 377 | pre.diff-highlight > code .token.token.inserted:not(.prefix)::-moz-selection, 378 | pre.diff-highlight > code .token.token.inserted:not(.prefix) *::-moz-selection, 379 | pre > code.diff-highlight .token.token.inserted:not(.prefix)::-moz-selection, 380 | pre > code.diff-highlight .token.token.inserted:not(.prefix) *::-moz-selection { 381 | background-color: hsla(135, 73%, 55%, 0.25); 382 | } 383 | 384 | pre.diff-highlight > code .token.token.inserted:not(.prefix)::selection, 385 | pre.diff-highlight > code .token.token.inserted:not(.prefix) *::selection, 386 | pre > code.diff-highlight .token.token.inserted:not(.prefix)::selection, 387 | pre > code.diff-highlight .token.token.inserted:not(.prefix) *::selection { 388 | background-color: hsla(135, 73%, 55%, 0.25); 389 | } 390 | 391 | /* Previewers plugin overrides */ 392 | /* Based on https://github.com/atom-community/atom-ide-datatip/blob/master/styles/atom-ide-datatips.less and https://github.com/atom/atom/blob/master/packages/one-dark-ui */ 393 | /* Border around popup */ 394 | .prism-previewer.prism-previewer:before, 395 | .prism-previewer-gradient.prism-previewer-gradient div { 396 | border-color: hsl(224, 13%, 17%); 397 | } 398 | 399 | /* Angle and time should remain as circles and are hence not included */ 400 | .prism-previewer-color.prism-previewer-color:before, 401 | .prism-previewer-gradient.prism-previewer-gradient div, 402 | .prism-previewer-easing.prism-previewer-easing:before { 403 | border-radius: 0.3em; 404 | } 405 | 406 | /* Triangles pointing to the code */ 407 | .prism-previewer.prism-previewer:after { 408 | border-top-color: hsl(224, 13%, 17%); 409 | } 410 | 411 | .prism-previewer-flipped.prism-previewer-flipped.after { 412 | border-bottom-color: hsl(224, 13%, 17%); 413 | } 414 | 415 | /* Background colour within the popup */ 416 | .prism-previewer-angle.prism-previewer-angle:before, 417 | .prism-previewer-time.prism-previewer-time:before, 418 | .prism-previewer-easing.prism-previewer-easing { 419 | background: hsl(219, 13%, 22%); 420 | } 421 | 422 | /* For angle, this is the positive area (eg. 90deg will display one quadrant in this colour) */ 423 | /* For time, this is the alternate colour */ 424 | .prism-previewer-angle.prism-previewer-angle circle, 425 | .prism-previewer-time.prism-previewer-time circle { 426 | stroke: hsl(220, 14%, 71%); 427 | stroke-opacity: 1; 428 | } 429 | 430 | /* Stroke colours of the handle, direction point, and vector itself */ 431 | .prism-previewer-easing.prism-previewer-easing circle, 432 | .prism-previewer-easing.prism-previewer-easing path, 433 | .prism-previewer-easing.prism-previewer-easing line { 434 | stroke: hsl(220, 14%, 71%); 435 | } 436 | 437 | /* Fill colour of the handle */ 438 | .prism-previewer-easing.prism-previewer-easing circle { 439 | fill: transparent; 440 | } 441 | -------------------------------------------------------------------------------- /example/src/prism-themes/one-light.css: -------------------------------------------------------------------------------- 1 | /** 2 | * One Light theme for prism.js 3 | * Based on Atom's One Light theme: https://github.com/atom/atom/tree/master/packages/one-light-syntax 4 | */ 5 | 6 | /** 7 | * One Light colours (accurate as of commit eb064bf on 19 Feb 2021) 8 | * From colors.less 9 | * --mono-1: hsl(230, 8%, 24%); 10 | * --mono-2: hsl(230, 6%, 44%); 11 | * --mono-3: hsl(230, 4%, 64%) 12 | * --hue-1: hsl(198, 99%, 37%); 13 | * --hue-2: hsl(221, 87%, 60%); 14 | * --hue-3: hsl(301, 63%, 40%); 15 | * --hue-4: hsl(119, 34%, 47%); 16 | * --hue-5: hsl(5, 74%, 59%); 17 | * --hue-5-2: hsl(344, 84%, 43%); 18 | * --hue-6: hsl(35, 99%, 36%); 19 | * --hue-6-2: hsl(35, 99%, 40%); 20 | * --syntax-fg: hsl(230, 8%, 24%); 21 | * --syntax-bg: hsl(230, 1%, 98%); 22 | * --syntax-gutter: hsl(230, 1%, 62%); 23 | * --syntax-guide: hsla(230, 8%, 24%, 0.2); 24 | * --syntax-accent: hsl(230, 100%, 66%); 25 | * From syntax-variables.less 26 | * --syntax-selection-color: hsl(230, 1%, 90%); 27 | * --syntax-gutter-background-color-selected: hsl(230, 1%, 90%); 28 | * --syntax-cursor-line: hsla(230, 8%, 24%, 0.05); 29 | */ 30 | 31 | code[class*="language-"], 32 | pre[class*="language-"] { 33 | background: hsl(230, 1%, 98%); 34 | color: hsl(230, 8%, 24%); 35 | font-family: "Fira Code", "Fira Mono", Menlo, Consolas, "DejaVu Sans Mono", monospace; 36 | direction: ltr; 37 | text-align: left; 38 | white-space: pre; 39 | word-spacing: normal; 40 | word-break: normal; 41 | line-height: 1.5; 42 | -moz-tab-size: 2; 43 | -o-tab-size: 2; 44 | tab-size: 2; 45 | -webkit-hyphens: none; 46 | -moz-hyphens: none; 47 | -ms-hyphens: none; 48 | hyphens: none; 49 | } 50 | 51 | /* Selection */ 52 | code[class*="language-"]::-moz-selection, 53 | code[class*="language-"] *::-moz-selection, 54 | pre[class*="language-"] *::-moz-selection { 55 | background: hsl(230, 1%, 90%); 56 | color: inherit; 57 | } 58 | 59 | code[class*="language-"]::selection, 60 | code[class*="language-"] *::selection, 61 | pre[class*="language-"] *::selection { 62 | background: hsl(230, 1%, 90%); 63 | color: inherit; 64 | } 65 | 66 | /* Code blocks */ 67 | pre[class*="language-"] { 68 | padding: 1em; 69 | margin: 0.5em 0; 70 | overflow: auto; 71 | border-radius: 0.3em; 72 | } 73 | 74 | /* Inline code */ 75 | :not(pre) > code[class*="language-"] { 76 | padding: 0.2em 0.3em; 77 | border-radius: 0.3em; 78 | white-space: normal; 79 | } 80 | 81 | .token.comment, 82 | .token.prolog, 83 | .token.cdata { 84 | color: hsl(230, 4%, 64%); 85 | } 86 | 87 | .token.doctype, 88 | .token.punctuation, 89 | .token.entity { 90 | color: hsl(230, 8%, 24%); 91 | } 92 | 93 | .token.attr-name, 94 | .token.class-name, 95 | .token.boolean, 96 | .token.constant, 97 | .token.number, 98 | .token.atrule { 99 | color: hsl(35, 99%, 36%); 100 | } 101 | 102 | .token.keyword { 103 | color: hsl(301, 63%, 40%); 104 | } 105 | 106 | .token.property, 107 | .token.tag, 108 | .token.symbol, 109 | .token.deleted, 110 | .token.important { 111 | color: hsl(5, 74%, 59%); 112 | } 113 | 114 | .token.selector, 115 | .token.string, 116 | .token.char, 117 | .token.builtin, 118 | .token.inserted, 119 | .token.regex, 120 | .token.attr-value, 121 | .token.attr-value > .token.punctuation { 122 | color: hsl(119, 34%, 47%); 123 | } 124 | 125 | .token.variable, 126 | .token.operator, 127 | .token.function { 128 | color: hsl(221, 87%, 60%); 129 | } 130 | 131 | .token.url { 132 | color: hsl(198, 99%, 37%); 133 | } 134 | 135 | /* HTML overrides */ 136 | .token.attr-value > .token.punctuation.attr-equals, 137 | .token.special-attr > .token.attr-value > .token.value.css { 138 | color: hsl(230, 8%, 24%); 139 | } 140 | 141 | /* CSS overrides */ 142 | .language-css .token.selector { 143 | color: hsl(5, 74%, 59%); 144 | } 145 | 146 | .language-css .token.property { 147 | color: hsl(230, 8%, 24%); 148 | } 149 | 150 | .language-css .token.function, 151 | .language-css .token.url > .token.function { 152 | color: hsl(198, 99%, 37%); 153 | } 154 | 155 | .language-css .token.url > .token.string.url { 156 | color: hsl(119, 34%, 47%); 157 | } 158 | 159 | .language-css .token.important, 160 | .language-css .token.atrule .token.rule { 161 | color: hsl(301, 63%, 40%); 162 | } 163 | 164 | /* JS overrides */ 165 | .language-javascript .token.operator { 166 | color: hsl(301, 63%, 40%); 167 | } 168 | 169 | .language-javascript .token.template-string > .token.interpolation > .token.interpolation-punctuation.punctuation { 170 | color: hsl(344, 84%, 43%); 171 | } 172 | 173 | /* JSON overrides */ 174 | .language-json .token.operator { 175 | color: hsl(230, 8%, 24%); 176 | } 177 | 178 | .language-json .token.null.keyword { 179 | color: hsl(35, 99%, 36%); 180 | } 181 | 182 | /* MD overrides */ 183 | .language-markdown .token.url, 184 | .language-markdown .token.url > .token.operator, 185 | .language-markdown .token.url-reference.url > .token.string { 186 | color: hsl(230, 8%, 24%); 187 | } 188 | 189 | .language-markdown .token.url > .token.content { 190 | color: hsl(221, 87%, 60%); 191 | } 192 | 193 | .language-markdown .token.url > .token.url, 194 | .language-markdown .token.url-reference.url { 195 | color: hsl(198, 99%, 37%); 196 | } 197 | 198 | .language-markdown .token.blockquote.punctuation, 199 | .language-markdown .token.hr.punctuation { 200 | color: hsl(230, 4%, 64%); 201 | font-style: italic; 202 | } 203 | 204 | .language-markdown .token.code-snippet { 205 | color: hsl(119, 34%, 47%); 206 | } 207 | 208 | .language-markdown .token.bold .token.content { 209 | color: hsl(35, 99%, 36%); 210 | } 211 | 212 | .language-markdown .token.italic .token.content { 213 | color: hsl(301, 63%, 40%); 214 | } 215 | 216 | .language-markdown .token.strike .token.content, 217 | .language-markdown .token.strike .token.punctuation, 218 | .language-markdown .token.list.punctuation, 219 | .language-markdown .token.title.important > .token.punctuation { 220 | color: hsl(5, 74%, 59%); 221 | } 222 | 223 | /* General */ 224 | .token.bold { 225 | font-weight: bold; 226 | } 227 | 228 | .token.comment, 229 | .token.italic { 230 | font-style: italic; 231 | } 232 | 233 | .token.entity { 234 | cursor: help; 235 | } 236 | 237 | .token.namespace { 238 | opacity: 0.8; 239 | } 240 | 241 | /* Plugin overrides */ 242 | /* Selectors should have higher specificity than those in the plugins' default stylesheets */ 243 | 244 | /* Show Invisibles plugin overrides */ 245 | .token.token.tab:not(:empty):before, 246 | .token.token.cr:before, 247 | .token.token.lf:before, 248 | .token.token.space:before { 249 | color: hsla(230, 8%, 24%, 0.2); 250 | } 251 | 252 | /* Toolbar plugin overrides */ 253 | /* Space out all buttons and move them away from the right edge of the code block */ 254 | div.code-toolbar > .toolbar.toolbar > .toolbar-item { 255 | margin-right: 0.4em; 256 | } 257 | 258 | /* Styling the buttons */ 259 | div.code-toolbar > .toolbar.toolbar > .toolbar-item > button, 260 | div.code-toolbar > .toolbar.toolbar > .toolbar-item > a, 261 | div.code-toolbar > .toolbar.toolbar > .toolbar-item > span { 262 | background: hsl(230, 1%, 90%); 263 | color: hsl(230, 6%, 44%); 264 | padding: 0.1em 0.4em; 265 | border-radius: 0.3em; 266 | } 267 | 268 | div.code-toolbar > .toolbar.toolbar > .toolbar-item > button:hover, 269 | div.code-toolbar > .toolbar.toolbar > .toolbar-item > button:focus, 270 | div.code-toolbar > .toolbar.toolbar > .toolbar-item > a:hover, 271 | div.code-toolbar > .toolbar.toolbar > .toolbar-item > a:focus, 272 | div.code-toolbar > .toolbar.toolbar > .toolbar-item > span:hover, 273 | div.code-toolbar > .toolbar.toolbar > .toolbar-item > span:focus { 274 | background: hsl(230, 1%, 78%); /* custom: darken(--syntax-bg, 20%) */ 275 | color: hsl(230, 8%, 24%); 276 | } 277 | 278 | /* Line Highlight plugin overrides */ 279 | /* The highlighted line itself */ 280 | .line-highlight.line-highlight { 281 | background: hsla(230, 8%, 24%, 0.05); 282 | } 283 | 284 | /* Default line numbers in Line Highlight plugin */ 285 | .line-highlight.line-highlight:before, 286 | .line-highlight.line-highlight[data-end]:after { 287 | background: hsl(230, 1%, 90%); 288 | color: hsl(230, 8%, 24%); 289 | padding: 0.1em 0.6em; 290 | border-radius: 0.3em; 291 | box-shadow: 0 2px 0 0 rgba(0, 0, 0, 0.2); /* same as Toolbar plugin default */ 292 | } 293 | 294 | /* Hovering over a linkable line number (in the gutter area) */ 295 | /* Requires Line Numbers plugin as well */ 296 | pre[id].linkable-line-numbers.linkable-line-numbers span.line-numbers-rows > span:hover:before { 297 | background-color: hsla(230, 8%, 24%, 0.05); 298 | } 299 | 300 | /* Line Numbers and Command Line plugins overrides */ 301 | /* Line separating gutter from coding area */ 302 | .line-numbers.line-numbers .line-numbers-rows, 303 | .command-line .command-line-prompt { 304 | border-right-color: hsla(230, 8%, 24%, 0.2); 305 | } 306 | 307 | /* Stuff in the gutter */ 308 | .line-numbers .line-numbers-rows > span:before, 309 | .command-line .command-line-prompt > span:before { 310 | color: hsl(230, 1%, 62%); 311 | } 312 | 313 | /* Match Braces plugin overrides */ 314 | /* Note: Outline colour is inherited from the braces */ 315 | .rainbow-braces .token.token.punctuation.brace-level-1, 316 | .rainbow-braces .token.token.punctuation.brace-level-5, 317 | .rainbow-braces .token.token.punctuation.brace-level-9 { 318 | color: hsl(5, 74%, 59%); 319 | } 320 | 321 | .rainbow-braces .token.token.punctuation.brace-level-2, 322 | .rainbow-braces .token.token.punctuation.brace-level-6, 323 | .rainbow-braces .token.token.punctuation.brace-level-10 { 324 | color: hsl(119, 34%, 47%); 325 | } 326 | 327 | .rainbow-braces .token.token.punctuation.brace-level-3, 328 | .rainbow-braces .token.token.punctuation.brace-level-7, 329 | .rainbow-braces .token.token.punctuation.brace-level-11 { 330 | color: hsl(221, 87%, 60%); 331 | } 332 | 333 | .rainbow-braces .token.token.punctuation.brace-level-4, 334 | .rainbow-braces .token.token.punctuation.brace-level-8, 335 | .rainbow-braces .token.token.punctuation.brace-level-12 { 336 | color: hsl(301, 63%, 40%); 337 | } 338 | 339 | /* Diff Highlight plugin overrides */ 340 | /* Taken from https://github.com/atom/github/blob/master/styles/variables.less */ 341 | pre.diff-highlight > code .token.token.deleted:not(.prefix), 342 | pre > code.diff-highlight .token.token.deleted:not(.prefix) { 343 | background-color: hsla(353, 100%, 66%, 0.15); 344 | } 345 | 346 | pre.diff-highlight > code .token.token.deleted:not(.prefix)::-moz-selection, 347 | pre.diff-highlight > code .token.token.deleted:not(.prefix) *::-moz-selection, 348 | pre > code.diff-highlight .token.token.deleted:not(.prefix)::-moz-selection, 349 | pre > code.diff-highlight .token.token.deleted:not(.prefix) *::-moz-selection { 350 | background-color: hsla(353, 95%, 66%, 0.25); 351 | } 352 | 353 | pre.diff-highlight > code .token.token.deleted:not(.prefix)::selection, 354 | pre.diff-highlight > code .token.token.deleted:not(.prefix) *::selection, 355 | pre > code.diff-highlight .token.token.deleted:not(.prefix)::selection, 356 | pre > code.diff-highlight .token.token.deleted:not(.prefix) *::selection { 357 | background-color: hsla(353, 95%, 66%, 0.25); 358 | } 359 | 360 | pre.diff-highlight > code .token.token.inserted:not(.prefix), 361 | pre > code.diff-highlight .token.token.inserted:not(.prefix) { 362 | background-color: hsla(137, 100%, 55%, 0.15); 363 | } 364 | 365 | pre.diff-highlight > code .token.token.inserted:not(.prefix)::-moz-selection, 366 | pre.diff-highlight > code .token.token.inserted:not(.prefix) *::-moz-selection, 367 | pre > code.diff-highlight .token.token.inserted:not(.prefix)::-moz-selection, 368 | pre > code.diff-highlight .token.token.inserted:not(.prefix) *::-moz-selection { 369 | background-color: hsla(135, 73%, 55%, 0.25); 370 | } 371 | 372 | pre.diff-highlight > code .token.token.inserted:not(.prefix)::selection, 373 | pre.diff-highlight > code .token.token.inserted:not(.prefix) *::selection, 374 | pre > code.diff-highlight .token.token.inserted:not(.prefix)::selection, 375 | pre > code.diff-highlight .token.token.inserted:not(.prefix) *::selection { 376 | background-color: hsla(135, 73%, 55%, 0.25); 377 | } 378 | 379 | /* Previewers plugin overrides */ 380 | /* Based on https://github.com/atom-community/atom-ide-datatip/blob/master/styles/atom-ide-datatips.less and https://github.com/atom/atom/blob/master/packages/one-light-ui */ 381 | /* Border around popup */ 382 | .prism-previewer.prism-previewer:before, 383 | .prism-previewer-gradient.prism-previewer-gradient div { 384 | border-color: hsl(0, 0, 95%); 385 | } 386 | 387 | /* Angle and time should remain as circles and are hence not included */ 388 | .prism-previewer-color.prism-previewer-color:before, 389 | .prism-previewer-gradient.prism-previewer-gradient div, 390 | .prism-previewer-easing.prism-previewer-easing:before { 391 | border-radius: 0.3em; 392 | } 393 | 394 | /* Triangles pointing to the code */ 395 | .prism-previewer.prism-previewer:after { 396 | border-top-color: hsl(0, 0, 95%); 397 | } 398 | 399 | .prism-previewer-flipped.prism-previewer-flipped.after { 400 | border-bottom-color: hsl(0, 0, 95%); 401 | } 402 | 403 | /* Background colour within the popup */ 404 | .prism-previewer-angle.prism-previewer-angle:before, 405 | .prism-previewer-time.prism-previewer-time:before, 406 | .prism-previewer-easing.prism-previewer-easing { 407 | background: hsl(0, 0%, 100%); 408 | } 409 | 410 | /* For angle, this is the positive area (eg. 90deg will display one quadrant in this colour) */ 411 | /* For time, this is the alternate colour */ 412 | .prism-previewer-angle.prism-previewer-angle circle, 413 | .prism-previewer-time.prism-previewer-time circle { 414 | stroke: hsl(230, 8%, 24%); 415 | stroke-opacity: 1; 416 | } 417 | 418 | /* Stroke colours of the handle, direction point, and vector itself */ 419 | .prism-previewer-easing.prism-previewer-easing circle, 420 | .prism-previewer-easing.prism-previewer-easing path, 421 | .prism-previewer-easing.prism-previewer-easing line { 422 | stroke: hsl(230, 8%, 24%); 423 | } 424 | 425 | /* Fill colour of the handle */ 426 | .prism-previewer-easing.prism-previewer-easing circle { 427 | fill: transparent; 428 | } 429 | -------------------------------------------------------------------------------- /example/src/prism-themes/pojoaque.css: -------------------------------------------------------------------------------- 1 | /* 2 | * Pojoaque Style by Jason Tate 3 | * http://web-cms-designs.com/ftopict-10-pojoaque-style-for-highlight-js-code-highlighter.html 4 | * Based on Solarized Style from http://ethanschoonover.com/solarized 5 | * http://softwaremaniacs.org/media/soft/highlight/test.html 6 | */ 7 | 8 | code[class*="language-"], 9 | pre[class*="language-"] { 10 | -moz-tab-size: 4; 11 | -o-tab-size: 4; 12 | tab-size: 4; 13 | -webkit-hyphens: none; 14 | -moz-hyphens: none; 15 | -ms-hyphens: none; 16 | hyphens: none; 17 | white-space: pre; 18 | white-space: pre-wrap; 19 | word-break: break-all; 20 | word-wrap: break-word; 21 | font-family: Menlo, Monaco, "Courier New", monospace; 22 | font-size: 15px; 23 | line-height: 1.5; 24 | color: #dccf8f; 25 | text-shadow: 0; 26 | } 27 | 28 | pre > code[class*="language-"] { 29 | font-size: 1em; 30 | } 31 | 32 | pre[class*="language-"], 33 | :not(pre) > code[class*="language-"] { 34 | border-radius: 5px; 35 | border: 1px solid #000; 36 | color: #DCCF8F; 37 | background: #181914 url('') repeat left top; 38 | } 39 | 40 | pre[class*="language-"] { 41 | padding: 12px; 42 | overflow: auto; 43 | } 44 | 45 | :not(pre) > code[class*="language-"] { 46 | padding: 2px 6px; 47 | } 48 | 49 | .token.namespace { 50 | opacity: .7; 51 | } 52 | 53 | .token.comment, 54 | .token.prolog, 55 | .token.doctype, 56 | .token.cdata { 57 | color: #586e75; 58 | font-style: italic; 59 | } 60 | 61 | .token.number, 62 | .token.string, 63 | .token.char, 64 | .token.builtin, 65 | .token.inserted { 66 | color: #468966; 67 | } 68 | 69 | .token.attr-name { 70 | color: #b89859; 71 | } 72 | 73 | .token.operator, 74 | .token.entity, 75 | .token.url, 76 | .language-css .token.string, 77 | .style .token.string { 78 | color: #dccf8f; 79 | } 80 | 81 | .token.selector, 82 | .token.regex { 83 | color: #859900; 84 | } 85 | 86 | .token.atrule, 87 | .token.keyword { 88 | color: #cb4b16; 89 | } 90 | 91 | .token.attr-value { 92 | color: #468966; 93 | } 94 | 95 | .token.function, 96 | .token.variable, 97 | .token.placeholder { 98 | color: #b58900; 99 | } 100 | 101 | .token.property, 102 | .token.tag, 103 | .token.boolean, 104 | .token.number, 105 | .token.constant, 106 | .token.symbol { 107 | color: #b89859; 108 | } 109 | 110 | .token.tag { 111 | color: #ffb03b; 112 | } 113 | 114 | .token.important, 115 | .token.statement, 116 | .token.deleted { 117 | color: #dc322f; 118 | } 119 | 120 | .token.punctuation { 121 | color: #dccf8f; 122 | } 123 | 124 | .token.entity { 125 | cursor: help; 126 | } 127 | 128 | .token.bold { 129 | font-weight: bold; 130 | } 131 | 132 | .token.italic { 133 | font-style: italic; 134 | } 135 | 136 | /* 137 | .pojoaque-colors { 138 | color: #586e75; 139 | color: #b64926; 140 | color: #468966; 141 | color: #ffb03b; 142 | color: #b58900; 143 | color: #b89859; 144 | color: #dccf8f; 145 | color: #d3a60c; 146 | color: #cb4b16; 147 | color: #dc322f; 148 | color: #073642; 149 | color: #181914; 150 | } 151 | */ 152 | -------------------------------------------------------------------------------- /example/src/prism-themes/prism-shades-of-purple.css: -------------------------------------------------------------------------------- 1 | /** 2 | * Shades of Purple Theme for Prism.js 3 | * 4 | * @author Ahmad Awais 5 | * @support Follow/tweet at https://twitter.com/MrAhmadAwais/ 6 | */ 7 | 8 | code[class*='language-'], 9 | pre[class*='language-'] { 10 | color: #9efeff; 11 | direction: ltr; 12 | text-align: left; 13 | white-space: pre; 14 | word-spacing: normal; 15 | word-break: normal; 16 | 17 | -moz-tab-size: 4; 18 | -o-tab-size: 4; 19 | tab-size: 4; 20 | 21 | -webkit-hyphens: none; 22 | -moz-hyphens: none; 23 | -ms-hyphens: none; 24 | hyphens: none; 25 | 26 | font-family: 'Operator Mono', 'Fira Code', Consolas, Monaco, 'Andale Mono', 'Ubuntu Mono', monospace; 27 | font-weight: 400; 28 | font-size: 17px; 29 | line-height: 25px; 30 | letter-spacing: 0.5px; 31 | text-shadow: 0 1px #222245; 32 | } 33 | 34 | pre[class*='language-']::-moz-selection, 35 | pre[class*='language-'] ::-moz-selection, 36 | code[class*='language-']::-moz-selection, 37 | code[class*='language-'] ::-moz-selection, 38 | pre[class*='language-']::selection, 39 | pre[class*='language-'] ::selection, 40 | code[class*='language-']::selection, 41 | code[class*='language-'] ::selection { 42 | color: inherit; 43 | background: #a599e9; 44 | } 45 | 46 | /* Code blocks. */ 47 | pre[class*='language-'] { 48 | /* padding: 2em; */ 49 | margin: 0.5em 0; 50 | overflow: auto; 51 | } 52 | 53 | :not(pre) > code[class*='language-'], 54 | pre[class*='language-'] { 55 | background: #1e1e3f; 56 | } 57 | 58 | /* Inline code */ 59 | :not(pre) > code[class*='language-'] { 60 | padding: 0.1em; 61 | border-radius: 0.3em; 62 | } 63 | 64 | .token { 65 | font-weight: 400; 66 | } 67 | 68 | .token.comment, 69 | .token.prolog, 70 | .token.cdata { 71 | color: #b362ff; 72 | } 73 | 74 | .token.delimiter, 75 | .token.keyword, 76 | .token.selector, 77 | .token.important, 78 | .token.atrule { 79 | color: #ff9d00; 80 | } 81 | 82 | .token.operator, 83 | .token.attr-name { 84 | color: rgb(255, 180, 84); 85 | } 86 | 87 | .token.punctuation { 88 | color: #ffffff; 89 | } 90 | 91 | .token.boolean { 92 | color: rgb(255, 98, 140); 93 | } 94 | 95 | .token.tag, 96 | .token.tag .punctuation, 97 | .token.doctype, 98 | .token.builtin { 99 | color: rgb(255, 157, 0); 100 | } 101 | 102 | .token.entity, 103 | .token.symbol { 104 | color: #6897bb; 105 | } 106 | 107 | .token.number { 108 | color: #ff628c; 109 | } 110 | 111 | .token.property, 112 | .token.constant, 113 | .token.variable { 114 | color: #ff628c; 115 | } 116 | 117 | .token.string, 118 | .token.char { 119 | color: #a5ff90; 120 | } 121 | 122 | .token.attr-value, 123 | .token.attr-value .punctuation { 124 | color: #a5c261; 125 | } 126 | 127 | .token.attr-value .punctuation:first-child { 128 | color: #a9b7c6; 129 | } 130 | 131 | .token.url { 132 | color: #287bde; 133 | text-decoration: underline; 134 | } 135 | 136 | .token.function { 137 | color: rgb(250, 208, 0); 138 | } 139 | 140 | .token.regex { 141 | background: #364135; 142 | } 143 | 144 | .token.bold { 145 | font-weight: bold; 146 | } 147 | 148 | .token.italic { 149 | font-style: italic; 150 | } 151 | 152 | .token.inserted { 153 | background: #00ff00; 154 | } 155 | 156 | .token.deleted { 157 | background: #ff000d; 158 | } 159 | 160 | code.language-css .token.property, 161 | code.language-css .token.property + .token.punctuation { 162 | color: #a9b7c6; 163 | } 164 | 165 | code.language-css .token.id { 166 | color: #ffc66d; 167 | } 168 | 169 | code.language-css .token.selector > .token.class, 170 | code.language-css .token.selector > .token.attribute, 171 | code.language-css .token.selector > .token.pseudo-class, 172 | code.language-css .token.selector > .token.pseudo-element { 173 | color: #ffc66d; 174 | } 175 | 176 | .token.class-name { 177 | color: #fb94ff; 178 | } 179 | 180 | .token.operator, 181 | .token.entity, 182 | .token.url, 183 | .language-css .token.string, 184 | .style .token.string { 185 | background: none; 186 | } 187 | 188 | .line-highlight.line-highlight { 189 | margin-top: 36px; 190 | background: linear-gradient(to right, rgba(179, 98, 255, 0.17), transparent); 191 | } 192 | 193 | .line-highlight.line-highlight:before, 194 | .line-highlight.line-highlight[data-end]:after { 195 | content: ''; 196 | } 197 | -------------------------------------------------------------------------------- /example/src/prism-themes/shades-of-purple.css: -------------------------------------------------------------------------------- 1 | /** 2 | * Shades of Purple Theme for Prism.js 3 | * 4 | * @author Ahmad Awais 5 | * @support Follow/tweet at https://twitter.com/MrAhmadAwais/ 6 | */ 7 | 8 | code[class*='language-'], 9 | pre[class*='language-'] { 10 | color: #9efeff; 11 | direction: ltr; 12 | text-align: left; 13 | white-space: pre; 14 | word-spacing: normal; 15 | word-break: normal; 16 | 17 | -moz-tab-size: 4; 18 | -o-tab-size: 4; 19 | tab-size: 4; 20 | 21 | -webkit-hyphens: none; 22 | -moz-hyphens: none; 23 | -ms-hyphens: none; 24 | hyphens: none; 25 | 26 | font-family: 'Operator Mono', 'Fira Code', Consolas, Monaco, 'Andale Mono', 'Ubuntu Mono', monospace; 27 | font-weight: 400; 28 | font-size: 17px; 29 | line-height: 25px; 30 | letter-spacing: 0.5px; 31 | text-shadow: 0 1px #222245; 32 | } 33 | 34 | pre[class*='language-']::-moz-selection, 35 | pre[class*='language-'] ::-moz-selection, 36 | code[class*='language-']::-moz-selection, 37 | code[class*='language-'] ::-moz-selection, 38 | pre[class*='language-']::selection, 39 | pre[class*='language-'] ::selection, 40 | code[class*='language-']::selection, 41 | code[class*='language-'] ::selection { 42 | color: inherit; 43 | background: #a599e9; 44 | } 45 | 46 | /* Code blocks. */ 47 | pre[class*='language-'] { 48 | /* padding: 2em; */ 49 | margin: 0.5em 0; 50 | overflow: auto; 51 | } 52 | 53 | :not(pre) > code[class*='language-'], 54 | pre[class*='language-'] { 55 | background: #1e1e3f; 56 | } 57 | 58 | /* Inline code */ 59 | :not(pre) > code[class*='language-'] { 60 | padding: 0.1em; 61 | border-radius: 0.3em; 62 | } 63 | 64 | .token { 65 | font-weight: 400; 66 | } 67 | 68 | .token.comment, 69 | .token.prolog, 70 | .token.cdata { 71 | color: #b362ff; 72 | } 73 | 74 | .token.delimiter, 75 | .token.keyword, 76 | .token.selector, 77 | .token.important, 78 | .token.atrule { 79 | color: #ff9d00; 80 | } 81 | 82 | .token.operator, 83 | .token.attr-name { 84 | color: rgb(255, 180, 84); 85 | } 86 | 87 | .token.punctuation { 88 | color: #ffffff; 89 | } 90 | 91 | .token.boolean { 92 | color: rgb(255, 98, 140); 93 | } 94 | 95 | .token.tag, 96 | .token.tag .punctuation, 97 | .token.doctype, 98 | .token.builtin { 99 | color: rgb(255, 157, 0); 100 | } 101 | 102 | .token.entity, 103 | .token.symbol { 104 | color: #6897bb; 105 | } 106 | 107 | .token.number { 108 | color: #ff628c; 109 | } 110 | 111 | .token.property, 112 | .token.constant, 113 | .token.variable { 114 | color: #ff628c; 115 | } 116 | 117 | .token.string, 118 | .token.char { 119 | color: #a5ff90; 120 | } 121 | 122 | .token.attr-value, 123 | .token.attr-value .punctuation { 124 | color: #a5c261; 125 | } 126 | 127 | .token.attr-value .punctuation:first-child { 128 | color: #a9b7c6; 129 | } 130 | 131 | .token.url { 132 | color: #287bde; 133 | text-decoration: underline; 134 | } 135 | 136 | .token.function { 137 | color: rgb(250, 208, 0); 138 | } 139 | 140 | .token.regex { 141 | background: #364135; 142 | } 143 | 144 | .token.bold { 145 | font-weight: bold; 146 | } 147 | 148 | .token.italic { 149 | font-style: italic; 150 | } 151 | 152 | .token.inserted { 153 | background: #00ff00; 154 | } 155 | 156 | .token.deleted { 157 | background: #ff000d; 158 | } 159 | 160 | code.language-css .token.property, 161 | code.language-css .token.property + .token.punctuation { 162 | color: #a9b7c6; 163 | } 164 | 165 | code.language-css .token.id { 166 | color: #ffc66d; 167 | } 168 | 169 | code.language-css .token.selector > .token.class, 170 | code.language-css .token.selector > .token.attribute, 171 | code.language-css .token.selector > .token.pseudo-class, 172 | code.language-css .token.selector > .token.pseudo-element { 173 | color: #ffc66d; 174 | } 175 | 176 | .token.class-name { 177 | color: #fb94ff; 178 | } 179 | 180 | .token.operator, 181 | .token.entity, 182 | .token.url, 183 | .language-css .token.string, 184 | .style .token.string { 185 | background: none; 186 | } 187 | 188 | .line-highlight.line-highlight { 189 | margin-top: 36px; 190 | background: linear-gradient(to right, rgba(179, 98, 255, 0.17), transparent); 191 | } 192 | 193 | .line-highlight.line-highlight:before, 194 | .line-highlight.line-highlight[data-end]:after { 195 | content: ''; 196 | } 197 | -------------------------------------------------------------------------------- /example/src/prism-themes/solarized-dark-atom.css: -------------------------------------------------------------------------------- 1 | /** 2 | * Solarized dark atom theme for `prism.js` 3 | * Based on Atom's `atom-dark` theme: https://github.com/atom/atom-dark-syntax 4 | * @author Pranay Chauhan (@PranayChauhan2516) 5 | */ 6 | 7 | code[class*="language-"], 8 | pre[class*="language-"] { 9 | color: #839496; 10 | text-shadow: 0 1px rgba(0, 0, 0, 0.3); 11 | font-family: Inconsolata, Monaco, Consolas, 'Courier New', Courier, monospace; 12 | direction: ltr; 13 | text-align: left; 14 | white-space: pre; 15 | word-spacing: normal; 16 | word-break: normal; 17 | line-height: 1.5; 18 | 19 | -moz-tab-size: 4; 20 | -o-tab-size: 4; 21 | tab-size: 4; 22 | 23 | -webkit-hyphens: none; 24 | -moz-hyphens: none; 25 | -ms-hyphens: none; 26 | hyphens: none; 27 | } 28 | 29 | /* Code blocks */ 30 | pre[class*="language-"] { 31 | padding: 1em; 32 | margin: .5em 0; 33 | overflow: auto; 34 | border-radius: 0.3em; 35 | } 36 | 37 | :not(pre) > code[class*="language-"], 38 | pre[class*="language-"] { 39 | background: #002b36; 40 | } 41 | 42 | /* Inline code */ 43 | :not(pre) > code[class*="language-"] { 44 | padding: .1em; 45 | border-radius: .3em; 46 | } 47 | 48 | .token.comment, 49 | .token.prolog, 50 | .token.doctype, 51 | .token.cdata { 52 | color: #586e75; 53 | } 54 | 55 | .token.punctuation { 56 | color: #93a1a1; 57 | } 58 | 59 | .namespace { 60 | opacity: .7; 61 | } 62 | 63 | .token.property, 64 | .token.keyword, 65 | .token.tag { 66 | color: #268bd2; 67 | } 68 | 69 | .token.class-name { 70 | color: #FFFFB6; 71 | text-decoration: underline; 72 | } 73 | 74 | .token.boolean, 75 | .token.constant { 76 | color: #b58900; 77 | } 78 | 79 | .token.symbol, 80 | .token.deleted { 81 | color: #dc322f; 82 | } 83 | 84 | .token.number { 85 | color: #859900; 86 | } 87 | 88 | .token.selector, 89 | .token.attr-name, 90 | .token.string, 91 | .token.char, 92 | .token.builtin, 93 | .token.inserted { 94 | color: #859900; 95 | } 96 | 97 | .token.variable { 98 | color: #268bd2; 99 | } 100 | 101 | .token.operator { 102 | color: #EDEDED; 103 | } 104 | 105 | .token.function { 106 | color: #268bd2; 107 | } 108 | 109 | .token.regex { 110 | color: #E9C062; 111 | } 112 | 113 | .token.important { 114 | color: #fd971f; 115 | } 116 | 117 | .token.entity { 118 | color: #FFFFB6; 119 | cursor: help; 120 | } 121 | 122 | .token.url { 123 | color: #96CBFE; 124 | } 125 | 126 | .language-css .token.string, 127 | .style .token.string { 128 | color: #87C38A; 129 | } 130 | 131 | .token.important, 132 | .token.bold { 133 | font-weight: bold; 134 | } 135 | 136 | .token.italic { 137 | font-style: italic; 138 | } 139 | 140 | .token.atrule, 141 | .token.attr-value { 142 | color: #F9EE98; 143 | } 144 | -------------------------------------------------------------------------------- /example/src/prism-themes/synthwave84.css: -------------------------------------------------------------------------------- 1 | /* 2 | * Synthwave '84 Theme originally by Robb Owen [@Robb0wen] for Visual Studio Code 3 | * Demo: https://marc.dev/demo/prism-synthwave84 4 | * 5 | * Ported for PrismJS by Marc Backes [@themarcba] 6 | */ 7 | 8 | code[class*="language-"], 9 | pre[class*="language-"] { 10 | color: #f92aad; 11 | text-shadow: 0 0 2px #100c0f, 0 0 5px #dc078e33, 0 0 10px #fff3; 12 | background: none; 13 | font-family: Consolas, Monaco, 'Andale Mono', 'Ubuntu Mono', monospace; 14 | font-size: 1em; 15 | text-align: left; 16 | white-space: pre; 17 | word-spacing: normal; 18 | word-break: normal; 19 | word-wrap: normal; 20 | line-height: 1.5; 21 | 22 | -moz-tab-size: 4; 23 | -o-tab-size: 4; 24 | tab-size: 4; 25 | 26 | -webkit-hyphens: none; 27 | -moz-hyphens: none; 28 | -ms-hyphens: none; 29 | hyphens: none; 30 | } 31 | 32 | /* Code blocks */ 33 | pre[class*="language-"] { 34 | padding: 1em; 35 | margin: .5em 0; 36 | overflow: auto; 37 | } 38 | 39 | :not(pre) > code[class*="language-"], 40 | pre[class*="language-"] { 41 | background-color: transparent !important; 42 | background-image: linear-gradient(to bottom, #2a2139 75%, #34294f); 43 | } 44 | 45 | /* Inline code */ 46 | :not(pre) > code[class*="language-"] { 47 | padding: .1em; 48 | border-radius: .3em; 49 | white-space: normal; 50 | } 51 | 52 | .token.comment, 53 | .token.block-comment, 54 | .token.prolog, 55 | .token.doctype, 56 | .token.cdata { 57 | color: #8e8e8e; 58 | } 59 | 60 | .token.punctuation { 61 | color: #ccc; 62 | } 63 | 64 | .token.tag, 65 | .token.attr-name, 66 | .token.namespace, 67 | .token.number, 68 | .token.unit, 69 | .token.hexcode, 70 | .token.deleted { 71 | color: #e2777a; 72 | } 73 | 74 | .token.property, 75 | .token.selector { 76 | color: #72f1b8; 77 | text-shadow: 0 0 2px #100c0f, 0 0 10px #257c5575, 0 0 35px #21272475; 78 | } 79 | 80 | .token.function-name { 81 | color: #6196cc; 82 | } 83 | 84 | .token.boolean, 85 | .token.selector .token.id, 86 | .token.function { 87 | color: #fdfdfd; 88 | text-shadow: 0 0 2px #001716, 0 0 3px #03edf975, 0 0 5px #03edf975, 0 0 8px #03edf975; 89 | } 90 | 91 | .token.class-name { 92 | color: #fff5f6; 93 | text-shadow: 0 0 2px #000, 0 0 10px #fc1f2c75, 0 0 5px #fc1f2c75, 0 0 25px #fc1f2c75; 94 | } 95 | 96 | .token.constant, 97 | .token.symbol { 98 | color: #f92aad; 99 | text-shadow: 0 0 2px #100c0f, 0 0 5px #dc078e33, 0 0 10px #fff3; 100 | } 101 | 102 | .token.important, 103 | .token.atrule, 104 | .token.keyword, 105 | .token.selector .token.class, 106 | .token.builtin { 107 | color: #f4eee4; 108 | text-shadow: 0 0 2px #393a33, 0 0 8px #f39f0575, 0 0 2px #f39f0575; 109 | } 110 | 111 | .token.string, 112 | .token.char, 113 | .token.attr-value, 114 | .token.regex, 115 | .token.variable { 116 | color: #f87c32; 117 | } 118 | 119 | .token.operator, 120 | .token.entity, 121 | .token.url { 122 | color: #67cdcc; 123 | } 124 | 125 | .token.important, 126 | .token.bold { 127 | font-weight: bold; 128 | } 129 | 130 | .token.italic { 131 | font-style: italic; 132 | } 133 | 134 | .token.entity { 135 | cursor: help; 136 | } 137 | 138 | .token.inserted { 139 | color: green; 140 | } 141 | -------------------------------------------------------------------------------- /example/src/prism-themes/vs.css: -------------------------------------------------------------------------------- 1 | /** 2 | * VS theme by Andrew Lock (https://andrewlock.net) 3 | * Inspired by Visual Studio syntax coloring 4 | */ 5 | 6 | code[class*="language-"], 7 | pre[class*="language-"] { 8 | color: #393A34; 9 | font-family: "Consolas", "Bitstream Vera Sans Mono", "Courier New", Courier, monospace; 10 | direction: ltr; 11 | text-align: left; 12 | white-space: pre; 13 | word-spacing: normal; 14 | word-break: normal; 15 | font-size: .9em; 16 | line-height: 1.2em; 17 | 18 | -moz-tab-size: 4; 19 | -o-tab-size: 4; 20 | tab-size: 4; 21 | 22 | -webkit-hyphens: none; 23 | -moz-hyphens: none; 24 | -ms-hyphens: none; 25 | hyphens: none; 26 | } 27 | 28 | pre > code[class*="language-"] { 29 | font-size: 1em; 30 | } 31 | 32 | pre[class*="language-"]::-moz-selection, pre[class*="language-"] ::-moz-selection, 33 | code[class*="language-"]::-moz-selection, code[class*="language-"] ::-moz-selection { 34 | background: #C1DEF1; 35 | } 36 | 37 | pre[class*="language-"]::selection, pre[class*="language-"] ::selection, 38 | code[class*="language-"]::selection, code[class*="language-"] ::selection { 39 | background: #C1DEF1; 40 | } 41 | 42 | /* Code blocks */ 43 | pre[class*="language-"] { 44 | padding: 1em; 45 | margin: .5em 0; 46 | overflow: auto; 47 | border: 1px solid #dddddd; 48 | background-color: white; 49 | } 50 | 51 | /* Inline code */ 52 | :not(pre) > code[class*="language-"] { 53 | padding: .2em; 54 | padding-top: 1px; 55 | padding-bottom: 1px; 56 | background: #f8f8f8; 57 | border: 1px solid #dddddd; 58 | } 59 | 60 | .token.comment, 61 | .token.prolog, 62 | .token.doctype, 63 | .token.cdata { 64 | color: #008000; 65 | font-style: italic; 66 | } 67 | 68 | .token.namespace { 69 | opacity: .7; 70 | } 71 | 72 | .token.string { 73 | color: #A31515; 74 | } 75 | 76 | .token.punctuation, 77 | .token.operator { 78 | color: #393A34; /* no highlight */ 79 | } 80 | 81 | .token.url, 82 | .token.symbol, 83 | .token.number, 84 | .token.boolean, 85 | .token.variable, 86 | .token.constant, 87 | .token.inserted { 88 | color: #36acaa; 89 | } 90 | 91 | .token.atrule, 92 | .token.keyword, 93 | .token.attr-value, 94 | .language-autohotkey .token.selector, 95 | .language-json .token.boolean, 96 | .language-json .token.number, 97 | code[class*="language-css"] { 98 | color: #0000ff; 99 | } 100 | 101 | .token.function { 102 | color: #393A34; 103 | } 104 | 105 | .token.deleted, 106 | .language-autohotkey .token.tag { 107 | color: #9a050f; 108 | } 109 | 110 | .token.selector, 111 | .language-autohotkey .token.keyword { 112 | color: #00009f; 113 | } 114 | 115 | .token.important { 116 | color: #e90; 117 | } 118 | 119 | .token.important, 120 | .token.bold { 121 | font-weight: bold; 122 | } 123 | 124 | .token.italic { 125 | font-style: italic; 126 | } 127 | 128 | .token.class-name, 129 | .language-json .token.property { 130 | color: #2B91AF; 131 | } 132 | 133 | .token.tag, 134 | .token.selector { 135 | color: #800000; 136 | } 137 | 138 | .token.attr-name, 139 | .token.property, 140 | .token.regex, 141 | .token.entity { 142 | color: #ff0000; 143 | } 144 | 145 | .token.directive.tag .tag { 146 | background: #ffff00; 147 | color: #393A34; 148 | } 149 | 150 | /* overrides color-values for the Line Numbers plugin 151 | * http://prismjs.com/plugins/line-numbers/ 152 | */ 153 | .line-numbers.line-numbers .line-numbers-rows { 154 | border-right-color: #a5a5a5; 155 | } 156 | 157 | .line-numbers .line-numbers-rows > span:before { 158 | color: #2B91AF; 159 | } 160 | 161 | /* overrides color-values for the Line Highlight plugin 162 | * http://prismjs.com/plugins/line-highlight/ 163 | */ 164 | .line-highlight.line-highlight { 165 | background: rgba(193, 222, 241, 0.2); 166 | background: -webkit-linear-gradient(left, rgba(193, 222, 241, 0.2) 70%, rgba(221, 222, 241, 0)); 167 | background: linear-gradient(to right, rgba(193, 222, 241, 0.2) 70%, rgba(221, 222, 241, 0)); 168 | } 169 | -------------------------------------------------------------------------------- /example/src/prism-themes/vsc-dark-plus.css: -------------------------------------------------------------------------------- 1 | pre[class*="language-"], 2 | code[class*="language-"] { 3 | color: #d4d4d4; 4 | font-size: 13px; 5 | text-shadow: none; 6 | font-family: Menlo, Monaco, Consolas, "Andale Mono", "Ubuntu Mono", "Courier New", monospace; 7 | direction: ltr; 8 | text-align: left; 9 | white-space: pre; 10 | word-spacing: normal; 11 | word-break: normal; 12 | line-height: 1.5; 13 | -moz-tab-size: 4; 14 | -o-tab-size: 4; 15 | tab-size: 4; 16 | -webkit-hyphens: none; 17 | -moz-hyphens: none; 18 | -ms-hyphens: none; 19 | hyphens: none; 20 | } 21 | 22 | pre[class*="language-"]::selection, 23 | code[class*="language-"]::selection, 24 | pre[class*="language-"] *::selection, 25 | code[class*="language-"] *::selection { 26 | text-shadow: none; 27 | background: #264F78; 28 | } 29 | 30 | @media print { 31 | pre[class*="language-"], 32 | code[class*="language-"] { 33 | text-shadow: none; 34 | } 35 | } 36 | 37 | pre[class*="language-"] { 38 | padding: 1em; 39 | margin: .5em 0; 40 | overflow: auto; 41 | background: #1e1e1e; 42 | } 43 | 44 | :not(pre) > code[class*="language-"] { 45 | padding: .1em .3em; 46 | border-radius: .3em; 47 | color: #db4c69; 48 | background: #1e1e1e; 49 | } 50 | /********************************************************* 51 | * Tokens 52 | */ 53 | .namespace { 54 | opacity: .7; 55 | } 56 | 57 | .token.doctype .token.doctype-tag { 58 | color: #569CD6; 59 | } 60 | 61 | .token.doctype .token.name { 62 | color: #9cdcfe; 63 | } 64 | 65 | .token.comment, 66 | .token.prolog { 67 | color: #6a9955; 68 | } 69 | 70 | .token.punctuation, 71 | .language-html .language-css .token.punctuation, 72 | .language-html .language-javascript .token.punctuation { 73 | color: #d4d4d4; 74 | } 75 | 76 | .token.property, 77 | .token.tag, 78 | .token.boolean, 79 | .token.number, 80 | .token.constant, 81 | .token.symbol, 82 | .token.inserted, 83 | .token.unit { 84 | color: #b5cea8; 85 | } 86 | 87 | .token.selector, 88 | .token.attr-name, 89 | .token.string, 90 | .token.char, 91 | .token.builtin, 92 | .token.deleted { 93 | color: #ce9178; 94 | } 95 | 96 | .language-css .token.string.url { 97 | text-decoration: underline; 98 | } 99 | 100 | .token.operator, 101 | .token.entity { 102 | color: #d4d4d4; 103 | } 104 | 105 | .token.operator.arrow { 106 | color: #569CD6; 107 | } 108 | 109 | .token.atrule { 110 | color: #ce9178; 111 | } 112 | 113 | .token.atrule .token.rule { 114 | color: #c586c0; 115 | } 116 | 117 | .token.atrule .token.url { 118 | color: #9cdcfe; 119 | } 120 | 121 | .token.atrule .token.url .token.function { 122 | color: #dcdcaa; 123 | } 124 | 125 | .token.atrule .token.url .token.punctuation { 126 | color: #d4d4d4; 127 | } 128 | 129 | .token.keyword { 130 | color: #569CD6; 131 | } 132 | 133 | .token.keyword.module, 134 | .token.keyword.control-flow { 135 | color: #c586c0; 136 | } 137 | 138 | .token.function, 139 | .token.function .token.maybe-class-name { 140 | color: #dcdcaa; 141 | } 142 | 143 | .token.regex { 144 | color: #d16969; 145 | } 146 | 147 | .token.important { 148 | color: #569cd6; 149 | } 150 | 151 | .token.italic { 152 | font-style: italic; 153 | } 154 | 155 | .token.constant { 156 | color: #9cdcfe; 157 | } 158 | 159 | .token.class-name, 160 | .token.maybe-class-name { 161 | color: #4ec9b0; 162 | } 163 | 164 | .token.console { 165 | color: #9cdcfe; 166 | } 167 | 168 | .token.parameter { 169 | color: #9cdcfe; 170 | } 171 | 172 | .token.interpolation { 173 | color: #9cdcfe; 174 | } 175 | 176 | .token.punctuation.interpolation-punctuation { 177 | color: #569cd6; 178 | } 179 | 180 | .token.boolean { 181 | color: #569cd6; 182 | } 183 | 184 | .token.property, 185 | .token.variable, 186 | .token.imports .token.maybe-class-name, 187 | .token.exports .token.maybe-class-name { 188 | color: #9cdcfe; 189 | } 190 | 191 | .token.selector { 192 | color: #d7ba7d; 193 | } 194 | 195 | .token.escape { 196 | color: #d7ba7d; 197 | } 198 | 199 | .token.tag { 200 | color: #569cd6; 201 | } 202 | 203 | .token.tag .token.punctuation { 204 | color: #808080; 205 | } 206 | 207 | .token.cdata { 208 | color: #808080; 209 | } 210 | 211 | .token.attr-name { 212 | color: #9cdcfe; 213 | } 214 | 215 | .token.attr-value, 216 | .token.attr-value .token.punctuation { 217 | color: #ce9178; 218 | } 219 | 220 | .token.attr-value .token.punctuation.attr-equals { 221 | color: #d4d4d4; 222 | } 223 | 224 | .token.entity { 225 | color: #569cd6; 226 | } 227 | 228 | .token.namespace { 229 | color: #4ec9b0; 230 | } 231 | /********************************************************* 232 | * Language Specific 233 | */ 234 | 235 | pre[class*="language-javascript"], 236 | code[class*="language-javascript"], 237 | pre[class*="language-jsx"], 238 | code[class*="language-jsx"], 239 | pre[class*="language-typescript"], 240 | code[class*="language-typescript"], 241 | pre[class*="language-tsx"], 242 | code[class*="language-tsx"] { 243 | color: #9cdcfe; 244 | } 245 | 246 | pre[class*="language-css"], 247 | code[class*="language-css"] { 248 | color: #ce9178; 249 | } 250 | 251 | pre[class*="language-html"], 252 | code[class*="language-html"] { 253 | color: #d4d4d4; 254 | } 255 | 256 | .language-regex .token.anchor { 257 | color: #dcdcaa; 258 | } 259 | 260 | .language-html .token.punctuation { 261 | color: #808080; 262 | } 263 | /********************************************************* 264 | * Line highlighting 265 | */ 266 | pre[class*="language-"] > code[class*="language-"] { 267 | position: relative; 268 | z-index: 1; 269 | } 270 | 271 | .line-highlight.line-highlight { 272 | background: #f7ebc6; 273 | box-shadow: inset 5px 0 0 #f7d87c; 274 | z-index: 0; 275 | } 276 | -------------------------------------------------------------------------------- /example/src/prism-themes/xonokai.css: -------------------------------------------------------------------------------- 1 | /** 2 | * xonokai theme for JavaScript, CSS and HTML 3 | * based on: https://github.com/MoOx/sass-prism-theme-base by Maxime Thirouin ~ MoOx --> http://moox.fr/ , which is Loosely based on Monokai textmate theme by http://www.monokai.nl/ 4 | * license: MIT; http://moox.mit-license.org/ 5 | */ 6 | code[class*="language-"], 7 | pre[class*="language-"] { 8 | -moz-tab-size: 2; 9 | -o-tab-size: 2; 10 | tab-size: 2; 11 | -webkit-hyphens: none; 12 | -moz-hyphens: none; 13 | -ms-hyphens: none; 14 | hyphens: none; 15 | white-space: pre; 16 | white-space: pre-wrap; 17 | word-wrap: normal; 18 | font-family: Menlo, Monaco, "Courier New", monospace; 19 | font-size: 14px; 20 | color: #76d9e6; 21 | text-shadow: none; 22 | } 23 | 24 | pre > code[class*="language-"] { 25 | font-size: 1em; 26 | } 27 | 28 | pre[class*="language-"], 29 | :not(pre) > code[class*="language-"] { 30 | background: #2a2a2a; 31 | } 32 | 33 | pre[class*="language-"] { 34 | padding: 15px; 35 | border-radius: 4px; 36 | border: 1px solid #e1e1e8; 37 | overflow: auto; 38 | position: relative; 39 | } 40 | 41 | pre[class*="language-"] code { 42 | white-space: pre; 43 | display: block; 44 | } 45 | 46 | :not(pre) > code[class*="language-"] { 47 | padding: 0.15em 0.2em 0.05em; 48 | border-radius: .3em; 49 | border: 0.13em solid #7a6652; 50 | box-shadow: 1px 1px 0.3em -0.1em #000 inset; 51 | } 52 | 53 | .token.namespace { 54 | opacity: .7; 55 | } 56 | 57 | .token.comment, 58 | .token.prolog, 59 | .token.doctype, 60 | .token.cdata { 61 | color: #6f705e; 62 | } 63 | 64 | .token.operator, 65 | .token.boolean, 66 | .token.number { 67 | color: #a77afe; 68 | } 69 | 70 | .token.attr-name, 71 | .token.string { 72 | color: #e6d06c; 73 | } 74 | 75 | .token.entity, 76 | .token.url, 77 | .language-css .token.string, 78 | .style .token.string { 79 | color: #e6d06c; 80 | } 81 | 82 | .token.selector, 83 | .token.inserted { 84 | color: #a6e22d; 85 | } 86 | 87 | .token.atrule, 88 | .token.attr-value, 89 | .token.keyword, 90 | .token.important, 91 | .token.deleted { 92 | color: #ef3b7d; 93 | } 94 | 95 | .token.regex, 96 | .token.statement { 97 | color: #76d9e6; 98 | } 99 | 100 | .token.placeholder, 101 | .token.variable { 102 | color: #fff; 103 | } 104 | 105 | .token.important, 106 | .token.statement, 107 | .token.bold { 108 | font-weight: bold; 109 | } 110 | 111 | .token.punctuation { 112 | color: #bebec5; 113 | } 114 | 115 | .token.entity { 116 | cursor: help; 117 | } 118 | 119 | .token.italic { 120 | font-style: italic; 121 | } 122 | 123 | code.language-markup { 124 | color: #f9f9f9; 125 | } 126 | 127 | code.language-markup .token.tag { 128 | color: #ef3b7d; 129 | } 130 | 131 | code.language-markup .token.attr-name { 132 | color: #a6e22d; 133 | } 134 | 135 | code.language-markup .token.attr-value { 136 | color: #e6d06c; 137 | } 138 | 139 | code.language-markup .token.style, 140 | code.language-markup .token.script { 141 | color: #76d9e6; 142 | } 143 | 144 | code.language-markup .token.script .token.keyword { 145 | color: #76d9e6; 146 | } 147 | 148 | /* Line highlight plugin */ 149 | .line-highlight.line-highlight { 150 | padding: 0; 151 | background: rgba(255, 255, 255, 0.08); 152 | } 153 | 154 | .line-highlight.line-highlight:before, 155 | .line-highlight.line-highlight[data-end]:after { 156 | padding: 0.2em 0.5em; 157 | background-color: rgba(255, 255, 255, 0.4); 158 | color: black; 159 | height: 1em; 160 | line-height: 1em; 161 | box-shadow: 0 1px 1px rgba(255, 255, 255, 0.7); 162 | } 163 | -------------------------------------------------------------------------------- /example/src/prism-themes/z-touch.css: -------------------------------------------------------------------------------- 1 | /* 2 | * Z-Toch 3 | * by Zeel Codder 4 | * https://github.com/zeel-codder 5 | * 6 | */ 7 | code[class*="language-"], 8 | pre[class*="language-"] { 9 | color: #22da17; 10 | font-family: monospace; 11 | text-align: left; 12 | white-space: pre; 13 | word-spacing: normal; 14 | word-break: normal; 15 | word-wrap: normal; 16 | -moz-tab-size: 4; 17 | -o-tab-size: 4; 18 | tab-size: 4; 19 | -webkit-hyphens: none; 20 | -moz-hyphens: none; 21 | -ms-hyphens: none; 22 | hyphens: none; 23 | line-height: 25px; 24 | font-size: 18px; 25 | margin: 5px 0; 26 | } 27 | 28 | pre[class*="language-"] * { 29 | font-family: monospace; 30 | } 31 | 32 | :not(pre) > code[class*="language-"], 33 | pre[class*="language-"] { 34 | color: white; 35 | background: #0a143c; 36 | padding: 22px; 37 | } 38 | 39 | /* Code blocks */ 40 | pre[class*="language-"] { 41 | padding: 1em; 42 | margin: 0.5em 0; 43 | overflow: auto; 44 | } 45 | 46 | pre[class*="language-"]::-moz-selection, 47 | pre[class*="language-"] ::-moz-selection, 48 | code[class*="language-"]::-moz-selection, 49 | code[class*="language-"] ::-moz-selection { 50 | text-shadow: none; 51 | background: rgba(29, 59, 83, 0.99); 52 | } 53 | 54 | pre[class*="language-"]::selection, 55 | pre[class*="language-"] ::selection, 56 | code[class*="language-"]::selection, 57 | code[class*="language-"] ::selection { 58 | text-shadow: none; 59 | background: rgba(29, 59, 83, 0.99); 60 | } 61 | 62 | @media print { 63 | code[class*="language-"], 64 | pre[class*="language-"] { 65 | text-shadow: none; 66 | } 67 | } 68 | 69 | :not(pre) > code[class*="language-"] { 70 | padding: 0.1em; 71 | border-radius: 0.3em; 72 | white-space: normal; 73 | } 74 | 75 | .token.comment, 76 | .token.prolog, 77 | .token.cdata { 78 | color: rgb(99, 119, 119); 79 | font-style: italic; 80 | } 81 | 82 | .token.punctuation { 83 | color: rgb(199, 146, 234); 84 | } 85 | 86 | .namespace { 87 | color: rgb(178, 204, 214); 88 | } 89 | 90 | .token.deleted { 91 | color: rgba(239, 83, 80, 0.56); 92 | font-style: italic; 93 | } 94 | 95 | .token.symbol, 96 | .token.property { 97 | color: rgb(128, 203, 196); 98 | } 99 | 100 | .token.tag, 101 | .token.operator, 102 | .token.keyword { 103 | color: rgb(127, 219, 202); 104 | } 105 | 106 | .token.boolean { 107 | color: rgb(255, 88, 116); 108 | } 109 | 110 | .token.number { 111 | color: rgb(247, 140, 108); 112 | } 113 | 114 | .token.constant, 115 | .token.function, 116 | .token.builtin, 117 | .token.char { 118 | color: rgb(34 183 199); 119 | } 120 | 121 | .token.selector, 122 | .token.doctype { 123 | color: rgb(199, 146, 234); 124 | font-style: italic; 125 | } 126 | 127 | .token.attr-name, 128 | .token.inserted { 129 | color: rgb(173, 219, 103); 130 | font-style: italic; 131 | } 132 | 133 | .token.string, 134 | .token.url, 135 | .token.entity, 136 | .language-css .token.string, 137 | .style .token.string { 138 | color: rgb(173, 219, 103); 139 | } 140 | 141 | .token.class-name, 142 | .token.atrule, 143 | .token.attr-value { 144 | color: rgb(255, 203, 139); 145 | } 146 | 147 | .token.regex, 148 | .token.important, 149 | .token.variable { 150 | color: rgb(214, 222, 235); 151 | } 152 | 153 | .token.important, 154 | .token.bold { 155 | font-weight: bold; 156 | } 157 | 158 | .token.italic { 159 | font-style: italic; 160 | } 161 | -------------------------------------------------------------------------------- /example/src/styles.css: -------------------------------------------------------------------------------- 1 | body { 2 | margin: 0; 3 | font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', 'Roboto', 'Oxygen', 4 | 'Ubuntu', 'Cantarell', 'Fira Sans', 'Droid Sans', 'Helvetica Neue', 5 | sans-serif; 6 | -webkit-font-smoothing: antialiased; 7 | -moz-osx-font-smoothing: grayscale; 8 | display: flex; 9 | color: white; 10 | justify-content: center; 11 | background-color: rgb(32, 32, 32); 12 | background-repeat: no-repeat; 13 | height: 100vh; 14 | color: white; 15 | width: 100vw; 16 | } 17 | 18 | code { 19 | font-family: source-code-pro, Menlo, Monaco, Consolas, 'Courier New', 20 | monospace; 21 | } 22 | 23 | * { 24 | box-sizing: border-box; 25 | } 26 | 27 | #root { 28 | width: 100vh; 29 | } 30 | -------------------------------------------------------------------------------- /example/src/themes/nord-highlight.css: -------------------------------------------------------------------------------- 1 | pre code.hljs { 2 | display: block; 3 | overflow-x: auto; 4 | padding: 1em; 5 | } 6 | code.hljs { 7 | padding: 3px 5px; 8 | } 9 | .hljs { 10 | background: #2e3440; 11 | } 12 | .hljs, 13 | .hljs-subst { 14 | color: #d8dee9; 15 | } 16 | .hljs-selector-tag { 17 | color: #81a1c1; 18 | } 19 | .hljs-selector-id { 20 | color: #8fbcbb; 21 | font-weight: 700; 22 | } 23 | .hljs-selector-attr, 24 | .hljs-selector-class { 25 | color: #8fbcbb; 26 | } 27 | .hljs-property, 28 | .hljs-selector-pseudo { 29 | color: #88c0d0; 30 | } 31 | .hljs-addition { 32 | background-color: rgba(163, 190, 140, 0.5); 33 | } 34 | .hljs-deletion { 35 | background-color: rgba(191, 97, 106, 0.5); 36 | } 37 | .hljs-built_in, 38 | .hljs-class, 39 | .hljs-type { 40 | color: #8fbcbb; 41 | } 42 | .hljs-function, 43 | .hljs-function > .hljs-title, 44 | .hljs-title.hljs-function { 45 | color: #88c0d0; 46 | } 47 | .hljs-keyword, 48 | .hljs-literal, 49 | .hljs-symbol { 50 | color: #81a1c1; 51 | } 52 | .hljs-number { 53 | color: #b48ead; 54 | } 55 | .hljs-regexp { 56 | color: #ebcb8b; 57 | } 58 | .hljs-string { 59 | color: #a3be8c; 60 | } 61 | .hljs-title { 62 | color: #8fbcbb; 63 | } 64 | .hljs-params { 65 | color: #d8dee9; 66 | } 67 | .hljs-bullet { 68 | color: #81a1c1; 69 | } 70 | .hljs-code { 71 | color: #8fbcbb; 72 | } 73 | .hljs-emphasis { 74 | font-style: italic; 75 | } 76 | .hljs-formula { 77 | color: #8fbcbb; 78 | } 79 | .hljs-strong { 80 | font-weight: 700; 81 | } 82 | .hljs-link:hover { 83 | text-decoration: underline; 84 | } 85 | .hljs-comment, 86 | .hljs-quote { 87 | color: #4c566a; 88 | } 89 | .hljs-doctag { 90 | color: #8fbcbb; 91 | } 92 | .hljs-meta, 93 | .hljs-meta .hljs-keyword { 94 | color: #5e81ac; 95 | } 96 | .hljs-meta .hljs-string { 97 | color: #a3be8c; 98 | } 99 | .hljs-attr { 100 | color: #8fbcbb; 101 | } 102 | .hljs-attribute { 103 | color: #d8dee9; 104 | } 105 | .hljs-name { 106 | color: #81a1c1; 107 | } 108 | .hljs-section { 109 | color: #88c0d0; 110 | } 111 | .hljs-tag { 112 | color: #81a1c1; 113 | } 114 | .hljs-template-variable, 115 | .hljs-variable { 116 | color: #d8dee9; 117 | } 118 | .hljs-template-tag { 119 | color: #5e81ac; 120 | } 121 | .language-abnf .hljs-attribute { 122 | color: #88c0d0; 123 | } 124 | .language-abnf .hljs-symbol { 125 | color: #ebcb8b; 126 | } 127 | .language-apache .hljs-attribute { 128 | color: #88c0d0; 129 | } 130 | .language-apache .hljs-section { 131 | color: #81a1c1; 132 | } 133 | .language-arduino .hljs-built_in { 134 | color: #88c0d0; 135 | } 136 | .language-aspectj .hljs-meta { 137 | color: #d08770; 138 | } 139 | .language-aspectj > .hljs-title { 140 | color: #88c0d0; 141 | } 142 | .language-bnf .hljs-attribute { 143 | color: #8fbcbb; 144 | } 145 | .language-clojure .hljs-name { 146 | color: #88c0d0; 147 | } 148 | .language-clojure .hljs-symbol { 149 | color: #ebcb8b; 150 | } 151 | .language-coq .hljs-built_in { 152 | color: #88c0d0; 153 | } 154 | .language-cpp .hljs-meta .hljs-string { 155 | color: #8fbcbb; 156 | } 157 | .language-css .hljs-built_in { 158 | color: #88c0d0; 159 | } 160 | .language-css .hljs-keyword { 161 | color: #d08770; 162 | } 163 | .language-diff .hljs-meta, 164 | .language-ebnf .hljs-attribute { 165 | color: #8fbcbb; 166 | } 167 | .language-glsl .hljs-built_in { 168 | color: #88c0d0; 169 | } 170 | .language-groovy .hljs-meta:not(:first-child), 171 | .language-haxe .hljs-meta, 172 | .language-java .hljs-meta { 173 | color: #d08770; 174 | } 175 | .language-ldif .hljs-attribute { 176 | color: #8fbcbb; 177 | } 178 | .language-lisp .hljs-name, 179 | .language-lua .hljs-built_in, 180 | .language-moonscript .hljs-built_in, 181 | .language-nginx .hljs-attribute { 182 | color: #88c0d0; 183 | } 184 | .language-nginx .hljs-section { 185 | color: #5e81ac; 186 | } 187 | .language-pf .hljs-built_in, 188 | .language-processing .hljs-built_in { 189 | color: #88c0d0; 190 | } 191 | .language-scss .hljs-keyword, 192 | .language-stylus .hljs-keyword { 193 | color: #81a1c1; 194 | } 195 | .language-swift .hljs-meta { 196 | color: #d08770; 197 | } 198 | .language-vim .hljs-built_in { 199 | color: #88c0d0; 200 | font-style: italic; 201 | } 202 | .language-yaml .hljs-meta { 203 | color: #d08770; 204 | } 205 | -------------------------------------------------------------------------------- /example/src/themes/nord-prism.css: -------------------------------------------------------------------------------- 1 | /** 2 | * Nord Theme Originally by Arctic Ice Studio 3 | * https://nordtheme.com 4 | * 5 | * Ported for PrismJS by Zane Hitchcoxc (@zwhitchcox) and Gabriel Ramos (@gabrieluizramos) 6 | */ 7 | 8 | code[class*='language-'], 9 | pre[class*='language-'] { 10 | color: #f8f8f2; 11 | background: none; 12 | font-family: 'Fira Code', Consolas, Monaco, 'Andale Mono', 'Ubuntu Mono', 13 | monospace; 14 | text-align: left; 15 | white-space: pre; 16 | word-spacing: normal; 17 | word-break: normal; 18 | word-wrap: normal; 19 | line-height: 1.5; 20 | -moz-tab-size: 4; 21 | -o-tab-size: 4; 22 | tab-size: 4; 23 | -webkit-hyphens: none; 24 | -moz-hyphens: none; 25 | -ms-hyphens: none; 26 | hyphens: none; 27 | } 28 | 29 | /* Code blocks */ 30 | pre[class*='language-'] { 31 | padding: 1em; 32 | margin: 0.5em 0; 33 | overflow: auto; 34 | border-radius: 0.3em; 35 | } 36 | 37 | :not(pre) > code[class*='language-'], 38 | pre[class*='language-'] { 39 | background: #2e3440; 40 | } 41 | 42 | /* Inline code */ 43 | :not(pre) > code[class*='language-'] { 44 | padding: 0.1em; 45 | border-radius: 0.3em; 46 | white-space: normal; 47 | } 48 | 49 | .token.comment, 50 | .token.prolog, 51 | .token.doctype, 52 | .token.cdata { 53 | color: #636f88; 54 | } 55 | 56 | .token.punctuation { 57 | color: #81a1c1; 58 | } 59 | 60 | .namespace { 61 | opacity: 0.7; 62 | } 63 | 64 | .token.property, 65 | .token.tag, 66 | .token.constant, 67 | .token.symbol, 68 | .token.deleted { 69 | color: #81a1c1; 70 | } 71 | 72 | .token.number { 73 | color: #b48ead; 74 | } 75 | 76 | .token.boolean { 77 | color: #81a1c1; 78 | } 79 | 80 | .token.selector, 81 | .token.attr-name, 82 | .token.string, 83 | .token.char, 84 | .token.builtin, 85 | .token.inserted { 86 | color: #a3be8c; 87 | } 88 | 89 | .token.operator, 90 | .token.entity, 91 | .token.url, 92 | .language-css .token.string, 93 | .style .token.string, 94 | .token.variable { 95 | color: #81a1c1; 96 | } 97 | 98 | .token.atrule, 99 | .token.attr-value, 100 | .token.function, 101 | .token.class-name { 102 | color: #88c0d0; 103 | } 104 | 105 | .token.keyword { 106 | color: #81a1c1; 107 | } 108 | 109 | .token.regex, 110 | .token.important { 111 | color: #ebcb8b; 112 | } 113 | 114 | .token.important, 115 | .token.bold { 116 | font-weight: bold; 117 | } 118 | 119 | .token.italic { 120 | font-style: italic; 121 | } 122 | 123 | .token.entity { 124 | cursor: help; 125 | } 126 | -------------------------------------------------------------------------------- /example/src/utils.ts: -------------------------------------------------------------------------------- 1 | // Credit to: WebCoder49 for the below code 2 | // https://github.com/WebCoder49/code-input/blob/main/plugins/indent.js 3 | export function handleTabKey( 4 | event: KeyboardEvent, 5 | input_element: HTMLTextAreaElement, 6 | code: string, 7 | ) { 8 | event.preventDefault(); 9 | if ( 10 | !event.shiftKey && 11 | input_element.selectionStart === input_element.selectionEnd 12 | ) { 13 | const before_selection = code.slice(0, input_element.selectionStart); 14 | const after_selection = code.slice(input_element.selectionEnd); 15 | const cursor_pos = input_element.selectionEnd + 1; 16 | const tab = '\t'; 17 | input_element.value = before_selection + tab + after_selection; 18 | input_element.selectionStart = cursor_pos; 19 | input_element.selectionEnd = cursor_pos; 20 | } else { 21 | let lines = input_element.value.split('\n'); 22 | let letter_i = 0; 23 | 24 | let selection_start = input_element.selectionStart; // where cursor moves after tab - moving forward by 1 indent 25 | let selection_end = input_element.selectionEnd; // where cursor moves after tab - moving forward by 1 indent 26 | 27 | let number_indents = 0; 28 | let first_line_indents = 0; 29 | 30 | for (let i = 0; i < lines.length; i++) { 31 | letter_i += lines[i].length + 1; // newline counted 32 | 33 | if ( 34 | input_element.selectionStart <= letter_i && 35 | input_element.selectionEnd >= letter_i - lines[i].length 36 | ) { 37 | // Starts before or at last char and ends after or at first char 38 | if (event.shiftKey) { 39 | if (lines[i][0] == '\t') { 40 | // Remove first tab 41 | lines[i] = lines[i].slice(1); 42 | if (number_indents == 0) first_line_indents--; 43 | number_indents--; 44 | } 45 | } else { 46 | lines[i] = '\t' + lines[i]; 47 | if (number_indents == 0) first_line_indents++; 48 | number_indents++; 49 | } 50 | } 51 | } 52 | input_element.value = lines.join('\n'); 53 | input_element.selectionStart = selection_start + first_line_indents; 54 | input_element.selectionEnd = selection_end + number_indents; 55 | } 56 | } 57 | 58 | export function handleEnterKey( 59 | event: KeyboardEvent, 60 | input_element: HTMLTextAreaElement, 61 | ) { 62 | event.preventDefault(); 63 | let lines = input_element.value.split('\n'); 64 | let letter_i = 0; 65 | let current_line = lines.length - 1; 66 | let new_line = ''; 67 | let number_indents = 0; 68 | 69 | // find the index of the line our cursor is currently on 70 | for (let i = 0; i < lines.length; i++) { 71 | letter_i += lines[i].length + 1; // newline counted 72 | if (input_element.selectionStart <= letter_i) { 73 | current_line = i; 74 | break; 75 | } 76 | } 77 | 78 | // count the number of indents the current line starts with (up to our cursor position in the line) 79 | let cursor_pos_in_line = 80 | lines[current_line].length - (letter_i - input_element.selectionEnd) + 1; 81 | for (let i = 0; i < cursor_pos_in_line; i++) { 82 | if (lines[current_line][i] == '\t') { 83 | number_indents++; 84 | } else { 85 | break; 86 | } 87 | } 88 | 89 | // determine the text before and after the cursor and chop the current line at the new line break 90 | let text_after_cursor = ''; 91 | if (cursor_pos_in_line != lines[current_line].length) { 92 | text_after_cursor = lines[current_line].substring(cursor_pos_in_line); 93 | lines[current_line] = lines[current_line].substring(0, cursor_pos_in_line); 94 | } 95 | 96 | // insert our indents and any text from the previous line that might have been after the line break 97 | for (let i = 0; i < number_indents; i++) { 98 | new_line += '\t'; 99 | } 100 | new_line += text_after_cursor; 101 | 102 | // save the current cursor position 103 | let selection_start = input_element.selectionStart; 104 | let selection_end = input_element.selectionEnd; 105 | 106 | // splice our new line into the list of existing lines and join them all back up 107 | lines.splice(current_line + 1, 0, new_line); 108 | input_element.value = lines.join('\n'); 109 | 110 | // move cursor to new position 111 | input_element.selectionStart = selection_start + number_indents + 1; // count the indent level and the newline character 112 | input_element.selectionEnd = selection_end + number_indents + 1; 113 | } 114 | -------------------------------------------------------------------------------- /example/tsconfig.json: -------------------------------------------------------------------------------- 1 | { 2 | "compilerOptions": { 3 | "target": "ESNext", 4 | "useDefineForClassFields": true, 5 | "module": "ESNext", 6 | "lib": ["ESNext", "DOM"], 7 | "moduleResolution": "Node", 8 | "strict": true, 9 | "sourceMap": true, 10 | "resolveJsonModule": true, 11 | "isolatedModules": true, 12 | "esModuleInterop": true, 13 | "noEmit": true, 14 | "noUnusedLocals": true, 15 | "noUnusedParameters": true, 16 | "noImplicitReturns": true, 17 | "skipLibCheck": true, 18 | "jsx": "preserve", 19 | "jsxImportSource": "solid-js" 20 | }, 21 | "include": ["src", "example", "../dist"] 22 | } 23 | -------------------------------------------------------------------------------- /example/tsconfig.node.json: -------------------------------------------------------------------------------- 1 | { 2 | "compilerOptions": { 3 | "composite": true, 4 | "module": "esnext", 5 | "moduleResolution": "node" 6 | }, 7 | "include": ["vite.config.ts"] 8 | } 9 | -------------------------------------------------------------------------------- /example/vite.config.ts: -------------------------------------------------------------------------------- 1 | import { defineConfig } from 'vite'; 2 | import dts from 'vite-plugin-dts'; 3 | import solid from 'vite-plugin-solid'; 4 | 5 | // https://vitejs.dev/config/ 6 | export default defineConfig({ 7 | plugins: [solid(), dts()], 8 | }); 9 | -------------------------------------------------------------------------------- /package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "@srsholmes/solid-code-input", 3 | "version": "0.0.18", 4 | "description": "Simple Code Input with syntax highlighting for SolidJS", 5 | "main": "dist/cjs/index.js", 6 | "module": "dist/esm/index.js", 7 | "types": "dist/types/index.d.ts", 8 | "repository": { 9 | "type": "git", 10 | "url": "git+https://github.com/srsholmes/solid-code-input.git" 11 | }, 12 | "publishConfig": { 13 | "access": "public", 14 | "registry": "https://registry.npmjs.org/" 15 | }, 16 | "exports": { 17 | ".": { 18 | "solid": "./dist/source/index.jsx", 19 | "import": "./dist/esm/index.js", 20 | "browser": "./dist/esm/index.js", 21 | "require": "./dist/cjs/index.js", 22 | "node": "./dist/cjs/index.js" 23 | } 24 | }, 25 | "files": [ 26 | "dist", 27 | "src" 28 | ], 29 | "keywords": [ 30 | "solidjs", 31 | "solid", 32 | "code", 33 | "input", 34 | "highlight", 35 | "prismjs", 36 | "highlightjs" 37 | ], 38 | "author": "Simon Holmes", 39 | "license": "MIT", 40 | "bugs": { 41 | "url": "https://github.com/srsholmes/solid-code-input/issues" 42 | }, 43 | "sideEffects": false, 44 | "scripts": { 45 | "build": "rollup -c && node scripts/copy.js", 46 | "dev:local": "rollup -c --watch", 47 | "minify": "terser --compress --mangle --module -- dist/cjs/index.js > dist/cjs/index.min.js", 48 | "format": "prettier --write src example" 49 | }, 50 | "homepage": "https://github.com/srsholmes/solid-code-input#readme", 51 | "dependencies": {}, 52 | "peerDependencies": { 53 | "solid-js": "^1.6.10", 54 | "@types/highlight.js": "9.12.2", 55 | "@types/prismjs": "1.26.0" 56 | }, 57 | "devDependencies": { 58 | "postcss": "8.4.21", 59 | "rollup-plugin-postcss": "4.0.2", 60 | "@rollup/plugin-babel": "^6.0.0", 61 | "@types/node": "^18.7.16", 62 | "prettier": "^2.7.1", 63 | "rollup": "^2.75.7", 64 | "rollup-plugin-terser": "^7.0.2", 65 | "rollup-preset-solid": "^1.4.0", 66 | "solid-js": "^1.6.10", 67 | "terser": "^5.14.1", 68 | "typescript": "^4.9.5" 69 | }, 70 | "prettier": { 71 | "singleQuote": true, 72 | "trailingComma": "all" 73 | } 74 | } 75 | -------------------------------------------------------------------------------- /resources/demo.gif: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/srsholmes/solid-code-input/b8ece72ebdec0a6d346846a874a337ead90b6767/resources/demo.gif -------------------------------------------------------------------------------- /resources/demo.mkv: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/srsholmes/solid-code-input/b8ece72ebdec0a6d346846a874a337ead90b6767/resources/demo.mkv -------------------------------------------------------------------------------- /resources/example.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/srsholmes/solid-code-input/b8ece72ebdec0a6d346846a874a337ead90b6767/resources/example.png -------------------------------------------------------------------------------- /rollup.config.js: -------------------------------------------------------------------------------- 1 | import withSolid from 'rollup-preset-solid'; 2 | import postcss from 'rollup-plugin-postcss'; 3 | 4 | export default withSolid({ 5 | targets: ['esm', 'cjs'], 6 | input: 'src/index.tsx', 7 | plugins: [ 8 | postcss({ 9 | include: ['**/*.module.css', '**/*.scss'], 10 | // extract: 'dist/source/components/CodeInput/styles.module.css', 11 | // extract: false, 12 | modules: true, 13 | }), 14 | ], 15 | }); 16 | -------------------------------------------------------------------------------- /scripts/copy.js: -------------------------------------------------------------------------------- 1 | // copy the file at src/components/CodeInput/styles.module.css 2 | // to dist/source/components/CodeInput/styles.module.css 3 | 4 | // Path: scripts/copy.js 5 | 6 | function copyCSSModuleFile() { 7 | const fs = require('fs'); 8 | const path = require('path'); 9 | const cssModuleFile = path.resolve( 10 | __dirname, 11 | '../src/components/CodeInput/styles.module.css', 12 | ); 13 | const distCSSModuleFile = path.resolve( 14 | __dirname, 15 | '../dist/source/components/CodeInput/styles.module.css', 16 | ); 17 | fs.copyFile(cssModuleFile, distCSSModuleFile, (err) => { 18 | if (err) throw err; 19 | console.log('CSS Module file was copied to dist'); 20 | }); 21 | } 22 | 23 | copyCSSModuleFile(); 24 | -------------------------------------------------------------------------------- /src/components/CodeInput/CodeInput.tsx: -------------------------------------------------------------------------------- 1 | import { Component, createSignal, mergeProps, onMount } from 'solid-js'; 2 | import { CodeInputProps } from '../../types'; 3 | import { handleEnterKey, handleTabKey } from '../../utils'; 4 | import styles from './styles.module.css'; 5 | 6 | export const CodeInput: Component = (props) => { 7 | const merged = mergeProps({ autoHeight: true }, props); 8 | 9 | const language = () => merged.language || 'typescript'; 10 | const value = () => merged.value || ''; 11 | 12 | let preElement: HTMLPreElement; 13 | let textAreaElement: HTMLTextAreaElement; 14 | let wrapperElement: HTMLDivElement; 15 | let outerElement: HTMLDivElement; 16 | 17 | // Used to detect when the user manually resizes the wrapper with handle 18 | let wrapperHeight: number; 19 | let wrapperWidth: number; 20 | 21 | const [manualResize, setManualResize] = createSignal(false); 22 | 23 | onMount(async () => { 24 | watchResize(); 25 | if (props.autoHeight) { 26 | autoHeight(); 27 | } 28 | setBackgroundWrapper(); 29 | }); 30 | 31 | function setBackgroundWrapper() { 32 | const preBackground = window.getComputedStyle(preElement).backgroundColor; 33 | outerElement.style.backgroundColor = preBackground; 34 | } 35 | 36 | function setSizes() { 37 | const { height, width } = getTextareaSize(); 38 | preElement.style.width = `${width}px`; 39 | preElement.style.height = `${height}px`; 40 | wrapperElement.style.width = `${width}px`; 41 | wrapperElement.style.height = `${height}px`; 42 | 43 | // calculate what 1rem is in pixels 44 | const rem = parseFloat( 45 | window.getComputedStyle(document.documentElement).fontSize, 46 | ); 47 | outerElement.style.width = `${width + rem}px`; 48 | outerElement.style.height = `${height + rem}px`; 49 | } 50 | 51 | function getTextareaSize() { 52 | const { height, width } = textAreaElement.getBoundingClientRect(); 53 | return { height, width }; 54 | } 55 | 56 | function autoHeight() { 57 | if (manualResize() === true) { 58 | return; 59 | } 60 | wrapperElement.style.height = `0px`; 61 | wrapperElement.style.height = textAreaElement.scrollHeight + 'px'; 62 | } 63 | 64 | function watchResize() { 65 | new ResizeObserver(setSizes).observe(textAreaElement); 66 | } 67 | 68 | function syncScroll() { 69 | preElement.scrollTop = textAreaElement.scrollTop; 70 | preElement.scrollLeft = textAreaElement.scrollLeft; 71 | // Prevents a scrolling issue when the user manually resizes the wrapper 72 | if (textAreaElement.scrollTop > preElement.scrollTop) { 73 | textAreaElement.scrollTop = preElement.scrollTop; 74 | } 75 | if (textAreaElement.scrollLeft > preElement.scrollLeft) { 76 | textAreaElement.scrollLeft = preElement.scrollLeft; 77 | } 78 | } 79 | 80 | const codeTokens = () => { 81 | try { 82 | if (merged.prismJS) { 83 | if (merged.prismJS.languages[language()]) { 84 | if (merged.autoHeight) { 85 | autoHeight(); 86 | } 87 | const tokens = merged.prismJS.highlight( 88 | value(), 89 | merged.prismJS.languages[language()], 90 | language(), 91 | ); 92 | return tokens; 93 | } else { 94 | if (merged.autoHeight) { 95 | autoHeight(); 96 | } 97 | return merged.prismJS.util.encode(value()).toString(); 98 | } 99 | } else if (merged.highlightjs) { 100 | const tokens = merged.highlightjs.highlight(value(), { 101 | language: language(), 102 | }).value; 103 | if (merged.autoHeight) { 104 | autoHeight(); 105 | } 106 | return tokens; 107 | } 108 | } catch (e) { 109 | console.error(e); 110 | } 111 | }; 112 | 113 | function handleKeyDown(event: KeyboardEvent) { 114 | let input_element = textAreaElement; 115 | let code = input_element.value; 116 | if (event.key === 'Tab') { 117 | handleTabKey(event, input_element, code); 118 | merged.onChange(input_element.value); 119 | } 120 | if (event.key === 'Enter') { 121 | handleEnterKey(event, input_element); 122 | merged.onChange(input_element.value); 123 | } 124 | } 125 | 126 | async function handleInput(e: Event) { 127 | merged.onChange((e.target as HTMLTextAreaElement).value); 128 | } 129 | 130 | function handleMouseDown() { 131 | const { height, width } = getTextareaSize(); 132 | wrapperHeight = height; 133 | wrapperWidth = width; 134 | } 135 | 136 | function handleMouseUp() { 137 | const { height, width } = getTextareaSize(); 138 | if (height !== wrapperHeight || width !== wrapperWidth) { 139 | setManualResize(true); 140 | } 141 | } 142 | 143 | return ( 144 |
149 |
155 | 165 |
170 |           
171 |
172 |
173 |
174 | ); 175 | }; 176 | 177 | export default CodeInput; 178 | -------------------------------------------------------------------------------- /src/components/CodeInput/styles.module.css: -------------------------------------------------------------------------------- 1 | /* Original CSS written by Oliver Geer (WebCoder49) */ 2 | /* https://css-tricks.com/creating-an-editable-textarea-that-supports-syntax-highlighted-code/ */ 3 | /* Updated for solid-code-input */ 4 | 5 | .outer-wrapper * { 6 | box-sizing: border-box; 7 | } 8 | 9 | .wrap { 10 | position: relative; 11 | display: block; 12 | min-height: 60px; 13 | box-sizing: border-box; 14 | position: relative; 15 | top: 0; 16 | left: 0; 17 | display: block; 18 | overflow: hidden; 19 | min-height: 76px; 20 | font-size: 16px; 21 | font-family: monospace; 22 | line-height: normal; 23 | tab-size: 2; 24 | caret-color: darkgrey; 25 | white-space: pre; 26 | } 27 | 28 | .wrap textarea, 29 | .wrap pre { 30 | width: 100%; 31 | height: 100%; 32 | border: none; 33 | overflow: auto; 34 | outline: none; 35 | position: absolute; 36 | top: 0; 37 | left: 0; 38 | font-family: monospace; 39 | font-size: inherit !important; 40 | line-height: inherit !important; 41 | background: transparent; 42 | padding: 0 !important; 43 | margin: 0 !important; 44 | } 45 | 46 | .wrap textarea, 47 | .wrap pre, 48 | .wrap pre * { 49 | font-size: inherit !important; 50 | font-family: inherit !important; 51 | line-height: inherit !important; 52 | tab-size: inherit !important; 53 | } 54 | 55 | .wrap textarea { 56 | display: block; 57 | color: transparent; 58 | background: transparent; 59 | caret-color: inherit !important; 60 | z-index: 1; 61 | } 62 | 63 | .wrap pre::-webkit-scrollbar { 64 | width: 0; 65 | height: 0; 66 | } 67 | 68 | .wrap pre { 69 | z-index: 0; 70 | } 71 | 72 | .wrap textarea, 73 | .wrap pre { 74 | overflow: auto !important; 75 | white-space: inherit; 76 | word-spacing: normal; 77 | word-break: normal; 78 | word-wrap: normal; 79 | } 80 | 81 | .wrap textarea.resize-both { 82 | resize: both; 83 | } 84 | 85 | .wrap textarea.resize-none { 86 | resize: none; 87 | } 88 | 89 | .wrap textarea.resize-horizontal { 90 | resize: horizontal; 91 | } 92 | 93 | .wrap textarea.resize-vertical { 94 | resize: vertical; 95 | } 96 | -------------------------------------------------------------------------------- /src/index.tsx: -------------------------------------------------------------------------------- 1 | export * from './types'; 2 | import { CodeInput } from './components/CodeInput/CodeInput'; 3 | export { CodeInput }; 4 | -------------------------------------------------------------------------------- /src/types.ts: -------------------------------------------------------------------------------- 1 | import highlightjs from 'highlight.js'; 2 | import Prism from 'prismjs'; 3 | 4 | export type CodeInputProps = { 5 | prismJS?: typeof Prism; 6 | highlightjs?: typeof highlightjs; 7 | value: string; 8 | language: string; 9 | onChange: (value: string) => void; 10 | placeholder?: string; 11 | resize?: 'none' | 'both' | 'horizontal' | 'vertical'; 12 | autoHeight?: boolean; 13 | }; 14 | -------------------------------------------------------------------------------- /src/utils.ts: -------------------------------------------------------------------------------- 1 | /* Original Code written by Oliver Geer (WebCoder49) */ 2 | // https://github.com/WebCoder49/code-input/blob/main/plugins/indent.js 3 | 4 | export function handleTabKey( 5 | event: KeyboardEvent, 6 | input_element: HTMLTextAreaElement, 7 | code: string, 8 | ) { 9 | event.preventDefault(); // stop normal 10 | 11 | if ( 12 | !event.shiftKey && 13 | input_element.selectionStart == input_element.selectionEnd 14 | ) { 15 | // Shift always means dedent - this places a tab here. 16 | let before_selection = code.slice(0, input_element.selectionStart); // text before tab 17 | let after_selection = code.slice( 18 | input_element.selectionEnd, 19 | input_element.value.length, 20 | ); // text after tab 21 | 22 | let cursor_pos = input_element.selectionEnd + 1; // where cursor moves after tab - moving forward by 1 char to after tab 23 | input_element.value = before_selection + '\t' + after_selection; // add tab char 24 | 25 | // move cursor 26 | input_element.selectionStart = cursor_pos; 27 | input_element.selectionEnd = cursor_pos; 28 | } else { 29 | let lines = input_element.value.split('\n'); 30 | let letter_i = 0; 31 | 32 | let selection_start = input_element.selectionStart; // where cursor moves after tab - moving forward by 1 indent 33 | let selection_end = input_element.selectionEnd; // where cursor moves after tab - moving forward by 1 indent 34 | 35 | let number_indents = 0; 36 | let first_line_indents = 0; 37 | 38 | for (let i = 0; i < lines.length; i++) { 39 | letter_i += lines[i].length + 1; // newline counted 40 | if ( 41 | input_element.selectionStart <= letter_i && 42 | input_element.selectionEnd >= letter_i - lines[i].length 43 | ) { 44 | // Starts before or at last char and ends after or at first char 45 | if (event.shiftKey) { 46 | if (lines[i][0] == '\t') { 47 | // Remove first tab 48 | lines[i] = lines[i].slice(1); 49 | if (number_indents == 0) first_line_indents--; 50 | number_indents--; 51 | } 52 | } else { 53 | lines[i] = '\t' + lines[i]; 54 | if (number_indents == 0) first_line_indents++; 55 | number_indents++; 56 | } 57 | } 58 | } 59 | input_element.value = lines.join('\n'); 60 | 61 | // move cursor 62 | input_element.selectionStart = selection_start + first_line_indents; 63 | input_element.selectionEnd = selection_end + number_indents; 64 | } 65 | } 66 | 67 | export function handleEnterKey( 68 | event: KeyboardEvent, 69 | input_element: HTMLTextAreaElement, 70 | ) { 71 | event.preventDefault(); 72 | let lines = input_element.value.split('\n'); 73 | let letter_i = 0; 74 | let current_line = lines.length - 1; 75 | let new_line = ''; 76 | let number_indents = 0; 77 | 78 | // find the index of the line our cursor is currently on 79 | for (let i = 0; i < lines.length; i++) { 80 | letter_i += lines[i].length + 1; // newline counted 81 | if (input_element.selectionStart <= letter_i) { 82 | current_line = i; 83 | break; 84 | } 85 | } 86 | 87 | // count the number of indents the current line starts with (up to our cursor position in the line) 88 | let cursor_pos_in_line = 89 | lines[current_line].length - (letter_i - input_element.selectionEnd) + 1; 90 | for (let i = 0; i < cursor_pos_in_line; i++) { 91 | if (lines[current_line][i] == '\t') { 92 | number_indents++; 93 | } else { 94 | break; 95 | } 96 | } 97 | 98 | // determine the text before and after the cursor and chop the current line at the new line break 99 | let text_after_cursor = ''; 100 | if (cursor_pos_in_line != lines[current_line].length) { 101 | text_after_cursor = lines[current_line].substring(cursor_pos_in_line); 102 | lines[current_line] = lines[current_line].substring(0, cursor_pos_in_line); 103 | } 104 | 105 | // insert our indents and any text from the previous line that might have been after the line break 106 | for (let i = 0; i < number_indents; i++) { 107 | new_line += '\t'; 108 | } 109 | new_line += text_after_cursor; 110 | 111 | // save the current cursor position 112 | let selection_start = input_element.selectionStart; 113 | let selection_end = input_element.selectionEnd; 114 | 115 | // splice our new line into the list of existing lines and join them all back up 116 | lines.splice(current_line + 1, 0, new_line); 117 | input_element.value = lines.join('\n'); 118 | 119 | // move cursor to new position 120 | input_element.selectionStart = selection_start + number_indents + 1; // count the indent level and the newline character 121 | input_element.selectionEnd = selection_end + number_indents + 1; 122 | } 123 | -------------------------------------------------------------------------------- /tsconfig.json: -------------------------------------------------------------------------------- 1 | { 2 | "compilerOptions": { 3 | "target": "ESNext", 4 | "useDefineForClassFields": true, 5 | "module": "ESNext", 6 | "lib": ["ESNext", "DOM"], 7 | "moduleResolution": "Node", 8 | "strict": true, 9 | "sourceMap": true, 10 | "resolveJsonModule": true, 11 | "isolatedModules": true, 12 | "esModuleInterop": true, 13 | "noEmit": true, 14 | "noUnusedLocals": true, 15 | "noUnusedParameters": true, 16 | "noImplicitReturns": true, 17 | "skipLibCheck": true, 18 | "jsx": "preserve", 19 | "jsxImportSource": "solid-js" 20 | }, 21 | "include": ["src", "example"] 22 | } 23 | -------------------------------------------------------------------------------- /tsconfig.node.json: -------------------------------------------------------------------------------- 1 | { 2 | "compilerOptions": { 3 | "composite": true, 4 | "module": "esnext", 5 | "moduleResolution": "node" 6 | }, 7 | "include": ["vite.config.ts"] 8 | } --------------------------------------------------------------------------------