活页夹中的Vaadin上传组件,例如CRUD编辑器

2022-03-17 00:00:00 spring java spring-boot vaadin vaadin-flow

我有一个Crud(来自Vaadin Pro),我想使用BinderCrudEditor中的Upload组件。Upload组件没有存储值(或者更确切地说,缺少HasValue接口),所以我不能使用绑定器。是否有办法以某种方式将其包括在内,而无需在Crud中创建用于文件上载的额外按钮,然后使用侦听器?


解决方案

最简单的方法可能是使用Vaadin框架的CustomField。您需要实际决定的是返回类型。此外,根据您选择返回类型的方式,设置字段的值也有点麻烦。因此,请更多地将其作为伪代码示例。

public class UploadField extends CustomField<InputStream> {

    InputStream is;
    FileBuffer buffer = new FileBuffer();
    
    public UploadField() {
        Upload upload = new Upload(buffer);
        upload.setAcceptedFileTypes("image/jpeg");
        upload.setMaxFiles(1);
        upload.addSucceededListener(event -> {
            is = buffer.getInputStream();
        });

        add(upload);            
    }
    
    public String getFileName() {
        return buffer.getFileName();
    }

    @Override
    protected InputStream generateModelValue() {
        return is;
    }

    @Override
    protected void setPresentationValue(InputStream newPresentationValue) {
    }
    
}

相关文章