source: extensions/jiwigo/trunk/src/main/java/fr/mael/jiwigo/service/CategoryService.java @ 6962

Last change on this file since 6962 was 6962, checked in by mlg, 14 years ago

"Feature" :
Until now, it was not possible to create a "root" category. It is now possible.

File size: 4.0 KB
Line 
1package fr.mael.jiwigo.service;
2
3import java.io.IOException;
4import java.util.List;
5
6import fr.mael.jiwigo.dao.CategoryDao;
7import fr.mael.jiwigo.om.Category;
8
9/**
10   Copyright (c) 2010, Mael
11   All rights reserved.
12
13   Redistribution and use in source and binary forms, with or without
14   modification, are permitted provided that the following conditions are met:
15    * Redistributions of source code must retain the above copyright
16      notice, this list of conditions and the following disclaimer.
17    * Redistributions in binary form must reproduce the above copyright
18      notice, this list of conditions and the following disclaimer in the
19      documentation and/or other materials provided with the distribution.
20    * Neither the name of jiwigo nor the
21      names of its contributors may be used to endorse or promote products
22      derived from this software without specific prior written permission.
23
24   THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
25   ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
26   WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
27   DISCLAIMED. IN NO EVENT SHALL Mael BE LIABLE FOR ANY
28   DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
29   (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
30   LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
31   ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
32   (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
33   SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
34   
35 * Service des catégories
36 * @author mael
37 *
38 */
39public class CategoryService {
40    /**
41     * Logger
42     */
43    public static final org.apache.commons.logging.Log LOG = org.apache.commons.logging.LogFactory
44            .getLog(CategoryService.class);
45
46    /**
47     * singleton
48     */
49    private static CategoryService instance;
50
51    /**
52     * @return le singleton
53     */
54    public static CategoryService getInstance() {
55        if (instance == null) {
56            instance = new CategoryService();
57        }
58        return instance;
59    }
60
61    /**
62     * Constructeur privé, pour n'avoir accès qu'au singleton
63     */
64    private CategoryService() {
65
66    }
67
68    /**
69     * Listing des categories
70     * @param rafraichir utilisation du cache ou non
71     * @param recursive
72     * @return la liste des catégories
73     * @throws IOException
74     */
75    public List<Category> lister(boolean recursive) throws IOException {
76        return CategoryDao.getInstance().lister(recursive);
77    }
78
79    /**
80     * Fonction qui permet de construire l'arbre des categorie
81     * En association catégories mères/catégories filles
82     * @return la liste des catégories
83     * @throws IOException
84     */
85    public List<Category> construireArbre() throws IOException {
86        List<Category> list = CategoryDao.getInstance().lister(true);
87        for (Category category : list) {
88            for (Category category2 : list) {
89                if (category2.getIdCategoriesMeres().size() != 1
90                        && category.getIdentifiant().equals(
91                                category2.getIdCategoriesMeres().get(category2.getIdCategoriesMeres().size() - 2))) {
92                    category.getCategoriesFilles().add(category2);
93                    category2.getCategoriesMeres().add(category);
94                }
95
96            }
97        }
98
99        return list;
100
101    }
102
103    /**
104     * Création d'une catégorie
105     * @param nom nom de la catégorie
106     * @param parent catégorie parent
107     * @return true si la catégorie a bien été créée
108     */
109    public boolean creer(String nom, Integer parent) {
110        Category category = new Category();
111        category.setParentDirect(parent);
112        category.setNom(nom);
113        return CategoryDao.getInstance().creer(category);
114    }
115
116    /**
117     * Création d'une catégorie
118     * @param nom nom de la catégorie
119     * @param parent catégorie parent
120     * @return true si la catégorie a bien été créée
121     */
122    public boolean creer(String nom) {
123        Category category = new Category();
124        category.setNom(nom);
125        return CategoryDao.getInstance().creer(category);
126    }
127}
Note: See TracBrowser for help on using the repository browser.