mirror of
https://github.com/yu-i-i/overleaf-cep.git
synced 2026-06-05 23:29:00 +02:00
Merge pull request #26909 from overleaf/dp-eq-preview-presentation-mode
Prevent codemirror tooltips appearing on top of pdf preview GitOrigin-RevId: 0c6ce15cd91b4958674fbc247bcd27ce5778f7fc
This commit is contained in:
@@ -53,6 +53,7 @@ import { ranges } from './ranges'
|
||||
import { historyOT } from './history-ot'
|
||||
import { trackDetachedComments } from './track-detached-comments'
|
||||
import { reviewTooltip } from './review-tooltip'
|
||||
import { tooltipsReposition } from './tooltips-reposition'
|
||||
|
||||
const moduleExtensions: Array<(options: Record<string, any>) => Extension> =
|
||||
importOverleafModules('sourceEditorExtensions').map(
|
||||
@@ -170,4 +171,5 @@ export const createExtensions = (options: Record<string, any>): Extension[] => [
|
||||
effectListeners(),
|
||||
geometryChangeEvent(),
|
||||
fileTreeItemDrop(),
|
||||
tooltipsReposition(),
|
||||
]
|
||||
|
||||
@@ -1,10 +1,4 @@
|
||||
import {
|
||||
EditorView,
|
||||
repositionTooltips,
|
||||
showTooltip,
|
||||
Tooltip,
|
||||
ViewPlugin,
|
||||
} from '@codemirror/view'
|
||||
import { EditorView, showTooltip, Tooltip, ViewPlugin } from '@codemirror/view'
|
||||
import {
|
||||
Compartment,
|
||||
EditorState,
|
||||
@@ -24,8 +18,8 @@ import { documentCommands } from '../languages/latex/document-commands'
|
||||
import { debugConsole } from '@/utils/debugging'
|
||||
import { nodeHasError } from '../utils/tree-operations/common'
|
||||
import { documentEnvironments } from '../languages/latex/document-environments'
|
||||
import { repositionAllTooltips } from './tooltips-reposition'
|
||||
|
||||
const REPOSITION_EVENT = 'editor:repositionMathTooltips'
|
||||
const HIDE_TOOLTIP_EVENT = 'editor:hideMathTooltip'
|
||||
|
||||
export const mathPreview = (enabled: boolean): Extension => {
|
||||
@@ -81,19 +75,16 @@ export const mathPreviewStateField = StateField.define<{
|
||||
showTooltip.compute([field], state => state.field(field).tooltip),
|
||||
|
||||
ViewPlugin.define(view => {
|
||||
const listener = () => repositionTooltips(view)
|
||||
const hideTooltip = () => {
|
||||
view.dispatch({
|
||||
effects: hideTooltipEffect.of(null),
|
||||
})
|
||||
}
|
||||
|
||||
window.addEventListener(REPOSITION_EVENT, listener)
|
||||
window.addEventListener(HIDE_TOOLTIP_EVENT, hideTooltip)
|
||||
|
||||
return {
|
||||
destroy() {
|
||||
window.removeEventListener(REPOSITION_EVENT, listener)
|
||||
window.removeEventListener(HIDE_TOOLTIP_EVENT, hideTooltip)
|
||||
},
|
||||
}
|
||||
@@ -220,7 +211,7 @@ const buildTooltipContent = (
|
||||
renderMath(math.content, math.displayMode, element, definitions)
|
||||
.then(() => {
|
||||
element.style.opacity = '1'
|
||||
window.dispatchEvent(new Event(REPOSITION_EVENT))
|
||||
repositionAllTooltips()
|
||||
})
|
||||
.catch(error => {
|
||||
debugConsole.error(error)
|
||||
|
||||
@@ -0,0 +1,20 @@
|
||||
import { repositionTooltips, ViewPlugin } from '@codemirror/view'
|
||||
|
||||
const REPOSITION_EVENT = 'editor:repositionAllTooltips'
|
||||
|
||||
export const tooltipsReposition = () =>
|
||||
ViewPlugin.define(view => {
|
||||
const listener = () => repositionTooltips(view)
|
||||
|
||||
window.addEventListener(REPOSITION_EVENT, listener)
|
||||
|
||||
return {
|
||||
destroy() {
|
||||
window.removeEventListener(REPOSITION_EVENT, listener)
|
||||
},
|
||||
}
|
||||
})
|
||||
|
||||
export const repositionAllTooltips = () => {
|
||||
window.dispatchEvent(new Event(REPOSITION_EVENT))
|
||||
}
|
||||
Reference in New Issue
Block a user