Project

General

Profile

Download (12.2 KB) Statistics
| Branch: | Tag: | Revision:
1
/**
2
* Copyright (C) 2018 EDIT
3
* European Distributed Institute of Taxonomy
4
* http://www.e-taxonomy.eu
5
*
6
* The contents of this file are subject to the Mozilla Public License Version 1.1
7
* See LICENSE.TXT at the top of this package for the full license terms.
8
*/
9
package eu.etaxonomy.cdm.vaadin.view.name;
10

    
11
import java.util.ArrayList;
12
import java.util.Arrays;
13
import java.util.EnumSet;
14
import java.util.HashSet;
15
import java.util.List;
16
import java.util.UUID;
17

    
18
import org.springframework.beans.factory.annotation.Autowired;
19
import org.springframework.context.annotation.Scope;
20
import org.vaadin.spring.events.annotation.EventBusListenerMethod;
21

    
22
import com.vaadin.spring.annotation.SpringComponent;
23

    
24
import eu.etaxonomy.cdm.api.service.DeleteResult;
25
import eu.etaxonomy.cdm.api.service.IService;
26
import eu.etaxonomy.cdm.api.service.dto.RegistrationDTO;
27
import eu.etaxonomy.cdm.api.service.name.TypeDesignationSetManager.TypeDesignationWorkingSet;
28
import eu.etaxonomy.cdm.api.service.registration.IRegistrationWorkingSetService;
29
import eu.etaxonomy.cdm.format.ReferenceEllypsisFormatter.LabelType;
30
import eu.etaxonomy.cdm.model.common.Annotation;
31
import eu.etaxonomy.cdm.model.name.NameTypeDesignation;
32
import eu.etaxonomy.cdm.model.name.NameTypeDesignationStatus;
33
import eu.etaxonomy.cdm.model.name.TaxonName;
34
import eu.etaxonomy.cdm.model.reference.Reference;
35
import eu.etaxonomy.cdm.persistence.hibernate.permission.CRUD;
36
import eu.etaxonomy.cdm.service.CdmFilterablePagingProvider;
37
import eu.etaxonomy.cdm.service.CdmStore;
38
import eu.etaxonomy.cdm.service.UserHelperAccess;
39
import eu.etaxonomy.cdm.vaadin.event.EditorActionTypeFilter;
40
import eu.etaxonomy.cdm.vaadin.event.EntityChangeEvent;
41
import eu.etaxonomy.cdm.vaadin.event.EntityChangeEvent.Type;
42
import eu.etaxonomy.cdm.vaadin.event.TaxonNameEditorAction;
43
import eu.etaxonomy.cdm.vaadin.event.ToOneRelatedEntityButtonUpdater;
44
import eu.etaxonomy.cdm.vaadin.event.ToOneRelatedEntityReloader;
45
import eu.etaxonomy.cdm.vaadin.ui.config.TaxonNamePopupEditorConfig;
46
import eu.etaxonomy.cdm.vaadin.util.ReferenceEllypsisCaptionGenerator;
47
import eu.etaxonomy.vaadin.mvp.AbstractCdmEditorPresenter;
48
import eu.etaxonomy.vaadin.mvp.AbstractView;
49
import eu.etaxonomy.vaadin.mvp.BeanInstantiator;
50
import eu.etaxonomy.vaadin.mvp.BoundField;
51
import eu.etaxonomy.vaadin.ui.view.PopupView;
52

    
53
/**
54
 * @author a.kohlbecker
55
 * @since Jan 26, 2018
56
 *
57
 */
