HowTos/Theming Kit
Contents
Prerequisites
On Debian-based systems, you must have dpkg installed. This is normally present.
On RPM-based systems, you must have the rpmbuild program present. This is normally not installed. It is probably in a package called rpm-build, which can be installed with the package maintenance program for your Linux distribution.
Installing the Software
The Theming Kit software is included in release 11.4.1 and more recent.
After upgrading your Scalix server, you will find the theming kit software in
<current version>/extras/swa/theming-kit/swa-theming-kit-<version>.tar.gz
For example: /root/scalix-11.4.1-U1-GA/extras/swa/theming-kit/swa-theming-kit-11.4.1-11592
gunzip and tar -xvf the file.
The swa-theming-kit-<version> contains the following directories:
- README.txt - instructions on how to use the Theming kit. This article is largely based on the README.
- package-theme.sh - used to build a new RPM or DEB from your theme files, to be installed on your SWA server.
- src - this is where you will put the files for your new theme; it also contains sample files from the Scalix Default theme that you can use as a basis for building your new theme.
- samples - contains the files for the Scalix Classic and Default themes.
- packages directory contains files used to build your theme package (the .rpm or .deb file); these files should not be altered.
Creating a Theme
- In the src directory, create a subdirectory with the name that you want your theme to have, for example, 'src/sunset'. Spaces are not allowed in the directory name.
- Copy the contents of one of the sample directories in "samples/" into your
new directory. Alternatively, you can copy the files from src/scalix-sample into your new directory.
# cp -pr samples/scalix-default/* src/sunset
or
# cp -pr src/scalix-sample/* src/sunset
- Edit the files but DO NOT CHANGE THEIR NAMES.
Quick Theme Change
These steps will help you create a new looking client with very little effort.
- Begin with a copy of the default theme
# cp -pr src/scalix-sample src/<theme>
- Edit src/<theme>/properties.xml - give your new theme a name, a long name, a description, and author
- Change the menu background: replace src/<theme>/img/app/md5/menuBar_d.gif with your own color choice; size is 1x1000 pixels; it should be dark on the left and your company color on the right
- Change the logo in the client: replace /src/<theme>/img/app/md5/partner_logo.gif with your own logo; size is 200x23 pixels; it should be on a transparent background; it should be a color that shows up well against your company color
- Change the logo on the log-in screen (this is not part of the theme, it will affect all logins but it is a nice touch): replace /var/opt/scalix/??/tomcat/webapps/webmail/img/logo.gif with your own logo; size is 180x33 pixels
- Change the selected item color and menu hover colors: edit src/<theme>/css/colors.css and change #D80000 to your company color throughout the file.
Adding Graphics
When adding graphics to the client, take pains that the image does not affect legibility of the text. For example, have a very light graphic and dark text. Here are the steps to take for adding a graphic to the message header area of the preview pane.
- Put the .gif file in src/<theme>/img/app; size is 500x77 pixels or less.
- Modify the src/<theme>/css/colors.css file:
.messageHeader {
  background-color:#A7A0ED;
  background-image:url(../img/messageHeader.gif);
  background-position:100% 0%;
  background-repeat:no-repeat;
}
The background position means place the image 100% to the right and 0% down; this positions the graphic in the top right corner of the Message Header in the preview pane.
Note that the background-image url does not mention the app subdirectory but states a path of ../img/<filename.gif>, even though the .gif file is actually placed in the app subdirectory.
Example of graphic in preview pane message header
Building the Package
In the folder where the package-theme.sh script is installed, run package-theme.sh <theme>
./package-theme sunset
This will create a "deb" or "rpm" package in the current directory.
Checking the Package
RPMs: 
rpm -qlp <package-file>
- List all the files in the package
scalix-swa-theme-sunset-11.4.1-11592.noarch.rpm
rpm -ql --dump <package-file> - List verbose information about all the files in the package
rpm -ql --dump scalix-swa-theme-sunset-11.4.1-11592.noarch.rpm
DEBs:
dpkg -x <package-file> <path>
- unpacks the data files as if the path named was "root"
- does not execute any of the scripts, such as preinst, postinst
- you can look at the files to see if they are in the right folders
mkdir out dpkg -x scalix-theme-sunset-11.4.1-123_all.deb out
Installing the New Theme
- Copy the package to the first Scalix SWA server where you wish to install it. The first server might be an SWA-only server that is used only for testing.
-  Install it. One way is to use the GUI-based package maintenance program for your Linux distribution. Look for documentation on installing packages that are on your hard drive and not in your repository.
 Another way is to use the "rpm" or "dpkg" commands. These are documented with "man" or "info".
