FileCard.js 3.3 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071
  1. const html = require('yo-yo')
  2. const getFileTypeIcon = require('./getFileTypeIcon')
  3. const { checkIcon } = require('./icons')
  4. module.exports = function fileCard (props) {
  5. const file = props.fileCardFor ? props.files[props.fileCardFor] : false
  6. const meta = {}
  7. const tempStoreMetaOrSubmit = (ev) => {
  8. if (ev.keyCode === 13) {
  9. props.done(meta, file.id)
  10. }
  11. const value = ev.target.value
  12. const name = ev.target.dataset.name
  13. meta[name] = value
  14. }
  15. function renderMetaFields (file) {
  16. const metaFields = props.metaFields || []
  17. return metaFields.map((field) => {
  18. return html`<fieldset class="UppyDashboardFileCard-fieldset">
  19. <label class="UppyDashboardFileCard-label">${field.name}</label>
  20. <input class="UppyDashboardFileCard-input"
  21. type="text"
  22. data-name="${field.id}"
  23. value="${file.meta[field.id]}"
  24. placeholder="${field.placeholder || ''}"
  25. onkeyup=${tempStoreMetaOrSubmit} /></fieldset>`
  26. })
  27. }
  28. return html`<div class="UppyDashboardFileCard" aria-hidden="${!props.fileCardFor}">
  29. ${props.fileCardFor
  30. ? html`
  31. <div style="width: 100%; height: 100%;">
  32. <div class="UppyDashboardContent-bar">
  33. <h2 class="UppyDashboardContent-title">Editing <span class="UppyDashboardContent-titleFile">${file.meta ? file.meta.name : file.name}</span></h2>
  34. <button class="UppyDashboardContent-back" type="button" title="Finish editing file"
  35. onclick=${() => props.done(meta, file.id)}>Done</button>
  36. </div>
  37. <div class="UppyDashboardFileCard-inner">
  38. <div class="UppyDashboardFileCard-preview" style="background-color: ${getFileTypeIcon(file.type).color}">
  39. ${file.preview
  40. ? html`<img alt="${file.name}" src="${file.preview}">`
  41. : html`<div class="UppyDashboardItem-previewIconWrap">
  42. <span class="UppyDashboardItem-previewIcon" style="color: ${getFileTypeIcon(file.type).color}">${getFileTypeIcon(file.type).icon}</span>
  43. <svg class="UppyDashboardItem-previewIconBg" width="72" height="93" viewBox="0 0 72 93"><g><path d="M24.08 5h38.922A2.997 2.997 0 0 1 66 8.003v74.994A2.997 2.997 0 0 1 63.004 86H8.996A2.998 2.998 0 0 1 6 83.01V22.234L24.08 5z" fill="#FFF"/><path d="M24 5L6 22.248h15.007A2.995 2.995 0 0 0 24 19.244V5z" fill="#E4E4E4"/></g></svg>
  44. </div>`
  45. }
  46. </div>
  47. <div class="UppyDashboardFileCard-info">
  48. <fieldset class="UppyDashboardFileCard-fieldset">
  49. <label class="UppyDashboardFileCard-label">Name</label>
  50. <input class="UppyDashboardFileCard-input" data-name="name" type="text" value="${file.meta.name}"
  51. onkeyup=${tempStoreMetaOrSubmit} />
  52. </fieldset>
  53. ${renderMetaFields(file)}
  54. </div>
  55. </div>
  56. <div class="UppyDashboard-actions">
  57. <button class="UppyButton--circular UppyButton--blue UppyDashboardFileCard-done"
  58. type="button"
  59. title="Finish editing file"
  60. onclick=${() => props.done(meta, file.id)}>${checkIcon()}</button>
  61. </div>
  62. </div>`
  63. : null
  64. }
  65. </div>`
  66. }