choose-file.js 1.3 KB
Newer Older
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59
import { fileToUrl } from 'uni-platform/helpers/file'
import _createInput from './create_input'

const {
  invokeCallbackHandler: invoke
} = UniServiceJSBridge

let fileInput = null

export function chooseFile ({
  // sizeType,
  count,
  sourceType,
  type,
  extension
}, callbackId) {
  // TODO handle sizeType 尝试通过 canvas 压缩

  if (fileInput) {
    document.body.removeChild(fileInput)
    fileInput = null
  }

  fileInput = _createInput({
    count,
    sourceType,
    type,
    extension
  })
  document.body.appendChild(fileInput)

  fileInput.addEventListener('change', function (event) {
    const tempFiles = []
    const fileCount = event.target.files.length
    for (let i = 0; i < fileCount; i++) {
      const file = event.target.files[i]
      let filePath
      Object.defineProperty(file, 'path', {
        get () {
          filePath = filePath || fileToUrl(file)
          return filePath
        }
      })
      if (i < count) tempFiles.push(file)
    }
    const res = {
      errMsg: 'chooseFile:ok',
      get tempFilePaths () {
        return tempFiles.map(({ path }) => path)
      },
      tempFiles: tempFiles
    }
    invoke(callbackId, res)

    // TODO 用户取消选择时,触发 fail,目前尚未找到合适的方法。
  })

  fileInput.click()
}