58
@SpringComponent
59
@Scope("prototype")
60
public class NameTypeDesignationPresenter
61
        extends AbstractCdmEditorPresenter<NameTypeDesignation, NameTypeDesignationEditorView> {
62

    
63
    @Autowired
64
    private IRegistrationWorkingSetService registrationWorkingSetService;
65

    
66
    HashSet<TaxonName> typifiedNamesAsLoaded;
67

    
68
    private TaxonName typifiedNameInContext;
69

    
70
    protected static BeanInstantiator<NameTypeDesignation> defaultBeanInstantiator = new BeanInstantiator<NameTypeDesignation>() {
71

    
72
        @Override
73
        public NameTypeDesignation createNewBean() {
74
            return NameTypeDesignation.NewInstance();
75
        }
76
    };
77

    
78

    
79
    @Override
80
    protected BeanInstantiator<NameTypeDesignation> defaultBeanInstantiator(){
81
       return defaultBeanInstantiator;
82
    }
83

    
84
    /**
85
     * {@inheritDoc}
86
     */
87
    @Override
88
    protected NameTypeDesignation loadBeanById(Object identifier) {
89
        if(identifier instanceof Integer || identifier == null){
90
            return super.loadBeanById(identifier);
91
//        } else if(identifier instanceof TypedEntityReference && ((TypedEntityReference)identifier).getType().equals(TaxonName.class)) {
92
//            typifiedNameInContext = getRepo().getNameService().find(((TypedEntityReference)identifier).getUuid());
93
//            bean = super.loadBeanById(null);
94
        } else {
95
            TypeDesignationWorkingsetEditorIdSet idset = (TypeDesignationWorkingsetEditorIdSet)identifier;
96
            RegistrationDTO regDTO = registrationWorkingSetService.loadDtoByUuid(idset.registrationUuid);
97
            typifiedNameInContext = regDTO.getTypifiedName();
98
            // find the working set
99
            TypeDesignationWorkingSet typeDesignationWorkingSet = regDTO.getTypeDesignationWorkingSet(idset.baseEntityRef);
100

    
101
            // NameTypeDesignation bameTypeDesignation = regDTO.getNameTypeDesignation(typeDesignationWorkingSet.getBaseEntityReference());
102
            if(!typeDesignationWorkingSet.getBaseEntityReference().getType().equals(NameTypeDesignation.class)){
103
                throw new RuntimeException("TypeDesignationWorkingsetEditorIdSet references not a NameTypeDesignation");
104
            }
105
            // TypeDesignationWorkingSet for NameTyped only contain one item!!!
106
            UUID nameTypeDesignationUuid = typeDesignationWorkingSet.getTypeDesignations().get(0).getUuid();
107
            return super.loadBeanById(nameTypeDesignationUuid);
108
        }
109
    }
110

    
111

    
112
    /**
113
     * {@inheritDoc}
114
     */
115
    @Override
116
    protected NameTypeDesignation loadCdmEntity(UUID uuid) {
117
        List<String> initStrategy = Arrays.asList(new String []{
118
                "$",
119
                "annotations.*", // * is needed as log as we are using a table in FilterableAnnotationsField
120
                "typifiedNames.typeDesignations", // important !!
121
                "typeName.$",
122
                "citation.authorship.$",
123
                }
124
        );
125

    
126
        NameTypeDesignation typeDesignation;
127
        if(uuid != null){
128
            typeDesignation = (NameTypeDesignation) getRepo().getNameService().loadTypeDesignation(uuid, initStrategy);
129
        } else {
130
            typeDesignation = createNewBean();
131
        }
132

    
133
        typifiedNamesAsLoaded = new HashSet<>(typeDesignation.getTypifiedNames());
134

    
135
        return typeDesignation;
136
    }
137

    
138

    
139

    
140

    
141
    /**
142
     * {@inheritDoc}
143
     */
144
    @Override
145
    public void handleViewEntered() {
146

    
147
        getView().getTypeStatusSelect().setContainerDataSource(cdmBeanItemContainerFactory.buildBeanItemContainer(NameTypeDesignationStatus.class));
148
        getView().getTypeStatusSelect().setItemCaptionPropertyId("description");
149

    
150
        getView().getCitationCombobox().getSelect().setCaptionGenerator(
151
                new ReferenceEllypsisCaptionGenerator(LabelType.BIBLIOGRAPHIC, getView().getCitationCombobox().getSelect())
152
                );
153
        CdmFilterablePagingProvider<Reference,Reference> referencePagingProvider = pagingProviderFactory.referencePagingProvider();
154
        getView().getCitationCombobox().loadFrom(referencePagingProvider, referencePagingProvider, referencePagingProvider.getPageSize());
155
        getView().getCitationCombobox().setNestedButtonStateUpdater(new ToOneRelatedEntityButtonUpdater<Reference>(getView().getCitationCombobox()));
156
        getView().getCitationCombobox().getSelect().addValueChangeListener(new ToOneRelatedEntityReloader<>(getView().getCitationCombobox(), this));
157

    
158
        CdmFilterablePagingProvider<TaxonName,TaxonName> namePagingProvider = pagingProviderFactory.taxonNamesWithoutOrthophicIncorrect();
159
        getView().getTypeNameField().loadFrom(namePagingProvider, namePagingProvider, namePagingProvider.getPageSize());
160
        getView().getTypeNameField().setNestedButtonStateUpdater(new ToOneRelatedEntityButtonUpdater<TaxonName>(getView().getTypeNameField()));
161
        getView().getTypeNameField().getSelect().addValueChangeListener(new ToOneRelatedEntityReloader<>(getView().getTypeNameField(), this));
162

    
163
        getView().getTypifiedNamesComboboxSelect().setPagingProviders(namePagingProvider, namePagingProvider, namePagingProvider.getPageSize(), this);
164

    
165
    }
166

    
167

    
168
    /**
169
     * {@inheritDoc}
170
     */
171
    @Override
172
    protected void guaranteePerEntityCRUDPermissions(UUID identifier) {
173
        if(crud != null){
174
            newAuthorityCreated = UserHelperAccess.userHelper().createAuthorityForCurrentUser(NameTypeDesignation.class, identifier, crud, null);
175
        }
176
    }
177

    
178
    /**
179
     * {@inheritDoc}
180
     */
181
    @Override
182
    protected void guaranteePerEntityCRUDPermissions(NameTypeDesignation bean) {
183
        // TODO Auto-generated method stub
184

    
185
    }
186

    
187
    /**
188
     * {@inheritDoc}
189
     */
190
    @Override
191
    protected IService<NameTypeDesignation> getService() {
192
        // No TypeDesignationService :( so I need override the generic save and delete methods
193
        return null;
194
    }
195

    
196
    @Override
197
    protected void deleteBean(NameTypeDesignation bean){
198
        // deleteTypedesignation(uuid, uuid) needs to be called so the name is loaded in the transaction of the method and is saved.
199
        DeleteResult deletResult = getRepo().getNameService().deleteTypeDesignation(typifiedNameInContext.getUuid(), bean.getUuid());
200
        if(deletResult.isOk()){
201
            EntityChangeEvent changeEvent = new EntityChangeEvent(bean, Type.REMOVED, (AbstractView) getView());
202
            viewEventBus.publish(this, changeEvent);
203
        } else {
204
            CdmStore.handleDeleteresultInError(deletResult);
205
        }
206
    }
207

    
208

    
209
    /**
210
     * {@inheritDoc}
211
     */
212
    @Override
213
    protected NameTypeDesignation preSaveBean(NameTypeDesignation bean) {
214

    
215
        // the typifiedNames can only be set on the name side, so we need to
216
        // handle changes explicitly here
217
        HashSet<TaxonName> typifiedNames = new HashSet<>(bean.getTypifiedNames());
218

    
219
        // handle adds
220
        for(TaxonName name : typifiedNames){
221
            if(name == null){
222
                throw new NullPointerException("typifiedName must not be null");
223
            }
224
            if(!name.getTypeDesignations().contains(bean)){
225
                name.addTypeDesignation(bean, false);
226
            }
227
        }
228
        // handle removed
229
        for(TaxonName name : typifiedNamesAsLoaded){
230
            if(!typifiedNames.contains(name)){
231
                name.removeTypeDesignation(bean);
232
            }
233
            // FIXME do we need to save the names here or is the delete cascaded from the typedesignation to the name?
234
        }
235

    
236
        // handle annotation changes
237
        List<Annotation> annotations = getView().getAnnotationsField().getValue();
238
        List<Annotation> currentAnnotations = new ArrayList<>(bean.getAnnotations());
239
        List<Annotation> annotationsSeen = new ArrayList<>();
240
        for(Annotation a : annotations){
241
            if(a == null){
242
                continue;
243
            }
244
            if(!currentAnnotations.contains(a)){
245
                bean.addAnnotation(a);
246
            }
247
            annotationsSeen.add(a);
248
        }
249
        for(Annotation a : currentAnnotations){
250
            if(!annotationsSeen.contains(a)){
251
                bean.removeAnnotation(a);
252
            }
253
        }
254

    
255

    
256
        return bean;
257
    }
258

    
259

    
260

    
261
    @EventBusListenerMethod(filter = EditorActionTypeFilter.Add.class)
262
    public void onTaxonNameEditorActionAdd(TaxonNameEditorAction action){
263

    
264
        if(!isFromOwnView(action)){
265
            return;
266
        }
267

    
268
        TaxonNamePopupEditor typeNamePopup = openPopupEditor(TaxonNamePopupEditor.class, action);
269
        typeNamePopup.grantToCurrentUser(EnumSet.of(CRUD.UPDATE, CRUD.DELETE));
270
        typeNamePopup.withDeleteButton(true);
271
        TaxonNamePopupEditorConfig.configure(typeNamePopup);
272
        typeNamePopup.loadInEditor(null);
273

    
274
    }
275

    
276

    
277
    @EventBusListenerMethod(filter = EditorActionTypeFilter.Edit.class)
278
    public void onTaxonNameEditorActionEdit(TaxonNameEditorAction action){
279

    
280
        if(!isFromOwnView(action)){
281
            return;
282
        }
283

    
284
        TaxonNamePopupEditor typeNamePopup = openPopupEditor(TaxonNamePopupEditor.class, action);
285
        typeNamePopup.grantToCurrentUser(EnumSet.of(CRUD.UPDATE, CRUD.DELETE));
286
        typeNamePopup.withDeleteButton(true);
287
        TaxonNamePopupEditorConfig.configure(typeNamePopup);
288
        typeNamePopup.loadInEditor(action.getEntityUuid());
289

    
290
    }
291

    
292
    @EventBusListenerMethod
293
    public void onEntityChangeEvent(EntityChangeEvent<?>event){
294

    
295
        BoundField boundTargetField = boundTargetField((PopupView) event.getSourceView());
296

    
297
        if(boundTargetField != null){
298
            if(boundTargetField.matchesPropertyIdPath("typeName")){
299
                if(event.isCreateOrModifiedType()){
300
                    getCache().load(event.getEntity());
301
                    if(event.isCreatedType()){
302
                        getView().getTypeNameField().setValue((TaxonName) event.getEntity());
303
                    } else {
304
                        getView().getTypeNameField().reload();
305
                    }
306
                }
307
                if(event.isRemovedType()){
308
                    getView().getTypeNameField().selectNewItem(null);
309
                }
310

    
311
            }
312
        }
313
    }
314

    
315
}
(4-4/14)