@thxgg/steward 0.1.24 → 0.1.26
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.output/nitro.json +1 -1
- package/.output/public/_nuxt/{Bc2V3wPK.js → B2ow85x_.js} +2 -2
- package/.output/public/_nuxt/{U78rMDmo.js → B6CbIr08.js} +1 -1
- package/.output/public/_nuxt/{BknRrWsw.js → BLQAF8wp.js} +1 -1
- package/.output/public/_nuxt/BXuwtOqb.js +1 -0
- package/.output/public/_nuxt/CAMiEhze.js +1 -0
- package/.output/public/_nuxt/{BRQ9Cxaw.js → CIBCqZF5.js} +1 -1
- package/.output/public/_nuxt/Ce0-nlm9.js +1 -0
- package/.output/public/_nuxt/{T11EuTtn.js → ConzneVY.js} +1 -1
- package/.output/public/_nuxt/D0qxz_Pn.js +1310 -0
- package/.output/public/_nuxt/D3PDtLSF.js +3 -0
- package/.output/public/_nuxt/{C73kduX-.js → DdKC0UAK.js} +1 -1
- package/.output/public/_nuxt/Detail.BGdvrJGh.css +1 -0
- package/.output/public/_nuxt/{C53_p0K1.js → Dkh9ic1y.js} +1 -1
- package/.output/public/_nuxt/LEjJTR7-.js +1 -0
- package/.output/public/_nuxt/{BTmXUZ_s.js → UqZfMfrZ.js} +1 -1
- package/.output/public/_nuxt/builds/latest.json +1 -1
- package/.output/public/_nuxt/builds/meta/25438e34-19a2-421d-aede-53fd18f1ccd4.json +1 -0
- package/.output/public/_nuxt/dckrK0oj.js +1 -0
- package/.output/public/_nuxt/entry.DT4p6_uW.css +1 -0
- package/.output/public/_nuxt/pIWeVmPw.js +1 -0
- package/.output/public/_nuxt/xrHaPo1U.js +60 -0
- package/.output/server/chunks/_/prd-service.mjs.map +1 -1
- package/.output/server/chunks/build/{Detail-DMMUwTWr.mjs → Detail-rpcemNXe.mjs} +674 -481
- package/.output/server/chunks/build/Detail-rpcemNXe.mjs.map +1 -0
- package/.output/server/chunks/build/DiffViewer-styles.B1FB5NJj.mjs +8 -0
- package/.output/server/chunks/build/DiffViewer-styles.B1FB5NJj.mjs.map +1 -0
- package/.output/server/chunks/build/{_prd_-ByugK4Yi.mjs → _prd_-CeibvZOH.mjs} +67 -233
- package/.output/server/chunks/build/_prd_-CeibvZOH.mjs.map +1 -0
- package/.output/server/chunks/build/client.precomputed.mjs +1 -1
- package/.output/server/chunks/build/{default-BKKgG7HJ.mjs → default-iq8SaDDN.mjs} +3 -3
- package/.output/server/chunks/build/default-iq8SaDDN.mjs.map +1 -0
- package/.output/server/chunks/build/{error-404-Bf6kdO80.mjs → error-404-DFale9A5.mjs} +2 -2
- package/.output/server/chunks/build/error-404-DFale9A5.mjs.map +1 -0
- package/.output/server/chunks/build/{index-DE1tjHAd.mjs → index-Po00RvHm.mjs} +2 -2
- package/.output/server/chunks/build/index-Po00RvHm.mjs.map +1 -0
- package/.output/server/chunks/build/{nuxt-link-SvT1nf8Z.mjs → nuxt-link-B4oWFn7n.mjs} +2 -2
- package/.output/server/chunks/build/nuxt-link-B4oWFn7n.mjs.map +1 -0
- package/.output/server/chunks/build/{repo-graph-DzT45gSB.mjs → repo-graph-BQVFpA-w.mjs} +5 -4
- package/.output/server/chunks/build/repo-graph-BQVFpA-w.mjs.map +1 -0
- package/.output/server/chunks/build/server.mjs +7 -7
- package/.output/server/chunks/build/styles.mjs +4 -5
- package/.output/server/chunks/build/{usePrd-hXZOmvAv.mjs → usePrd-Bb6jlnNZ.mjs} +2 -2
- package/.output/server/chunks/build/usePrd-Bb6jlnNZ.mjs.map +1 -0
- package/.output/server/chunks/nitro/nitro.mjs +983 -678
- package/.output/server/chunks/nitro/nitro.mjs.map +1 -1
- package/.output/server/node_modules/@pierre/diffs/dist/components/File.js +324 -0
- package/.output/server/node_modules/@pierre/diffs/dist/components/FileDiff.js +395 -0
- package/.output/server/node_modules/@pierre/diffs/dist/components/FileStream.js +161 -0
- package/.output/server/node_modules/@pierre/diffs/dist/components/web-components.js +25 -0
- package/.output/server/node_modules/@pierre/diffs/dist/constants.js +23 -0
- package/.output/server/node_modules/@pierre/diffs/dist/highlighter/languages/areLanguagesAttached.js +11 -0
- package/.output/server/node_modules/@pierre/diffs/dist/highlighter/languages/attachResolvedLanguages.js +20 -0
- package/.output/server/node_modules/@pierre/diffs/dist/highlighter/languages/cleanUpResolvedLanguages.js +11 -0
- package/.output/server/node_modules/@pierre/diffs/dist/highlighter/languages/constants.js +8 -0
- package/.output/server/node_modules/@pierre/diffs/dist/highlighter/languages/getResolvedLanguages.js +16 -0
- package/.output/server/node_modules/@pierre/diffs/dist/highlighter/languages/getResolvedOrResolveLanguage.js +11 -0
- package/.output/server/node_modules/@pierre/diffs/dist/highlighter/languages/hasResolvedLanguages.js +11 -0
- package/.output/server/node_modules/@pierre/diffs/dist/highlighter/languages/resolveLanguage.js +30 -0
- package/.output/server/node_modules/@pierre/diffs/dist/highlighter/languages/resolveLanguages.js +25 -0
- package/.output/server/node_modules/@pierre/diffs/dist/highlighter/shared_highlighter.js +71 -0
- package/.output/server/node_modules/@pierre/diffs/dist/highlighter/themes/areThemesAttached.js +12 -0
- package/.output/server/node_modules/@pierre/diffs/dist/highlighter/themes/attachResolvedThemes.js +24 -0
- package/.output/server/node_modules/@pierre/diffs/dist/highlighter/themes/cleanUpResolvedThemes.js +11 -0
- package/.output/server/node_modules/@pierre/diffs/dist/highlighter/themes/constants.js +9 -0
- package/.output/server/node_modules/@pierre/diffs/dist/highlighter/themes/getResolvedOrResolveTheme.js +11 -0
- package/.output/server/node_modules/@pierre/diffs/dist/highlighter/themes/getResolvedThemes.js +16 -0
- package/.output/server/node_modules/@pierre/diffs/dist/highlighter/themes/hasResolvedThemes.js +11 -0
- package/.output/server/node_modules/@pierre/diffs/dist/highlighter/themes/registerCustomCSSVariableTheme.js +18 -0
- package/.output/server/node_modules/@pierre/diffs/dist/highlighter/themes/registerCustomTheme.js +14 -0
- package/.output/server/node_modules/@pierre/diffs/dist/highlighter/themes/resolveTheme.js +35 -0
- package/.output/server/node_modules/@pierre/diffs/dist/highlighter/themes/resolveThemes.js +21 -0
- package/.output/server/node_modules/@pierre/diffs/dist/index.js +84 -0
- package/.output/server/node_modules/@pierre/diffs/dist/managers/LineSelectionManager.js +282 -0
- package/.output/server/node_modules/@pierre/diffs/dist/managers/MouseEventManager.js +244 -0
- package/.output/server/node_modules/@pierre/diffs/dist/managers/ResizeManager.js +132 -0
- package/.output/server/node_modules/@pierre/diffs/dist/managers/ScrollSyncManager.js +62 -0
- package/.output/server/node_modules/@pierre/diffs/dist/managers/UniversalRenderingManager.js +32 -0
- package/.output/server/node_modules/@pierre/diffs/dist/renderers/DiffHunksRenderer.js +655 -0
- package/.output/server/node_modules/@pierre/diffs/dist/renderers/FileRenderer.js +243 -0
- package/.output/server/node_modules/@pierre/diffs/dist/shiki-stream/stream.js +32 -0
- package/.output/server/node_modules/@pierre/diffs/dist/shiki-stream/tokenizer.js +71 -0
- package/.output/server/node_modules/@pierre/diffs/dist/sprite.js +55 -0
- package/.output/server/node_modules/@pierre/diffs/dist/style.js +6 -0
- package/.output/server/node_modules/@pierre/diffs/dist/themes/pierre-dark.js +1328 -0
- package/.output/server/node_modules/@pierre/diffs/dist/themes/pierre-light.js +1328 -0
- package/.output/server/node_modules/@pierre/diffs/dist/utils/areFilesEqual.js +8 -0
- package/.output/server/node_modules/@pierre/diffs/dist/utils/areObjectsEqual.js +18 -0
- package/.output/server/node_modules/@pierre/diffs/dist/utils/areOptionsEqual.js +12 -0
- package/.output/server/node_modules/@pierre/diffs/dist/utils/areSelectionsEqual.js +8 -0
- package/.output/server/node_modules/@pierre/diffs/dist/utils/areThemesEqual.js +9 -0
- package/.output/server/node_modules/@pierre/diffs/dist/utils/cleanLastNewline.js +8 -0
- package/.output/server/node_modules/@pierre/diffs/dist/utils/createAnnotationElement.js +21 -0
- package/.output/server/node_modules/@pierre/diffs/dist/utils/createAnnotationWrapperNode.js +12 -0
- package/.output/server/node_modules/@pierre/diffs/dist/utils/createCodeNode.js +12 -0
- package/.output/server/node_modules/@pierre/diffs/dist/utils/createEmptyRowBuffer.js +16 -0
- package/.output/server/node_modules/@pierre/diffs/dist/utils/createFileHeaderElement.js +84 -0
- package/.output/server/node_modules/@pierre/diffs/dist/utils/createHoverContentNode.js +15 -0
- package/.output/server/node_modules/@pierre/diffs/dist/utils/createNoNewlineElement.js +24 -0
- package/.output/server/node_modules/@pierre/diffs/dist/utils/createPreElement.js +28 -0
- package/.output/server/node_modules/@pierre/diffs/dist/utils/createRowNodes.js +20 -0
- package/.output/server/node_modules/@pierre/diffs/dist/utils/createSeparator.js +69 -0
- package/.output/server/node_modules/@pierre/diffs/dist/utils/createSpanNodeFromToken.js +13 -0
- package/.output/server/node_modules/@pierre/diffs/dist/utils/createStyleElement.js +19 -0
- package/.output/server/node_modules/@pierre/diffs/dist/utils/createTransformerWithState.js +56 -0
- package/.output/server/node_modules/@pierre/diffs/dist/utils/createUnsafeCSSStyleNode.js +12 -0
- package/.output/server/node_modules/@pierre/diffs/dist/utils/cssWrappers.js +21 -0
- package/.output/server/node_modules/@pierre/diffs/dist/utils/diffAcceptRejectHunk.js +82 -0
- package/.output/server/node_modules/@pierre/diffs/dist/utils/formatCSSVariablePrefix.js +8 -0
- package/.output/server/node_modules/@pierre/diffs/dist/utils/getFiletypeFromFileName.js +343 -0
- package/.output/server/node_modules/@pierre/diffs/dist/utils/getHighlighterOptions.js +13 -0
- package/.output/server/node_modules/@pierre/diffs/dist/utils/getHighlighterThemeStyles.js +40 -0
- package/.output/server/node_modules/@pierre/diffs/dist/utils/getHunkSeparatorSlotName.js +8 -0
- package/.output/server/node_modules/@pierre/diffs/dist/utils/getIconForType.js +15 -0
- package/.output/server/node_modules/@pierre/diffs/dist/utils/getLineAnnotationName.js +8 -0
- package/.output/server/node_modules/@pierre/diffs/dist/utils/getLineEndingType.js +11 -0
- package/.output/server/node_modules/@pierre/diffs/dist/utils/getLineNodes.js +15 -0
- package/.output/server/node_modules/@pierre/diffs/dist/utils/getSingularPatch.js +20 -0
- package/.output/server/node_modules/@pierre/diffs/dist/utils/getThemes.js +16 -0
- package/.output/server/node_modules/@pierre/diffs/dist/utils/getTotalLineCountFromHunks.js +10 -0
- package/.output/server/node_modules/@pierre/diffs/dist/utils/hast_utils.js +42 -0
- package/.output/server/node_modules/@pierre/diffs/dist/utils/isWorkerContext.js +8 -0
- package/.output/server/node_modules/@pierre/diffs/dist/utils/parseDiffDecorations.js +34 -0
- package/.output/server/node_modules/@pierre/diffs/dist/utils/parseDiffFromFile.js +23 -0
- package/.output/server/node_modules/@pierre/diffs/dist/utils/parseLineType.js +17 -0
- package/.output/server/node_modules/@pierre/diffs/dist/utils/parsePatchFiles.js +211 -0
- package/.output/server/node_modules/@pierre/diffs/dist/utils/prerenderHTMLIfNecessary.js +10 -0
- package/.output/server/node_modules/@pierre/diffs/dist/utils/processLine.js +42 -0
- package/.output/server/node_modules/@pierre/diffs/dist/utils/renderDiffWithHighlighter.js +339 -0
- package/.output/server/node_modules/@pierre/diffs/dist/utils/renderFileWithHighlighter.js +52 -0
- package/.output/server/node_modules/@pierre/diffs/dist/utils/setLanguageOverride.js +11 -0
- package/.output/server/node_modules/@pierre/diffs/dist/utils/setWrapperNodeProps.js +29 -0
- package/.output/server/node_modules/@pierre/diffs/package.json +89 -0
- package/.output/server/node_modules/@shikijs/transformers/dist/index.mjs +831 -0
- package/.output/server/node_modules/@shikijs/transformers/package.json +37 -0
- package/.output/server/node_modules/diff/libesm/convert/dmp.js +21 -0
- package/.output/server/node_modules/diff/libesm/convert/xml.js +31 -0
- package/.output/server/node_modules/diff/libesm/diff/array.js +16 -0
- package/.output/server/node_modules/diff/libesm/diff/base.js +253 -0
- package/.output/server/node_modules/diff/libesm/diff/character.js +7 -0
- package/.output/server/node_modules/diff/libesm/diff/css.js +10 -0
- package/.output/server/node_modules/diff/libesm/diff/json.js +78 -0
- package/.output/server/node_modules/diff/libesm/diff/line.js +65 -0
- package/.output/server/node_modules/diff/libesm/diff/sentence.js +43 -0
- package/.output/server/node_modules/diff/libesm/diff/word.js +296 -0
- package/.output/server/node_modules/diff/libesm/index.js +30 -0
- package/.output/server/node_modules/diff/libesm/package.json +1 -0
- package/.output/server/node_modules/diff/libesm/patch/apply.js +257 -0
- package/.output/server/node_modules/diff/libesm/patch/create.js +228 -0
- package/.output/server/node_modules/diff/libesm/patch/line-endings.js +44 -0
- package/.output/server/node_modules/diff/libesm/patch/parse.js +147 -0
- package/.output/server/node_modules/diff/libesm/patch/reverse.js +23 -0
- package/.output/server/node_modules/diff/libesm/util/distance-iterator.js +37 -0
- package/.output/server/node_modules/diff/libesm/util/params.js +14 -0
- package/.output/server/node_modules/diff/libesm/util/string.js +128 -0
- package/.output/server/node_modules/diff/package.json +132 -0
- package/.output/server/package.json +4 -1
- package/README.md +41 -0
- package/bin/prd +1 -1
- package/dist/host/src/index.js +10 -0
- package/dist/host/src/sync.js +201 -0
- package/dist/server/utils/db.js +64 -0
- package/dist/server/utils/git.js +8 -6
- package/dist/server/utils/prd-state.js +24 -2
- package/dist/server/utils/repos.js +12 -2
- package/dist/server/utils/state-migration.js +4 -3
- package/dist/server/utils/sync-apply.js +380 -0
- package/dist/server/utils/sync-export.js +183 -0
- package/dist/server/utils/sync-identity.js +231 -0
- package/dist/server/utils/sync-inspect.js +103 -0
- package/dist/server/utils/sync-merge.js +579 -0
- package/dist/server/utils/sync-schema.js +100 -0
- package/package.json +2 -1
- package/.output/public/_nuxt/6tINjQEd.js +0 -141
- package/.output/public/_nuxt/B2mIQf5X.js +0 -3
- package/.output/public/_nuxt/C0BBSDJ7.js +0 -1
- package/.output/public/_nuxt/CN46Bgts.js +0 -1
- package/.output/public/_nuxt/CTJgb0zb.js +0 -1
- package/.output/public/_nuxt/Cce168lk.js +0 -30
- package/.output/public/_nuxt/CyVSeLw5.js +0 -1
- package/.output/public/_nuxt/Detail.CYc96mGf.css +0 -1
- package/.output/public/_nuxt/ZNypZshD.js +0 -13
- package/.output/public/_nuxt/builds/meta/8c342d49-fe70-4f67-a987-821c16f86125.json +0 -1
- package/.output/public/_nuxt/entry.Bw0CE6Iz.css +0 -1
- package/.output/public/_nuxt/pYJYAY-W.js +0 -60
- package/.output/server/chunks/build/Detail-DMMUwTWr.mjs.map +0 -1
- package/.output/server/chunks/build/DiffViewer-styles-1.mjs-d2dQvARr.mjs +0 -4
- package/.output/server/chunks/build/DiffViewer-styles-1.mjs-d2dQvARr.mjs.map +0 -1
- package/.output/server/chunks/build/DiffViewer-styles-2.mjs-X6QKNjM0.mjs +0 -4
- package/.output/server/chunks/build/DiffViewer-styles-2.mjs-X6QKNjM0.mjs.map +0 -1
- package/.output/server/chunks/build/DiffViewer-styles.0AbHFl6N.mjs +0 -8
- package/.output/server/chunks/build/DiffViewer-styles.0AbHFl6N.mjs.map +0 -1
- package/.output/server/chunks/build/DiffViewer-styles.BDwAqkTk.mjs +0 -8
- package/.output/server/chunks/build/DiffViewer-styles.BDwAqkTk.mjs.map +0 -1
- package/.output/server/chunks/build/DiffViewer-styles.DRJh5Ui4.mjs +0 -10
- package/.output/server/chunks/build/DiffViewer-styles.DRJh5Ui4.mjs.map +0 -1
- package/.output/server/chunks/build/_prd_-ByugK4Yi.mjs.map +0 -1
- package/.output/server/chunks/build/default-BKKgG7HJ.mjs.map +0 -1
- package/.output/server/chunks/build/error-404-Bf6kdO80.mjs.map +0 -1
- package/.output/server/chunks/build/index-DE1tjHAd.mjs.map +0 -1
- package/.output/server/chunks/build/nuxt-link-SvT1nf8Z.mjs.map +0 -1
- package/.output/server/chunks/build/repo-graph-DzT45gSB.mjs.map +0 -1
- package/.output/server/chunks/build/usePrd-hXZOmvAv.mjs.map +0 -1
|
@@ -0,0 +1,395 @@
|
|
|
1
|
+
import { DEFAULT_THEMES, DIFFS_TAG_NAME, HEADER_METADATA_SLOT_ID, UNSAFE_CSS_ATTRIBUTE } from "../constants.js";
|
|
2
|
+
import { LineSelectionManager, pluckLineSelectionOptions } from "../managers/LineSelectionManager.js";
|
|
3
|
+
import { MouseEventManager, pluckMouseEventOptions } from "../managers/MouseEventManager.js";
|
|
4
|
+
import { ResizeManager } from "../managers/ResizeManager.js";
|
|
5
|
+
import { getLineAnnotationName } from "../utils/getLineAnnotationName.js";
|
|
6
|
+
import { SVGSpriteSheet } from "../sprite.js";
|
|
7
|
+
import { areFilesEqual } from "../utils/areFilesEqual.js";
|
|
8
|
+
import { createAnnotationWrapperNode } from "../utils/createAnnotationWrapperNode.js";
|
|
9
|
+
import { createCodeNode } from "../utils/createCodeNode.js";
|
|
10
|
+
import { createHoverContentNode } from "../utils/createHoverContentNode.js";
|
|
11
|
+
import { createUnsafeCSSStyleNode } from "../utils/createUnsafeCSSStyleNode.js";
|
|
12
|
+
import { wrapUnsafeCSS } from "../utils/cssWrappers.js";
|
|
13
|
+
import { prerenderHTMLIfNecessary } from "../utils/prerenderHTMLIfNecessary.js";
|
|
14
|
+
import { setPreNodeProperties } from "../utils/setWrapperNodeProps.js";
|
|
15
|
+
import { DiffsContainerLoaded } from "./web-components.js";
|
|
16
|
+
import { ScrollSyncManager } from "../managers/ScrollSyncManager.js";
|
|
17
|
+
import { DiffHunksRenderer } from "../renderers/DiffHunksRenderer.js";
|
|
18
|
+
import { parseDiffFromFile } from "../utils/parseDiffFromFile.js";
|
|
19
|
+
import { toHtml } from "hast-util-to-html";
|
|
20
|
+
|
|
21
|
+
//#region src/components/FileDiff.ts
|
|
22
|
+
let instanceId = -1;
|
|
23
|
+
var FileDiff = class {
|
|
24
|
+
static LoadedCustomComponent = DiffsContainerLoaded;
|
|
25
|
+
__id = ++instanceId;
|
|
26
|
+
fileContainer;
|
|
27
|
+
spriteSVG;
|
|
28
|
+
pre;
|
|
29
|
+
unsafeCSSStyle;
|
|
30
|
+
hoverContent;
|
|
31
|
+
headerElement;
|
|
32
|
+
headerMetadata;
|
|
33
|
+
customHunkElements = [];
|
|
34
|
+
errorWrapper;
|
|
35
|
+
hunksRenderer;
|
|
36
|
+
resizeManager;
|
|
37
|
+
scrollSyncManager;
|
|
38
|
+
mouseEventManager;
|
|
39
|
+
lineSelectionManager;
|
|
40
|
+
annotationElements = [];
|
|
41
|
+
lineAnnotations = [];
|
|
42
|
+
oldFile;
|
|
43
|
+
newFile;
|
|
44
|
+
fileDiff;
|
|
45
|
+
constructor(options = { theme: DEFAULT_THEMES }, workerManager, isContainerManaged = false) {
|
|
46
|
+
this.options = options;
|
|
47
|
+
this.workerManager = workerManager;
|
|
48
|
+
this.isContainerManaged = isContainerManaged;
|
|
49
|
+
this.hunksRenderer = new DiffHunksRenderer({
|
|
50
|
+
...options,
|
|
51
|
+
hunkSeparators: typeof options.hunkSeparators === "function" ? "custom" : options.hunkSeparators
|
|
52
|
+
}, this.handleHighlightRender, this.workerManager);
|
|
53
|
+
this.resizeManager = new ResizeManager();
|
|
54
|
+
this.scrollSyncManager = new ScrollSyncManager();
|
|
55
|
+
this.mouseEventManager = new MouseEventManager("diff", pluckMouseEventOptions(options, typeof options.hunkSeparators === "function" || (options.hunkSeparators ?? "line-info") === "line-info" ? this.handleExpandHunk : void 0));
|
|
56
|
+
this.lineSelectionManager = new LineSelectionManager(pluckLineSelectionOptions(options));
|
|
57
|
+
this.workerManager?.subscribeToThemeChanges(this);
|
|
58
|
+
}
|
|
59
|
+
handleHighlightRender = () => {
|
|
60
|
+
this.rerender();
|
|
61
|
+
};
|
|
62
|
+
setOptions(options) {
|
|
63
|
+
if (options == null) return;
|
|
64
|
+
this.options = options;
|
|
65
|
+
this.hunksRenderer.setOptions({
|
|
66
|
+
...this.options,
|
|
67
|
+
hunkSeparators: typeof options.hunkSeparators === "function" ? "custom" : options.hunkSeparators
|
|
68
|
+
});
|
|
69
|
+
this.mouseEventManager.setOptions(pluckMouseEventOptions(options, typeof options.hunkSeparators === "function" || (options.hunkSeparators ?? "line-info") === "line-info" ? this.handleExpandHunk : void 0));
|
|
70
|
+
this.lineSelectionManager.setOptions(pluckLineSelectionOptions(options));
|
|
71
|
+
}
|
|
72
|
+
mergeOptions(options) {
|
|
73
|
+
this.options = {
|
|
74
|
+
...this.options,
|
|
75
|
+
...options
|
|
76
|
+
};
|
|
77
|
+
}
|
|
78
|
+
setThemeType(themeType) {
|
|
79
|
+
if ((this.options.themeType ?? "system") === themeType) return;
|
|
80
|
+
this.mergeOptions({ themeType });
|
|
81
|
+
this.hunksRenderer.setThemeType(themeType);
|
|
82
|
+
if (this.headerElement != null) if (themeType === "system") delete this.headerElement.dataset.themeType;
|
|
83
|
+
else this.headerElement.dataset.themeType = themeType;
|
|
84
|
+
if (this.pre != null) switch (themeType) {
|
|
85
|
+
case "system":
|
|
86
|
+
delete this.pre.dataset.themeType;
|
|
87
|
+
break;
|
|
88
|
+
case "light":
|
|
89
|
+
case "dark":
|
|
90
|
+
this.pre.dataset.themeType = themeType;
|
|
91
|
+
break;
|
|
92
|
+
}
|
|
93
|
+
}
|
|
94
|
+
getHoveredLine = () => {
|
|
95
|
+
return this.mouseEventManager.getHoveredLine();
|
|
96
|
+
};
|
|
97
|
+
setLineAnnotations(lineAnnotations) {
|
|
98
|
+
this.lineAnnotations = lineAnnotations;
|
|
99
|
+
}
|
|
100
|
+
setSelectedLines(range) {
|
|
101
|
+
this.lineSelectionManager.setSelection(range);
|
|
102
|
+
}
|
|
103
|
+
cleanUp() {
|
|
104
|
+
this.hunksRenderer.cleanUp();
|
|
105
|
+
this.resizeManager.cleanUp();
|
|
106
|
+
this.mouseEventManager.cleanUp();
|
|
107
|
+
this.scrollSyncManager.cleanUp();
|
|
108
|
+
this.lineSelectionManager.cleanUp();
|
|
109
|
+
this.workerManager?.unsubscribeToThemeChanges(this);
|
|
110
|
+
this.workerManager = void 0;
|
|
111
|
+
this.fileDiff = void 0;
|
|
112
|
+
this.oldFile = void 0;
|
|
113
|
+
this.newFile = void 0;
|
|
114
|
+
if (!this.isContainerManaged) this.fileContainer?.parentNode?.removeChild(this.fileContainer);
|
|
115
|
+
if (this.fileContainer?.shadowRoot != null) this.fileContainer.shadowRoot.innerHTML = "";
|
|
116
|
+
this.fileContainer = void 0;
|
|
117
|
+
this.pre = void 0;
|
|
118
|
+
this.headerElement = void 0;
|
|
119
|
+
this.errorWrapper = void 0;
|
|
120
|
+
}
|
|
121
|
+
hydrate(props) {
|
|
122
|
+
const { fileContainer, prerenderedHTML } = props;
|
|
123
|
+
prerenderHTMLIfNecessary(fileContainer, prerenderedHTML);
|
|
124
|
+
for (const element of Array.from(fileContainer.shadowRoot?.children ?? [])) {
|
|
125
|
+
if (element instanceof SVGElement) {
|
|
126
|
+
this.spriteSVG = element;
|
|
127
|
+
continue;
|
|
128
|
+
}
|
|
129
|
+
if (!(element instanceof HTMLElement)) continue;
|
|
130
|
+
if (element instanceof HTMLPreElement) {
|
|
131
|
+
this.pre = element;
|
|
132
|
+
continue;
|
|
133
|
+
}
|
|
134
|
+
if ("diffsHeader" in element.dataset) {
|
|
135
|
+
this.headerElement = element;
|
|
136
|
+
continue;
|
|
137
|
+
}
|
|
138
|
+
if (element instanceof HTMLStyleElement && element.hasAttribute(UNSAFE_CSS_ATTRIBUTE)) {
|
|
139
|
+
this.unsafeCSSStyle = element;
|
|
140
|
+
continue;
|
|
141
|
+
}
|
|
142
|
+
}
|
|
143
|
+
if (this.pre == null) this.render(props);
|
|
144
|
+
else {
|
|
145
|
+
const { lineAnnotations, oldFile, newFile, fileDiff } = props;
|
|
146
|
+
this.fileContainer = fileContainer;
|
|
147
|
+
delete this.pre.dataset.dehydrated;
|
|
148
|
+
this.lineAnnotations = lineAnnotations ?? this.lineAnnotations;
|
|
149
|
+
this.newFile = newFile;
|
|
150
|
+
this.oldFile = oldFile;
|
|
151
|
+
this.fileDiff = fileDiff ?? (oldFile != null && newFile != null ? parseDiffFromFile(oldFile, newFile) : void 0);
|
|
152
|
+
this.hunksRenderer.hydrate(this.fileDiff);
|
|
153
|
+
this.renderAnnotations();
|
|
154
|
+
this.renderHoverUtility();
|
|
155
|
+
this.injectUnsafeCSS();
|
|
156
|
+
this.mouseEventManager.setup(this.pre);
|
|
157
|
+
this.lineSelectionManager.setup(this.pre);
|
|
158
|
+
if ((this.options.overflow ?? "scroll") === "scroll") {
|
|
159
|
+
this.resizeManager.setup(this.pre);
|
|
160
|
+
if ((this.options.diffStyle ?? "split") === "split") this.scrollSyncManager.setup(this.pre);
|
|
161
|
+
}
|
|
162
|
+
}
|
|
163
|
+
}
|
|
164
|
+
rerender() {
|
|
165
|
+
if (this.fileDiff == null && this.newFile == null && this.oldFile == null) return;
|
|
166
|
+
this.render({
|
|
167
|
+
oldFile: this.oldFile,
|
|
168
|
+
newFile: this.newFile,
|
|
169
|
+
fileDiff: this.fileDiff,
|
|
170
|
+
forceRender: true
|
|
171
|
+
});
|
|
172
|
+
}
|
|
173
|
+
handleExpandHunk = (hunkIndex, direction) => {
|
|
174
|
+
this.expandHunk(hunkIndex, direction);
|
|
175
|
+
};
|
|
176
|
+
expandHunk(hunkIndex, direction) {
|
|
177
|
+
this.hunksRenderer.expandHunk(hunkIndex, direction);
|
|
178
|
+
this.rerender();
|
|
179
|
+
}
|
|
180
|
+
render({ oldFile, newFile, fileDiff, forceRender = false, lineAnnotations, fileContainer, containerWrapper }) {
|
|
181
|
+
const filesDidChange = oldFile != null && newFile != null && (!areFilesEqual(oldFile, this.oldFile) || !areFilesEqual(newFile, this.newFile));
|
|
182
|
+
const annotationsChanged = lineAnnotations != null && (lineAnnotations.length > 0 || this.lineAnnotations.length > 0) ? lineAnnotations !== this.lineAnnotations : false;
|
|
183
|
+
if (!forceRender && !annotationsChanged && (fileDiff != null && fileDiff === this.fileDiff || fileDiff == null && !filesDidChange)) return;
|
|
184
|
+
this.oldFile = oldFile;
|
|
185
|
+
this.newFile = newFile;
|
|
186
|
+
if (fileDiff != null) this.fileDiff = fileDiff;
|
|
187
|
+
else if (oldFile != null && newFile != null && filesDidChange) this.fileDiff = parseDiffFromFile(oldFile, newFile);
|
|
188
|
+
if (lineAnnotations != null) this.setLineAnnotations(lineAnnotations);
|
|
189
|
+
if (this.fileDiff == null) return;
|
|
190
|
+
this.hunksRenderer.setOptions({
|
|
191
|
+
...this.options,
|
|
192
|
+
hunkSeparators: typeof this.options.hunkSeparators === "function" ? "custom" : this.options.hunkSeparators
|
|
193
|
+
});
|
|
194
|
+
this.hunksRenderer.setLineAnnotations(this.lineAnnotations);
|
|
195
|
+
const { disableFileHeader = false, disableErrorHandling = false } = this.options;
|
|
196
|
+
if (disableFileHeader) {
|
|
197
|
+
if (this.headerElement != null) {
|
|
198
|
+
this.headerElement.parentNode?.removeChild(this.headerElement);
|
|
199
|
+
this.headerElement = void 0;
|
|
200
|
+
}
|
|
201
|
+
}
|
|
202
|
+
fileContainer = this.getOrCreateFileContainer(fileContainer, containerWrapper);
|
|
203
|
+
try {
|
|
204
|
+
const hunksResult = this.hunksRenderer.renderDiff(this.fileDiff);
|
|
205
|
+
if (hunksResult == null) {
|
|
206
|
+
if (this.workerManager != null && !this.workerManager.isInitialized()) this.workerManager.initialize().then(() => this.rerender());
|
|
207
|
+
return;
|
|
208
|
+
}
|
|
209
|
+
if (hunksResult.headerElement != null) this.applyHeaderToDOM(hunksResult.headerElement, fileContainer);
|
|
210
|
+
const pre = this.getOrCreatePreNode(fileContainer);
|
|
211
|
+
this.applyHunksToDOM(pre, hunksResult);
|
|
212
|
+
this.renderSeparators(hunksResult.hunkData);
|
|
213
|
+
this.renderAnnotations();
|
|
214
|
+
this.renderHoverUtility();
|
|
215
|
+
} catch (error) {
|
|
216
|
+
if (disableErrorHandling) throw error;
|
|
217
|
+
console.error(error);
|
|
218
|
+
if (error instanceof Error) this.applyErrorToDOM(error, fileContainer);
|
|
219
|
+
}
|
|
220
|
+
}
|
|
221
|
+
renderSeparators(hunkData) {
|
|
222
|
+
const { hunkSeparators } = this.options;
|
|
223
|
+
if (this.isContainerManaged || this.fileContainer == null || typeof hunkSeparators !== "function") return;
|
|
224
|
+
for (const element of this.customHunkElements) element.parentNode?.removeChild(element);
|
|
225
|
+
this.customHunkElements.length = 0;
|
|
226
|
+
for (const hunk of hunkData) {
|
|
227
|
+
const element = document.createElement("div");
|
|
228
|
+
element.style.display = "contents";
|
|
229
|
+
element.slot = hunk.slotName;
|
|
230
|
+
element.appendChild(hunkSeparators(hunk, this));
|
|
231
|
+
this.fileContainer.appendChild(element);
|
|
232
|
+
this.customHunkElements.push(element);
|
|
233
|
+
}
|
|
234
|
+
}
|
|
235
|
+
renderAnnotations() {
|
|
236
|
+
if (this.isContainerManaged || this.fileContainer == null) return;
|
|
237
|
+
for (const element of this.annotationElements) element.parentNode?.removeChild(element);
|
|
238
|
+
this.annotationElements.length = 0;
|
|
239
|
+
const { renderAnnotation } = this.options;
|
|
240
|
+
if (renderAnnotation != null && this.lineAnnotations.length > 0) for (const annotation of this.lineAnnotations) {
|
|
241
|
+
const content = renderAnnotation(annotation);
|
|
242
|
+
if (content == null) continue;
|
|
243
|
+
const el = createAnnotationWrapperNode(getLineAnnotationName(annotation));
|
|
244
|
+
el.appendChild(content);
|
|
245
|
+
this.annotationElements.push(el);
|
|
246
|
+
this.fileContainer.appendChild(el);
|
|
247
|
+
}
|
|
248
|
+
}
|
|
249
|
+
renderHoverUtility() {
|
|
250
|
+
const { renderHoverUtility } = this.options;
|
|
251
|
+
if (this.fileContainer == null || renderHoverUtility == null) return;
|
|
252
|
+
if (this.hoverContent == null) {
|
|
253
|
+
this.hoverContent = createHoverContentNode();
|
|
254
|
+
this.fileContainer.appendChild(this.hoverContent);
|
|
255
|
+
}
|
|
256
|
+
const element = renderHoverUtility(this.mouseEventManager.getHoveredLine);
|
|
257
|
+
this.hoverContent.innerHTML = "";
|
|
258
|
+
if (element != null) this.hoverContent.appendChild(element);
|
|
259
|
+
}
|
|
260
|
+
getOrCreateFileContainer(fileContainer, parentNode) {
|
|
261
|
+
this.fileContainer = fileContainer ?? this.fileContainer ?? document.createElement(DIFFS_TAG_NAME);
|
|
262
|
+
if (parentNode != null && this.fileContainer.parentNode !== parentNode) parentNode.appendChild(this.fileContainer);
|
|
263
|
+
if (this.spriteSVG == null) {
|
|
264
|
+
const fragment = document.createElement("div");
|
|
265
|
+
fragment.innerHTML = SVGSpriteSheet;
|
|
266
|
+
const firstChild = fragment.firstChild;
|
|
267
|
+
if (firstChild instanceof SVGElement) {
|
|
268
|
+
this.spriteSVG = firstChild;
|
|
269
|
+
this.fileContainer.shadowRoot?.appendChild(this.spriteSVG);
|
|
270
|
+
}
|
|
271
|
+
}
|
|
272
|
+
return this.fileContainer;
|
|
273
|
+
}
|
|
274
|
+
getFileContainer() {
|
|
275
|
+
return this.fileContainer;
|
|
276
|
+
}
|
|
277
|
+
getOrCreatePreNode(container) {
|
|
278
|
+
if (this.pre == null) {
|
|
279
|
+
this.pre = document.createElement("pre");
|
|
280
|
+
container.shadowRoot?.appendChild(this.pre);
|
|
281
|
+
} else if (this.pre.parentNode !== container) container.shadowRoot?.appendChild(this.pre);
|
|
282
|
+
return this.pre;
|
|
283
|
+
}
|
|
284
|
+
applyHeaderToDOM(headerAST, container) {
|
|
285
|
+
this.cleanupErrorWrapper();
|
|
286
|
+
const tempDiv = document.createElement("div");
|
|
287
|
+
tempDiv.innerHTML = toHtml(headerAST);
|
|
288
|
+
const newHeader = tempDiv.firstElementChild;
|
|
289
|
+
if (!(newHeader instanceof HTMLElement)) return;
|
|
290
|
+
if (this.headerElement != null) container.shadowRoot?.replaceChild(newHeader, this.headerElement);
|
|
291
|
+
else container.shadowRoot?.prepend(newHeader);
|
|
292
|
+
this.headerElement = newHeader;
|
|
293
|
+
if (this.isContainerManaged) return;
|
|
294
|
+
const { renderHeaderMetadata } = this.options;
|
|
295
|
+
if (this.headerMetadata != null) this.headerMetadata.parentNode?.removeChild(this.headerMetadata);
|
|
296
|
+
const content = renderHeaderMetadata?.({
|
|
297
|
+
oldFile: this.oldFile,
|
|
298
|
+
newFile: this.newFile,
|
|
299
|
+
fileDiff: this.fileDiff
|
|
300
|
+
}) ?? void 0;
|
|
301
|
+
if (content != null) {
|
|
302
|
+
this.headerMetadata = document.createElement("div");
|
|
303
|
+
this.headerMetadata.slot = HEADER_METADATA_SLOT_ID;
|
|
304
|
+
if (content instanceof Element) this.headerMetadata.appendChild(content);
|
|
305
|
+
else this.headerMetadata.innerText = `${content}`;
|
|
306
|
+
container.appendChild(this.headerMetadata);
|
|
307
|
+
}
|
|
308
|
+
}
|
|
309
|
+
injectUnsafeCSS() {
|
|
310
|
+
if (this.fileContainer?.shadowRoot == null) return;
|
|
311
|
+
const { unsafeCSS } = this.options;
|
|
312
|
+
if (unsafeCSS == null || unsafeCSS === "") return;
|
|
313
|
+
if (this.unsafeCSSStyle == null) {
|
|
314
|
+
this.unsafeCSSStyle = createUnsafeCSSStyleNode();
|
|
315
|
+
this.fileContainer.shadowRoot.appendChild(this.unsafeCSSStyle);
|
|
316
|
+
}
|
|
317
|
+
this.unsafeCSSStyle.innerText = wrapUnsafeCSS(unsafeCSS);
|
|
318
|
+
}
|
|
319
|
+
applyHunksToDOM(pre, result) {
|
|
320
|
+
this.cleanupErrorWrapper();
|
|
321
|
+
this.applyPreNodeAttributes(pre, result);
|
|
322
|
+
pre.innerHTML = "";
|
|
323
|
+
let codeDeletions;
|
|
324
|
+
let codeAdditions;
|
|
325
|
+
if (result.unifiedAST != null) {
|
|
326
|
+
const codeUnified = createCodeNode({ columnType: "unified" });
|
|
327
|
+
codeUnified.innerHTML = this.hunksRenderer.renderPartialHTML(result.unifiedAST);
|
|
328
|
+
pre.appendChild(codeUnified);
|
|
329
|
+
} else {
|
|
330
|
+
if (result.deletionsAST != null) {
|
|
331
|
+
codeDeletions = createCodeNode({ columnType: "deletions" });
|
|
332
|
+
codeDeletions.innerHTML = this.hunksRenderer.renderPartialHTML(result.deletionsAST);
|
|
333
|
+
pre.appendChild(codeDeletions);
|
|
334
|
+
}
|
|
335
|
+
if (result.additionsAST != null) {
|
|
336
|
+
codeAdditions = createCodeNode({ columnType: "additions" });
|
|
337
|
+
codeAdditions.innerHTML = this.hunksRenderer.renderPartialHTML(result.additionsAST);
|
|
338
|
+
pre.appendChild(codeAdditions);
|
|
339
|
+
}
|
|
340
|
+
}
|
|
341
|
+
this.injectUnsafeCSS();
|
|
342
|
+
this.mouseEventManager.setup(pre);
|
|
343
|
+
this.lineSelectionManager.setup(pre);
|
|
344
|
+
if ((this.options.overflow ?? "scroll") === "scroll") {
|
|
345
|
+
this.resizeManager.setup(pre);
|
|
346
|
+
if ((this.options.diffStyle ?? "split") === "split") this.scrollSyncManager.setup(pre, codeDeletions, codeAdditions);
|
|
347
|
+
else this.scrollSyncManager.cleanUp();
|
|
348
|
+
} else {
|
|
349
|
+
this.resizeManager.cleanUp();
|
|
350
|
+
this.scrollSyncManager.cleanUp();
|
|
351
|
+
}
|
|
352
|
+
}
|
|
353
|
+
applyPreNodeAttributes(pre, { themeStyles, baseThemeType, additionsAST, deletionsAST, totalLines }) {
|
|
354
|
+
const { diffIndicators = "bars", disableBackground = false, disableLineNumbers = false, overflow = "scroll", themeType = "system", diffStyle = "split" } = this.options;
|
|
355
|
+
setPreNodeProperties({
|
|
356
|
+
pre,
|
|
357
|
+
diffIndicators,
|
|
358
|
+
disableBackground,
|
|
359
|
+
disableLineNumbers,
|
|
360
|
+
overflow,
|
|
361
|
+
split: diffStyle === "unified" ? false : additionsAST != null && deletionsAST != null,
|
|
362
|
+
themeStyles,
|
|
363
|
+
themeType: baseThemeType ?? themeType,
|
|
364
|
+
totalLines
|
|
365
|
+
});
|
|
366
|
+
}
|
|
367
|
+
applyErrorToDOM(error, container) {
|
|
368
|
+
this.cleanupErrorWrapper();
|
|
369
|
+
const pre = this.getOrCreatePreNode(container);
|
|
370
|
+
pre.innerHTML = "";
|
|
371
|
+
pre.parentNode?.removeChild(pre);
|
|
372
|
+
this.pre = void 0;
|
|
373
|
+
const shadowRoot = container.shadowRoot ?? container.attachShadow({ mode: "open" });
|
|
374
|
+
this.errorWrapper ??= document.createElement("div");
|
|
375
|
+
this.errorWrapper.dataset.errorWrapper = "";
|
|
376
|
+
this.errorWrapper.innerHTML = "";
|
|
377
|
+
shadowRoot.appendChild(this.errorWrapper);
|
|
378
|
+
const errorMessage = document.createElement("div");
|
|
379
|
+
errorMessage.dataset.errorMessage = "";
|
|
380
|
+
errorMessage.innerText = error.message;
|
|
381
|
+
this.errorWrapper.appendChild(errorMessage);
|
|
382
|
+
const errorStack = document.createElement("pre");
|
|
383
|
+
errorStack.dataset.errorStack = "";
|
|
384
|
+
errorStack.innerText = error.stack ?? "No Error Stack";
|
|
385
|
+
this.errorWrapper.appendChild(errorStack);
|
|
386
|
+
}
|
|
387
|
+
cleanupErrorWrapper() {
|
|
388
|
+
this.errorWrapper?.parentNode?.removeChild(this.errorWrapper);
|
|
389
|
+
this.errorWrapper = void 0;
|
|
390
|
+
}
|
|
391
|
+
};
|
|
392
|
+
|
|
393
|
+
//#endregion
|
|
394
|
+
export { FileDiff };
|
|
395
|
+
//# sourceMappingURL=FileDiff.js.map
|
|
@@ -0,0 +1,161 @@
|
|
|
1
|
+
import { DEFAULT_THEMES, DIFFS_TAG_NAME } from "../constants.js";
|
|
2
|
+
import { getSharedHighlighter } from "../highlighter/shared_highlighter.js";
|
|
3
|
+
import { getHighlighterOptions } from "../utils/getHighlighterOptions.js";
|
|
4
|
+
import { formatCSSVariablePrefix } from "../utils/formatCSSVariablePrefix.js";
|
|
5
|
+
import { getHighlighterThemeStyles } from "../utils/getHighlighterThemeStyles.js";
|
|
6
|
+
import { createCodeNode } from "../utils/createCodeNode.js";
|
|
7
|
+
import { setPreNodeProperties } from "../utils/setWrapperNodeProps.js";
|
|
8
|
+
import { queueRender } from "../managers/UniversalRenderingManager.js";
|
|
9
|
+
import { CodeToTokenTransformStream } from "../shiki-stream/stream.js";
|
|
10
|
+
import { createRowNodes } from "../utils/createRowNodes.js";
|
|
11
|
+
import { createSpanFromToken } from "../utils/createSpanNodeFromToken.js";
|
|
12
|
+
|
|
13
|
+
//#region src/components/FileStream.ts
|
|
14
|
+
var FileStream = class {
|
|
15
|
+
highlighter;
|
|
16
|
+
stream;
|
|
17
|
+
abortController;
|
|
18
|
+
fileContainer;
|
|
19
|
+
pre;
|
|
20
|
+
code;
|
|
21
|
+
constructor(options = { theme: DEFAULT_THEMES }) {
|
|
22
|
+
this.options = options;
|
|
23
|
+
this.currentLineIndex = this.options.startingLineIndex ?? 1;
|
|
24
|
+
}
|
|
25
|
+
cleanUp() {
|
|
26
|
+
this.abortController?.abort();
|
|
27
|
+
this.abortController = void 0;
|
|
28
|
+
}
|
|
29
|
+
setThemeType(themeType) {
|
|
30
|
+
if ((this.options.themeType ?? "system") === themeType) return;
|
|
31
|
+
this.options = {
|
|
32
|
+
...this.options,
|
|
33
|
+
themeType
|
|
34
|
+
};
|
|
35
|
+
if (this.pre != null) switch (themeType) {
|
|
36
|
+
case "system":
|
|
37
|
+
delete this.pre.dataset.themeType;
|
|
38
|
+
break;
|
|
39
|
+
case "light":
|
|
40
|
+
case "dark":
|
|
41
|
+
this.pre.dataset.themeType = themeType;
|
|
42
|
+
break;
|
|
43
|
+
}
|
|
44
|
+
}
|
|
45
|
+
async initializeHighlighter() {
|
|
46
|
+
this.highlighter = await getSharedHighlighter(getHighlighterOptions(this.options.lang, this.options));
|
|
47
|
+
return this.highlighter;
|
|
48
|
+
}
|
|
49
|
+
queuedSetupArgs;
|
|
50
|
+
async setup(_source, _wrapper) {
|
|
51
|
+
const isSettingUp = this.queuedSetupArgs != null;
|
|
52
|
+
this.queuedSetupArgs = [_source, _wrapper];
|
|
53
|
+
if (isSettingUp) return;
|
|
54
|
+
this.highlighter ??= await this.initializeHighlighter();
|
|
55
|
+
const [source, wrapper] = this.queuedSetupArgs;
|
|
56
|
+
this.queuedSetupArgs = void 0;
|
|
57
|
+
const stream = source;
|
|
58
|
+
this.setupStream(stream, wrapper, this.highlighter);
|
|
59
|
+
}
|
|
60
|
+
setupStream(stream, wrapper, highlighter) {
|
|
61
|
+
const { disableLineNumbers = false, overflow = "scroll", theme = DEFAULT_THEMES, themeType = "system" } = this.options;
|
|
62
|
+
const fileContainer = this.getOrCreateFileContainer();
|
|
63
|
+
if (fileContainer.parentElement == null) wrapper.appendChild(fileContainer);
|
|
64
|
+
this.pre ??= document.createElement("pre");
|
|
65
|
+
if (this.pre.parentElement == null) fileContainer.shadowRoot?.appendChild(this.pre);
|
|
66
|
+
const themeStyles = getHighlighterThemeStyles({
|
|
67
|
+
theme,
|
|
68
|
+
highlighter
|
|
69
|
+
});
|
|
70
|
+
const baseThemeType = typeof theme === "string" ? highlighter.getTheme(theme).type : void 0;
|
|
71
|
+
const pre = setPreNodeProperties({
|
|
72
|
+
diffIndicators: "none",
|
|
73
|
+
disableBackground: true,
|
|
74
|
+
disableLineNumbers,
|
|
75
|
+
overflow,
|
|
76
|
+
pre: this.pre,
|
|
77
|
+
split: false,
|
|
78
|
+
themeType: baseThemeType ?? themeType,
|
|
79
|
+
themeStyles,
|
|
80
|
+
totalLines: 0
|
|
81
|
+
});
|
|
82
|
+
pre.innerHTML = "";
|
|
83
|
+
this.pre = pre;
|
|
84
|
+
this.code = createCodeNode({ pre });
|
|
85
|
+
this.abortController?.abort();
|
|
86
|
+
this.abortController = new AbortController();
|
|
87
|
+
const { onStreamStart, onStreamClose, onStreamAbort } = this.options;
|
|
88
|
+
this.stream = stream;
|
|
89
|
+
this.stream.pipeThrough(typeof theme === "string" ? new CodeToTokenTransformStream({
|
|
90
|
+
...this.options,
|
|
91
|
+
theme,
|
|
92
|
+
highlighter,
|
|
93
|
+
allowRecalls: true,
|
|
94
|
+
defaultColor: false,
|
|
95
|
+
cssVariablePrefix: formatCSSVariablePrefix("token")
|
|
96
|
+
}) : new CodeToTokenTransformStream({
|
|
97
|
+
...this.options,
|
|
98
|
+
themes: theme,
|
|
99
|
+
highlighter,
|
|
100
|
+
allowRecalls: true,
|
|
101
|
+
defaultColor: false,
|
|
102
|
+
cssVariablePrefix: formatCSSVariablePrefix("token")
|
|
103
|
+
})).pipeTo(new WritableStream({
|
|
104
|
+
start(controller) {
|
|
105
|
+
onStreamStart?.(controller);
|
|
106
|
+
},
|
|
107
|
+
close() {
|
|
108
|
+
onStreamClose?.();
|
|
109
|
+
},
|
|
110
|
+
abort(reason) {
|
|
111
|
+
onStreamAbort?.(reason);
|
|
112
|
+
},
|
|
113
|
+
write: this.handleWrite
|
|
114
|
+
}), { signal: this.abortController.signal }).catch((error) => {
|
|
115
|
+
if (error.name !== "AbortError") console.error("FileStream pipe error:", error);
|
|
116
|
+
});
|
|
117
|
+
}
|
|
118
|
+
queuedTokens = [];
|
|
119
|
+
handleWrite = (token) => {
|
|
120
|
+
if ("recall" in token && this.queuedTokens.length >= token.recall) this.queuedTokens.length = this.queuedTokens.length - token.recall;
|
|
121
|
+
else this.queuedTokens.push(token);
|
|
122
|
+
queueRender(this.render);
|
|
123
|
+
this.options.onStreamWrite?.(token);
|
|
124
|
+
};
|
|
125
|
+
currentLineIndex;
|
|
126
|
+
currentLineElement;
|
|
127
|
+
render = () => {
|
|
128
|
+
this.options.onPreRender?.(this);
|
|
129
|
+
const linesToAppend = [];
|
|
130
|
+
for (const token of this.queuedTokens) if ("recall" in token) {
|
|
131
|
+
if (this.currentLineElement == null) throw new Error("FileStream.render: no current line element, shouldnt be possible to get here");
|
|
132
|
+
if (token.recall > this.currentLineElement.childNodes.length) throw new Error(`FileStream.render: Token recall exceed the current line, there's probably a bug...`);
|
|
133
|
+
for (let i = 0; i < token.recall; i++) this.currentLineElement.lastChild?.remove();
|
|
134
|
+
} else {
|
|
135
|
+
const span = createSpanFromToken(token);
|
|
136
|
+
if (this.currentLineElement == null) linesToAppend.push(this.createLine());
|
|
137
|
+
this.currentLineElement?.appendChild(span);
|
|
138
|
+
if (token.content === "\n") {
|
|
139
|
+
this.currentLineIndex++;
|
|
140
|
+
linesToAppend.push(this.createLine());
|
|
141
|
+
}
|
|
142
|
+
}
|
|
143
|
+
for (const line of linesToAppend) this.code?.appendChild(line);
|
|
144
|
+
this.queuedTokens.length = 0;
|
|
145
|
+
this.options.onPostRender?.(this);
|
|
146
|
+
};
|
|
147
|
+
createLine() {
|
|
148
|
+
const { row, content } = createRowNodes(this.currentLineIndex);
|
|
149
|
+
this.currentLineElement = content;
|
|
150
|
+
return row;
|
|
151
|
+
}
|
|
152
|
+
getOrCreateFileContainer(fileContainer) {
|
|
153
|
+
if (fileContainer != null && fileContainer === this.fileContainer || fileContainer == null && this.fileContainer != null) return this.fileContainer;
|
|
154
|
+
this.fileContainer = fileContainer ?? document.createElement(DIFFS_TAG_NAME);
|
|
155
|
+
return this.fileContainer;
|
|
156
|
+
}
|
|
157
|
+
};
|
|
158
|
+
|
|
159
|
+
//#endregion
|
|
160
|
+
export { FileStream };
|
|
161
|
+
//# sourceMappingURL=FileStream.js.map
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
import { DIFFS_TAG_NAME } from "../constants.js";
|
|
2
|
+
import style_default from "../style.js";
|
|
3
|
+
|
|
4
|
+
//#region src/components/web-components.ts
|
|
5
|
+
if (typeof HTMLElement !== "undefined" && customElements.get(DIFFS_TAG_NAME) == null) {
|
|
6
|
+
let sheet;
|
|
7
|
+
class FileDiffContainer extends HTMLElement {
|
|
8
|
+
constructor() {
|
|
9
|
+
super();
|
|
10
|
+
if (this.shadowRoot != null) return;
|
|
11
|
+
const shadowRoot = this.attachShadow({ mode: "open" });
|
|
12
|
+
if (sheet == null) {
|
|
13
|
+
sheet = new CSSStyleSheet();
|
|
14
|
+
sheet.replaceSync(style_default);
|
|
15
|
+
}
|
|
16
|
+
shadowRoot.adoptedStyleSheets = [sheet];
|
|
17
|
+
}
|
|
18
|
+
}
|
|
19
|
+
customElements.define(DIFFS_TAG_NAME, FileDiffContainer);
|
|
20
|
+
}
|
|
21
|
+
const DiffsContainerLoaded = true;
|
|
22
|
+
|
|
23
|
+
//#endregion
|
|
24
|
+
export { DiffsContainerLoaded };
|
|
25
|
+
//# sourceMappingURL=web-components.js.map
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
//#region src/constants.ts
|
|
2
|
+
const DIFFS_TAG_NAME = "diffs-container";
|
|
3
|
+
const COMMIT_METADATA_SPLIT = /(?=^From [a-f0-9]+ .+$)/m;
|
|
4
|
+
const GIT_DIFF_FILE_BREAK_REGEX = /(?=^diff --git)/gm;
|
|
5
|
+
const UNIFIED_DIFF_FILE_BREAK_REGEX = /(?=^---\s+\S)/gm;
|
|
6
|
+
const FILE_CONTEXT_BLOB = /(?=^@@ )/gm;
|
|
7
|
+
const HUNK_HEADER = /^@@ -(\d+)(?:,(\d+))? \+(\d+)(?:,(\d+))? @@(?: (.*))?/m;
|
|
8
|
+
const SPLIT_WITH_NEWLINES = /(?<=\n)/;
|
|
9
|
+
const FILENAME_HEADER_REGEX = /^(---|\+\+\+)\s+([^\t\r\n]+)/;
|
|
10
|
+
const FILENAME_HEADER_REGEX_GIT = /^(---|\+\+\+)\s+[ab]\/([^\t\r\n]+)/;
|
|
11
|
+
const ALTERNATE_FILE_NAMES_GIT = /^diff --git (?:"a\/(.+?)"|a\/(.+?)) (?:"b\/(.+?)"|b\/(.+?))$/;
|
|
12
|
+
const FILE_MODE_FROM_INDEX = /^index (?:[0-9a-f]+)\.\.(?:[0-9a-f]+)(?: (\d+))?/;
|
|
13
|
+
const HEADER_METADATA_SLOT_ID = "header-metadata";
|
|
14
|
+
const DEFAULT_THEMES = {
|
|
15
|
+
dark: "pierre-dark",
|
|
16
|
+
light: "pierre-light"
|
|
17
|
+
};
|
|
18
|
+
const UNSAFE_CSS_ATTRIBUTE = "data-unsafe-css";
|
|
19
|
+
const CORE_CSS_ATTRIBUTE = "data-core-css";
|
|
20
|
+
|
|
21
|
+
//#endregion
|
|
22
|
+
export { ALTERNATE_FILE_NAMES_GIT, COMMIT_METADATA_SPLIT, CORE_CSS_ATTRIBUTE, DEFAULT_THEMES, DIFFS_TAG_NAME, FILENAME_HEADER_REGEX, FILENAME_HEADER_REGEX_GIT, FILE_CONTEXT_BLOB, FILE_MODE_FROM_INDEX, GIT_DIFF_FILE_BREAK_REGEX, HEADER_METADATA_SLOT_ID, HUNK_HEADER, SPLIT_WITH_NEWLINES, UNIFIED_DIFF_FILE_BREAK_REGEX, UNSAFE_CSS_ATTRIBUTE };
|
|
23
|
+
//# sourceMappingURL=constants.js.map
|
package/.output/server/node_modules/@pierre/diffs/dist/highlighter/languages/areLanguagesAttached.js
ADDED
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import { AttachedLanguages } from "./constants.js";
|
|
2
|
+
|
|
3
|
+
//#region src/highlighter/languages/areLanguagesAttached.ts
|
|
4
|
+
function areLanguagesAttached(languages) {
|
|
5
|
+
for (const language of Array.isArray(languages) ? languages : [languages]) if (!AttachedLanguages.has(language)) return false;
|
|
6
|
+
return true;
|
|
7
|
+
}
|
|
8
|
+
|
|
9
|
+
//#endregion
|
|
10
|
+
export { areLanguagesAttached };
|
|
11
|
+
//# sourceMappingURL=areLanguagesAttached.js.map
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import { AttachedLanguages, ResolvedLanguages } from "./constants.js";
|
|
2
|
+
|
|
3
|
+
//#region src/highlighter/languages/attachResolvedLanguages.ts
|
|
4
|
+
function attachResolvedLanguages(resolvedLanguages, highlighter) {
|
|
5
|
+
resolvedLanguages = Array.isArray(resolvedLanguages) ? resolvedLanguages : [resolvedLanguages];
|
|
6
|
+
for (const resolvedLang of resolvedLanguages) {
|
|
7
|
+
if (AttachedLanguages.has(resolvedLang.name)) continue;
|
|
8
|
+
let lang = ResolvedLanguages.get(resolvedLang.name);
|
|
9
|
+
if (lang == null) {
|
|
10
|
+
lang = resolvedLang;
|
|
11
|
+
ResolvedLanguages.set(resolvedLang.name, lang);
|
|
12
|
+
}
|
|
13
|
+
AttachedLanguages.add(lang.name);
|
|
14
|
+
highlighter.loadLanguageSync(lang.data);
|
|
15
|
+
}
|
|
16
|
+
}
|
|
17
|
+
|
|
18
|
+
//#endregion
|
|
19
|
+
export { attachResolvedLanguages };
|
|
20
|
+
//# sourceMappingURL=attachResolvedLanguages.js.map
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import { AttachedLanguages, ResolvedLanguages } from "./constants.js";
|
|
2
|
+
|
|
3
|
+
//#region src/highlighter/languages/cleanUpResolvedLanguages.ts
|
|
4
|
+
function cleanUpResolvedLanguages() {
|
|
5
|
+
ResolvedLanguages.clear();
|
|
6
|
+
AttachedLanguages.clear();
|
|
7
|
+
}
|
|
8
|
+
|
|
9
|
+
//#endregion
|
|
10
|
+
export { cleanUpResolvedLanguages };
|
|
11
|
+
//# sourceMappingURL=cleanUpResolvedLanguages.js.map
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
//#region src/highlighter/languages/constants.ts
|
|
2
|
+
const ResolvedLanguages = /* @__PURE__ */ new Map();
|
|
3
|
+
const ResolvingLanguages = /* @__PURE__ */ new Map();
|
|
4
|
+
const AttachedLanguages = /* @__PURE__ */ new Set();
|
|
5
|
+
|
|
6
|
+
//#endregion
|
|
7
|
+
export { AttachedLanguages, ResolvedLanguages, ResolvingLanguages };
|
|
8
|
+
//# sourceMappingURL=constants.js.map
|
package/.output/server/node_modules/@pierre/diffs/dist/highlighter/languages/getResolvedLanguages.js
ADDED
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import { ResolvedLanguages } from "./constants.js";
|
|
2
|
+
|
|
3
|
+
//#region src/highlighter/languages/getResolvedLanguages.ts
|
|
4
|
+
function getResolvedLanguages(languages) {
|
|
5
|
+
const resolvedLanguages = [];
|
|
6
|
+
for (const language of languages) {
|
|
7
|
+
const resolvedLanguage = ResolvedLanguages.get(language);
|
|
8
|
+
if (resolvedLanguage == null) throw new Error(`getResolvedLanguages: ${language} is not resolved. Please resolve languages before calling getResolvedLanguages`);
|
|
9
|
+
resolvedLanguages.push(resolvedLanguage);
|
|
10
|
+
}
|
|
11
|
+
return resolvedLanguages;
|
|
12
|
+
}
|
|
13
|
+
|
|
14
|
+
//#endregion
|
|
15
|
+
export { getResolvedLanguages };
|
|
16
|
+
//# sourceMappingURL=getResolvedLanguages.js.map
|