2023-04-05 13:42:20 +00:00
|
|
|
function getDeviceDetails (device) {
|
2023-03-07 20:36:31 +00:00
|
|
|
return device.productName || `Unknown device ${device.deviceId}`
|
2022-11-22 21:50:32 +00:00
|
|
|
}
|
|
|
|
|
2023-04-05 13:42:20 +00:00
|
|
|
async function testIt () {
|
2022-11-22 21:50:32 +00:00
|
|
|
const noDevicesFoundMsg = 'No devices found'
|
|
|
|
const grantedDevices = await navigator.usb.getDevices()
|
|
|
|
let grantedDeviceList = ''
|
2023-02-01 11:59:16 +00:00
|
|
|
if (grantedDevices.length > 0) {
|
2022-11-22 21:50:32 +00:00
|
|
|
grantedDevices.forEach(device => {
|
|
|
|
grantedDeviceList += `<hr>${getDeviceDetails(device)}</hr>`
|
2023-02-01 11:59:16 +00:00
|
|
|
})
|
2022-11-22 21:50:32 +00:00
|
|
|
} else {
|
|
|
|
grantedDeviceList = noDevicesFoundMsg
|
|
|
|
}
|
|
|
|
document.getElementById('granted-devices').innerHTML = grantedDeviceList
|
|
|
|
|
|
|
|
grantedDeviceList = ''
|
|
|
|
try {
|
|
|
|
const grantedDevice = await navigator.usb.requestDevice({
|
|
|
|
filters: []
|
|
|
|
})
|
|
|
|
grantedDeviceList += `<hr>${getDeviceDetails(device)}</hr>`
|
|
|
|
} catch (ex) {
|
|
|
|
if (ex.name === 'NotFoundError') {
|
|
|
|
grantedDeviceList = noDevicesFoundMsg
|
|
|
|
}
|
|
|
|
}
|
|
|
|
document.getElementById('granted-devices2').innerHTML = grantedDeviceList
|
|
|
|
}
|
|
|
|
|
2023-04-05 13:42:20 +00:00
|
|
|
document.getElementById('clickme').addEventListener('click', testIt)
|