const html = require('choo/html'); const assets = require('../../common/assets'); function timeLeft(milliseconds, state) { const minutes = Math.floor(milliseconds / 1000 / 60); const hours = Math.floor(minutes / 60); if (hours >= 1) { return state.translate('expiresHoursMinutes', { hours, minutes: minutes % 60 }); } else if (hours === 0) { if (minutes === 0) { return state.translate('expiresMinutes', { minutes: '< 1' }); } return state.translate('expiresMinutes', { minutes }); } return null; } module.exports = function(file, state, emit) { const ttl = file.expiresAt - Date.now(); const remainingTime = timeLeft(ttl, state) || state.translate('linkExpiredAlt'); const downloadLimit = file.dlimit || 1; const totalDownloads = file.dtotal || 0; const row = html` ${file.name} ${remainingTime} ${totalDownloads} / ${downloadLimit} `; function copyClick(e) { emit('copy', { url: file.url, location: 'upload-list' }); const icon = e.target; const text = e.target.nextSibling; icon.hidden = true; text.hidden = false; setTimeout(() => { icon.hidden = false; text.hidden = true; }, 500); } function showPopup() { const tr = document.getElementById(file.id); const popup = tr.querySelector('.popuptext'); popup.classList.add('show'); popup.focus(); } function cancel(e) { e.stopPropagation(); const tr = document.getElementById(file.id); const popup = tr.querySelector('.popuptext'); popup.classList.remove('show'); } function deleteFile() { emit('delete', { file, location: 'upload-list' }); emit('render'); } return row; };