mirror of
https://github.com/easydiffusion/easydiffusion.git
synced 2025-01-03 21:09:12 +01:00
Merge pull request #474 from JeLuF/beta
Add paste button next to copy button
This commit is contained in:
commit
14bbd7b7ae
@ -887,6 +887,10 @@ input::file-selector-button {
|
|||||||
margin-bottom: 15px;
|
margin-bottom: 15px;
|
||||||
box-shadow: 0 4px 8px 0 rgba(0, 0, 0, 0.15), 0 6px 20px 0 rgba(0, 0, 0, 0.15);
|
box-shadow: 0 4px 8px 0 rgba(0, 0, 0, 0.15), 0 6px 20px 0 rgba(0, 0, 0, 0.15);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
i.active {
|
||||||
|
background: var(--accent-color);
|
||||||
|
}
|
||||||
#system-info .value {
|
#system-info .value {
|
||||||
text-align: left;
|
text-align: left;
|
||||||
}
|
}
|
||||||
|
@ -396,16 +396,44 @@ const TASK_REQ_NO_EXPORT = [
|
|||||||
"save_to_disk_path"
|
"save_to_disk_path"
|
||||||
]
|
]
|
||||||
|
|
||||||
// Adds a copy icon if the browser grants permission to write to clipboard.
|
// Retrieve clipboard content and try to parse it
|
||||||
|
async function pasteFromClipboard() {
|
||||||
|
//const text = await navigator.clipboard.readText()
|
||||||
|
let text = await navigator.clipboard.readText();
|
||||||
|
text=text.trim();
|
||||||
|
if (text.startsWith('{') && text.endsWith('}')) {
|
||||||
|
try {
|
||||||
|
const task = JSON.parse(text)
|
||||||
|
restoreTaskToUI(task)
|
||||||
|
} catch (e) {
|
||||||
|
console.warn(`Clipboard JSON couldn't be parsed.`, e)
|
||||||
|
}
|
||||||
|
return
|
||||||
|
}
|
||||||
|
// Normal txt file.
|
||||||
|
const task = parseTaskFromText(text)
|
||||||
|
if (task) {
|
||||||
|
restoreTaskToUI(task)
|
||||||
|
} else {
|
||||||
|
console.warn(`Clipboard content - File couldn't be parsed.`)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Adds a copy and a paste icon if the browser grants permission to write to clipboard.
|
||||||
function checkWriteToClipboardPermission (result) {
|
function checkWriteToClipboardPermission (result) {
|
||||||
if (result.state == "granted" || result.state == "prompt") {
|
if (result.state == "granted" || result.state == "prompt") {
|
||||||
const resetSettings = document.getElementById('reset-image-settings')
|
const resetSettings = document.getElementById('reset-image-settings')
|
||||||
|
|
||||||
|
// COPY ICON
|
||||||
const copyIcon = document.createElement('i')
|
const copyIcon = document.createElement('i')
|
||||||
// copyIcon.id = 'copy-image-settings'
|
|
||||||
copyIcon.className = 'fa-solid fa-clipboard section-button'
|
copyIcon.className = 'fa-solid fa-clipboard section-button'
|
||||||
copyIcon.innerHTML = `<span class="simple-tooltip right">Copy Image Settings</span>`
|
copyIcon.innerHTML = `<span class="simple-tooltip right">Copy Image Settings</span>`
|
||||||
copyIcon.addEventListener('click', (event) => {
|
copyIcon.addEventListener('click', (event) => {
|
||||||
event.stopPropagation()
|
event.stopPropagation()
|
||||||
|
// Add css class 'active'
|
||||||
|
copyIcon.classList.add('active')
|
||||||
|
// In 1000 ms remove the 'active' class
|
||||||
|
asyncDelay(1000).then(() => copyIcon.classList.remove('active'))
|
||||||
const uiState = readUI()
|
const uiState = readUI()
|
||||||
TASK_REQ_NO_EXPORT.forEach((key) => delete uiState.reqBody[key])
|
TASK_REQ_NO_EXPORT.forEach((key) => delete uiState.reqBody[key])
|
||||||
if (uiState.reqBody.init_image && !IMAGE_REGEX.test(uiState.reqBody.init_image)) {
|
if (uiState.reqBody.init_image && !IMAGE_REGEX.test(uiState.reqBody.init_image)) {
|
||||||
@ -415,8 +443,24 @@ function checkWriteToClipboardPermission (result) {
|
|||||||
navigator.clipboard.writeText(JSON.stringify(uiState, undefined, 4))
|
navigator.clipboard.writeText(JSON.stringify(uiState, undefined, 4))
|
||||||
})
|
})
|
||||||
resetSettings.parentNode.insertBefore(copyIcon, resetSettings)
|
resetSettings.parentNode.insertBefore(copyIcon, resetSettings)
|
||||||
|
|
||||||
|
// PASTE ICON
|
||||||
|
const pasteIcon = document.createElement('i')
|
||||||
|
pasteIcon.className = 'fa-solid fa-paste section-button'
|
||||||
|
pasteIcon.innerHTML = `<span class="simple-tooltip right">Paste Image Settings</span>`
|
||||||
|
pasteIcon.addEventListener('click', (event) => {
|
||||||
|
event.stopPropagation()
|
||||||
|
// Add css class 'active'
|
||||||
|
pasteIcon.classList.add('active')
|
||||||
|
// In 1000 ms remove the 'active' class
|
||||||
|
asyncDelay(1000).then(() => pasteIcon.classList.remove('active'))
|
||||||
|
pasteFromClipboard()
|
||||||
|
})
|
||||||
|
resetSettings.parentNode.insertBefore(pasteIcon, resetSettings)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Determine which access we have to the clipboard. Clipboard access is only available on localhost or via TLS.
|
||||||
navigator.permissions.query({ name: "clipboard-write" }).then(checkWriteToClipboardPermission, (e) => {
|
navigator.permissions.query({ name: "clipboard-write" }).then(checkWriteToClipboardPermission, (e) => {
|
||||||
if (e instanceof TypeError && typeof navigator?.clipboard?.writeText === 'function') {
|
if (e instanceof TypeError && typeof navigator?.clipboard?.writeText === 'function') {
|
||||||
// Fix for firefox https://bugzilla.mozilla.org/show_bug.cgi?id=1560373
|
// Fix for firefox https://bugzilla.mozilla.org/show_bug.cgi?id=1560373
|
||||||
|
Loading…
Reference in New Issue
Block a user