import { $ } from 'mdui/jq'
import 'pinch-zoom-element'
import { snackbar } from "../snackbar.ts";
function openImageViewer(src: string) {
$('#image-viewer-dialog-inner').empty()
const e = new Image()
e.onload = () => ($('#image-viewer-dialog-inner').get(0) as any).scaleTo(0.1, {
// Transform origin. Can be a number, or string percent, eg "50%"
originX: '50%',
originY: '50%',
// Should the transform origin be relative to the container, or content?
relativeTo: 'container',
})
e.src = src
$('#image-viewer-dialog-inner').append(e)
$('#image-viewer-dialog').attr('open', 'true')
}
customElements.define('chat-image', class extends HTMLElement {
constructor() {
super()
}
connectedCallback() {
const e = new Image()
e.style.maxWidth = "100%"
e.style.maxHeight = "90%"
e.style.marginTop = '5px'
e.style.marginBottom = '5px'
e.style.borderRadius = "var(--mdui-shape-corner-medium)"
e.alt = $(this).attr('alt') || ""
e.onerror = () => {
const src = $(this).attr('src')
$(this).html(``)
$(this).attr('alt', '無法加載圖像')
$(this).on('click', () => {
snackbar({
message: `圖片 (${src}) 無法加載!`,
placement: 'top'
})
})
}
e.src = $(this).attr('src') as string
e.onclick = () => {
openImageViewer($(this).attr('src') as string)
}
this.appendChild(e)
}
})
document.body.appendChild(new DOMParser().parseFromString(`
`, 'text/html').body.firstChild as Node)