StyleSheetHome.java

  1. /*
  2.  * Copyright (c) 2002-2022, City of Paris
  3.  * All rights reserved.
  4.  *
  5.  * Redistribution and use in source and binary forms, with or without
  6.  * modification, are permitted provided that the following conditions
  7.  * are met:
  8.  *
  9.  *  1. Redistributions of source code must retain the above copyright notice
  10.  *     and the following disclaimer.
  11.  *
  12.  *  2. Redistributions in binary form must reproduce the above copyright notice
  13.  *     and the following disclaimer in the documentation and/or other materials
  14.  *     provided with the distribution.
  15.  *
  16.  *  3. Neither the name of 'Mairie de Paris' nor 'Lutece' nor the names of its
  17.  *     contributors may be used to endorse or promote products derived from
  18.  *     this software without specific prior written permission.
  19.  *
  20.  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
  21.  * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
  22.  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
  23.  * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDERS OR CONTRIBUTORS BE
  24.  * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
  25.  * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
  26.  * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
  27.  * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
  28.  * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
  29.  * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
  30.  * POSSIBILITY OF SUCH DAMAGE.
  31.  *
  32.  * License 1.0
  33.  */
  34. package fr.paris.lutece.portal.business.stylesheet;

  35. import fr.paris.lutece.portal.service.html.XmlTransformerService;
  36. import fr.paris.lutece.portal.service.spring.SpringContextService;

  37. import java.util.Collection;

  38. /**
  39.  * This class provides instances management methods (create, find, ...) for Stylesheet objects
  40.  */
  41. public final class StyleSheetHome
  42. {
  43.     // Static variable pointed to the DAO instance
  44.     private static IStyleSheetDAO _dao = SpringContextService.getBean( "styleSheetDAO" );

  45.     /**
  46.      * Creates a new StyleSheetHome object.
  47.      */
  48.     private StyleSheetHome( )
  49.     {
  50.     }

  51.     /**
  52.      * Creation of an instance of a Stylesheet file in the database
  53.      *
  54.      * @param stylesheet
  55.      *            An instance of a stylesheet which contains the informations to store
  56.      * @return The instance of the stylesheet which has been created.
  57.      */
  58.     public static StyleSheet create( StyleSheet stylesheet )
  59.     {
  60.         _dao.insert( stylesheet );

  61.         return stylesheet;
  62.     }

  63.     /**
  64.      * Deletes the StylesSheet whose identifier is specified in parameter
  65.      *
  66.      * @param nId
  67.      *            the identifier of the stylesheet to delete
  68.      */
  69.     public static void remove( int nId )
  70.     {
  71.         _dao.delete( nId );
  72.         XmlTransformerService.clearXslCache( );
  73.     }

  74.     /**
  75.      * Update the StylesSheet whose identifier is specified in parameter
  76.      *
  77.      * @param stylesheet
  78.      *            the stylesheet to update
  79.      */
  80.     public static void update( StyleSheet stylesheet )
  81.     {
  82.         _dao.store( stylesheet );
  83.         XmlTransformerService.clearXslCache( );
  84.     }

  85.     // /////////////////////////////////////////////////////////////////////////
  86.     // Finders

  87.     /**
  88.      * Returns an instance of a stylesheet file whose identifier is specified in parameter
  89.      *
  90.      * @param nKey
  91.      *            the stylesheet primary key
  92.      * @return the instance of the styleSheet whose identifier is the nKey
  93.      */
  94.     public static StyleSheet findByPrimaryKey( int nKey )
  95.     {
  96.         return _dao.load( nKey );
  97.     }

  98.     /**
  99.      * Returns the number of stylesheets associated to the style and the mode specified in parameter
  100.      *
  101.      * @param nStyleId
  102.      *            the style id
  103.      * @param nModeId
  104.      *            the mode id
  105.      * @return the number of stylesheet associated
  106.      */
  107.     public static int getStyleSheetNbPerStyleMode( int nStyleId, int nModeId )
  108.     {
  109.         return _dao.selectStyleSheetNbPerStyleMode( nStyleId, nModeId );
  110.     }

  111.     /**
  112.      * Returns a collection of StyleSheet objet
  113.      *
  114.      * @param nModeId
  115.      *            The mode identifier
  116.      * @return A collection of StyleSheet object
  117.      */
  118.     public static Collection<StyleSheet> getStyleSheetList( int nModeId )
  119.     {
  120.         return _dao.selectStyleSheetList( nModeId );
  121.     }
  122. }