The present invention relates generally to electronic calendars and, more particularly, to managing flexible events in an electronic calendar.
Various electronic calendaring systems have been developed that enable users to make changes to an electronic schedule. Some electronic calendaring systems enable multiple users to access one another's electronic calendar to coordinate the scheduling of electronic calendar events.
In an aspect of the invention, a computer-implemented method includes: determining, by a computing device, that an electronic calendar event is a flexible event based on recording data of the electronic calendar event indicating that a recording of the electronic calendar event may be available; determining, by the computing device, an end date by which the electronic calendar event must be completed based on the scheduling data; and displaying, by the computing device, an electronic calendar with the electronic calendar event to a user.
In another aspect of the invention, there is a computer program product for managing flexible events in an electronic calendar. The computer program product comprises a computer readable storage medium having program instructions embodied therewith. The program instructions are executable by a computing device to cause the computing device to: receive scheduling data for an electronic calendar event, the scheduling data including recording data indicating that a recording of the electronic calendar event may be available; determine that the electronic calendar event is a flexible event based on the recording data; determine an end date by which the electronic calendar event must be completed based on the scheduling data; and displaying an electronic calendar with the electronic calendar event and indicia indicating that the electronic calendar event is a flexible event.
In another aspect of the invention, there is a system for managing flexible events in an electronic calendar. The system includes a CPU, a computer readable memory and a computer readable storage medium associated with a computing device. The system further includes program instructions to receive scheduling data for an electronic calendar event from a remote computing device, the scheduling data including recording data indicating that a recording of the electronic calendar event may be available; program instructions to determine that the electronic calendar event is a flexible event based on the recording data; program instructions to determine an end date by which the electronic calendar event must be completed based on the scheduling data; program instructions to updating the electronic calendar with the electronic calendar event, wherein the electronic calendar event includes indicia indicating that the electronic calendar event is a flexible event; and program instructions to display the electronic calendar event to a user as a flexible event, wherein the program instructions are stored on the computer readable storage medium for execution by the CPU via the computer readable memory.
The present invention is described in the detailed description which follows, in reference to the noted plurality of drawings by way of non-limiting examples of exemplary embodiments of the present invention.
The present invention relates generally to electronic calendars and, more particularly, to managing flexible events in an electronic calendar. In embodiments, a system provides for automatically managing rescheduling of calendar events that have been deemed “flexible” to enable the scheduling of less flexible events in their place. A “flexible” calendar event may be one that meets one or more of the following criteria: the event is deemed flexible when it is scheduled; the event is tagged as flexible when it is accepted into a user's electronic calendar; the event is detected to be flexible based on keywords that are entered into a user's profile/setting; or the event has a recording that can be replayed later, where the user is prompted to check if the event should be designated as flexible. In aspects, a host of an event is able to view multiple electronic calendars of respective users, and is able to distinguish flexible events from non-flexible events based on a visual indicator. In embodiments, when a new calendar event is accepted by a user of an electronic calendar, but the new event overlaps with a previously scheduled flexible calendar event, a system of the invention automatically reschedules the flexible calendar event for a time period that is open (available) on the user's electronic calendar. In aspects, by enabling users to visually distinguish flexible calendar events from non-flexible calendar events, the system provides more opportunities for scheduling calendar events in a manner that is acceptable for all event participants. In embodiments, flexible calendar events are only designated as “flexible” for a predetermined period of time, after which the system automatically adjusts the designation of the calendar event to a non-flexible calendar event.
When calendaring lower priority meetings or events, such as education events in the form of seminars, webinars, or the like, there may arise a conflict with higher priority meetings or tasks. Embodiments of the invention provide a method to clear a user's calendar for a particular time period, but not lose the lower priority tasks scheduled during the time period. In embodiments, a system is provided that enables a user to select a time period to reschedule a meeting that is naturally more flexible, such as events that have been established with a replay channel/URL before a live event. In embodiments, a system is provided to enable a user to select a check box to automatically move a flexible event to a first available time slot on an electronic calendar within a predetermined time range/time period.
The present invention may be a system, a method, and/or a computer program product at any possible technical detail level of integration. The computer program product may include a computer readable storage medium (or media) having computer readable program instructions thereon for causing a processor to carry out aspects of the present invention.
The computer readable storage medium can be a tangible device that can retain and store instructions for use by an instruction execution device. The computer readable storage medium may be, for example, but is not limited to, an electronic storage device, a magnetic storage device, an optical storage device, an electromagnetic storage device, a semiconductor storage device, or any suitable combination of the foregoing. A non-exhaustive list of more specific examples of the computer readable storage medium includes the following: a portable computer diskette, a hard disk, a random access memory (RAM), a read-only memory (ROM), an erasable programmable read-only memory (EPROM or Flash memory), a static random access memory (SRAM), a portable compact disc read-only memory (CD-ROM), a digital versatile disk (DVD), a memory stick, a floppy disk, a mechanically encoded device such as punch-cards or raised structures in a groove having instructions recorded thereon, and any suitable combination of the foregoing. A computer readable storage medium, as used herein, is not to be construed as being transitory signals per se, such as radio waves or other freely propagating electromagnetic waves, electromagnetic waves propagating through a waveguide or other transmission media (e.g., light pulses passing through a fiber-optic cable), or electrical signals transmitted through a wire.
Computer readable program instructions described herein can be downloaded to respective computing/processing devices from a computer readable storage medium or to an external computer or external storage device via a network, for example, the Internet, a local area network, a wide area network and/or a wireless network. The network may comprise copper transmission cables, optical transmission fibers, wireless transmission, routers, firewalls, switches, gateway computers and/or edge servers. A network adapter card or network interface in each computing/processing device receives computer readable program instructions from the network and forwards the computer readable program instructions for storage in a computer readable storage medium within the respective computing/processing device.
Computer readable program instructions for carrying out operations of the present invention may be assembler instructions, instruction-set-architecture (ISA) instructions, machine instructions, machine dependent instructions, microcode, firmware instructions, state-setting data, configuration data for integrated circuitry, or either source code or object code written in any combination of one or more programming languages, including an object oriented programming language such as Smalltalk, C++, or the like, and procedural programming languages, such as the “C” programming language or similar programming languages. The computer readable program instructions may execute entirely on the user's computer, partly on the user's computer, as a stand-alone software package, partly on the user's computer and partly on a remote computer or entirely on the remote computer or server. In the latter scenario, the remote computer may be connected to the user's computer through any type of network, including a local area network (LAN) or a wide area network (WAN), or the connection may be made to an external computer (for example, through the Internet using an Internet Service Provider). In some embodiments, electronic circuitry including, for example, programmable logic circuitry, field-programmable gate arrays (FPGA), or programmable logic arrays (PLA) may execute the computer readable program instructions by utilizing state information of the computer readable program instructions to personalize the electronic circuitry, in order to perform aspects of the present invention.
Aspects of the present invention are described herein with reference to flowchart illustrations and/or block diagrams of methods, apparatus (systems), and computer program products according to embodiments of the invention. It will be understood that each block of the flowchart illustrations and/or block diagrams, and combinations of blocks in the flowchart illustrations and/or block diagrams, can be implemented by computer readable program instructions.
These computer readable program instructions may be provided to a processor of a general purpose computer, special purpose computer, or other programmable data processing apparatus to produce a machine, such that the instructions, which execute via the processor of the computer or other programmable data processing apparatus, create means for implementing the functions/acts specified in the flowchart and/or block diagram block or blocks. These computer readable program instructions may also be stored in a computer readable storage medium that can direct a computer, a programmable data processing apparatus, and/or other devices to function in a particular manner, such that the computer readable storage medium having instructions stored therein comprises an article of manufacture including instructions which implement aspects of the function/act specified in the flowchart and/or block diagram block or blocks.
The computer readable program instructions may also be loaded onto a computer, other programmable data processing apparatus, or other device to cause a series of operational steps to be performed on the computer, other programmable apparatus or other device to produce a computer implemented process, such that the instructions which execute on the computer, other programmable apparatus, or other device implement the functions/acts specified in the flowchart and/or block diagram block or blocks.
The flowchart and block diagrams in the Figures illustrate the architecture, functionality, and operation of possible implementations of systems, methods, and computer program products according to various embodiments of the present invention. In this regard, each block in the flowchart or block diagrams may represent a module, segment, or portion of instructions, which comprises one or more executable instructions for implementing the specified logical function(s). In some alternative implementations, the functions noted in the blocks may occur out of the order noted in the Figures. For example, two blocks shown in succession may, in fact, be executed substantially concurrently, or the blocks may sometimes be executed in the reverse order, depending upon the functionality involved. It will also be noted that each block of the block diagrams and/or flowchart illustration, and combinations of blocks in the block diagrams and/or flowchart illustration, can be implemented by special purpose hardware-based systems that perform the specified functions or acts or carry out combinations of special purpose hardware and computer instructions.
Referring now to
In computing infrastructure 10 there is a computer system (or server) 12, which is operational with numerous other general purpose or special purpose computing system environments or configurations. Examples of well-known computing systems, environments, and/or configurations that may be suitable for use with computer system 12 include, but are not limited to, personal computer systems, server computer systems, thin clients, thick clients, hand-held or laptop devices, multiprocessor systems, microprocessor-based systems, set top boxes, programmable consumer electronics, network PCs, minicomputer systems, mainframe computer systems, and distributed cloud computing environments that include any of the above systems or devices, and the like.
Computer system 12 may be described in the general context of computer system executable instructions, such as program modules, being executed by a computer system. Generally, program modules may include routines, programs, objects, components, logic, data structures, and so on that perform particular tasks or implement particular abstract data types. Computer system 12 may be practiced in distributed cloud computing environments where tasks are performed by remote processing devices that are linked through a communications network. In a distributed cloud computing environment, program modules may be located in both local and remote computer system storage media including memory storage devices.
As shown in
Bus 18 represents one or more of any of several types of bus structures, including a memory bus or memory controller, a peripheral bus, an accelerated graphics port, and a processor or local bus using any of a variety of bus architectures. By way of example, and not limitation, such architectures include Industry Standard Architecture (ISA) bus, Micro Channel Architecture (MCA) bus, Enhanced ISA (EISA) bus, Video Electronics Standards Association (VESA) local bus, and Peripheral Component Interconnects (PCI) bus.
Computer system 12 typically includes a variety of computer system readable media. Such media may be any available media that is accessible by computer system 12, and it includes both volatile and non-volatile media, removable and non-removable media.
System memory 28 can include computer system readable media in the form of volatile memory, such as random access memory (RAM) 30 and/or cache memory 32. Computer system 12 may further include other removable/non-removable, volatile/non-volatile computer system storage media. By way of example only, storage system 34 can be provided for reading from and writing to a nonremovable, non-volatile magnetic media (not shown and typically called a “hard drive”). Although not shown, a magnetic disk drive for reading from and writing to a removable, non-volatile magnetic disk (e.g., a “floppy disk”), and an optical disk drive for reading from or writing to a removable, non-volatile optical disk such as a CD-ROM, DVD-ROM or other optical media can be provided. In such instances, each can be connected to bus 18 by one or more data media interfaces. As will be further depicted and described below, memory 28 may include at least one program product having a set (e.g., at least one) of program modules that are configured to carry out the functions of embodiments of the invention.
Program/utility 40, having a set (at least one) of program modules 42, may be stored in memory 28 by way of example, and not limitation, as well as an operating system, one or more application programs, other program modules, and program data. Each of the operating system, one or more application programs, other program modules, and program data or some combination thereof, may include an implementation of a networking environment. Program modules 42 generally carry out the functions and/or methodologies of embodiments of the invention as described herein.
Computer system 12 may also communicate with one or more external devices 14 such as a keyboard, a pointing device, a display 24, etc.; one or more devices that enable a user to interact with computer system 12; and/or any devices (e.g., network card, modem, etc.) that enable computer system 12 to communicate with one or more other computing devices. Such communication can occur via Input/Output (I/O) interfaces 22. Still yet, computer system 12 can communicate with one or more networks such as a local area network (LAN), a general wide area network (WAN), and/or a public network (e.g., the Internet) via network adapter 20. As depicted, network adapter 20 communicates with the other components of computer system 12 via bus 18. It should be understood that although not shown, other hardware and/or software components could be used in conjunction with computer system 12. Examples, include, but are not limited to: microcode, device drivers, redundant processing units, external disk drive arrays, RAID systems, tape drives, and data archival storage systems, etc.
Still referring to
The network 55 may be any suitable communication network or combination of networks, such as a local area network (LAN), a general wide area network (WAN), and/or a public network (e.g., the Internet). Electronic calendar modules 61 and 71 may communicate with one another via the network 55. Alternatively, a scheduling server 80 may manage communications between electronic calendar modules 61 and 71 of the respective user computer devices 60 and 70 via the network 55. The scheduling server 80 may comprise components of the computer system 12 of
In embodiments, the scheduling server 80 includes a distributed calendar module 81 configured to perform one or more of the functions described herein. The distributed calendar module 81 may include one or more program modules (e.g., program module 42 of
At step 300, a user computer device 60 receives user profile data for an electronic calendar system. In embodiments, the user computer device 60 may present a user with options to configure rules of the electronic calendar module 61. For example, a user may enter parameters for moving a flexible event within the user's electronic calendar, such as the number of hours a flexible event may be moved, or how far into the future a flexible event may be moved. In aspects, the user computer device 60 receives parameters from a user designating how a flexible event should be presented to others viewing the flexible event (e.g., an administrator scheduling group events across multiple electronic calendars). As used herein the term flexible event means an event that can be automatically moved from a first schedule location on an electronic calendar to a second (e.g., future) open schedule location on the electronic calendar within time constraints associated with the flexible event. In embodiments, the electronic calendar module 61 enables a user to set limits on the number of total meetings or flexible meetings that can be moved within a given timeframe. In aspects, a graphical user interface of the user computer device 60 may enable a user to override any rules or parameters stored with the user profile data.
At step 301, a user computer device 60 receives scheduling data for a calendar event to be scheduled. In aspects, the scheduling data may be entered into the user computer device 60 by the user of the electronic calendar. In embodiments, the user computer device 60 receives the scheduling data from another user computer device 70 through the network 55. In an alternative embodiment, the user computer device 60 receives the scheduling data from the scheduling server 80 via the network 55. In aspects, the electronic calendar module 61 of the user computer device 60 receives the scheduling data from one of the scheduling server 80 and another user computer device 70 via the network 55. In embodiments, the scheduling data includes recording data indicating that a recording of the electronic calendar event may be available. Recording data may include, for example: an established replay channel/URL; metadata such as “meeting recording availability”; or keywords demonstrating flexibility of an event such as “recorded”, “self paced study”, etc.
At step 302, the user computer device 60 determines that the electronic calendar event is a flexible event. In aspects, the electronic calendar module 61 determines the calendar event is a flexible event based on one of the following: received scheduling data indicating that the event is flexible; scheduling data added by a user of the calendar indicating that the event is flexible (e.g., event is tagged by the user as flexible); electronic calendar module 61 automatically detecting that the event is flexible based on keyword recognition (e.g., user profile setting includes rules designating certain keywords as indicating a flexible event); or electronic calendar module 61 automatically detecting that the event is associated with a recording based on recording data. In embodiments, a user may tag an electronic calendar event as a flexible event when accepting the electronic calendar event (e.g., accepting an invitation to schedule the electronic calendar event) or when editing the electronic calendar event in the user's electronic calendar. In this case, the user computer device 60 would determine that the electronic calendar event is a flexible event based on the user's tag.
In aspects, the flexible event is an event associated with recorded data or recorded replays (e.g., a digital video) to be viewed by a user during the event, wherein the pre-recorded data may be viewed by the user within a predetermined time frame (e.g., by a viewing deadline). In embodiments, the user computer device 60 analyzes the scheduling data to determine that the event to be scheduled is associated with recorded data, and is therefore considered a flexible event. For example, the electronic calendar module 61 may utilize natural language processing to recognize keywords (e.g., recorded, self paced study, etc.) in the scheduling data that indicate that pre-recorded data is available for the electronic calendar event at issue. In embodiments, the electronic calendar module 61 determines that the electronic calendar event is a flexible event by determining that metadata in the scheduling data indicates that a recording or possible recording of the electronic calendar event is available. For example, the electronic calendar module 61 may recognize that the metadata includes “meeting recording availability” data.
At step 303, the user computer device 60 determines an end date by which the electronic calendar event (flexible event) from step 302 must be completed. For example, the electronic calendar module 61 may determine that metadata in the scheduling data indicates a “meeting recording availability through May 7, 2017”, and determines that the end date by which the electronic calendar event must be completed is May 7, 2017. In embodiments, a user may edit the electronic calendar event in the user's electronic calendar to indicate an end date. In this case, the user computer device 60 would determine the end date based on the user's edits to the electronic calendar event. Step 303 may be performed simultaneously with step 302, such as when metadata in the scheduling data indicates that the electronic calendar event is associated with a recording that has an associated “view by” date (e.g., view by May 7, 2017).
Optionally, at step 304, the user computer device 60 presents a user with an option to confirm that the electronic calendar event is a flexible event (i.e., requests confirmation of a flexible event designation). In aspects, the option to confirm includes an indication of the end date of the flexible event, determined at step 301. In embodiments, the electronic calendar module 71 prompts a user for confirmation that the event is a flexible event. In embodiments, the electronic calendar module 71 also prompts the user for a timeline within which the event must be completed (e.g., deadline for completion), if any. In this embodiment, step 303 is completed after the user computer device receives the timeline information from the user. Alternatively, the electronic calendar module may automatically recognize the end date by which the event must be completed (deadline) at step 303, and may present the end date to a user when prompting the user to confirm that the event is a flexible event at step 304.
At step 305, the user computer device 60 receives confirmation that the electronic calendar event is a flexible event, based on the option to confirm presented to the user at step 304. In embodiments, the user computer device 60 also receives confirmation of the end date determined at step 303. In aspects, the electronic calendar module 61 receives the user confirmation. In alternative embodiments, once the user computer device 60 receives the confirmation from the user that the electronic calendar event is a flexible event, the user computer device 60 prompts the user to enter a deadline by which the flexible event must take place in accordance with step 303.
At step 306, the user computer device 60 updates the electronic calendar of the user with the electronic calendar event (flexible event) and associated end date information (deadline, completion date, etc.). In embodiments, the electronic calendar module 71 recognizes receipt of the confirmation from step 305, and records the event in the user's electronic calendar as a flexible event. In aspects, electronic calendar event includes indicia indicating that the electronic calendar event is a flexible event, such as a color designation, an icon, a symbol, a border, or other visual representation of the flexible event designation. In embodiments, the electronic calendar event includes indicia indicating the end date by which the electronic calendar event must be completed.
At step 307, the user computer device 60 displays the electronic calendar event to a user as a flexible event. In embodiments, indicia (color designation, an icon, or other visual indicator) associated with the displayed electronic calendar event indicates that the electronic calendar event is a flexible event. In embodiments, the user computer device 60 displays the end date determined at step 303 as part of the display of the electronic calendar event.
At step 308, the user computer device 60 automatically updates the flexible event designation of the electronic calendar event and the display of the electronic calendar event, as necessary, based on stored rules. In embodiments, the user computer device 60 automatically removes a flexible event designation if the electronic calendar module 61 determines that the electronic calendar event can no longer be moved from the current schedule location to a future open schedule location, such as when no future open schedule location exists before the end date. For example, if a stored rule indicates that an electronic calendar event can no longer be designated as a flexible event if there are no calendar openings between its current location on an electronic calendar and the end date, and the user computer device 60 determines that no future open schedule locations are available before the end date, then the user computer device 60 automatically updates the electronic calendar event to indicate that it is a non-movable or non-flexible event, removes any indicia indicating that the electronic calendar event is a flexible event, and automatically presents an updated depiction of the electronic calendar event in an electronic calendar interface. It should be understood that steps 300-308 may be broken into more or less steps than those illustrated in
An example of scheduling a flexible event in accordance with embodiments of the invention is described with reference to
At step 400, a user computer device 70 receives a request to schedule a new event, including invitee data. The term new event as used herein may include a new event to be entered into one or more electronic calendars of invitees, or a pre-existing calendar event that is being rescheduled or moved within the one or more electronic calendars of the invitees. By way of example, an administrator at the user computer device 70 may enter a list of users (invitees) to be invited to the new event and a date range for the event into the user computer device 70. In aspects, the request to schedule a new event may comprise a user clicking on a date within their electronic calendar, wherein the invitee data includes only the user themselves.
At step 401, the user computer device 70 receives scheduling options from the electronic calendars of one or more invitees. For example, the user computer device 70 may receive copies of portions of the electronic calendars of one or more invitees (e.g., interface showing weekly calendars of the one or more invitees, with scheduling events and open schedule locations). The scheduling options are not limited to any particular calendar data configuration, and may include any data configuration that enables an administrator or user to determine availability of one or more invitees for scheduling purposes. In embodiments, the electronic calendar module 71 may retrieve scheduling options from the scheduling server 80 via the network 55. In aspects, the scheduling options are in the form of an electronic calendar interface for a sole user of the user computer device 70, wherein the user computer device 70 receives scheduling options in the form of the user's electronic calendar interface (e.g., interface showing weekly calendar of user with scheduled events and open schedule locations).
At step 402, the user computer device 70 displays the scheduling options to a user, such as through a user display 24 of
At step 403, the user computer device 70 receives a scheduling selection for a new event to be scheduled in the electronic calendars of one or more of the invitees. In embodiments, the electronic calendar module 71 recognizes that a user has entered a scheduling selection into a user interface of the user computer device 70. For example, the electronic calendar module 71 may determine that an administrator has selected a meeting date of May 6, 2017 between 10:30 AM and 1:30 PM for one or more invitees.
At step 404, the user computer device 70 issues one or more requests to schedule the new event. In embodiments, the electronic calendar module 71 sends the requests to one or more user computer device (e.g., 60) through the scheduling server 80 via the network 55. In alternative embodiments, the electronic calendar module 71 sends the requests directly to one or more user computer device (e.g., 60) via the network 55.
At step 405, the user computer device 60 receives the request to schedule the new event issued by the user computer device 70 at step 311. In embodiments, the user computer device 60 receives the request from the scheduling server 80 via the network 55. In alternative embodiments, the user computer device 60 receives the request directly from the user computer device 70 via the network 55.
Optionally, at step 406, the user computer device 60 displays an option to accept the invitation to schedule the new event. For example, the user computer device 60 may display the invitation to a user of the user computer device 60 through an email invitation or the like. Alternatively, the electronic calendar module 61 of the user computer device 60 may be configured to automatically accept a request to schedule the new event.
Optionally, at step 407, the user computer device 60 receives acceptance of the invitation to schedule the new event. For example, the user computer device 60 may determine that a user has clicked on an “accept” button or on a link to accept the invitations to schedule the new event, even though the new event conflicts with the electronic calendar event (flexible event) previously scheduled at step 306 of
At step 408, the user computer device 60 automatically reschedules the previously recorded electronic calendar event (flexible event), when the electronic calendar event conflicts with the new event. In embodiment, the electronic calendar module 61 determines that the new event conflicts with the electronic calendar event (e.g., the new event overlaps in time with at least a portion of the electronic calendar event) and automatically reschedules the electronic calendar event by moving the electronic calendar event from a first location to an open second location on the electronic calendar, wherein the open second location is a location prior to the end date (deadline) determined at step 303 of
At step 409, the user computer device 60 displays the updated electronic calendar to the user. In embodiments, the electronic calendar module 61 causes the electronic calendar display to be updated such that the user views the changes to the electronic calendar imparted by the automatic rescheduling in step 408.
At step 410, the user computer device 60 automatically updates the flexible event designation of the electronic calendar event, as needed. In embodiments, the electronic calendar module 61 determines that the no open locations remain on the electronic calendar between the second location and the end date associated with the electronic calendar event, and updates the electronic calendar to indicate that the electronic calendar event is no longer a flexible event (e.g., removes indicia indicating the electronic calendar event is a flexible event and records the electronic calendar event as a non-flexible event).
In another use scenario, an administrator wishes to schedule a meeting with several invitees (parties). The administrator enters a request into a user interface of the user computer device 70 for scheduling options for the invitees, in accordance with step 400 of
It should be understood that steps 400-409 may be performed in the context of a sole user being both the administrator and an invitee. For example, a user computer device 60 may receive a request to schedule a new event (step 400) in the form of a user opening their calendar and entering new event data into the electronic calendar, wherein the new event conflicts with a scheduled flexible event. In this scenario, the step of receiving scheduling options (step 401) may be in the form of the electronic calendar module 61 retrieving scheduling options from a database and then presenting an electronic calendar interface to a user in accordance with step 402. The step of receiving a schedule selection for the new event (step 403) may comprise the user entering the calendar data at step 400, wherein the user computer device 60 may issue a request to the electronic calendar module 61 to schedule the new event (step 404), the electronic calendar module 61 may receive the request (step 405), and the electronic calendar module 61 may automatically reschedule the flexible event based on the user's schedule (step 408).
In the use scenario illustrated in
Referring to
Advantageously, embodiments of the present invention provide improvements to electronic calendaring systems by enabling an administrator to schedule or reschedule a new electronic calendar event with multiple invitees, each utilizing a different user computer device (e.g., 60, 70), by providing automatic rescheduling of conflicting flexible events in the electronic calendars of each of the multiple invitees. Aspects of the invention thus eliminate the need for the multiple invitees (often at remote locations) to participate in the rescheduling of a conflicting flexible event in their respective electronic calendars. Moreover, aspects of the invention provide for automatic detection of a flexible calendar event by a user's computer device utilizing metadata or other scheduling data provided by another user computer device. Further, embodiments of the invention cause a user computer device to automatically update the manner in which it displays an electronic calendar event to a user, to impart additional information to the user regarding the flexible or non-flexible nature of the electronic calendar event.
In embodiments, a service provider could offer to perform the processes described herein. In this case, the service provider can create, maintain, deploy, support, etc., the computer infrastructure that performs the process steps of the invention for one or more customers. These customers may be, for example, any business that uses electronic calendaring systems. In return, the service provider can receive payment from the customer(s) under a subscription and/or fee agreement and/or the service provider can receive payment from the sale of advertising content to one or more third parties.
In still another embodiment, the invention provides a computer-implemented method for managing flexible events in an electronic calendar. In this case, a computer infrastructure, such as computer system 12 (
The descriptions of the various embodiments of the present invention have been presented for purposes of illustration, but are not intended to be exhaustive or limited to the embodiments disclosed. Many modifications and variations will be apparent to those of ordinary skill in the art without departing from the scope and spirit of the described embodiments. The terminology used herein was chosen to best explain the principles of the embodiments, the practical application or technical improvement over technologies found in the marketplace, or to enable others of ordinary skill in the art to understand the embodiments disclosed herein.
Number | Name | Date | Kind |
---|---|---|---|
5270920 | Pearse | Dec 1993 | A |
5572728 | Tada | Nov 1996 | A |
5692125 | Schloss | Nov 1997 | A |
5727950 | Cook | Mar 1998 | A |
5899979 | Miller | May 1999 | A |
6047260 | Levinson | Apr 2000 | A |
6119147 | Toomey | Sep 2000 | A |
6438353 | Casey-Cholakis | Aug 2002 | B1 |
6487585 | Yurkovic | Nov 2002 | B1 |
6661877 | Lee | Dec 2003 | B1 |
7512454 | Li | Mar 2009 | B1 |
7703048 | Alford, Jr. | Apr 2010 | B2 |
8060567 | Carroll | Nov 2011 | B2 |
8180662 | Minert | May 2012 | B2 |
8180663 | Tischhauser | May 2012 | B2 |
8535059 | Noble, Jr. | Sep 2013 | B1 |
8560371 | Levitt | Oct 2013 | B2 |
8681808 | Tessier | Mar 2014 | B1 |
8743171 | Hiller | Jun 2014 | B2 |
8843558 | Murphy, Jr. | Sep 2014 | B2 |
9053500 | Etesse | Jun 2015 | B2 |
9152953 | Lai | Oct 2015 | B2 |
9253330 | Boss et al. | Feb 2016 | B2 |
9348897 | Shoham | May 2016 | B2 |
9559847 | Hurst | Jan 2017 | B2 |
9626659 | Bathiya | Apr 2017 | B2 |
9660824 | Shi | May 2017 | B2 |
9679274 | Roth | Jun 2017 | B1 |
9680775 | Sirota | Jun 2017 | B2 |
10027796 | Almog | Jul 2018 | B1 |
10062057 | Kitada | Aug 2018 | B2 |
10074078 | Siegel | Sep 2018 | B2 |
10102198 | Astigarraga | Oct 2018 | B2 |
10241654 | Meyer | Mar 2019 | B2 |
10565564 | Bender | Feb 2020 | B2 |
20010049617 | Berenson | Dec 2001 | A1 |
20020059373 | Boys | May 2002 | A1 |
20020188607 | Kogut-O'Connell | Dec 2002 | A1 |
20030120516 | Perednia | Jun 2003 | A1 |
20030149606 | Cragun | Aug 2003 | A1 |
20030152904 | Doty | Aug 2003 | A1 |
20030169330 | Ben-Shachar | Sep 2003 | A1 |
20030204474 | Capek | Oct 2003 | A1 |
20050065832 | Virta | Mar 2005 | A1 |
20050076037 | Shen | Apr 2005 | A1 |
20050165631 | Horvitz | Jul 2005 | A1 |
20050256754 | Nastacio | Nov 2005 | A1 |
20050278632 | McKethan, Jr. | Dec 2005 | A1 |
20060010023 | Tromczynski | Jan 2006 | A1 |
20060271399 | Robson, Sr. | Nov 2006 | A1 |
20070112926 | Brett | May 2007 | A1 |
20070300163 | Alford | Dec 2007 | A1 |
20080028317 | Castelli | Jan 2008 | A1 |
20080037721 | Yao | Feb 2008 | A1 |
20080040187 | Carraher | Feb 2008 | A1 |
20080046437 | Wood | Feb 2008 | A1 |
20080059265 | Biazetti | Mar 2008 | A1 |
20080059618 | May | Mar 2008 | A1 |
20080141247 | Saravanan | Jun 2008 | A1 |
20080168113 | Hickling | Jul 2008 | A1 |
20080175104 | Grieb | Jul 2008 | A1 |
20080198979 | Skakkebaek | Aug 2008 | A1 |
20080243582 | Chen | Oct 2008 | A1 |
20080307323 | Coffman | Dec 2008 | A1 |
20090006410 | Choi | Jan 2009 | A1 |
20090132329 | Lam | May 2009 | A1 |
20090165022 | Madsen | Jun 2009 | A1 |
20090292625 | King | Nov 2009 | A1 |
20100088143 | Platt | Apr 2010 | A1 |
20100153160 | Bezemer | Jun 2010 | A1 |
20100211424 | Hill | Aug 2010 | A1 |
20120150956 | Tucker | Jun 2012 | A1 |
20120203551 | Lakshmanan | Aug 2012 | A1 |
20120209860 | Gummagatta | Aug 2012 | A1 |
20120239451 | Caligor | Sep 2012 | A1 |
20130063542 | Bhat | Mar 2013 | A1 |
20130073329 | Shoham | Mar 2013 | A1 |
20130282421 | Graff | Oct 2013 | A1 |
20130325972 | Boston | Dec 2013 | A1 |
20140006082 | Harms | Jan 2014 | A1 |
20140200940 | Putterman | Jul 2014 | A1 |
20140379407 | Horton | Dec 2014 | A1 |
20150127403 | Petty | May 2015 | A1 |
20150142895 | Beran | May 2015 | A1 |
20150199653 | Cili | Jul 2015 | A1 |
20150200786 | Stott | Jul 2015 | A1 |
20150227879 | Bertanzetti | Aug 2015 | A1 |
20150254518 | Griffin | Sep 2015 | A1 |
20150324754 | Bathiya | Nov 2015 | A1 |
20160027442 | Burton | Jan 2016 | A1 |
20160217432 | Yavor | Jul 2016 | A1 |
20160267439 | Bitran | Sep 2016 | A1 |
20160292651 | Bathiya | Oct 2016 | A1 |
20160335572 | Bennett | Nov 2016 | A1 |
20160344673 | Abou Mahmoud | Nov 2016 | A1 |
20160350720 | Moorjani | Dec 2016 | A1 |
20170059337 | Barker | Mar 2017 | A1 |
20170199866 | Gunaratna et al. | Jul 2017 | A1 |
20170249596 | Weir | Aug 2017 | A1 |
20170286853 | Liensberger | Oct 2017 | A1 |
20170358305 | Kudurshian | Dec 2017 | A1 |
20180039478 | Sung | Feb 2018 | A1 |
20180091459 | Bastide | Mar 2018 | A1 |
20180101761 | Nelson | Apr 2018 | A1 |
20180191907 | Herrin | Jul 2018 | A1 |
20180234545 | Barak | Aug 2018 | A1 |
20180260785 | Bender | Sep 2018 | A1 |
20210027253 | Gray | Jan 2021 | A1 |
Number | Date | Country |
---|---|---|
2016081325 | May 2016 | WO |
Entry |
---|
Padwick et al., Special Edition Using Microsoft Outlook 2000 Que, May 12, 1999 (Year: 1999). |
Buseman, Stephan et al., Natural Language Dialogue Service for Appointment Scheduling Agents ANLC '97 Proceedings of the fifth conference on Applied natural language processing, 1997 (Year: 1997), 8 pages. |
Maddix, Nicholas, A Comparison of Text Importing Tools for Users of Palm Compatible PDAs Textual, 2001 (Year: 2001), 11 pages. |
Refanidis, Ioannis et al., On Scheduling Events and Tasks by an Intelligent Calendar Assistant Association for the Advancement of Artificial Intelligence, 2009 (Year: 2009), 10 pages. |
List of IBM Patents or Patent Applications Treated as Related, dated Nov. 25, 2019, 1 page. |
Number | Date | Country | |
---|---|---|---|
20200090134 A1 | Mar 2020 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 15453075 | Mar 2017 | US |
Child | 16693951 | US |