Skip to content

Commit

Permalink
Revert "fixes #2304 (#2391)"
Browse files Browse the repository at this point in the history
This reverts commit 36311cc.
  • Loading branch information
recursiveforte authored Oct 9, 2024
1 parent 146b738 commit 7497e0a
Showing 1 changed file with 55 additions and 62 deletions.
117 changes: 55 additions & 62 deletions src/components/popups-etc/editor-modal.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -45,36 +45,27 @@ export default function EditorModal() {
// This is probably bad practice
const _openEditor = openEditor.peek() // Gotta peek to avoid cycles
const _text = text.value // But we want to sub to this
if (!codeMirror.value || !_openEditor) return

// Sync only if there's an active CodeMirror editor and an open editor
if (!codeMirror.value || !_openEditor) return;

// Differentiate between map and palette updates
if (_openEditor.kind === 'palette' || _openEditor.kind === 'map') {
console.log('dispatching', _openEditor.editRange, _text);

codeMirror.value.dispatch({
changes: {
from: _openEditor.editRange.from,
to: _openEditor.editRange.to,
insert: _text
}
})

// Update openEditor with new text and correct range
openEditor.value = {
..._openEditor,
text: _text,
editRange: {
from: _openEditor.editRange.from,
to: _openEditor.editRange.from + _text.length
}
};
codeMirror.value.dispatch({
changes: {
..._openEditor.editRange,
insert: _text
}
})

openEditor.value = {
..._openEditor,
text: _text,
editRange: {
from: _openEditor.editRange.from,
to: _openEditor.editRange.from + _text.length
}
}

setUpdateCulprit(UpdateCulprit.OpenEditor);
}, [text.value]);


useEffect(() => {
// if update comes from codemirror doc (probably from a collab session)
// this ensures that updates are not triggered from this effect which may cause an
Expand All @@ -96,53 +87,55 @@ export default function EditorModal() {
if (!openEditor.value) return;

const code = codeMirror.value?.state.doc.toString() ?? '';
const levenshtainDistances = _foldRanges.value.map((foldRange, index) => {
const widgetKind = _widgets.value[index]?.value.spec.widget.props.kind;
const levenshteinDistances = _foldRanges.value.map((foldRange, foldRangeIndex) => {
const widgetKind = _widgets.value[foldRangeIndex]?.value.spec.widget.props.kind;

// Filter out unrelated widgets
if (!openEditor.value || widgetKind !== openEditor.value.kind) return -1;
// if the widget kind is not the same as the open editor kind, don't do anything
if (widgetKind !== openEditor.value?.kind) return -1;

const foldCode = code.slice(foldRange.from, foldRange.to);
return levenshtein(text.value, foldCode);
const theCode = code.slice(foldRange?.from, foldRange?.to);

const distance = levenshtein(text.value, theCode)
return distance;
});

// Find closest matching fold range
const validDistances = levenshtainDistances.filter(d => d >= 0);
if (validDistances.length === 0) return;
// if (levenshtainDistances.length === 0) alert(`You are currently editing a deleted ${openEditor.value?.kind}`);
if (levenshteinDistances.length === 0) return;

const indexOfMinDistance = validDistances.indexOf(Math.min(...validDistances));
const editRange = _foldRanges.value[indexOfMinDistance];
// compute the index of the min distance
let indexOfMinDistance = 0;
levenshteinDistances.forEach((distance, didx) => {
if (levenshteinDistances[indexOfMinDistance]! < 0) indexOfMinDistance = didx;
const min = levenshteinDistances[indexOfMinDistance]!;
if (distance >= 0 && distance <= min) indexOfMinDistance = didx;
});

// Update the open editor range and content
if (editRange) {
const openEditorCode = code.slice(editRange.from, editRange.to);
// update the open editor if the index is not -1
if (indexOfMinDistance !== -1) {
const editRange = _foldRanges.value[indexOfMinDistance]
const openEditorCode = code.slice(editRange?.from, editRange?.to)

// If it's a map editor, update bitmaps based on headless game logic
if (openEditor.value.kind === 'map') {
runGameHeadless(code);
}
// the map editor needs to get the bitmaps after running the code
if (openEditor.value?.kind === 'map') runGameHeadless(code ?? '');

openEditor.value = {
...openEditor.value as OpenEditor,
editRange: {
from: editRange.from,
to: editRange.to
},
text: openEditorCode
}
}
text.value = openEditorCode;

openEditor.value = {
...openEditor.value as OpenEditor,
editRange: {
from: editRange!.from,
to: editRange!.to
},
text: openEditorCode
}

}
}

// Handle closing modal on escape key press or outside click
usePopupCloseClick(styles.content!, () => openEditor.value = null, !!openEditor.value)
useEffect(() => {
const unsubscribe = tinykeys(window, {
'Escape': () => openEditor.value = null
});
return () => unsubscribe()
}, [])

// Render only when there's an open editor
useEffect(() => tinykeys(window, {
'Escape': () => openEditor.value = null
}), [])
if (!openEditor.value) return null

return (
Expand All @@ -153,4 +146,4 @@ export default function EditorModal() {
</div>
</div>
)
}
}

0 comments on commit 7497e0a

Please sign in to comment.