dddcc09185
* docs: add fiddle example Co-authored-by: Alice Zhao <alice@makenotion.com> * docs: add tutorial guide Co-authored-by: Alice Zhao <alice@makenotion.com> * refactor: PR review comments Co-authored-by: Alice Zhao <alice@makenotion.com> * refactor: add eof Co-authored-by: Alice Zhao <alice@makenotion.com> * refactor: render navigation history and make demo better. Co-authored-by: Alice Zhao <alice@makenotion.com> * refactor: fix broken links Co-authored-by: Alice Zhao <alice@makenotion.com> * refactor: add eof newline Co-authored-by: Alice Zhao <alice@makenotion.com> * docs: review feedback :) Co-authored-by: Alice Zhao <alice@makenotion.com> * chore: lint add space around list Co-authored-by: Alice Zhao <alice@makenotion.com> * doc: transformURL Co-authored-by: Alice Zhao <alice@makenotion.com> --------- Co-authored-by: trop[bot] <37223003+trop[bot]@users.noreply.github.com> Co-authored-by: Alice Zhao <alice@makenotion.com>
84 lines
2.5 KiB
JavaScript
84 lines
2.5 KiB
JavaScript
const backBtn = document.getElementById('backBtn')
|
|
const forwardBtn = document.getElementById('forwardBtn')
|
|
const backHistoryBtn = document.getElementById('backHistoryBtn')
|
|
const forwardHistoryBtn = document.getElementById('forwardHistoryBtn')
|
|
const urlInput = document.getElementById('urlInput')
|
|
const goBtn = document.getElementById('goBtn')
|
|
const historyPanel = document.getElementById('historyPanel')
|
|
|
|
async function updateButtons () {
|
|
const canGoBack = await window.electronAPI.canGoBack()
|
|
const canGoForward = await window.electronAPI.canGoForward()
|
|
backBtn.disabled = !canGoBack
|
|
backHistoryBtn.disabled = !canGoBack
|
|
|
|
forwardBtn.disabled = !canGoForward
|
|
forwardHistoryBtn.disabled = !canGoForward
|
|
}
|
|
|
|
async function updateURL () {
|
|
urlInput.value = await window.electronAPI.getCurrentURL()
|
|
}
|
|
|
|
function transformURL (url) {
|
|
if (!url.startsWith('http://') && !url.startsWith('https://')) {
|
|
const updatedUrl = 'https://' + url
|
|
return updatedUrl
|
|
}
|
|
return url
|
|
}
|
|
|
|
async function navigate (url) {
|
|
const urlInput = transformURL(url)
|
|
|
|
await window.electronAPI.loadURL(urlInput)
|
|
}
|
|
|
|
async function showHistory (forward = false) {
|
|
const history = await window.electronAPI.getHistory()
|
|
const currentIndex = history.findIndex(entry => entry.url === transformURL(urlInput.value))
|
|
|
|
if (!currentIndex) {
|
|
return
|
|
}
|
|
|
|
const relevantHistory = forward
|
|
? history.slice(currentIndex + 1)
|
|
: history.slice(0, currentIndex).reverse()
|
|
|
|
historyPanel.innerHTML = ''
|
|
relevantHistory.forEach(entry => {
|
|
const div = document.createElement('div')
|
|
div.textContent = `Title: ${entry.title}, URL: ${entry.url}`
|
|
div.onclick = () => navigate(entry.url)
|
|
historyPanel.appendChild(div)
|
|
})
|
|
|
|
historyPanel.style.display = 'block'
|
|
}
|
|
|
|
backBtn.addEventListener('click', () => window.electronAPI.goBack())
|
|
forwardBtn.addEventListener('click', () => window.electronAPI.goForward())
|
|
backHistoryBtn.addEventListener('click', () => showHistory(false))
|
|
forwardHistoryBtn.addEventListener('click', () => showHistory(true))
|
|
goBtn.addEventListener('click', () => navigate(urlInput.value))
|
|
|
|
urlInput.addEventListener('keypress', (e) => {
|
|
if (e.key === 'Enter') {
|
|
navigate(urlInput.value)
|
|
}
|
|
})
|
|
|
|
document.addEventListener('click', (e) => {
|
|
if (e.target !== historyPanel && !historyPanel.contains(e.target) &&
|
|
e.target !== backHistoryBtn && e.target !== forwardHistoryBtn) {
|
|
historyPanel.style.display = 'none'
|
|
}
|
|
})
|
|
|
|
window.electronAPI.onNavigationUpdate(() => {
|
|
updateButtons()
|
|
updateURL()
|
|
})
|
|
|
|
updateButtons()
|