| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950 |
- import { checksum } from "@opencode-ai/util/encode"
- import { FileDiff } from "@pierre/diffs"
- import { createEffect, createMemo, onCleanup, splitProps } from "solid-js"
- import { createDefaultOptions, type DiffProps, styleVariables } from "../pierre"
- import { getWorkerPool } from "../pierre/worker"
- export function Diff<T>(props: DiffProps<T>) {
- let container!: HTMLDivElement
- const [local, others] = splitProps(props, ["before", "after", "class", "classList", "annotations"])
- const options = createMemo(() => ({
- ...createDefaultOptions(props.diffStyle),
- ...others,
- }))
- let instance: FileDiff<T> | undefined
- createEffect(() => {
- const opts = options()
- const workerPool = getWorkerPool(props.diffStyle)
- const annotations = local.annotations
- const beforeContents = typeof local.before?.contents === "string" ? local.before.contents : ""
- const afterContents = typeof local.after?.contents === "string" ? local.after.contents : ""
- instance?.cleanUp()
- instance = new FileDiff<T>(opts, workerPool)
- container.innerHTML = ""
- instance.render({
- oldFile: {
- ...local.before,
- contents: beforeContents,
- cacheKey: checksum(beforeContents),
- },
- newFile: {
- ...local.after,
- contents: afterContents,
- cacheKey: checksum(afterContents),
- },
- lineAnnotations: annotations,
- containerWrapper: container,
- })
- })
- onCleanup(() => {
- instance?.cleanUp()
- })
- return <div data-component="diff" style={styleVariables} ref={container} />
- }
|