Wtyczka favourites przychodzi z wbudowanym zbiorem elementów ulubionych. Elementy ulubione mogą być przedstawiane w postaci drzewa, aby ułatwić użytkownikowi wyszukiwanie interesujących go elementów.
Predefiniowane elementy to:
- Zadania - prowadzi do skrzynki zadań użytkownika
- Procesy- prowadzi do listy dostępnych procesów
- Proces - umożliwia stworzenie poszczególnych procesów
- Archiwum- otwiera elektroniczne archiwum systemu
- Klasy dokumentów - prowadzi do zakładki klas dokumentów
- Zestawy dokumentów - prowadzi do zakładki zestawów dokumentów
- Widoki - otwiera zakładkę widoków użytkownika
- Widok - wyświetla wyniki wybranego widoku użytkownika
Każda wtyczka może sama zdefiniować elementy ulubione, które będą dostępne dla użytkownika - dostarcza ona opis elementów oraz reguły ich wyświetlania w gadżecie lub stronie startowej.
Moduł <favourites>
Moduł favourites umożliwia wtyczką rejestrację własnych obiektów typu , które odpowiedzialne są za dostarczanie:
- definicji elementów (także w postaci drzewa) - elementy, które wyświetlane są użytkownikowi podczas budowy zestawów
- obiektów renderujących - przygotowujących dane do wyświetlenia
Implementacja handler'a
W pierwszej kolejności należy stworzyć klasę implementującą interfejs :
public class ExampleFavouriteHandler implements FavouriteHandler {
@Override
public boolean supports(String type) {
return "test".equals(type) || "test-sub".equals(type);
}
@Override
public Collection<Definition> getDefinitions() {
List<Definition> definitions = new ArrayList<Definition>();
Definition definition = new Definition("test");
definition.setName("TEST - Nazwa");
definition.setDescription("TEST - Opis");
definition.setTypeDescription("TEST - Typ");
definition.setCountable(false);
definitions.add(definition);
NestedDefinition nestedDefinition = new NestedDefinition(definition.getType(), "test-sub");
nestedDefinition.setName("TEST-SUB - Nazwa");
nestedDefinition.setDescription("TEST-SUB - Opis");
nestedDefinition.setTypeDescription("TEST-SUB - Typ");
nestedDefinition.setCountable(true);
definitions.add(nestedDefinition);
return definitions;
}
@Override
public FavouritesRenderer getRenderer(FavouriteElement favourite) {
ExampleFavouriteRenderer renderer = new ExampleFavouriteRenderer();
renderer.setFavourite(favourite);
return renderer;
}
}
Komentarze do pliku:
4-5: informujemy jakie typy definicji wspieramy - jesteśmy ich autorami i potrafimy je narysować
12-17: element ulubiony typu test
19-24: element ulubiony typu test-sub - jest on zagnieżdżony w elemencie test, co spowoduje stworzenie struktury drzewa z oknie wyboru
31-33: tworzymy obiekt, który narysuje podany element ulubionych.
Klasa handlera zdefiniowana w module <favourites> zostanie stworzona z wykorzystaniem kontekstu wtyczki, dzięki czemu możliwe jest standardowe korzystanie z adnotacji @Component.
Powyższy kod definicji będzie skutkował dodaniem 2 nowych elementów ulubionych do wyboru w postaci drzewa:
Implementacja obiektu renderującego
Obiekt odpowiedzialny za narysowanie elementów w gadżecie to .
Istnieje obiekt pomocniczy który dostarcza domyślne zachowanie rysowania pozwalając na łatwe przeciążenie.
Obiekt FavouritesRendererSupport nie jest ThreadSafe - zawsze musimy stworzyć nową instancję tej klasy zwracając ją w metodzie getRenderer(FavouriteElement favourite)
Implementacja takiego obiektu może wyglądać tak:
public class ExampleFavouriteRenderer extends FavouritesRendererSupport {
@Override
public boolean shouldRender() {
return true;
}
}
Deklaracja modułu <favourites>
Ostatnim krokiem jest deklaracja modułu <favoruites> w pliku suncode-plugin.xml:
<favourites key="favourite-entry" handler="com.suncode.plugin.example.ExampleFavouriteHandler"/>

