Skip to content

Commit

Permalink
✨ add react-remark library, test it in SimpleMarkdownText
Browse files Browse the repository at this point in the history
  • Loading branch information
danyx23 committed Oct 27, 2023
1 parent 5081d4b commit 7a3fe54
Show file tree
Hide file tree
Showing 5 changed files with 421 additions and 32 deletions.
1 change: 1 addition & 0 deletions package.json
Original file line number Diff line number Diff line change
Expand Up @@ -187,6 +187,7 @@
"react-intersection-observer": "^9.4.0",
"react-move": "^6.5.0",
"react-recaptcha": "^2.3.10",
"react-remark": "^2.1.0",
"react-router-dom": "^5.3.1",
"react-select": "^5.7.3",
"react-tag-autocomplete": "^7.1.0",
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -49,11 +49,9 @@ export const IndicatorProcessing = (props: IndicatorProcessingProps) => {
Notes on our processing step for this indicator
</h5>
<div className="variable-processing-info__description">
<p className="article-block__text">
<SimpleMarkdownText
text={props.descriptionProcessing}
/>
</p>
<SimpleMarkdownText
text={props.descriptionProcessing}
/>
</div>
</div>
)}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -65,11 +65,9 @@ export const IndicatorSources = (props: IndicatorSourcesProps) => {
content={
<>
{source.description && (
<p className="article-block__text">
<SimpleMarkdownText
text={source.description}
/>
</p>
<SimpleMarkdownText
text={source.description}
/>
)}
{(dateAccessed || source.urlMain) && (
<div
Expand Down
35 changes: 15 additions & 20 deletions packages/@ourworldindata/components/src/SimpleMarkdownText.tsx
Original file line number Diff line number Diff line change
@@ -1,11 +1,6 @@
import React from "react"
import { computed } from "mobx"
import {
IRToken,
parsimmonToTextTokens,
recursiveMergeTextTokens,
} from "./MarkdownTextWrap/MarkdownTextWrap.js"
import { MarkdownRoot, mdParser } from "./MarkdownTextWrap/parser.js"
import { Remark } from "react-remark"
type SimpleMarkdownTextProps = {
text: string
}
Expand All @@ -15,22 +10,22 @@ export class SimpleMarkdownText extends React.Component<SimpleMarkdownTextProps>
return this.props.text
}

@computed get ast(): MarkdownRoot["children"] {
if (!this.text) return []
const result = mdParser.markdown.parse(this.props.text)
if (result.status) {
return result.value.children
}
return []
}
// @computed get ast(): MarkdownRoot["children"] {
// if (!this.text) return []
// const result = mdParser.markdown.parse(this.props.text)
// if (result.status) {
// return result.value.children
// }
// return []
// }

@computed get tokens(): IRToken[] {
const tokens = parsimmonToTextTokens(this.ast, {})
return recursiveMergeTextTokens(tokens)
}
// @computed get tokens(): IRToken[] {
// const tokens = parsimmonToTextTokens(this.ast, {})
// return recursiveMergeTextTokens(tokens)
// }

render(): JSX.Element | null {
const { tokens } = this
return <>{tokens.map((token, index) => token.toHTML(index))}</>
// const { tokens } = this
return <Remark>{this.text}</Remark>
}
}
Loading

0 comments on commit 7a3fe54

Please sign in to comment.