Difference between revisions of "HowTos/Theming Kit"

From Scalix Wiki
Jump to: navigation, search
(colors.css)
(colors.css)
Line 168: Line 168:
 
***.calendarViewHeaderCell - depending on the calendar view selected, this is day and date, or day  
 
***.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
 
***.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. Best to not mess with this or set it to match your slider or your dayWeekViewAllDayEntryCell
+
***.dayWeekViewAllDayFillerCell - the little cell to the right of the "all week" bar in a day or week view.
 
***.dayWeekViewApptDiv
 
***.dayWeekViewApptDiv
 
***.dayWeekViewAllDayApptDiv
 
***.dayWeekViewAllDayApptDiv
Line 188: Line 188:
 
***.grid_header_mousedown - what happens when you click a grid header, to sort by subject, date, author, etc.
 
***.grid_header_mousedown - what happens when you click a grid header, to sort by subject, date, author, etc.
 
***.grid_unhighlighted_data_row  
 
***.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.  Set grid_highlighted_focused_data_row, menuItem_hover, table_view_highlighted_focused_data_row, and treeviewNodeLabelCell_selected to the same value for a consistent look and feel.
+
***.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
 
***.grid_highlighted_unfocused_data_row - the selected message or contact in the grid when focus is on the table
 
**menu.css
 
**menu.css
Line 199: Line 199:
 
***.menuItem_hover .menuItemCaptionCell - 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
 
***.menuItemShortcutCell -  the "shortcut keys" in the menu, for example "control+<" for previous message
***.menuItem_disabled .menuItemShortcutCell - the color of the "shortcut key" in the menu when you hover your mouse over the selection
+
***.menuItem_disabled .menuItemShortcutCell
***.menuItem_hover .menuItemShortcutCell
+
***.menuItem_hover .menuItemShortcutCell - the color of the "shortcut key" in the menu when you hover your mouse over the selection
 
***.menuItem_hover .menuItemRightIconCell  
 
***.menuItem_hover .menuItemRightIconCell  
 
***.singleToolbarMenu  
 
***.singleToolbarMenu  
Line 228: Line 228:
 
***.table_view_scrollable_div  
 
***.table_view_scrollable_div  
 
***.table_view_unhighlighted_data_row  
 
***.table_view_unhighlighted_data_row  
***.table_view_highlighted_focused_data_row - controls how a highlighted table item appears when the table is in focus.  Set grid_highlighted_focused_data_row,  menuItem_hover, table_view_highlighted_focused_data_row, and treeviewNodeLabelCell_selected to the same value for a consistent look and feel.
+
***.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
 
***.table_view_highlighted_unfocused_data_row - the selected folder in the table when focus is in the grid
 
***.col_separator  
 
***.col_separator  
Line 239: Line 239:
 
***.toolbarButton_down - indicates that you have clicked on a toolbar icon
 
***.toolbarButton_down - indicates that you have clicked on a toolbar icon
 
**treeview.css
 
**treeview.css
***.treeviewNodeLabelCell_selected - Set grid_highlighted_focused_data_row,  menuItem_hover, table_view_highlighted_focused_data_row, and treeviewNodeLabelCell_selected to the same value for a consistent look and feel.
+
***.treeviewNodeLabelCell_selected  
 
***.treeviewNodeLabelCell_selected_blur  
 
***.treeviewNodeLabelCell_selected_blur  
 
***.treeviewContainer  
 
***.treeviewContainer  

Revision as of 19:06, 29 August 2008

Hc theme2 b.jpg

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 alarm.gif - displayed when there is a reminder set on an appointment or meeting
  • Meeting.gif meeting.gif - used in calendar view to indicate a meeting rather than an appointment
  • Meeting organizer.gif meeting_organizer.gif - appears beside the organizer's name in the list of meeting attendees
  • Meeting resource.gif 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 optional_attendee.gif - appears beside optional attendees' names in the list of meeting attendees
  • Private.gif private.gif - appears in calendar view to show an appointment or meeting is private
  • Repeat.gif repeat.gif - appears in calendar view to show an appointment or meeting is recurring
  • Repeat ex.gif repeat_ex.gif - used to indicate a recurring appointment or meeting for which one instance has been edited (recurring exception)
  • Required attendee.gif 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

fonts.css

  • fonts.css - fonts used with calendar, menus, tabs, etc.

modebar.css

tableview.css

treeview.css

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

grid.css

shpants.css

tabs.css

  • tabs.css

wnd_ComposeAppt.css

dragdrop.css

menu.css

slider.css

  • slider.css - controls the slider

toolbar.css

Ltward 14:05, 26 August 2008 (PDT)