首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何在KeystoneJS 6中播种/上传图像?

如何在KeystoneJS 6中播种/上传图像?
EN

Stack Overflow用户
提问于 2022-01-09 20:57:20
回答 1查看 509关注 0票数 1

使用示例这里,如果我随后向Post添加了一个图像字段:

代码语言:javascript
复制
// schema.ts
import { list } from '@keystone-6/core';
import { select, relationship, text, timestamp } from '@keystone-6/core/fields';

export const lists = {
  Post: list({
    fields: {
       featureImage: image(),
    }),
    /* ... */
  },
  /* ... */
});

然后如何调整seed/index.ts文件以从本地驱动器上传图像?

代码语言:javascript
复制
// seed/index.ts
await context.query.Post.createOne({
    data: {
        ...postData,
        featureImage: { /* ??? What goes here ??? */ }
    },
    query: 'id',
});

否则,我如何以编程方式添加图像,以便keystonejs知道它们?

EN

回答 1

Stack Overflow用户

发布于 2022-06-20 15:56:04

从这里得到的https://github.com/keystonejs/keystone-discussions-archive/discussions/54

代码语言:javascript
复制
// prepareToUpload.ts
import mime from 'mime'
import fs from 'fs'
import path from 'path'
import { Upload } from 'graphql-upload'

export const prepareToUpload = (filePath: string) => {
  const filename = path.basename(filePath)

  const createReadStream = () => fs.createReadStream(filePath)
  // @ts-ignore
  const mimetype = mime.getType(filePath)
  const encoding = 'utf-8'

  const image = {
    createReadStream,
    filename,
    mimetype,
    encoding,
  }

  const upload = new Upload()
  // @ts-ignore
  upload.resolve(image)

  return upload
}
代码语言:javascript
复制
  await context.query.Film.createOne({
      data: {
        name: filmData.name,
        imagePoster: {
          // imagePoster MUST by a object with `upload` field
          upload: prepareToUpload(__dirname + '/folder_to_local_file/here.jpg'),
        },
      },
      query: 'id',
    })
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/70645438

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档