mirror of
https://github.com/lana-k/sqliteviz.git
synced 2025-12-06 18:18:53 +08:00
add tests for clipboard lib
This commit is contained in:
@@ -1,27 +1,6 @@
|
|||||||
import Lib from 'plotly.js/src/lib'
|
import Lib from 'plotly.js/src/lib'
|
||||||
import dataUrlToBlob from 'dataurl-to-blob'
|
import dataUrlToBlob from 'dataurl-to-blob'
|
||||||
|
|
||||||
async function _copyBlob (blob) {
|
|
||||||
await navigator.clipboard.write([
|
|
||||||
new ClipboardItem({ // eslint-disable-line no-undef
|
|
||||||
[blob.type]: blob
|
|
||||||
})
|
|
||||||
])
|
|
||||||
}
|
|
||||||
|
|
||||||
async function _copyFromDataUrl (url) {
|
|
||||||
const blob = dataUrlToBlob(url)
|
|
||||||
await _copyBlob(blob)
|
|
||||||
Lib.notifier('Image copied to clipboard successfully', 'long')
|
|
||||||
}
|
|
||||||
|
|
||||||
async function _copyCanvas (canvas) {
|
|
||||||
canvas.toBlob(async (blob) => {
|
|
||||||
await _copyBlob(blob)
|
|
||||||
Lib.notifier('Image copied to clipboard successfully', 'long')
|
|
||||||
}, 'image/png', 1)
|
|
||||||
}
|
|
||||||
|
|
||||||
export default {
|
export default {
|
||||||
async copyCsv (str) {
|
async copyCsv (str) {
|
||||||
await navigator.clipboard.writeText(str)
|
await navigator.clipboard.writeText(str)
|
||||||
@@ -30,9 +9,30 @@ export default {
|
|||||||
|
|
||||||
async copyImage (source) {
|
async copyImage (source) {
|
||||||
if (source instanceof HTMLCanvasElement) {
|
if (source instanceof HTMLCanvasElement) {
|
||||||
return _copyCanvas(source)
|
return this._copyCanvas(source)
|
||||||
} else {
|
} else {
|
||||||
return _copyFromDataUrl(source)
|
return this._copyFromDataUrl(source)
|
||||||
}
|
}
|
||||||
|
},
|
||||||
|
|
||||||
|
async _copyBlob (blob) {
|
||||||
|
await navigator.clipboard.write([
|
||||||
|
new ClipboardItem({ // eslint-disable-line no-undef
|
||||||
|
[blob.type]: blob
|
||||||
|
})
|
||||||
|
])
|
||||||
|
},
|
||||||
|
|
||||||
|
async _copyFromDataUrl (url) {
|
||||||
|
const blob = dataUrlToBlob(url)
|
||||||
|
await this._copyBlob(blob)
|
||||||
|
Lib.notifier('Image copied to clipboard successfully', 'long')
|
||||||
|
},
|
||||||
|
|
||||||
|
async _copyCanvas (canvas) {
|
||||||
|
canvas.toBlob(async (blob) => {
|
||||||
|
await this._copyBlob(blob)
|
||||||
|
Lib.notifier('Image copied to clipboard successfully', 'long')
|
||||||
|
}, 'image/png', 1)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
30
tests/lib/utils/clipboardIo.spec.js
Normal file
30
tests/lib/utils/clipboardIo.spec.js
Normal file
@@ -0,0 +1,30 @@
|
|||||||
|
import { expect } from 'chai'
|
||||||
|
import cIo from '@/lib/utils/clipboardIo'
|
||||||
|
import sinon from 'sinon'
|
||||||
|
|
||||||
|
describe('clipboardIo.js', async () => {
|
||||||
|
afterEach(() => {
|
||||||
|
sinon.restore()
|
||||||
|
})
|
||||||
|
|
||||||
|
it('copyCsv', async () => {
|
||||||
|
sinon.stub(navigator.clipboard, 'writeText').resolves(true)
|
||||||
|
await cIo.copyCsv('id\tname\r\n1\t2')
|
||||||
|
expect(navigator.clipboard.writeText.calledOnceWith('id\tname\r\n1\t2'))
|
||||||
|
})
|
||||||
|
|
||||||
|
it('copyImage for canvas calls _copyCanvas', async () => {
|
||||||
|
sinon.stub(cIo, '_copyCanvas').resolves(true)
|
||||||
|
const canvas = document.createElement('canvas')
|
||||||
|
|
||||||
|
await cIo.copyImage(canvas)
|
||||||
|
expect(cIo._copyCanvas.calledOnceWith(canvas))
|
||||||
|
})
|
||||||
|
|
||||||
|
it('copyImage for dataUrl calls _copyFromDataUrl', async () => {
|
||||||
|
sinon.stub(cIo, '_copyFromDataUrl').resolves(true)
|
||||||
|
const url = document.createElement('canvas').toDataURL()
|
||||||
|
await cIo.copyImage(url)
|
||||||
|
expect(cIo._copyFromDataUrl.calledOnceWith(url))
|
||||||
|
})
|
||||||
|
})
|
||||||
Reference in New Issue
Block a user