Project

General

Profile

Download (4.21 KB) Statistics
| Branch: | Revision:
1
/**
2
* Copyright (C) 2017 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.io.plantglossary;
10

    
11
import java.net.URI;
12
import java.net.URISyntaxException;
13
import java.util.ArrayList;
14
import java.util.HashSet;
15
import java.util.List;
16
import java.util.Set;
17

    
18
import eu.etaxonomy.cdm.api.service.ITermService;
19
import eu.etaxonomy.cdm.api.service.IVocabularyService;
20
import eu.etaxonomy.cdm.io.csv.in.CsvImportState;
21
import eu.etaxonomy.cdm.model.agent.Institution;
22
import eu.etaxonomy.cdm.model.agent.Person;
23
import eu.etaxonomy.cdm.model.agent.Team;
24
import eu.etaxonomy.cdm.model.common.IdentifiableSource;
25
import eu.etaxonomy.cdm.model.common.OriginalSourceType;
26
import eu.etaxonomy.cdm.model.common.TermType;
27
import eu.etaxonomy.cdm.model.common.TermVocabulary;
28
import eu.etaxonomy.cdm.model.common.VerbatimTimePeriod;
29
import eu.etaxonomy.cdm.model.description.State;
30
import eu.etaxonomy.cdm.model.reference.Reference;
31
import eu.etaxonomy.cdm.model.reference.ReferenceFactory;
32

    
33
/**
34
 *
35
 * @author pplitzner
36
 * @since Dec 7, 2018
37
 *
38
 */
39
public class PlantGlossaryCsvImportState extends CsvImportState<PlantGlossaryCsvImportConfigurator> {
40

    
41
    private TermVocabulary modifierVoc;
42
    private List<TermVocabulary> existingVocabularies = new ArrayList<>();
43
    private List<State> existingTerms = new ArrayList<>();
44
    private Set<TermVocabulary> vocabularies = new HashSet<>();
45
    private final Reference citation;
46

    
47

    
48
    protected PlantGlossaryCsvImportState(PlantGlossaryCsvImportConfigurator config) {
49
        super(config);
50
        citation = ReferenceFactory.newGeneric();
51
        citation.setTitle("FloraTerms");
52
        Team team = Team.NewInstance();
53
        team.addTeamMember(Person.NewInstance(null, "Cui", null, "Hong"));
54
        team.addTeamMember(Person.NewInstance(null, "Cole", null, "Heather"));
55
        team.addTeamMember(Person.NewInstance(null, "Endara", null, "Lorena"));
56
        team.addTeamMember(Person.NewInstance(null, "Macklin", null, "James"));
57
        team.addTeamMember(Person.NewInstance(null, "Sachs", null, "Joel"));
58
        citation.setAuthorship(team);
59
        VerbatimTimePeriod datePublished = VerbatimTimePeriod.NewVerbatimInstance();
60
        datePublished.setStartYear(2014);
61
        datePublished.setStartMonth(6);
62
        datePublished.setStartDay(13);
63
        citation.setDatePublished(datePublished);
64
        Institution institution = Institution.NewNamedInstance("OTO System");
65
        institution.addUrl(URI.create("http://biosemantics.arizona.edu/OTO/"));
66
        citation.setInstitution(institution);
67
        URI uri;
68
        try {
69
            uri = new URI("https://terms.tdwg.org/wiki/FloraTerms");
70
            citation.setUri(uri);
71
        } catch (URISyntaxException e) {
72
        }
73

    
74
        modifierVoc = TermVocabulary.NewInstance(TermType.Modifier);
75
        modifierVoc.setLabel("Plant Glossary Modifiers");
76
        modifierVoc.addSource(IdentifiableSource.NewInstance(OriginalSourceType.Import, citation.getTitle(), null, citation, null));
77
    }
78

    
79
    @Override
80
    public void resetSession(){
81
        super.resetSession();
82
    }
83

    
84
    public TermVocabulary getModifierVoc() {
85
        return modifierVoc;
86
    }
87

    
88
    void addVocabulary(TermVocabulary vocabulary) {
89
        vocabularies.add(vocabulary);
90
    }
91

    
92
    TermVocabulary checkVocabularies(String vocName, IVocabularyService vocabularyService){
93
        if(existingVocabularies.isEmpty()){
94
            existingVocabularies = vocabularyService.list(TermVocabulary.class, null, null, null, null);
95
        }
96
        for (TermVocabulary termVocabulary : vocabularies) {
97
            if(termVocabulary.getLabel().equals(vocName)){
98
                return termVocabulary;
99
            }
100
        }
101
        return null;
102
    }
103

    
104
    public boolean isTermPresent(String termName, ITermService termService) {
105
        if(existingTerms.isEmpty()){
106
            existingTerms = termService.list(State.class, null, null, null, null);
107
        }
108
        return existingTerms.stream().map(term->term.getLabel()).anyMatch(label->label.equals(termName));
109
    }
110

    
111
    Reference getCitation() {
112
        return citation;
113
    }
114

    
115
}
(5-5/6)