rpm -i scalix-swa-theme-sunset-11.4.1-11592.noarch.rpm
- Restart SWA on that server.
service scalix-tomcat restart
- Test on that server to make sure that it behaves as you expect.
- Repeat for all the Scalix servers that have SWA installed on them.
Activating the New Theme
The user must activate the new theme in their own profile. Perform the following steps:
- If the user had an SWA client window open on their desktop while SWA was restarted on the server, close the window and log in again.
- Click on the following:
- Tools
- Options
- Select the "Themes" tab in the bar on the left.
- From the drop down "Themes" list, select the new theme, i.e. 'sunset'.
- Click "OK"
- The user may need to close SWA and login again for the changes to take effect.
Files You can Modify
This is just a partial description to get you started. Play and have fun with it! To help you understand what's what, here's some terminology: Panes - appear in the left hand side of the SWA client and can show folder list, calendar list, upcoming appointments, date navigation, etc. Panels - appear on the right hand side of the SWA client and can list messages, show a preview of a message, show the calendar, etc. Tree - Table - the list of folders Grid - the list of messages, contacts, or notes in the table Menu - file, edit, view, actions tools, help Toolbar - beneath the menu; icons to launch various tools; context-sensitive
<theme>/img/app
 alarm.gif - displayed when there is a reminder set on an appointment or meeting alarm.gif - displayed when there is a reminder set on an appointment or meeting
 meeting.gif - used in calendar view to indicate a meeting rather than an appointment meeting.gif - used in calendar view to indicate a meeting rather than an appointment
 meeting_organizer.gif - appears beside the organizer's name in the list of meeting attendees meeting_organizer.gif - appears beside the organizer's name in the list of meeting attendees
 meeting_resource.gif - displayed when an invitee is a resource meeting_resource.gif - displayed when an invitee is a resource
 misc_icons.gif - misc_icons.gif -
 month_cal_overflow.gif - month_cal_overflow.gif -
 optional_attendee.gif - appears beside optional attendees' names in the list of meeting attendees optional_attendee.gif - appears beside optional attendees' names in the list of meeting attendees
 private.gif - appears in calendar view to show an appointment or meeting is private private.gif - appears in calendar view to show an appointment or meeting is private
 repeat.gif - appears in calendar view to show an appointment or meeting is recurring repeat.gif - appears in calendar view to show an appointment or meeting is recurring
 repeat_ex.gif - used to indicate a recurring appointment or meeting for which one instance has been edited (recurring exception) repeat_ex.gif - used to indicate a recurring appointment or meeting for which one instance has been edited (recurring exception)
 required_attendee.gif - appears beside required attendees' names in the list of meeting attendees required_attendee.gif - appears beside required attendees' names in the list of meeting attendees
