Skip to content

Commit

Permalink
Add a README.md file.
Browse files Browse the repository at this point in the history
  • Loading branch information
drgrice1 committed Oct 11, 2024
1 parent d1121fa commit 241ecd9
Show file tree
Hide file tree
Showing 2 changed files with 98 additions and 1 deletion.
3 changes: 2 additions & 1 deletion .prettierrc
Original file line number Diff line number Diff line change
Expand Up @@ -5,5 +5,6 @@
"printWidth": 120,
"semi": true,
"singleQuote": true,
"trailingComma": "none"
"trailingComma": "none",
"overrides": [{ "files": "*.md", "options": { "tabWidth": 1 } }]
}
96 changes: 96 additions & 0 deletions README.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,96 @@
# PG CodeMirror 6 Editor

This package implements a CodeMirror 6 editor that is primarily intended for editing PG problem files for the WeBWorK
Online Homework Delivery System. However, it also supports editing Perl, HTML, XML, Mojolicious HTML templates, and
Mojolicious raw text templates since those are needed by webwork2.

The `dist/pg-codemirror-editor.js` can be used via a script tag and sets the global `PGCodeMirrorEditor` object. The
`PGCodeMirrorEditor.View` class is the only key in the object. It can be used as follows

```Javascript
const pgEditor = new PGCodeMirrorEditor.View(codeMirrorElt, { source: sourceCode });
```

## `PGCodeMirrorEditor.View` class

The following methods and attributes for the `PGCodeMirrorEditor.View` class are available. Note that although the theme
and keymap can be set via initialization options or provided methods, usually you do not want to do this. The theme and
keymap can be changed by the user via the user interface provided in the editor, and the user's choices are saved in
local storage in the browser.

### Constructor

The syntax for usage of the `PGCodeMirrorEditor.View` is

```Javascript
new PGCodeMirrorEditor.View(
element: HTMLElement,
options?: {
language?: string;
source?: string;
theme?: string;
keyMap?: string;
});
```

The options are described below.

- `language`: One of 'pg', 'perl', 'html', 'xml', 'mt-html', or 'mt-text'. (Defaults to 'pg')
- `source`: A string containing the source code to edit. (Defaults to the empty string)
- `theme`: A string naming one of the following themes. (Defaults to 'Default')
- 'Default': A modified version of the CodeMirror 6 default theme defined in `src/light-theme.ts`.
- 'Amy': From the [thememirror](https://thememirror.net/) package.
- 'Ayu Light': From the [thememirror](https://thememirror.net/) package.
- 'Barf': From the [thememirror](https://thememirror.net/) package.
- 'Basic Dark': From the [cm6-theme-basic-dark](https://github.com/craftzdog/cm6-themes) package.
- 'Basic Light': From the [cm6-theme-basic-light](https://github.com/craftzdog/cm6-themes) package.
- 'Bespin': From the [thememirror](https://thememirror.net/) package.
- 'Birds of Paradise': From the [thememirror](https://thememirror.net/) package.
- 'Boys and Girls': From the [thememirror](https://thememirror.net/) package.
- 'Clouds': From the [thememirror](https://thememirror.net/) package.
- 'Cobalt': From the [thememirror](https://thememirror.net/) package.
- 'Cool Glow': From the [thememirror](https://thememirror.net/) package.
- 'Dracula': From the [thememirror](https://thememirror.net/) package.
- 'Espresso': From the [thememirror](https://thememirror.net/) package.
- 'Gruvbox Dark': From the [cm6-theme-gruvbox-dark](https://github.com/craftzdog/cm6-themes) package.
- 'Gruvbox Light': From the [cm6-theme-gruvbox-light](https://github.com/craftzdog/cm6-themes) package.
- 'Material Dark': From the [cm6-theme-material-dark](https://github.com/craftzdog/cm6-themes) package.
- 'Noctis Lilac': From the [thememirror](https://thememirror.net/) package.
- 'Nord': From the [cm6-theme-nord](https://github.com/craftzdog/cm6-themes) package.
- 'One Dark': From the [@codemirror/theme-one-dark](https://github.com/codemirror/theme-one-dark) package.
- 'Rose Pine Dawn': From the [thememirror](https://thememirror.net/) package.
- 'Smoothy': From the [thememirror](https://thememirror.net/) package.
- 'Solarized Dark': From the [cm6-theme-solarized-dark](https://github.com/craftzdog/cm6-themes) package.
- 'Solarized Light': From the [cm6-theme-solarized-light](https://github.com/craftzdog/cm6-themes) package.
- 'Solarized Light 2': From the [thememirror](https://thememirror.net/) package.
- 'Tomorrow': From the [thememirror](https://thememirror.net/) package.
- `keymap`: One of 'Default', 'Emacs', or 'Vim'. (Defaults to 'Default')

### `source`

Set the source code to be edited with the `source` getter, and get the current source with the `source` getter. Note
that setting the source will reset the editor state (including undo and redo history).

### `setLanguage(newLanguage)`

Set the language for the editor after initialization. `newLanguage` must be one of the languages listed in the
constructor `language` option. Note that this method is `async`.

### `setTheme(newTheme)`

Set the theme for the editor after initialization. `newTheme` must be one of the themes listed in the constructor
`theme` option. Note that this method is `async`.

### `setKeyMap(newKeymap)`

Set the keymap for the editor after initialization. `newKeymap` must be one of the keymaps listed in the constructor
`keymap` option. Note that this method is `async`.

### `refresh(key)`

Schedule a layout measurement for the editor. Provide a string `key` that identifies the call. When multiple requests
with the same key are scheduled, only the last one will actually be run.

## Development Testing

Executing `npm run serve` will make an html test page available at `http://localhost:8080`.

0 comments on commit 241ecd9

Please sign in to comment.