Electronically presented calendars include entries with information about events. The events may include locations, dates, times, participants, or other details. Some calendars provide scheduling options, such as appointments, meetings, video conferencing, telephony, or the like. An electronic calendar may be presented in a calendar user interface. A calendar user interface may be a stand-alone app or integrated into another app, such as a communications app.
In the drawings, which are not necessarily drawn to scale, like numerals may describe similar components in different views. Like numerals having different letter suffixes may represent different instances of similar components. The drawings illustrate generally, by way of example, but not by way of limitation, various embodiments discussed in the present document.
Systems and methods for presenting a calendar user interface are described herein. The calendar user interface may display entries of a primary calendar. The primary calendar may be determined based on a current context, such as based on a user login, a current user attribute (e.g., selection, type of user, credentials, etc.), a time of day, an app context (e.g., based on a chat conversation or a video conference), a location (e.g., work, home, etc.), or the like. One or more secondary calendars may be associated with the primary calendar or the user. The one or more secondary calendars may be user selected or generated based on context information.
In an example, these systems and methods may be used to display a primary calendar and an associated secondary calendar in a minimized view or in an expanded view. The minimized view may include displaying one or more awareness indicators on a calendar user interface that is also displaying events of the primary calendar. The awareness indicators correspond to events on the secondary calendar. More than one secondary calendar may correspond to the primary calendar and respective awareness indicators may correspond to one or more of the secondary calendars. The awareness indicators may be small indicators of events that are displayed visually distinct from events of the primary calendar. In an example the awareness indicators may be expanded to include additional details not shown in the minimized view.
In an example, systems and methods described herein may be used to block off a time slot on a secondary calendar via an entry on a primary calendar. The time slot may be automatically blocked off on the secondary calendar when an entry is configured (e.g., generated or modified) on the primary calendar. In order to block off the time slot, an entry on the secondary calendar may be generated. The entry on the secondary calendar may have fewer details than the entry on the primary calendar (e.g., as little as the time or as much as leaving out a single detail, such as content of a meeting, or the like). The entry on the secondary calendar may be tied to the entry on the primary calendar (e.g., be conditional on the entry in the primary calendar). For example, when the entry on the primary calendar is changed, the entry on the secondary calendar may be automatically changed.
In an example, a user may configure a rule for blocking off time slots on one or more secondary calendars. For example, blocking off may occur only when certain conditions are met, such as a time of day, a type of entry, a user selection to block off the time slot occurs, a particular person is on a meeting invite, or the like. The blocking off may occur when a user selects an option block off the time slot (e.g., by long pressing or right clicking or the like) on the entry on the primary calendar.
The systems and methods described herein solve technical problems related to visualization and processing of multiple calendars for a user. One example technical solution described herein provides a user interface to display aspects of multiple calendars (e.g., an improvement in current calendar display technology that results in a technical effect of displaying awareness indicators of a second calendar in a primary calendar user interface). Another technical solution described herein provides a technique for sharing limited information from one calendar to another, for example by blocking off a time entry in a secondary calendar the time entry corresponding to a calendar entry in a primary calendar. The blocking off of the time entry provides a technical effect of preventing a user from entering a calendar entry on a secondary calendar that conflicts with an entry on a primary calendar (e.g., with a prompt). This example may provide a visual representation, on a secondary calendar user interface, of an entry of a primary calendar without sharing potentially sensitive details from the entry of the primary calendar.
The calendar user interface first state 100A of
In an example, awareness indicators corresponding to a particular secondary calendar (e.g., 104A-104C) may include a color or identifying mark signifying that the awareness indicators (e.g., 104A-C) all belong to that particular secondary calendar (shown in
In an example, the color 110 or the identifying mark 112 may be automatically generated or may be selectable or changeable by a user. For example, for the user context shown on the calendar user interface 100, an indication 108 appears as “family” indicating that the primary calendar shown is a family calendar. The identifying mark 112 is a family icon, which corresponds to the user context of “family.” Other examples are shown in
The calendar user interface second state 100B of
The expanded view may be specific to an awareness indicator (e.g., a single expanded view format is displayed while other awareness indicators are not expanded) or general to the calendar user interface 100A-100B (e.g., all awareness indicators are displayed in the expanded view format when accessed). The expanded view may be activated based on a user input (e.g., a gesture such as a swipe, a click, or the like).
In other examples, a secondary calendar may be subordinate or dependent in some manner on a primary calendar. For example, a user may select a calendar to be a primary calendar and include one or more secondary calendars. A secondary calendar may be secondary based on a rule (which may be automatically implemented, user configured once for a calendar, or user selected on a case-by-case basis). The rule may include, for example, automatically blocking off time in a secondary calendar when a primary calendar entry is configured (e.g., generated, updated, saved, etc.). In another example, a secondary calendar may be secondary because of content, such as for public calendars, non-user controlled calendars, co-controlled calendars, or the like.
In the calendar user interface 200, the example calendar shown is a “budget” calendar. The budget calendar shows calendar entries including details, such as entries 204 (“budget”) and 206 (“planning). The calendar user interface 200 includes an example blocked off time slot, with a blocked off calendar entry 202. The blocked off calendar entry 202 in this example may correspond to the “tryout” calendar entry 102A or 102D of
In the example calendar user interface 200, an awareness indicator for another calendar may be displayed (e.g., in addition to calendar entries corresponding to a current user context or calendar, and blocked off calendar entries for one or more other calendars). A first awareness indicator 210 is shown corresponding to the family calendar (e.g., identifiable by color in this example, but may include an icon or other identifying feature). This example illustrates that not all entries for a calendar need be turned into blocked off calendar entries, but instead the blocked off calendar entries may be applied based on a rule. For example, a blocked off calendar entry may be generated for entries on another calendar within a time frame, based on a user selection in a case-by-case basis, for particular activities, based on a user device (e.g., always block of entries received from a computer, but do not automatically block off entries received from a mobile device), based on a method of generating the entry on the other calendar (e.g., if the entry is automatically added to the other calendar, such as via a meeting invite, do not block off time), or the like.
A second awareness indicator 212 is shown in the example calendar user interface 200 to illustrate an example where a third calendar has related entries for display. The second awareness indicator 212 may correspond to a calendar that is secondary to the current user context calendar displayed in the calendar user interface 200. The awareness indicators may be displayed in a minimized view or in an expanded view format as described above with respect to
The blocked off calendar entry 202 may be automatically generated for the secondary calendar (e.g., the budget calendar) based on generation of a calendar entry on a primary calendar (e.g., the family calendar). In an example, the blocked off calendar entry 202 is displayed on the calendar user interface 200 when the secondary calendar is selected for display (e.g., based on a current user context).
In an example, details related to the blocked off calendar entry 202 may be displayed when the blocked off calendar entry 202 is selected. For example, when the user has access to both calendars (e.g., has applicable credentials or read-access), the details may be viewed when the blocked off calendar entry 202 is selected.
In an example, details (e.g., additional scheduling information for a time slot) related to the blocked off calendar entry 202 or an awareness indicator may be cached locally on a device displaying the calendar user interface 200. When a secondary calendar (e.g., with the blocked off calendar entry 202 or corresponding to the awareness indicator 212) is selected for display, the local cache may supply the details for display on the secondary calendar as needed.
In an example, when the user selects the option to block off the secondary calendar, a corresponding calendar entry may be generated for the secondary calendar (e.g., the blocked off calendar entry 202 of
In another example, the calendar entry rule configuration user interface component 302 may pop up automatically when a calendar entry is generated within the calendar user interface 300 to confirm whether to block off a secondary calendar. More than one secondary calendar may be blocked off simultaneously using the calendar entry rule configuration user interface component 302, according to an example.
The example shown in
Display of an icon corresponding to an event of a secondary calendar may be toggled on or off by a user. Similarly, display of an awareness indicator may be toggled on or off by a user. User selection may change the calendar user interface 400 among the agenda view and the day view (e.g., shown in
The calendar user interface 500 includes a rule configuration component 502 for allowing a user to configure rules. The rules configured on the component 502 may be rules for the primary calendar shown in the calendar user interface 500 (e.g., according to the context), or may be rules for a user-specified calendar (e.g., a particular secondary calendar).
The rule configuration component 502 includes a plurality of options that may be configured for calendar entries that are populated or generated on the current calendar (or selected calendar). The rules may be applied to a set of calendars (e.g., all secondary calendars when a calendar entry is configured on a primary calendar), a pair of calendars (e.g., calendar 1 and calendar 2 may have a specified rule, where a calendar entry configured on calendar 1 applies a rule to calendar 2), or for a single calendar (e.g., for a work calendar, a family calendar, a school calendar, etc.).
The rule configuration component 502 shows example options of rules that may be configured for calendar entries on a calendar. For example, the rule configuration component 502 allows a user to configure a rule to block off all other calendars when an entry is configured on the current calendar, confine blocking off to a particular time frame (e.g., only block off during working hours), based on an entry type (e.g., when the user configures an entry, block off other calendars, but when someone else configures an entry, such as from a meeting invite, then do not block off other calendars), or based on participant (e.g., an invite from the user's boss may be configured to always block off other calendars, while an invite from a coworker may be configured to not automatically block off other calendars). In an example, a rule may include prompting the user after configuring the calendar entry for whether to block off another calendar. Other options for rules may be used with the techniques and systems described herein,
The rule configuration component 502 may be displayed on the calendar user interface 500 in response to a user input, such as generation of a calendar entry for a first time, or the like. A user input may include a long press on a touchscreen, a right click using a mouse, etc. In an example, a user may configure a rule for blocking off time slots on one or more secondary calendars. For example, blocking off may occur only when certain conditions are met, such as a time of day, a type of entry, a user selection to block off the time slot occurs, a particular person is on a meeting invite, or the like. The blocking off may occur when a user selects an option block off the time slot (e.g., by long pressing or right clicking or the like) on the entry on the primary calendar.
The technique 600 includes an operation 610 to receive a user configuration of a calendar entry within a time slot in a primary calendar displayed on a calendar user interface. The technique 600 includes an operation 620 to identify an secondary calendar associated with the primary calendar.
The technique 600 includes an operation 630 to block off the time slot by generating a second calendar entry on the secondary calendar based on the user configuration of the calendar entry. Operation 630 may include generating or displaying the second calendar entry in the secondary calendar without at least one detail of the calendar entry from the primary calendar. The at least one detail may include an attendee, a subject, a location, or the like. In another example, blocking off the time slot may be configured based on a received user input configuring a rule defining an automatic action to be taken with respect to the secondary calendar when the calendar entry is configured in the primary calendar. Operation 630 may include prompting a user to confirm whether to block off the time slot on the secondary calendar.
In an example, the user configuration of the calendar entry includes a generation of the calendar entry. In another example, the user configuration includes a modification to a time characteristic of the calendar entry in the primary calendar (e.g., moving or changing the time or date). In response to the modification, the technique 600 may include automatically modifying the blocked off time slot on the secondary calendar. For example, the second calendar entry may be removed, moved, a new calendar entry may be generated, a color of the second calendar entry may be changed (e.g., greyed out), or the like.
The technique 600 includes an operation 640 to in response to a user selection to display the secondary calendar, display the secondary calendar including the blocked off time slot. In an example, a primary or secondary calendar may be determined based on a user context. For example, a current user context may be used to identify a current primary calendar.
The technique 600 may further include an operation to determine a conflict between the user configuration of the calendar entry in the primary calendar and a third calendar entry on the secondary calendar within the time slot (e.g., when a user tries to configure the third calendar entry to be in the same time slot after the calendar entry is already configured). In response to determining the conflict, an alert may be provided (e.g., a popup indicating the conflict may be displayed to the user, a sound may be played, a communication may be generated or sent, etc.).
In an example, the calendar user interface is operable to display the primary calendar including the calendar entry and at least one awareness indicator of the secondary calendar, the awareness indicator corresponding to a secondary calendar entry of the secondary calendar. In an example, the technique 600 includes an operation to receive a user input on the secondary calendar to generate a third calendar entry in at least a portion of the time slot. The technique 600 may include generating an alert indicating a conflict between the third calendar entry and the calendar entry of the primary calendar.
The technique 700 includes an operation 710 to present a calendar user interface operable to display a primary calendar and an associated secondary calendar in a minimized view and an expanded view. The primary calendar may be identified based on a current user context.
The technique 700 includes an operation 720 to, when operating in the minimized view, display the primary calendar including a time slot and invoke display of a primary calendar entry in an expanded view format and at least one awareness indicator corresponding to the time slot of the primary calendar. In an example, the awareness indicator may represent the associated secondary calendar including scheduling information in the time slot, More than one awareness indicator may be displayed on the calendar user interface, such as two or more awareness indicators corresponding to a first secondary calendar, or one or more awareness indicators corresponding to a first secondary calendar and one or more awareness indicators corresponding to a second secondary calendar. An awareness indicator may be displayed in a reserved portion on a side of the calendar user interface (e.g., in a rightmost 5% or 10% of the calendar user interface
The technique 700 includes an operation 730 to receive a user input to activate switching from the minimized view to the expanded view. The user input may be a gesture, such as a swipe, a mouse click, a keyboard press, etc.
The technique 700 includes an operation 740 to responsive to receiving the user input, display the primary calendar entry and displaying additional scheduling information for the time slot from the associated secondary calendar corresponding to the awareness indicator in the expanded view format. Operation 740 may include displaying an icon corresponding to the primary calendar at the primary calendar entry or a second icon corresponding to the secondary calendar at the displayed additional scheduling information in the expanded view format. In an example, entries for the primary calendar are displayed in a first color and the awareness indicator or the displayed additional scheduling information in the expanded view format may be displayed in one or more second colors. For example, a calendar's entries or awareness indicators may share a color, but may, for example, have different shades of that color.
The technique 700 may further include an operation to locally cache information related to the additional scheduling information for the time slot from the associated secondary calendar. In response to the user input, the information may be retrieved from the local cache to display on the primary calendar.
In an example, the calendar user interface is operable to display the primary calendar entry in an agenda view that skips dates without entries. The agenda view may include a date corresponding to the awareness indicator, the date not including any calendar entries of the primary calendar.
Examples, as described herein, may include, or may operate on, logic or a number of components, modules, or mechanisms (hereinafter “modules”). Modules are tangible entities (e.g., hardware) capable of performing specified operations and may be configured or arranged in a certain manner. In an example, circuits may be arranged (e.g., internally or with respect to external entities such as other circuits) in a specified manner as a module. In an example, the whole or part of one or more computer systems (e.g., a standalone, client or server computer system) or one or more hardware processors may be configured by firmware or software (e.g., instructions, an application portion, or an application) as a module that operates to perform specified operations. In an example, the software may reside on a machine readable medium. In an example, the software, when executed by the underlying hardware of the module, causes the hardware to perform the specified operations.
Accordingly, the term “module” is understood to encompass a tangible entity, be that an entity that is physically constructed, specifically configured (e.g., hardwired), or temporarily (e.g., transitorily) configured (e.g., programmed) to operate in a specified manner or to perform part or all of any operation described herein. Considering examples in which modules are temporarily configured, each of the modules need not be instantiated at any one moment in time. For example, where the modules comprise a general-purpose hardware processor configured using software, the general-purpose hardware processor may be configured as respective different modules at different times. Software may accordingly configure a hardware processor, for example, to constitute a particular module at one instance of time and to constitute a different module at a different instance of time.
Machine (e.g., computer system) 800 may include a hardware processor 802 (e.g., a central processing unit (CPU), a graphics processing unit (GPU), a hardware processor core, or any combination thereof), a main memory 804 and a static memory 806, some or all of which may communicate with each other via an interlink (e.g., bus) 808. The machine 800 may further include a display unit 810, an alphanumeric input device 812 (e.g., a keyboard), and a user interface (UI) navigation device 814 (e.g., a mouse). In an example, the display unit 810, input device 812 and UI navigation device 814 may be a touch screen display. The machine 800 may additionally include a storage device (e.g., drive unit) 816, a signal generation device 818 (e.g., a speaker), a network interface device 820, and one or more sensors 821, such as a global positioning system (GPS) sensor, compass, accelerometer, or other sensor. The machine 800 may include an output controller 828, such as a serial (e.g., universal serial bus (USB), parallel, or other wired or wireless (e.g., infrared (IR), near field communication (NFC), etc.) connection to communicate or control one or more peripheral devices (e.g., a printer, card reader, etc.).
The storage device 816 may include a machine readable medium 822 on which is stored one or more sets of data structures or instructions 824 (e.g., software) embodying or utilized by any one or more of the techniques or functions described herein. The instructions 824 may also reside, completely or at least partially, within the main memory 804, within static memory 806, or within the hardware processor 802 during execution thereof by the machine 800. In an example, one or any combination of the hardware processor 802, the main memory 804, the static memory 806, or the storage device 816 may constitute machine readable media.
While the machine readable medium s illustrated as a single medium, the term “machine readable medium” may include a single medium or multiple media (e.g., a centralized or distributed database, and/or associated caches and servers) configured to store the one or more instructions 824.
The term “machine readable medium” may include any medium that is capable of storing, encoding, or carrying instructions for execution by the machine 800 and that cause the machine 800 to perform any one or more of the techniques of the present disclosure, or that is capable of storing, encoding or carrying data structures used by or associated with such instructions. Non-limiting machine-readable medium examples may include solid-state memories, and optical and magnetic media. Specific examples of machine readable media may include: non-volatile memory, such as semiconductor memory devices (e.g., Electrically Programmable Read-Only Memory (EPROM), Electrically Erasable Programmable Read-Only Memory (EEPROM)) and flash memory devices; magnetic disks, such as internal hard disks and removable disks; magneto-optical disks; Random Access Memory (RAM); Solid State Drives (SSD); and CD-ROM and DVD-ROM disks. In some examples, machine readable media may be non-transitory machine-readable media. In some examples, machine readable media may include machine readable media that is not a transitory propagating signal.
The instructions 824 may further be transmitted or received over a communications network 826 using a transmission medium via the network interface device 820. The machine 800 may communicate with one or more other machines utilizing any one of a number of transfer protocols (e.g., frame relay, internet protocol (IP), transmission control protocol (TCP), user datagram protocol (UDP), hypertext transfer protocol (HTTP), etc.). Example communication networks may include a local area network (LAN), a wide area network (WAN), a packet data network (e.g., the Internet), mobile telephone networks (e.g., cellular networks), Plain Old Telephone (POTS) networks, and wireless data networks (e.g., Institute of Electrical and Electronics Engineers (IEEE) 802.11 family of standards known as Wi-Fi®, IEEE 802.16 family of standards known as WiMax®), IEEE 802.15.4 family of standards, a Long Term Evolution (LTE) family of standards, a Universal Mobile Telecommunications System (UMTS) family of standards, peer-to-peer (P2P) networks, among others. In an example, the network interface device 820 may include one or more physical jacks (e.g., Ethernet, coaxial, or phone jacks) or one or more antennas to connect to the communications network 826. In an example, the network interface device 820 may include a plurality of antennas to wirelessly communicate using at least one of single-input multiple-output (SIMO), multiple-input multiple-output (MIMO), or multiple-input single-output (MISO) techniques. In some examples, the network interface device 820 may wirelessly communicate using Multiple User MIMO techniques.
Example 1 is a method performed by a data processing system for presenting a calendar user interface operable to display a primary calendar and an associated secondary calendar in a minimized view and an expanded view, the method comprising: when operating in the minimized view, causing a display device to display the primary calendar including a time slot and invoking display of a primary calendar entry in an expanded view format showing at least one detail of the primary calendar entry and at least one awareness indicator corresponding to the time slot of the primary calendar, the awareness indicator representing the associated secondary calendar including scheduling information in the time slot and providing fewer details than the expanded view format; receiving a user input to activate switching from the minimized view to the expanded view; and responsive to receiving the user input, causing the display device to display the primary calendar entry and additional scheduling information for the time slot from the associated secondary calendar corresponding to the awareness indicator in the expanded view format.
In Example 2, the subject matter of Example 1 includes, wherein the user input is a swipe gesture.
In Example 3, the subject matter of Examples 1-2 includes, wherein the at least one awareness indicator includes at least two awareness indicators including a first awareness indicator from the associated secondary calendar and a second awareness indicator from another secondary calendar.
In Example 4, the subject matter of Examples 1-3 includes, locally caching information related to the additional scheduling information for the time slot from the associated secondary calendar for displaying locally in response to the user input.
In Example 5, the subject matter of Examples 1-4 includes, wherein the at least one awareness indicator is displayed in a reserved portion on a side of the calendar user interface.
In Example 6, the subject matter of Examples 1-5 includes, wherein the calendar user interface is operable to display the primary calendar entry in an agenda view that skips dates without entries, and wherein the agenda view includes a date corresponding to the awareness indicator, the date not including any calendar entries of the primary calendar.
In Example 7, the subject matter of Examples 1-6 includes, wherein displaying the primary calendar entry and the additional scheduling information in the expanded view format includes displaying an icon corresponding to the primary calendar at the primary calendar entry and a second icon corresponding to the secondary calendar at the displayed additional scheduling information in the expanded view format.
In Example 8, the subject matter of Examples 1-7 includes, wherein entries for the primary calendar are displayed in a first color and wherein the awareness indicator and the displayed additional scheduling information in the expanded view format are displayed in a second color.
In Example 9, the subject matter of Examples 1-8 includes, wherein the primary calendar is identified based on a current user context.
Example 10 is a data processing system for presenting a calendar user interface operable to display a primary calendar and an associated secondary calendar in a minimized view and an expanded view, the system comprising: a processor and memory, including instructions, which when executed by the processor, cause the processor to perform operations to: when operating in the minimized view, cause a display device to display the primary calendar including a time slot and invoking display of a primary calendar entry in an expanded view format showing at least one detail of the primary calendar entry and at least one awareness indicator corresponding to the time slot of the primary calendar, the awareness indicator representing the associated secondary calendar including scheduling information in the time slot and providing fewer details than the expanded view format; receive a user input to activate switching from the minimized view to the expanded view; and responsive to receiving the user input, cause the display device to display the primary calendar entry and additional scheduling information for the time slot from the associated secondary calendar corresponding to the awareness indicator in the expanded view format.
In Example 11, the subject matter of Example 10 includes, wherein the user input is a swipe gesture.
In Example 12, the subject matter of Examples 10-11 includes, wherein the at least one awareness indicator includes at least two awareness indicators including a first awareness indicator from the associated secondary calendar and a second awareness indicator from another secondary calendar.
In Example 13, the subject matter of Examples 10-12 includes, wherein the processor is further caused to locally cache information related to the additional scheduling information for the time slot from the associated secondary calendar for displaying locally in response to the user input.
In Example 14, the subject matter of Examples 10-13 includes, wherein the at least one awareness indicator is displayed in a reserved portion on a side of the calendar user interface.
In Example 15, the subject matter of Examples 10-14 includes, wherein the calendar user interface is operable to display the primary calendar entry in an agenda view that skips dates without entries, and wherein the agenda view includes a date corresponding to the awareness indicator, the date not including any calendar entries of the primary calendar.
In Example 16, the subject matter of Examples 10-15 includes, wherein to display the primary calendar entry and the additional scheduling information in the expanded view format, the processor is further caused to display an icon corresponding to the primary calendar at the primary calendar entry and a second icon corresponding to the secondary calendar at the displayed additional scheduling information in the expanded view format.
In Example 17, the subject matter of Examples 10-16 includes, wherein entries for the primary calendar are displayed in a first color and wherein the awareness indicator and the displayed additional scheduling information in the expanded view format are displayed in a second color.
In Example 18, the subject matter of Examples 10-17 includes, wherein the primary calendar is identified based on a current user context.
Example 19 is a non-transitory machine-readable medium, storing instructions for presenting a calendar user interface operable to display a primary calendar and an associated secondary calendar in a minimized view and an expanded view, which when executed, cause a machine to perform operations to: when operating in the minimized view, cause a display device to display the primary calendar including a time slot and invoking display of a primary calendar entry in an expanded view format showing at least one detail of the primary calendar entry and at least one awareness indicator corresponding to the time slot of the primary calendar, the awareness indicator representing the associated secondary calendar including scheduling information in the time slot and providing fewer details than the expanded view format; receive a user input to activate switching from the minimized view to the expanded view; and responsive to receiving the user input, cause the display device to display the primary calendar entry and additional scheduling information for the time slot from the associated secondary calendar corresponding to the awareness indicator in the expanded view format.
In Example 20, the subject matter of Examples 10-19 includes, wherein the instructions further cause the machine to perform operations to locally cache information related to the additional scheduling information for the time slot from the associated secondary calendar for displaying locally in response to the user input.
Example 21 is at least one machine-readable medium including instructions that, when executed by processing circuitry, cause the processing circuitry to perform operations to implement of any of Examples 1-20.
Example 22 is an apparatus comprising means to implement of any of Examples 1-20.
Example 23 is a system to implement of any of Examples 1-20.
Example 24 is a method to implement of any of Examples 1-20.