Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

expose useGetLineProps, useGetTokenProps, useThemeDictionary #249

Closed
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
5 changes: 5 additions & 0 deletions .changeset/famous-olives-destroy.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
---
"prism-react-renderer": minor
---

expose useGetLineProps, useGetTokenProps, useThemeDictionary,
57 changes: 57 additions & 0 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -60,6 +60,9 @@ _(If you just want to use your Prism CSS-file themes, that's also no problem)_
- [Utility Functions](#utility-functions)
- [`normalizeTokens`](#normalizetokens)
- [`useTokenize`](#usetokenize)
- [`useGetLineProps`](#useGetLineProps)
- [`useGetTokenProps`](#useGetTokenProps)
- [`useThemeDictionary`](#useThemeDictionary)
- [Theming](#theming)
- [Upgrading from v1 to v2](#upgrade)
- [LICENSE](#license)
Expand Down Expand Up @@ -325,6 +328,60 @@ Takes an array of Prism’s tokens and groups them by line, converting strings i
- `content: string`: the content of the token
- `empty: boolean`: a flag indicating whether the token is empty or not.

### `useGetLineProps`

> `themeDictionary?: ThemeDict`

```ts
type ThemeDict = {
[type: string]: React.CSSProperties;
root: StyleObj;
plain: StyleObj;
}

```
Takes in an optional `ThemeDict` object which can have any number of string key value pairs where the type of value is `React.CSSProperties`. It also has `root` and `plain` with type `StyleObj` which is an object with `CSSProperties`.

`useGetLineProps` is a memoized hook that provides a way to compute the props for a line of code by considering the theme dictionary and any additional styles provided.

### `useGetTokenProps`

> `themeDictionary?: ThemeDict`

```ts
type ThemeDict = {
[type: string]: React.CSSProperties;
root: StyleObj;
plain: StyleObj;
}

```
Takes in an optional `ThemeDict` object which can have any number of string key value pairs where the type of value is `React.CSSProperties`. It also has `root` and `plain` with type `StyleObj` which is an object with `CSSProperties`.

`useGetTokenProps` is a memoized hook that provides a way to compute the props for a token by using account the theme dictionary and any additional styles provided.

### `useThemeDictionary`

> `(language: Language, theme: PrismTheme)`

```ts
type Language = string
type PrismTheme = {
plain: StyleObj
styles: Array<{
types: string[]
style: StyleObj
languages?: Language[]
}>
}

```
Takes in two parameters
`language: Language`: the language to use for tokenization. This should be a language that Prism supports. `theme : PrismTheme` : themes are JSON-based and are heavily inspired by VSCode's theme format. More details are explained here "[Theming](#theming)"


`useThemeDictionary` hook computes and caches a theme dictionary based on the language and theme props, and returns the theme dictionary as a state value.

## Theming

The `defaultProps` you'd typically apply in a basic use-case, contain a default theme.
Expand Down
14 changes: 13 additions & 1 deletion packages/prism-react-renderer/src/index.ts
Original file line number Diff line number Diff line change
Expand Up @@ -5,6 +5,9 @@ import { Highlight as InternalHighlight } from "./components/highlight"
import { HighlightProps, PrismLib } from "./types"
import normalizeTokens from "./utils/normalizeTokens"
import { useTokenize } from "./components/useTokenize"
import { useGetLineProps } from "./components/useGetLineProps"
import { useGetTokenProps } from "./components/useGetTokenProps"
import { useThemeDictionary } from "./components/useThemeDictionary"
export * from "./types"

/**
Expand All @@ -20,4 +23,13 @@ const Highlight = (props: HighlightProps) =>
language: props.language,
})

export { Highlight, Prism, themes, normalizeTokens, useTokenize }
export {
Highlight,
Prism,
themes,
normalizeTokens,
useTokenize,
useGetLineProps,
useGetTokenProps,
useThemeDictionary,
}