The present description relates to the field of computing and networking, and more specifically to online scheduling tools and methods.
Recent progress in mobile processing devices, and more specifically with regards to cellular phones, now permits using mobile phone devices to access internet-based tools and run mobile applications.
With the feature above came the appearance of online networking, contact and time management tools using application programming interfaces (API) to request remote procedures over the Internet. The adaptation of some of these applications for mobile phones has begun.
In light of all the different networking, contact and time management tools available on the market, it is difficult to find a single program or tool which interfaces with all the other tools. For example, some users have their calendar associated with their email, and synchronized with a database of their email provider e.g. Hotmail®, Gmail®, Yahoo® etc. Some other people have their calendar synchronized with their computer e.g. using Microsoft Outlook® etc. These programs do not interface with each other and the calendar information associated with the users is dispersed on several databases which are not interfaced with each other.
Therefore, when a meeting is needed between two or more users, an organizing user has to suggest a specific time and send a meeting request. If the other user(s) is/are not available in the time specified, they may either reject or propose another time. This sequence goes on and on until a time block is found during which all the users are free. Complexity of this scenario increases dramatically with the presence of user preferences and the multitude of users, until it becomes nearly impossible.
Therefore, it is preferable to consolidate all of these tools into one unique application that is able to manage contacts and schedule appointments with contacts using different programs and contact tools.
There is thus a need for a mobile application and method for calendar sharing and scheduling which addresses at least some of the above discussed issues.
Herein proposed is an application device, user interface and method adapted for use with mobile phones or other mobile devices, which allows users to schedule meetings, share their calendar and their contact information with others; view other users' shared calendars and contact information when authorized; organize meeting schedules with other users, and request automatic scheduling suggestions while using their mobile phone.
In accordance with an aspect, there is provided an application device for scheduling a meeting of participants comprising an organizing participant to whom the application device is associated. Each participant has an identification and data entities associated with said identification. Said data entities are synchronized with a database. The application device comprises a processor having access to a remote server via a communication network, a user interface for receiving identifications of the participants and a database query from the organizing participant, and a memory operatively coupled to the processor for storing instructions to be performed by the processor.
When the instructions are performed by the processor, they cause the processor to: receive the identifications of the participants from the user interface; and upon receipt of the database query, communicate the identifications of the participants to the remote server over the communication network for the remote server to perform a search of the database and process data entities associated with each participant to determine a block of time during which all participants are free. The instructions also cause the processor to receive said block of time from the remote server; and output at least a portion of said block of time for display on the user interface.
In an embodiment, the user interface further receives a time duration from the organizing participant, and the instructions stored in the memory cause the processor to further: receive the time duration from the user interface, and upon receipt of the database query, communicate the time duration to the remote server to determine a block of time which comprises the meeting duration.
In another embodiment, the user interface further receives a selection of the block of time from the organizing participant; and the instructions stored in the memory cause the processor to receive the selection of the block of time from the user interface; and book the selected block of time on a calendar of the organizing participant.
In a further embodiment, the user interface further receives a meeting request from the organizing participant; and the instructions stored in the memory cause the processor to: receive the meeting request from the user interface; and send the meeting request to the participants in accordance with the block of time selected.
In yet a further embodiment, the instructions stored in the memory cause the processor to retrieve, from the remote server, calendars of the participants when settings associated with the calendars allow a sharing of the calendars with the organizing participant; and output the calendars to the user interface for display.
It is possible to repeat the search of the database to determine a different block of time during which all of the participants are commonly free, upon receipt of instructions from the user interface.
It is also possible to implement the application device for use with a mobile phone which includes an accelerometer, wherein the scheduling request is triggered by inducing a given acceleration to the accelerometer by manually shaking the mobile phone. In an embodiment, a further scheduling request is triggered by inducing the given acceleration to the accelerometers by manually shaking the mobile phone again thereby resulting in a determination by the server of a different block of time during which all of the participants are commonly free.
In one embodiment, only new blocks of time are output to the user interface for display in a new database query. In another embodiment, the database query takes into consideration at least one of filters and buffers pre-set by each participant.
The database may be associated with the remote server. It may be also be external and accessible by the remote server through a communication link. In an embodiment, the remote server may access more than one database to perform the database query.
In an embodiment, if no block of time is found during which all participants are free, the instructions stored in the memory cause the processor to display a message to that effect on the user interface.
In another embodiment, the user interface allows the organising participant to select at least one of start time and enter time for the search. In this embodiment, if no end time is chosen for the search and no block of time is found during which all participants are free, the search may be performed within an unlimited future time frame.
In another aspect, there is provided a method for scheduling a meeting of participants each having an identification and data entities associated with said identification which are synchronized with a database. The method comprises receiving identifications of participants from a user interface, communicating the identifications of participants to a remote server over a communication network, and upon the user interface receiving a database query, forwarding the database query to the remote server, for the remote server to perform a search of the database and process data entities associated with each participant to determine a block of time during which all of the participants are commonly free. The method also comprises receiving said block of time from the remote server, and outputting at least a portion of the block of time for display on the user interface.
In one embodiment, the method may comprise the steps of receiving a meeting duration from the user interface; and communicating the meeting duration to the remote server to determine a block of time which comprises the meeting duration.
In another embodiment, the method may comprise receiving a selection of the block of time; and booking the block of time on a calendar associated with a user of the user interface.
In yet another embodiment, the method may comprise receiving a meeting request from the user interface; and sending the meeting request to the participants.
In accordance with another aspect, there is provided a mobile application device for calendar sharing comprising: a mobile processor having an access to a remote server via a communication network; a user interface for receiving a contact identification from a user, and for displaying a contact calendar associated with the contact identification; and a memory operatively coupled to the mobile processor for storing instructions to be performed by the mobile processor, the instructions implementing the mobile processor to: receive the contact identification from the user interface; communicate an identification of the user and the contact identification to the remote server over the communication network; retrieve, from the remote server, the contact calendar when a setting associated with the contact calendar allows a sharing of the contact calendar with the user; and send the contact calendar to the user interface for display to the user.
In an embodiment, the user interface receives a scheduling request from the user, and the instructions cause the processor to: receive the scheduling request from the user and forward the same to the remote server to perform a search of the contact calendar to determine a block of time during which the user and a contact associated with the contact identification are both commonly free.
In accordance with a further aspect, there is provided a method for calendar sharing and scheduling over a communication network, the method comprising: communicating a user identification and a contact identification over the communication network, from a mobile phone to a remote server; retrieving from the remote server, a calendar sharing setting associated with the contact identification; retrieving from the remote server, a contact calendar corresponding to the contact identification based on the calendar sharing setting and the user identification; and displaying the contact calendar on a display of the mobile phone.
In an embodiment, the method further comprises synchronizing a user calendar and a user contact with calendar and contact information of an external application, the user calendar and the user contact being one of: stored locally and on the remote server in association with the user identification.
In another embodiment, the method comprises, upon reception of a scheduling request, searching the contact calendar and the user calendar to determine a block of time of a user-specified meeting duration, during which a user associated with the user identification and a contact associated with the contact identification are both commonly free.
In yet a further aspect, there is provided a graphical user interface (GUI) for calendar sharing and scheduling, comprising: a contact field for allowing a user to perform at least one of: selecting a contact and inputting an identification of the contact; a calendar field comprising a plurality of contact calendar fields and respective contact identification icons, each one of the contact identification icons identifying a respective one of the user and the contact, and the contact calendar fields each respectively displaying at least a synchronized portion of a user calendar and of a contact calendar, as retrieved based on the identification of the contact; the calendar field comprising a time block selection zone above the contact calendar fields, for allowing the user to select a block of time; and an invitation icon for sending a meeting request to the contact based the block of time selected.
In still another aspect, there is provided a method for processing data entities associated with identifications of a respective participant from a group of participants. The method comprising: receiving the identifications of the participants; receiving a start time and an end time identifying a given period; receiving, from at least two databases, the data entities associated with each participants; processing the data entities associated with each participant, the data entities associated with each participants having a free status associated with free blocks of time, to select a block of time, from the free blocks of time, which is common to the data entities of each participant having a free status during the given period; and outputting at least a portion of said block of time which is common for display on a user interface.
The embodiments discussed herein describe an application device and method for calendar sharing and scheduling over a communication network. When a meeting is to be scheduled between two or more participants, the organizing participant enters an identification of the participants and requests a time suggestion. In response to the request, information relating to the availability and/or preferences of each participant is gathered from one or more databases and processed centrally in a remote server to determine a block of time during which all the participants are commonly free. The block of time is pushed to a user interface for display. If the organizing user selects the block of time, a meeting request may be sent to the participants to confirm the meeting.
In reference to
The application device 102 has a memory 106, a processor 108, and a user interface 112. The processor 108 accesses the remote server system 104 over a communication network and via the communication device 110.
The user interface 112 receives user-input information by allowing a user to enter information via the I/O devices 114. For example, a user may interact with the device 100 via a touch screen, device buttons, and/or by manipulating the device when embodied as a handheld for example, in order to activate a movement sensor (aka accelerometer(s)) within the device 100 (e.g. by shaking, moving or rotating a mobile phone for example).
The user interface 112 allows a user to enter his/her user identification (ID), contact IDs, meeting duration(s); select participant(s) from a contact list to send participant(s)' IDs and to make meeting requests; make scheduling requests (aka database queries) to find blocks of time during which a meeting of participants could take place in accordance with the calendars of the contacts/participants (referred to as contact calendars) shared with the user. The user interface 112 also communicates with the I/O devices 114 to display the contact calendars and the user's calendar on a display of the device 100.
The scheduling request should not be confused with the meeting request. The scheduling request is also known as the database query. The database query is sent to the remote server to ask the server for time suggestions. Upon receipt of the database query, the server performs a search of database entities to find a block (or blocks) of time during which all participants are commonly free to suggest these to the user. The database query does not require input from the participants.
On the other hand, the meeting request which is also known as the meeting invitation, is sent to the participants and requires their input e.g. accept or reject etc. in order for the meeting to be confirmed or cancelled. The meeting request is performed after the database query, when the user selects a block of time suggested by the remote server to request the meeting from the participants.
The memory 106 communicates with the processor 108 and stores instructions to be performed by the processor 108. The instructions allow the processor 108 to perform a series of tasks as described in greater detail herein below.
The memory also stores the list of contacts with contact information such as contact IDs, respective telephone numbers, names, email addresses, SMS/MMS addresses, contact picture or avatar, contact calendars, and/or free/busy current statuses of the contacts, as well as calendar sharing settings which define the type of sharing between the user's calendar and the contact's calendar. Contact information is made accessible to the user for sending invitations to share calendars when the user and the contact are not sharing, place a call to the contact, send emails, SMS, MMS, and/or schedule meeting by sending a meeting request directly to the contact. The user interface 112 displays the relevant information on the device 100, coordinated by the processing device to achieve such actions. The memory caches respective contact information until a refresh occurs (e.g. resynchronization with the remote server system 104). The refreshing occurs upon startup of the application device 102 or may be performed manually by a user sending a refresh request via the user interface 112. The refreshing is performed not to block further interaction between the user interface 112 and the user. The user may thus pursue with meeting organization during refreshing.
It should be noted that the contact information can be retrieved from another contact tool used with the device 100, or entered manually by the user. When retrieved from another contact tool, matches between a user-entered or selected contact names, emails and other types of contact information are searched. Pictures or avatars corresponding to a contact are also transferable from the other tool to the application device 102.
Still in reference to
Although the example shown in
In an embodiment, each registered user has an identification and data entities associated with the identification. Such data entities include time information, ID of the user, preferences information, time zones, buffers and filters, calendar information etc.
For instance, the calendar information may include sharing settings, synchronized calendars, past scheduling requests, invitations sent, synchronized free/busy statuses, and/or any other pertinent profile information. Preferences information may include preferences based on the time (e.g. the user may prefer to have phone meetings in the afternoon, or they may prefer in-person meetings on selected days of the week, or they may prefer to be notified of the meeting few days before etc.), preferences based on the location (e.g. depending on the location of the user, or location of the meeting), preferences based on the type of the conference (by phone, by internet, by person etc.).
The users register such data entities with the remote server system 104 first when creating an account, and at each synchronization between calendar and contact information of any typical contact, email and time management tool used on the device 100.
In the embodiment as illustrated by
A user may also organize a meeting by entering a meeting duration and identifications of participants (by selecting contacts or entering contact IDs for example) via the user interface 112. In such a case, the identifications, including that of the user, are sent from the device 100 to the remote server system 104 to retrieve calendars of the participants which corresponding to the IDs when their respective sharing settings allow the sharing of their calendars with the user organizing the meeting. When the organizing user triggers or sends a scheduling request via the user interface 112, the processor 108 searches all the calendars being shared with the user to determine a block of time during which all of the participants are commonly free. The block of time has a start and end time defined by the meeting duration. Once the block of time is found, it is outputted to the user interface for display on the mobile phone 100. Multiple blocks of times can be searched and proposed to the user.
The searching optionally takes into consideration filters and buffers pre-set by each participant. This information is part of user and contact information as stored in the server system 104. Buffers allow users to insert free time blocks between meetings, ensuring smooth transition between scheduled meetings. Filters allow users to block certain time zones from ever being booked for a meeting.
In step 202, a user calendar stored on the remote server in association with the user identification, (and/or a local user calendar stored locally in a memory of the processing device being used—e.g. a mobile phone or a computer), are synchronized with calendar and contact information found in another external application. The other application can be any application used by the user such as an email application with calendar or agenda tools, or an address book.
In step 204, user identification and contact identification are communicated over a communication network, from a mobile phone to a remote server.
In step 206, a calendar sharing setting associated with the contact identification is retrieved from the remote server.
In step 208, a contact calendar corresponding to the contact identification is retrieved from the remote server based on the calendar sharing setting and the user identification.
In step 210, the contact calendar is displayed on a display of the mobile phone.
In step 212, upon reception of a scheduling request, the contact calendar and the user calendar are searched to determine a block of time of a user-specified meeting duration, during which the user and the contact are both commonly free. Many blocks of time can be proposed, according to a pre-set number, in a random or time-dependent manner. If the user is unsatisfied by returned proposed blocks of time, a new secluding request can be triggered by the user and the searching starts over. A following search may have a start time defined by the last block of time proposed. Alternatively, if the searching is randomized, previously proposed blocks of time are stored in association with the user in order to return only new time propositions.
In step 212, if no block of time is found, a message to this effect is outputted to the user. A user may initially define a given start and end time within which the search is to be performed. If no end time is entered by the user, the blocks of time searched are within an unlimited future time frame. User and contact-defined time filters are taken into account during the search. In addition, when sending a scheduling request, the user can request a given request mode, such as urgent, within this week, month, quarter, year, etc. When the mode is urgent, the earliest commonly free block(s) of time are proposed to the user.
In an embodiment, step 212 is performed independently of steps 202 to 210, and involves receiving a meeting duration and identifications of participants from a user interface and communicating these to a remote server. Upon the user sending a scheduling request, the scheduling request is forwarded to the remote server. The remote server then performs a search of the calendars of the participants, as retrieved from the identifications. The search is performed to determine a block of time comprising the meeting duration, and during which all of the participants are commonly free. In this case, step 212 also involves the reception of the results of the search (i.e. no blocks of time found or a list of times) from the server and their output for display.
The above-described application and method are adaptable to comprise a series of additional functionalities as provided by the below described examples. Different tabs allow different functionalities to a user, such as knowing the presence/status of contacts, schedule meetings, manage invitations, calendar sharing requests, and/or meeting conflicts, change user settings.
Now in reference to
As seen in
The contact icons can be edited by the user and selected to edit sharing settings with each contact, view contact information, see the contact calendar in a detailed view, and invite contacts which are not sharing any information to share their calendar.
All contact calendars are synchronized in time with a time block selection zone located above the contact calendar fields. The synchronization takes into account contact geographical addresses for time zone differences existing between users. This zone gives the time and date, and allows the user to select a block of time. Once a block of time is selected, a user's time block can be directly booked according to entered event details, a meeting request can be sent to selected contacts based on the block(s) of time selected. A send meeting request button (not shown in this view) allows the request to be sent.
In
The view of
When selected, the + sign in
Other GUI views are also available to help he user in managing invitations to share calendars (aka sharing requests), answer meeting invitations (aka meeting requests), manage meeting conflicts and ready to be booked meeting (when all the invitees have sent their availability), view upcoming booked meetings, edit user settings and information (username, password, default configurations, etc.).
Now referring to
Once the scheduling request is sent, various blocks of time are returned and listed as shown in
As exemplified in
In an embodiment, the time block selection zone is provided above the contact calendar fields.
As described earlier, the present application describes a method for scheduling a meeting of participants, and an application device for implementing the method.
Step 402 comprises receiving identifications of participants from a user interface. The identifications of participants may be entered by the user to select the participants with whom the user wants to meet. For example the user may select the participants using a keyboard, a touch screen, a voice command interface or any such means.
Step 404 comprises communicating the identifications of participants to a remote server over a communication network.
At step 406, a database query is received at the user interface. The database query is forwarded to the remote server to perform a search of the database and process data entities associated with each participant to determine a block of time during which all of the participants are commonly free.
It is important to note that steps 404 and 406 may be performed at the same time. However, the method is not limited to this scenario.
At step 408, the block of time found by the remote server is received from the remote server. At step 410, at least a portion of the block of time is output for display on the user interface. The block of time may be displayed as a table on the user interface. In an embodiment, the block of time may include a plurality of time intervals. These time intervals may be displayed in the table, for the user selection.
While preferred embodiments of the invention have been described above and illustrated in the accompanying drawings, it will be evident to those skilled in the art that modifications may be made therein without departing from the essence of this invention. Such modifications are considered as possible variants comprised in the scope of the invention.
This application claims priority under 35 USC §119(e) of U.S. provisional patent application 60/244,068, filed on Sep. 20, 2009, the specification of which is hereby incorporated by reference.
Number | Date | Country | |
---|---|---|---|
61244068 | Sep 2009 | US |