mirror of
https://github.com/MindWorkAI/AI-Studio.git
synced 2026-03-22 20:31:36 +00:00
Some checks are pending
Build and Release / Read metadata (push) Waiting to run
Build and Release / Build app (${{ matrix.dotnet_runtime }}) (-aarch64-apple-darwin, osx-arm64, macos-latest, aarch64-apple-darwin, dmg updater) (push) Blocked by required conditions
Build and Release / Build app (${{ matrix.dotnet_runtime }}) (-aarch64-pc-windows-msvc.exe, win-arm64, windows-latest, aarch64-pc-windows-msvc, nsis updater) (push) Blocked by required conditions
Build and Release / Build app (${{ matrix.dotnet_runtime }}) (-aarch64-unknown-linux-gnu, linux-arm64, ubuntu-22.04-arm, aarch64-unknown-linux-gnu, appimage deb updater) (push) Blocked by required conditions
Build and Release / Build app (${{ matrix.dotnet_runtime }}) (-x86_64-apple-darwin, osx-x64, macos-latest, x86_64-apple-darwin, dmg updater) (push) Blocked by required conditions
Build and Release / Build app (${{ matrix.dotnet_runtime }}) (-x86_64-pc-windows-msvc.exe, win-x64, windows-latest, x86_64-pc-windows-msvc, nsis updater) (push) Blocked by required conditions
Build and Release / Build app (${{ matrix.dotnet_runtime }}) (-x86_64-unknown-linux-gnu, linux-x64, ubuntu-22.04, x86_64-unknown-linux-gnu, appimage deb updater) (push) Blocked by required conditions
Build and Release / Prepare & create release (push) Blocked by required conditions
Build and Release / Publish release (push) Blocked by required conditions
134 lines
4.8 KiB
JavaScript
134 lines
4.8 KiB
JavaScript
window.generateDiff = function (text1, text2, divDiff, divLegend) {
|
||
let wikEdDiff = new WikEdDiff();
|
||
let targetDiv = document.getElementById(divDiff)
|
||
targetDiv.innerHTML = wikEdDiff.diff(text1, text2);
|
||
targetDiv.classList.add('mud-typography-body1', 'improvedDiff');
|
||
|
||
let legend = document.getElementById(divLegend);
|
||
legend.innerHTML = `
|
||
<div class="legend mt-2">
|
||
<h3>Legend</h3>
|
||
<ul class="mt-2">
|
||
<li><span class="wikEdDiffMarkRight" title="Moved block" id="wikEdDiffMark999" onmouseover="wikEdDiffBlockHandler(undefined, this, 'mouseover');"></span> Original block position</li>
|
||
<li><span title="+" class="wikEdDiffInsert">Inserted<span class="wikEdDiffSpace"><span class="wikEdDiffSpaceSymbol"></span> </span>text<span class="wikEdDiffNewline"> </span></span></li>
|
||
<li><span title="−" class="wikEdDiffDelete">Deleted<span class="wikEdDiffSpace"><span class="wikEdDiffSpaceSymbol"></span> </span>text<span class="wikEdDiffNewline"> </span></span></li>
|
||
<li><span class="wikEdDiffBlockLeft" title="◀" id="wikEdDiffBlock999" onmouseover="wikEdDiffBlockHandler(undefined, this, 'mouseover');">Moved<span class="wikEdDiffSpace"><span class="wikEdDiffSpaceSymbol"></span> </span>block<span class="wikEdDiffNewline"> </span></span></li>
|
||
</ul>
|
||
</div>
|
||
`;
|
||
}
|
||
|
||
window.clearDiv = function (divName) {
|
||
let targetDiv = document.getElementById(divName);
|
||
targetDiv.innerHTML = '';
|
||
}
|
||
|
||
window.scrollToBottom = function(element) {
|
||
element.scrollIntoView({ behavior: 'smooth', block: 'end', inline: 'nearest' });
|
||
}
|
||
|
||
window.formatChatInputMarkdown = function (inputId, formatType) {
|
||
let input = document.getElementById(inputId)
|
||
if (input && input.tagName !== 'TEXTAREA' && input.tagName !== 'INPUT')
|
||
input = input.querySelector('textarea, input')
|
||
|
||
if (!input)
|
||
return ''
|
||
|
||
input.focus()
|
||
|
||
const value = input.value ?? ''
|
||
const start = input.selectionStart ?? value.length
|
||
const end = input.selectionEnd ?? value.length
|
||
const hasSelection = end > start
|
||
const selectedText = value.substring(start, end)
|
||
|
||
let insertedText = ''
|
||
let selectionStart = start
|
||
let selectionEnd = start
|
||
|
||
switch (formatType) {
|
||
case 'bold': {
|
||
const text = hasSelection ? selectedText : ''
|
||
insertedText = `**${text}**`
|
||
selectionStart = start + 2
|
||
selectionEnd = selectionStart + text.length
|
||
break
|
||
}
|
||
|
||
case 'italic': {
|
||
const text = hasSelection ? selectedText : ''
|
||
insertedText = `*${text}*`
|
||
selectionStart = start + 1
|
||
selectionEnd = selectionStart + text.length
|
||
break
|
||
}
|
||
|
||
case 'heading': {
|
||
if (hasSelection) {
|
||
insertedText = selectedText
|
||
.split('\n')
|
||
.map(line => line.startsWith('# ') ? line : `# ${line}`)
|
||
.join('\n')
|
||
|
||
selectionStart = start
|
||
selectionEnd = start + insertedText.length
|
||
} else {
|
||
const text = ''
|
||
insertedText = `# ${text}`
|
||
selectionStart = start + 2
|
||
selectionEnd = selectionStart + text.length
|
||
}
|
||
|
||
break
|
||
}
|
||
|
||
case 'bullet_list': {
|
||
if (hasSelection) {
|
||
insertedText = selectedText
|
||
.split('\n')
|
||
.map(line => line.startsWith('- ') ? line : `- ${line}`)
|
||
.join('\n')
|
||
|
||
selectionStart = start
|
||
selectionEnd = start + insertedText.length
|
||
} else {
|
||
insertedText = '- '
|
||
selectionStart = start + 2
|
||
selectionEnd = start + insertedText.length
|
||
}
|
||
|
||
break
|
||
}
|
||
|
||
case 'code':
|
||
default: {
|
||
if (hasSelection) {
|
||
if (selectedText.includes('\n')) {
|
||
insertedText = `\`\`\`\n${selectedText}\n\`\`\``
|
||
selectionStart = start + 4
|
||
selectionEnd = selectionStart + selectedText.length
|
||
} else {
|
||
insertedText = `\`${selectedText}\``
|
||
selectionStart = start + 1
|
||
selectionEnd = selectionStart + selectedText.length
|
||
}
|
||
} else {
|
||
const text = ''
|
||
insertedText = `\`${text}\``
|
||
selectionStart = start + 1
|
||
selectionEnd = selectionStart + text.length
|
||
}
|
||
|
||
break
|
||
}
|
||
}
|
||
|
||
const nextValue = value.slice(0, start) + insertedText + value.slice(end)
|
||
input.value = nextValue
|
||
input.setSelectionRange(selectionStart, selectionEnd)
|
||
input.dispatchEvent(new Event('input', { bubbles: true }))
|
||
|
||
return nextValue
|
||
}
|