<theme>/img/app/md5
- calpop.gif - used when creating an appointment or meeting, or setting a contact's birthday or anniversary; when you want to pop-up a calendar from which to select a date
- divider_d.gif - used to divide left hand panes from right hand panes (for example, mailbox list, upcoming events, date navigator from message list and preview)
- freebusy_info_bg.gif - used when free/busy info is not available
- folderIcons.gif - used beside list of folders to indicate inbox, outbox, drafts, calendar, etc.
- hoveroverstick.gif - Used to make part of the "speech bubble" for context-sensitive information that appears when you hover your mouse over something; for example, when you hover your mouse over a bold date in the date navigator, or an appointment in the calendar.
- indicator.gif
- labels.gif - used to label appointment or meeting (Important, Business, Personal, Vacation...)
- logo.gif -
- menuBar_d.gif - the background behind the text menu and the logo
- misc_icons.gif
- modebar.gif - indicates whether you're looking at messages or calendars (bottom left corner)
- modebar_bg.gif - background for mode bar
- partner_logo.gif - logo in top right corner of SWA client
- preferencesIcons.gif - used for the Tools->Options menu
- search_relevance_off.gif - used in search results window to indicate relevance
- search_relevance_on.gif - used in search results window to indicate relevance
- tableIcons.gif - used in the list of messages to indicate new message, attachment, follow-up flag, meeting request accepted, non-delivery, etc.
- toolbar.gif - icons used in the toolbar (context-senstitive horizontal icons, just below the menu)
- toolbar_d.gif - background for toolbar icons
- tree_background.gif - used for the background of panes; use this to shade from white top to gray bottom, for example
<theme>/css
calendar.css
- calendar.css - controls calendar; uses tree_background.gif, labels.gif
fonts.css
- fonts.css - fonts used with calendar, menus, tabs, etc.
modebar.css
- modebar.css - controls the area where you pick mail/calendar view; uses modebar.gif, modebar_bg.gif, and indicator.gif
tableview.css
- tableview.css - ; uses folderIcons.gif
treeview.css
- treeview.css - controls the folder list area; uses tree_background.gif, folderIcons.gif
colors.css
colors.css - colors used in the other .css file
-  calendar.css
- .upcomingAppointmentsDiv
- .calendarViewHeaderCell - depending on the calendar view selected, this is day and date, or day
- .dayWeekViewAllDayEntryCell - in day or week view, the end user can double-click this bar just beneath day/date and create an all-day entry
- .dayWeekViewAllDayFillerCell - the little cell to the right of the "all week" bar in a day or week view.
- .dayWeekViewApptDiv
- .dayWeekViewAllDayApptDiv
- .monthViewAllDayApptDiv
- .dayWeekViewApptBody
- .isToday - the color of today's date in day or week view; usually set to same vlaue as .monthViewEntryCell .isToday
- .monthViewEntryCell .selected - the selected date in the calendar month view. The selected date is displayed on a background of "background-color"
- .monthViewEntryCell .isToday - when the calendar is in month view, today's date shows up in this color; usually set to the same value as .dayWeekViewApptDiv .isToday
- .isNotToday - color of date numbers in month view that are not today
- .upcomingAppointmentHeaderCell
- .upcomingAppointmentTimeCell
- .upcomingAppointmentSubjectCell
- .calendarLoadingDiv
 
- dragdrop.css
- grid.css
- .grid_container
- .grid_scrollable_div
- .grid_header
- .grid_header_mousedown - what happens when you click a grid header, to sort by subject, date, author, etc.
- .grid_unhighlighted_data_row
- .grid_highlighted_focused_data_row - controls how a highlighted item appears in the grid - i.e. a highlighted message or contact.
- .grid_highlighted_unfocused_data_row - the selected message or contact in the grid when focus is on the table
 
- menu.css
- .menuBar - color behind the text menu. If you use MenuBar_d.gif it will cover up .menuBar
- .menuTitle_hover - highlights the menu item your mouse is hovering over, before you select it
- .menu - the drop down menus; file, edit, view, actions, tools, help
- .menuShadow - color behind the drop-down menus
- .menuItemLeftIconCell - this will show to the left of the active options in a drop-down menu
- .menuItem_hover .menuItemLeftIconCell - the icon (or empty cell) of the item your mouse is hovering over in the drop-down menu
- .menuItem_hover .menuItemCaptionCell - the item your mouse is hovering over in the drop-down menu
- .menuItemShortcutCell - the "shortcut keys" in the menu, for example "control+<" for previous message
- .menuItem_disabled .menuItemShortcutCell
- .menuItem_hover .menuItemShortcutCell - the color of the "shortcut key" in the menu when you hover your mouse over the selection
- .menuItem_hover .menuItemRightIconCell
- .singleToolbarMenu
- .singleToolbarMenuLeft
- .singleToolbarMenuRight
- .menuItem_disabled .singleToolbarMenuRight
 
