1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34 package fr.paris.lutece.plugins.document.business.portlet;
35
36 import fr.paris.lutece.portal.service.util.AppPropertiesService;
37
38 import org.apache.commons.lang3.StringUtils;
39
40
41
42
43
44 public class PortletOrder
45 {
46
47 public static final int DATE_UPDATE_PORTLET = AppPropertiesService.getPropertyInt( "document.order.date_update_portlet",
48 0 );
49 public static final int PAGE_NAME = AppPropertiesService.getPropertyInt( "document.order.page_name", 1 );
50 public static final int PAGE_ID = AppPropertiesService.getPropertyInt( "document.order.page_id", 2 );
51 public static final int PORTLET_NAME = AppPropertiesService.getPropertyInt( "document.order.portlet_name", 3 );
52 public static final int SORT_ASC = AppPropertiesService.getPropertyInt( "document.order.asc", 1 );
53 private static final String SQL_ORDER_BY_PAGE_NAME = " ORDER BY f.name ";
54 private static final String SQL_ORDER_BY_PAGE_ID = " ORDER BY a.id_page ";
55 private static final String SQL_ORDER_BY_PORTLET_NAME = " ORDER BY a.name ";
56 private static final String SQL_ORDER_BY_DATE_UPDATE_PORTLET = " ORDER BY a.date_update ";
57 private static final String SQL_ASC = " ASC ";
58 private static final String SQL_DESC = " DESC ";
59
60
61 private boolean _bSortAsc;
62 private int _nTypeOrder;
63
64
65
66
67 public PortletOrder( )
68 {
69 _bSortAsc = false;
70 _nTypeOrder = DATE_UPDATE_PORTLET;
71 }
72
73
74
75
76
77
78 public PortletOrder( boolean bSortAsc, int nTypeOrder )
79 {
80 _bSortAsc = bSortAsc;
81 _nTypeOrder = nTypeOrder;
82 }
83
84
85
86
87
88 public void setSortAsc( boolean bSortAsc )
89 {
90 _bSortAsc = bSortAsc;
91 }
92
93
94
95
96
97 public boolean isSortAsc( )
98 {
99 return _bSortAsc;
100 }
101
102
103
104
105
106 public void setTypeOrder( int nTypeOrder )
107 {
108 _nTypeOrder = nTypeOrder;
109 }
110
111
112
113
114
115 public int getTypeOrder( )
116 {
117 return _nTypeOrder;
118 }
119
120
121
122
123
124 public String getSQLOrderBy( )
125 {
126 StringBuilder sbSQL = new StringBuilder( );
127
128 if ( _nTypeOrder == PAGE_NAME )
129 {
130 sbSQL.append( SQL_ORDER_BY_PAGE_NAME );
131 }
132 else if ( _nTypeOrder == PAGE_ID )
133 {
134 sbSQL.append( SQL_ORDER_BY_PAGE_ID );
135 }
136 else if ( _nTypeOrder == PORTLET_NAME )
137 {
138 sbSQL.append( SQL_ORDER_BY_PORTLET_NAME );
139 }
140 else if ( _nTypeOrder == DATE_UPDATE_PORTLET )
141 {
142 sbSQL.append( SQL_ORDER_BY_DATE_UPDATE_PORTLET );
143 }
144
145 if ( StringUtils.isNotBlank( sbSQL.toString( ) ) )
146 {
147 sbSQL.append( _bSortAsc ? SQL_ASC : SQL_DESC );
148 }
149
150 return sbSQL.toString( );
151 }
152 }