Applications today have a problem of delivering complex views that are based upon dates and times, such as calendar events, calendar appointments, and project plans. The traditional approach is to position time related elements by having the client computer translate date/time objects into its own coordinate system. In the case of web-based scheduling applications, a lot of code, such as Java code, often needs to be interpreted on the client. The translation process and/or display process can be rather unstable based upon the limitations of the client computer, such as the type of scripts the client computer's web browser supports or the system resources available on the client computer. Moreover, if the client computer's local date/time setting is incorrect, such as having a different time zone setting than the server computer, the entire calendar event and/or appointment view is rendered inappropriately and can cause the user to miss important events or appointments. Also, depending on regional support, the client computer may not be able to display alternative calendaring systems correctly.
Various technologies and techniques are disclosed that improve the interpretation and display of schedule data on a client. A server stores the schedule information. The same server or a different server stores a user time zone setting. A client requests the schedule information from the server. The server translates the schedule information into one or more data packets based on a coordinate system that is understood by the client. In one implementation, the data is stored in a data store in the coordinate system format. In another implementation, the data is stored in a data store in a different format and then translated to the coordinate system format prior to transmission to the client. The client receives the data packets containing the schedule information and interprets the data packets based on the agreed-upon coordinate system. The client displays the schedule information on a user interface.
This Summary was provided to introduce a selection of concepts in a simplified form that are further described below in the Detailed Description. This Summary is not intended to identify key features or essential features of the claimed subject matter, nor is it intended to be used as an aid in determining the scope of the claimed subject matter.
For the purposes of promoting an understanding of the principles of the invention, reference will now be made to the embodiments illustrated in the drawings and specific language will be used to describe the same. It will nevertheless be understood that no limitation of the scope is thereby intended. Any alterations and further modifications in the described embodiments, and any further applications of the principles as described herein are contemplated as would normally occur to one skilled in the art.
The system may be described in the general context as a coordinate system that improves the interpretation and display of schedule data on a client. A server translates schedule information into one or more data packets based on a coordinate system that is understood by the client. In one implementation, this coordinate system does not depend on and/or use the client's date/time setting. The client receives the data packets containing the schedule information and interprets the data packets based on the agreed-upon coordinate system. The client displays the schedule information on a user interface.
In one implementation, the computer accurately displays the correct date and time of an appointment when the client computer's date and time setting is incorrect. As a few non-limiting examples, the client computer's date can be incorrect when the user travels across different time zones, and when the date setting on the client computer resets to a default date after a software or hardware failure. In another implementation, the client computer displays the correct date and time of an appointment without having to execute a lot of interpreted scripting code to create a coordinate system to enable the schedule to be displayed.
As shown in
Additionally, devices 100 and/or 130 may also have additional features/functionality. For example, devices 100 and/or 130 may also include additional storage (removable and/or non-removable) including, but not limited to, magnetic or optical disks or tape. Such additional storage is illustrated in
Computing devices 100 and/or 130 include one or more communication connections that allow computing devices 100 and/or 130 to communicate with each other and/or one or more other computing devices (150, 160, and 170, respectively) over network 116. Communications connection(s) 114 and 144 are examples of communication media. Communication media typically embodies computer readable instructions, data structures, program modules or other data in a modulated data signal such as a carrier wave or other transport mechanism and includes any information delivery media. The term “modulated data signal” means a signal that has one or more of its characteristics set or changed in such a manner as to encode information in the signal. By way of example, and not limitation, communication media includes wired media such as a wired network or direct-wired connection, and wireless media such as acoustic, RF, infrared and other wireless media. The term computer readable media as used herein includes both storage media and communication media.
In one implementation, computing device 100 is a client computer that communicates with server computer 130 using communication connection 114 and 144 over network 116. In such an implementation, user interface 118 of client computing device 100 accesses schedule data 148 and user time-zone information 150 on server computing device 130 to retrieve and display schedule information correctly. It will be appreciated that schedule data 148 and/or user time zone info 150 can be stored on the same server or different servers, but that they are shown on the same server computing device 130 for the sake of clarity. In one implementation, user interface 118 of client computing device 100 is a browser-based user interface, such as MICROSOFT® OUTLOOK® Web Access (OWA), and server computing device 130 is a web server, such as one having access to a data store using MICROSOFT® Exchange. In another implementation, user interface 118 of client computing device 100 is a user interface included in an executable program located on client computing device 100, such as MICROSOFT® Office OUTLOOK®, MICROSOFT® Project, or Lotus Notes.
Computing devices 100 and 130 may also have input device(s) (114 and 134, respectively) such as keyboard, mouse, pen, voice input device, touch input device, etc. Output device(s) (116 and 136, respectively) such as a display, speakers, printer, etc. may also be included. These devices are well known in the art and need not be discussed at length here.
Turning now to
The client requests the schedule data from the server (stage 210). The server retrieves the schedule data and translates it into a coordinate system format, if it is not already in the coordinate system format (stage 215). In one implementation, the server retrieves the user's time zone information, and uses the time zone information to help with translating the schedule data into the coordinate system format. In one implementation, the coordinate system format is a two-dimensional representation of the data. More or fewer dimensions and/or other ways for representing data in a coordinate format could also be used. The server transmits the coordinate data to the client (stage 220). The coordinate data is interpreted by the client computer based upon the agreed-upon translation logic (stage 225). In one implementation, the client's local date and time setting is not used in interpreting the schedule data, because the coordinates are not based upon dates and times. A graphical representation of the schedule data is displayed on the user interface to the user (stage 230).
Turning now to
The event value in each coordinate record includes the name or other identifier for the event. The Y value includes the row position information. The X value includes the column position information. The width value is based on how many days of the total number of days being displayed the particular event spans. For example, event A (475) spans three days, and starts with Tuesday, September 13 (465) and continues through Thursday, September 15 (470). Hence, event A (475) has a width numeric value of 3. Event B (490) only spans a single day, and is displayed as the third event, based on the Y coordinate. Event C (485) only spans a single day and is displayed as the second event for Thursday, September 15. Event D (480) spans two days and is shown as the second event for each day, based on the Y coordinate.
Turning now to
The mapping algorithm creates a coordinate data representation for each appointment data record, including the appointment subject/description, starting row position, length of the appointment, starting position within the column (e.g. percent of total width), and the width of the appointment within the column (e.g. based on the number of overlapping appointments (stage 525). The coordinate data for the appointment is sent to the client upon request, along with other events and/or appointments as applicable (stage 530). The client computer interprets the coordinate data based upon an agreed format (stage 535). The client computer displays the appointment in a user interface (stage 540). The process then ends at end point 545.
The appointment value in each coordinate record includes the name or other identifier for the event. The Y value includes the row position information, in half hour increments. The height value includes the number of half hour increments that the appointment spans. The X value includes the column position information, based on percentage of screen width. The width value indicates how wide the appointment should be, and is based on how many other appointments are being shown for the same time range. For example, appointment A (665) has an overlapping time period with appointment B (680), and thus appointment A (665) only takes up half of the screen width. Appointment A (665) spans three time periods of thirty minutes each. Thus, appointment A (665) has a height numeric value of 3. Appointment C (690) only spans a single time span, but has a period that overlaps with appointment B (680). Appointment D (675) does not have an overlapping time span, and takes up the entire column width.
The examples in
Although the subject matter has been described in language specific to structural features and/or methodological acts, it is to be understood that the subject matter defined in the appended claims is not necessarily limited to the specific features or acts described above. Rather, the specific features and acts described above are disclosed as example forms of implementing the claims. All equivalents, changes, and modifications that come within the spirit of the implementations as described herein and/or by the following claims are desired to be protected.
For example, a person of ordinary skill in the computer software art will recognize that the client and/or server arrangements, user interface screen content, and/or data layouts as described in the examples discussed herein could be organized differently on one or more computers to include fewer or additional options or features than as portrayed in the examples.