- shpants.css
- .panel_header
- .panel
- .paneDivider
- .paneDividerOn
- .pane, .messagepane, .appointmentspane
- .bigTableResizer
- .renamer - box when you are renaming a folder in the table
- .paneHeader - header for Folder list, Calendar list, Upcoming Appointments, Date Navigator
- .messageHeader - the message header in the preview pane
- .miniCalendarPane
- .textInputField - where you enter text, such as a name to search for when addressing a message by clicking the "to" button
- .messageRenderer - the message in the preview pane
- .popdownButton - button to select start/end time when creating an appointment or meeting
- .infobar
- .hoverOverMenu - the bubble that pops up when you hover over an upcoming event in the upcoming events pane, or a bold date in the date navigation pane
- .calendarSetPane
 
- tableview.css
- .table_view_header - The column headers over the list of messages or contacts in the grid, i.e. From, Subject, Date, etc.
- .table_view_header_mousedown
- .table_view_scrollable_div
- .table_view_unhighlighted_data_row
- .table_view_highlighted_focused_data_row - controls how a highlighted table item appears when the table is in focus.
- .table_view_highlighted_unfocused_data_row - the selected folder in the table when focus is in the grid
- .col_separator
 
- tabs.css
- .tab
- .tab_selected - indicates which tab you are on when creating an appointment or menu - for example, when creating a meeting if you're on the appointment, scheduling, or recurrence tab.
- .tab_pane - the window where you create an appointment or meeting
 
- toolbar.css
- .toolbar
- .toolbarButton_down - indicates that you have clicked on a toolbar icon
 
- treeview.css
- .treeviewNodeLabelCell_selected
- .treeviewNodeLabelCell_selected_blur
- .treeviewContainer
 
- wnd_ComposeAppt.css
- .FreeBusyTableHeader - shows date and hours above free/busy view on scheduling tab when creating a meeting
- .FreeBusyMeetingBody - where the free and busy time is displayed on scheduling tab when creating a meeting
- .FreeBusyMeetingLeftBar - in scheduling tab, this color is on the lefthand side of the free-busy display area
- .FreeBusyMeetingRightBar
- .timePopStart, .timePopEnd, .fb_timePopStart, .fb_timePopEnd
 
- override colors
- body.print
- iframe.messageRenderer html body
- .datePickerCell
 
 
-  calendar.css
grid.css
- grid.css - ; uses folderIcons.gif
shpants.css
- shpants.css - controls panes in SWA client; uses calpop.gif, folderIcons.gif, hoveroverstick.gif, misc_icons.gif, search_relevance_off.gif, search_relevance_on.gif, toolbar.gif, tree_background.gif
tabs.css
- tabs.css
wnd_ComposeAppt.css
- wnd_ComposeAppt.css - controls the appointment window; uses freebusy_info_bg.gif, calpop.gif, tableIcons.gif
dragdrop.css
- dragdrop.css - controls drag-and-drop; uses folderIcons.gif
- menu.css - controls menu (File, Edit, View...) and the context dependent icon menu below that in all windows; uses menuBar_d.gif, toolbar.gif, misc_icons.gif
slider.css
- slider.css - controls the slider
toolbar.css
- toolbar.css - controls the context dependent icon menus; uses toolbar_d.gif, toolbar.gif, labels.gif, misc_icons.gif
Ltward 14:05, 26 August 2008 (PDT)

