The present invention pertains generally to user interfaces and data, and relates more particularly to systems and methods for data entry.
The creation of events for a calendar application, whether that application is a desktop application or a networked application typically involved long and detailed forms in order to populate many database fields used to describe a typical event.
Interfaces such as the one illustrated in
Although these interfaces may be easy to implement for a programmer or applications developer, they can be inefficient and time consumer for the users who must traverse them just to enter an event. Accordingly, what is needed are systems and methods for entering event data that are more efficient and better suited for users than traditional event entry interfaces.
Reference will be made to embodiments of the invention, examples of which may be illustrated in the accompanying figures. These figures are intended to be illustrative, not limiting. Although the invention is generally described in the context of these embodiments, it should be understood that it is not intended to limit the scope of the invention to these particular embodiments.
In the following description, for purposes of explanation, specific details are set forth in order to provide an understanding of the disclosure. It will be apparent, however, to one skilled in the art that the disclosure can be practiced without these details. Furthermore, one skilled in the art will recognize that embodiments of the present disclosure, described below, may be implemented in a variety of ways, such as a process, an apparatus, a system/device, or a method on a tangible computer-readable medium.
Components, or modules, shown in diagrams are illustrative of exemplary embodiments of the disclosure and are meant to avoid obscuring the disclosure. It shall be understood that throughout this discussion that components may be described as separate functional units, which may comprise sub-units, but those skilled in the art will recognize that various components, or portions thereof, may be divided into separate components or may be integrated together, including, for example, being in a single system or component. It should be noted that functions or operations discussed herein may be implemented as components. Components may be implemented in software, hardware, or a combination thereof.
Furthermore, connections between components or systems within the figures are not intended to be limited to direct connections. Rather, data between these components may be modified, re-formatted, or otherwise changed by intermediary components. Also, additional or fewer connections may be used. It shall also be noted that the terms “coupled,” “connected,” “communicatively coupled,” “interfacing,” “interface,” or any of their derivatives shall be understood to include direct connections, indirect connections through one or more intermediary devices, and wireless connections. It shall also be noted that any communication, such as a signal, response, reply, acknowledgement, message, query, etc., may comprise one or more exchanges of information.
Reference in the specification to “one or more embodiments,” “preferred embodiment,” “an embodiment,” “embodiments,” or the like means that a particular feature, structure, characteristic, or function described in connection with the embodiment is included in at least one embodiment of the disclosure and may be in more than one embodiment. Also, the appearances of the above-noted phrases in various places in the specification are not necessarily all referring to the same embodiment or embodiments.
The use of certain terms in various places in the specification is for illustration and should not be construed as limiting. The terms “include,” “including,” “comprise,” “comprising,” and any of their variants shall be understood to be open terms, and any examples or lists of items are provided by way of illustration and shall not be used to limit the scope of this disclosure.
A service, function, or resource is not limited to a single service, function, or resource; usage of these terms may refer to a grouping of related services, functions, or resources, which may be distributed or aggregated. The use of memory, database, information base, data store, tables, hardware, cache, and the like may be used herein to refer to system component or components into which information may be entered or otherwise recorded. The terms “data,” “information,” along with similar terms, may be replaced by other terminologies referring to a group of one or more bits, and may be used interchangeably. The terms “packet” or “frame” shall be understood to mean a group of one or more bits.
It shall be noted that: (1) certain steps may optionally be performed; (2) steps may not be limited to the specific order set forth herein; (3) certain steps may be performed in different orders; and (4) certain steps may be done concurrently.
Any headings used herein are for organizational purposes only and shall not be used to limit the scope of the description or the claims. Each reference/document mentioned in this patent document is incorporated by reference herein in its entirety.
A. Embodiments of Data Entry
Aspects of the present invention relate to systems and methods for providing concise entry of information into an application, such as a calendaring application. In one or more embodiments, an entry may be provided via a single entry interface, which may be referred to herein as a “one box” entry. In one or more embodiments, the present invention simplifies the creation of an event through parsing, fixed or suggested formats, reserved syntax, contextual information, display logic, or combinations thereof. In one or more embodiments, an event may be a new calendar event, which may comprise several database fields including, but not limited to: summary, start date/time, end date/time, notes, invitees, location, tags, privacy setting, repeat pattern, reminder setting, and attached documents. Embodiments of the present disclosure may also simplify or streamline the entry process by enabling or triggering actions related to the event. Embodiments of the present disclosures may include the creation of an event by traditional web post, ajax web post, email, SMS/text messaging, instant messaging (IM), and/or desktop or embedded widgets.
Returning to
Once loaded, a view with a single entry interface may be displayed (210) to the user.
The depicted embodiment also includes a link 315 to the calendar section of the application. In one or more embodiments, selection of the link 315 may cause a primary view of the calendar to be displayed to the user. For the purposes of illustration, a primary view referred to herein will be a month view or four-week view 310.
A user may add an event to the calendar application by inputting (215) data into the one box interface 305. In one or more embodiments, the calendar application may use parsing, fixed or suggested formats, reserved syntax, contextual information, natural language logic, display logic, or combinations thereof to ascertain information regarding an event. For purposes of illustration various embodiment and examples are provided below.
In one or more embodiments, data entered into the one box entry interface 305 may be examined (220) to determine if an action or actions may be taken. In one embodiment, each keystroke of the user inputted data may be examined for specific syntax or contextual clues. These specific sets of syntax and clues may be referred to herein as being part of pre-set data, readily-identified data, or triggers. In one or more embodiments, syntax clues may be a reserved word, text format, or character used to help determine meaning or action when parsing. It shall be understood that the use of the term “words,” “clue,” or “text” shall be understood to mean any symbol which may be entered by a user or any combination thereof, regardless of whether any such inputted symbol or collection of inputted symbols form a commonly readable or identified “word” or “text.” In one or more embodiments, the inputted data may be parsed and may be compared against one or more sets of pre-set data, such as a set of syntax and/or contextual formats.
If data conforming to a specific syntax or a contextual clue is identified, an action may be taken. Examples of actions include, but are not limited to, prompting the user for additional information, providing additional information to the user, and/or initiating action with a third party (person, application, device, and/or system).
Consider, by way of illustration, the example depicted in
In the embodiment depicted in
Examples of pre-set/readily-identifiable data, such as syntax or context clues, that may invoke prompts or data wizards may include, but are not limited to:
1) the word “tag” followed by a space may trigger a drop-down list of the user's list of tags (if any) by which the user may classify the event with one or more tags, such as, work, family, volunteer group, church, etc.;
2) the character “+” may trigger a drop-down list of email addresses for the user's Buddies (if any);
3) the word “repeat” followed by a space may trigger a drop-down list of repeat intervals;
4) the word “remind” followed by a space may trigger a drop-down list of reminder intervals; and
5) the word “via” preceded by a “remind” interval and followed by space may trigger a drop-down list of means by which the user may be contacted to be reminded, such as, by one or more of the following: email, SMS/Text messaging, instant messaging, fax, etc. This contact information may be included in the user's profile.
Returning to
It shall also be noted that data wizards or prompts may be provided for other reasons, including but not limited to, providing options for entry of event information, to resolve ambiguities, or to obtain user input on additional matters. Consider, by way of illustration, the example depicted in
It should also be noted that to further reduce the amount of data that a user may need to input into the one box interface and/or to facilitate processing of an event, embodiments of the present disclosure may utilize assumptions. In one or more embodiments, additional data may be used to determine what assumptions should be used. For example, the view from which a user inputs data into the one box interface 305 may be noted and assumptions may be made based upon that view. In one or more embodiments, it may be assumed that any entry made to a primary view that does not contain an explicit date (e.g., Feb. 2, 2007) or relative reference to a date (e.g., next Thursday) may be assigned the current date of the user's local time. It may be assumed that entries made from a day view may be assigned a default time of that date. Thus, for example, because the event depicted in
Returning to
Additional actions include, but are not limited to, causing one or more actions to be performed contemporaneously and/or at a future date. The action may involve interfacing with one or more applications. The applications may be part of data manager 1130, or data manager 1130 may interact or otherwise interface with the applications to perform the action, such as for example, sending invitations to invitees of the event.
It should be understood that, in one or more embodiments, steps 235 and 240 may be performed on the client side, such as by example client module 1125, and that steps 245-255 may be performed on the server side, such as by server 1130. However, one skilled in the art shall recognize that a single system may perform the steps. Accordingly, in one or more embodiments, steps 235, 240 may be consolidated with step 250 and/or with step 255. Furthermore, some of the steps of the methods depicted herein may be optionally performed. For example, steps 220 and 225 of
As previously noted, in one or more embodiments one or more actions may be triggered (240/250/255). Examples of these actions may include, without limitation, the following:
In one or more embodiments, system 1130 may perform some or all of the above action or may interface with one or more systems or applications to perform the action, including without limitation a client module. For example, server 1130 may interface directly or indirectly with an application 1145 (e.g., email, SMS, IM, etc.) to have a reminder sent or to notify an invitee. In one or more embodiments, the application or system 1145 may be part of data manager 1130 and/or may be a third-party application or system 1145. In one or more embodiments, the client 1125 may perform one or more of the actions. For example, display actions may be performed by client module 1125 upon return of the structured data file.
In one or more embodiments, the structured data file is returned (255) to the user and one or more actions may be triggered upon return. In one or more embodiments, the returned data may comprise or also include html and/or javascript code derived from the structured data. In one or more embodiments, the client-server system 1100 may employ AJAX (asynchronous javascript and xml, which is a method of posting data to a server from a client and affecting an action within a browser without refreshing the entire page) and a client-side display function, which may be part of the client-side processing of the client module 1125, may be called as part of the actions. The local data objects may be updated and a Display Update function or functions may be triggered. In one or more embodiments, the calendar display may center on the new event and trigger a visual notification, such as a color flash.
Other actions triggered (240/250/255) may include without limitation:
Turning to
Consider, for purposes of illustration, submission of information by email. A user may schedule an event by sending an email to the calendaring application. For example, an email may be sent to an email address at 30boxes.com where it is piped from a mail server to the application layer. In one or more embodiments, the email may be authenticated (either by recognizing the “To” address as a custom email address used for that user only or by using the “From” address and comparing it to existing calendaring users). In one or more embodiments, the email may be addressed to additional individuals as well and those email addresses may be included in the user's list of emails/buddies. In one or more embodiments, those emails may be included as invitees of the event.
In one or more embodiments, the subject line and/or the message body may be considered as an equivalent to data entered into a one box entry interface 305. In an alternative embodiment, the subject line of the email may be treated as a one box data entry and undergoes the steps described herein from the point that the data is posted to the server. In one or more embodiments, the body of the email may be parsed by separating out MIME types, and if it contains a plain text or html MIME type, the body may be converted into an html page that is stored in a database (such as database 1135A) or a file system (1135B) and may be linked to the new event as an attachment. In one or more embodiments, other MIME types may be supported such as audio, video, images, and the like.
In one or more embodiments, a response, such as a return email or other notification, may be sent to the user alerting the user of the success or failure of the event creation.
Returning to
It shall be noted that to aid in the extraction of the event information, syntax, context clues, fixed or suggested formats may be employed. By way of illustration and not limitation, examples are provided in Appendix A.
In one or more embodiments, all readily-identified data may be removed from the submitted data and the remaining text may be submitted for processing (815) using natural language logic (NLL) to extract information. Natural language logic may be used to deduce the intended date of the event from the submitted data. Dates may be explicitly stated in standard formats (5/1/07, May 1, 2007), abbreviated versions (June 1, 6.1), or relative references (tomorrow, next tuesday). The dates may be a single date or may be spans (e.g., May 1-5). The dates may include a single time or time spans (e.g. May 1 2-3 pm). The natural language logic is used to examine, rearrange, and prepare the text that is thought to contain date and time information. In one or more embodiments, the data may be broken into parts and repeatedly tested with the PHP function “strtotime” until the entire date, time, or date/time span has been deduced. One skilled in the art shall recognize that other string-to-time functions or applications may be employed and that no specific function or implementation is critical to the present invention.
For purpose of illustration, listed below are some examples of conversions of time-related strings to regular or common expressions:
One skilled in the art shall recognize that the above conversions may not be required to be done for the parsing and that the selection of formats is a choice of style and is not critical to the practice of the present invention.
The modified data may then be examined (910) for the last instance of a digit, meridian, month name, day name, or time-related (time/date) abbreviation. In one or more embodiments, any text after that instance may be removed and added (915) to the event summary field of a structured message file, or alternatively, may be added to a notes field.
The remaining data may be searched (920) for span clue word (e.g., to, thru, through, until, -, etc.). If a span word is not found (925), the remaining data may be examined (930) to extract date/time information. If a span word is found (925/935), the remaining data may be split (940) in two sets of text, wherein the first set of text comprises the text before the span clue word and a second set of text comprises the text after the span clue word.
Each set of text may be examined (945) to extract the date/time information, if it is present in the set of text. If the two sets represent a same-day span, that information may be stored (965) in a structured data file. If the two sets do not represent a same-day span, the two sets may be examined to determine (955) if they represent a date span. If the two sets represent a date span, that information may be stored (965) in a structured data file. If the two sets do not represent a date span, it may be assumed (960) that the event is a single-day event with no duration, and that information may be stored (965) in a structured data file.
Returning to
One skilled in the art will recognize that embodiments of the present disclosure, some of which are described herein, may be incorporated into a number of different systems and devices including general purpose computers, specialized computers, mobile devices (including without limitation mobile telephones, personal data assistants (PDAs), and multimedia devices), and the like. The embodiments of the present disclosure may be implemented in software, hardware, firmware, or combinations thereof. It shall be noted that the specific implementation is not critical to the present invention.
It shall be understood that devices or components (or modules), shown in block diagrams are illustrative of embodiments of the invention and are meant to avoid obscuring the invention. It shall also be understood that throughout this discussion that device or components may be described as separate functional units, which may comprise sub-units, but those skilled in the art will recognize that the various devices or components, or portions thereof, may be divided into separate devices or components or may be integrated together, including integrating within a single system, device, or component.
Furthermore, connections between devices, systems, and components within the figures are not intended to be limited to direct connections. Rather, data between these items may be modified, re-formatted, or otherwise changed by intermediary components. Also, additional or fewer connections may be used. It shall also be noted that the terms “coupled” or “communicatively coupled” shall be understood to include direct connections, indirect connections through one or more intermediary devices, and wireless connections.
As previously indicated, embodiments of the present disclosure may be implemented in a web application. For purposes of illustration, an example of such an embodiment is provided herein. In one or more embodiments, a user loads 30boxes.com, wherein interface/display module 1128 displays a form, such as an html—the time zone is set as part of the html form 1115 and the One Box entry interface 305 is displayed. Assume for this illustration that the user types the following characters:
In the embodiment depicted in
After the word “tag” has been entered, the client parser and analyzer 1126 recognizes that a trigger text has been added and the appropriate data wizard 1127B causes a prompt (such as a drop-down menu of the user's existing tags) to be displayed for easy selection of one or more tags.
Assume the user selects the following tag:
Also assume that the user ends the entry with an asterisk
In one or more embodiments, when the “Add” button is clicked, the client module 1125 may parse the text locally and recognizes the event as a birthday. Another data wizard 1127 may initial a pop-up dialog to be displayed to allow further settings. The form data is then submitted to the data manager 1130, which may include data from hidden form fields 1120 and the unstructured data from the one box text.
The data manager 1130 receives the information and the one box text may be parsed to identify syntax clues to create fields for the new event data object. Natural language logic may be used to deduce times, dates, and other fields of the event. During the course of the parsing, certain actions may be triggered. In this example, an annual reminder action will be set for the event. Thus, in one or more embodiments, data manager 1130 may also include data wizards (not shown) or one or more application interfaces 1336 to facilitate interaction with one or more application 1145. The event data may be stored in a table in storage 1135 on the server, and additional data may be stored relating to triggered actions (such as the reminder). It should be noted that storage 1135 may be part of data manager 1130. Applications 1145 may also be part of data manager 1130 and/or may be separate from data manager 1130.
The data is now in a structured format and may be returned to the client. In one or more embodiments, the client 1125 may parse the data locally. For example, the structured data that is returned to the client may be “parsed” by javascript so it is available for use in the javascript programs running on the client browser. The return of the structured file triggers the interface/display module 1128 to updated the user's display to reflect the new event. Additionally, certain display actions may be triggered; in this example, the display includes a star icon and a repeat icon.
One skilled in the art shall recognize that system 1100, server system 1130, client 1105, or portions thereof may be implemented on one or more a computing/instruction-executing device, such as, for example, depicted in
Aspects of the present invention relate to systems and methods for allowing the sharing of content with one or more individuals or groups. In one or more embodiments, shared content may be associated with one or more identifiers, or tags. These tags may be used to grant sharing rights to individuals or groups.
Aspects of the present invention involve systems and methods of sharing information using metadata, which may be used for various purposes, such as for permission, which metadata may also be referred to herein as a tag or label. The systems and methods of the present invention may be embodied in an application, web service, or web site, which may be a calendaring application or multimedia application that involves one or more forms of media (photos, graphics, videos, texts, animations, hyperlinks, website, and the like). In one or more embodiments, the application may be an Internet application or a networked application, wherein a user and/or the third parties (individuals and/or groups) with which the user shares content interface with the application through a browser or application interface. It shall be noted that neither the specific implementation of the methods of the present invention nor the specific implementations of a device or system is critical to the present invention.
1. Methods for Tag Sharing
A user also can have one or more tags associated (1410) with a third party or third parties. The third parties may be individuals or groups of individuals. In one or more embodiments, a user interface may be presented to a user to facilitate the associating of one or more tags with a third party. In one or more embodiments, a contacts or buddy profile may include a section for the user to input or select tags. In one or more embodiments, the user may create the tag designations. In one or more embodiments, the user-created tags may be selected from a pre-existing or pre-populated list.
It should be noted that the metadata associated with a third party may be obtained from another service or context. For example, if User A interacts with third parties through a social networking application, information related to the User A's interactions with third parties, such as key words from messages, profile information, or the like may be used or imported as part of the associated metadata.
By associating (1410) one or more tags with a third party or third parties, the user may grant access (1415) to none, some, or all of the content items using the associated tags. The granting of access to a content item may be based upon a comparison of metadata associated with the content item and metadata associated with a third party. For example, any content items with a “personal” tag are shared with User B; whereas, only content items with a “work” tag are shared with User G. In one or more embodiments, a third party who is granted access to an item may share that item with one or more additional parties. Furthermore, the third party may add or otherwise re-tag the event for sharing purposes. For example, individual A may share an item with a label “work” with individual B, and individual B could re-share or syndicate the event to individual C under a tag, such as “executives,” which was set by individual B.
It shall be noted that the comparison to grant access to content items may be performed in any fashion or combination using, for example one or more logical operators, such as Boolean operators, conditionals, and the like. In one or more embodiments, logical operations may be implied. For example, a listing of descriptive tags with no logical operator may be implied to be the logical operator “OR,” which creates unions of content items that contain at least one of the listed tags. In one or more embodiments, logical operations may be expressly included as part of the metadata. Alternatively, a tag may include a logical operation or operations (e.g., “Work but not Travel” may be considered a tag, and as a tag would share all content items with a “Work” label so long as there is not also a “Travel” tag associated with the content item). It should also be noted that a tag may represent a set or subset of other tag (the tag “All” may be defined to be equivalent to listing all descriptive tags linked with the logical operator “OR”). In one or more embodiments, tags may also be used to set levels of permissions including read and write permissions to content items. One skilled in the art shall recognize that a particular benefit of the present invention is the ability to quickly and easily create complex sharing arrangements.
Consider, by way of illustration and not limitation, the example shown in
At least one additional metadata descriptor is also associated (1710) with the content item, wherein the first metadata descriptor and the at least one additional metadata descriptor are concurrently associated with the content item. The phrase “concurrently associated” shall be construed to mean that there is at least some time period of overlap. Thus, concurrently associated shall include situations in which a first tag is associated and then one or more additional tags are subsequently associated. Thus, concurrently associated shall include situations in which tags are edited, added, or removed so long as at a time when access rights are determined for a third party a plurality of tags are associated. The user associates (1715) one or more tags with a third party, and the third party may be granted access (1720) to the content item based upon a comparison of the tags associated with the content item and the one or more tags associated with the third party. In one or more embodiments, the user may create the tag designations. In one or more embodiments, the tags may be selected from a pre-existing or pre-populated list. In one or more embodiments, a third party who is granted access to an item may share that item with one or more additional parties, including sharing the event with additional third parties using the same or different tag designations.
In contrast, embodiments of the present invention provide methods for segmenting items of information (events, photos, videos, links, text, etc.) so that they may be easily shared with others without having to duplicate efforts.
Returning to
User A associates (1810) user-created tags with third parties that User A wishes to share events with. In one or more embodiments, content items may be shared actively with other users who have been made buddies to User A through an application service.
These third parties are allowed access (1815) to the calendar events based upon a comparison of the one or more user-created descriptive metadata associated with the calendar events and the one or more user-created descriptive metadata associated with the third party. For example, User A may allow User X to view all events with the tag: birthdays. User X would be able to view the events on May 1 (“Jen's Birthday”) and June 10 (“Jack's Birthday”). User A may allow User Y to view all events with the tags: personal or travel. User Y would be able to view the events on May 1 (“Jen's Birthday”), June 2 (“Trip to Denver”), and July 2-7 (“Trip to Baltimore”). User A may instead allow User Y to view all events with the tags: personal and travel. In that case, User Y would only be able to view the calendar event July 2-7 (“Trip to Baltimore”). In one or more embodiments, a display of the shared events may appear on public facing obfuscated URL. In one or more embodiments, a specific URL may be created for each subset of content to be shared. In one or more embodiments, a third party who is granted access to an item may share that item with one or more additional parties, including sharing the event using a tag or tags designated by the third party.
As noted previously, typical shared calendars involved the creating of a separate, group calendar. It should be noted that another aspect of the present invention is its ability to easily create and maintain shared calendars by generating views of content based upon metadata.
In alternative embodiments, User A may request the generation of a display that has the shared event as well as other events for User A, which display may only be accessible by User A. Additional displays may be easily generated by changing the tags that are shared, the users that share, or both.
One skilled in the art shall recognize a number of advantages of the present invention. For example, there are several important efficiencies created using aspects of the present invention. In existing calendar interfaces, the multiple calendar paradigm would present a need to enter redundant events. For example, certain events to be shared with different audiences would have to be entered twice, once on each calendar. With sharing by tags, a single event may be shared with various audiences. Furthermore, sharing privileges may be easily changed at a user/buddy level or at a tag level by modifying the tags a user can view or by changing the tag associated with content. Also, as noted previously, more robust or complex sharing scenarios may be used by applying conditions or logical operations on the tags. Other advantages will be apparent to those skilled in the art.
2. Systems for Tag Sharing
Consider, by way of illustration and not limitation, the following example. A user 2110 registers with a web service, such as 30Boxes.com, and keeps a calendar of events and other content on their system 2100. In one or more embodiments, a user may be an individual or group that uses the web services and may have an entry in a user database tied to one or more email addresses. A server of the web services 2100 may store the user database, which may also include profile information. A “buddy” may comprise a web services profile tied with a database entry to another profile. In one or more embodiments, a profile may indicate a relationship between the users, such as a trusted relationship, and may also contain metadata.
The user 2110 can have metadata associated with calendar events stored on the system 2100 and can also have metadata associated with one or more third party 2120. In one or more embodiments, metadata may be passed from a client (e.g., 2110) to a server (e.g., 2100) through one of several means (including, but not limited to, http GET, POST, email, SMS, IM, etc.) where it may be parsed and stored as a field. Third parties may interface with system 2100 to obtain access to the content of the user. In one or more embodiments, one or more of the third parties may access the content indirectly from system 2100. For example, system 2100 may have the content to which a third party has permissions forwarded to the third party via another service (e.g., email, instant message, forward to another application, etc.). Thus, it should be noted that a third party need not be a user of the services provided by system 2100 nor must they directly connect with the system 2100.
The content items and the tag information may be stored in storage 2230. In one or more embodiments, application 2210 may also facilitate the display or transfer of content items to the user and to third parties. Application 2210 may also represent a service or services that utilizes the content items as well as facilitates sharing. For example, application 2210 may be a calendaring application, photo sharing application, blog, or the like.
When a request to access content is received, access rights module 2220 performs a comparison to determine what content items are to be shared, if any. System 2100 may be implemented on a computing/instruction-executing device, such as, for example, depicted in
An addressable memory 2306, coupled to processor 2302, may be used to store data and software instructions to be executed by processor 2302. Memory 2306 may be, for example, firmware, read only memory (ROM), flash memory, non-volatile random access memory (NVRAM), random access memory (RAM), or any combination thereof. In one embodiment, memory 2306 stores a number of software objects, otherwise known as services, utilities, components, or modules. One skilled in the art will also recognize that storage 2304 and memory 2306 may be the same items and function in both capacities. In one or more embodiments, one or more of the components of
In one or more embodiments, computing system 2300 provides the ability to communicate with other devices, other networks, or both. Computing system 2300 may include one or more network interfaces or adapters 2312, 2314 to communicatively couple computing system 2300 to other networks and devices. For example, computing system 2300 may include a network interface 2312, a communications port 2314, or both, each of which are communicatively coupled to processor 2302, and which may be used to couple computing system 2300 to other computer systems, networks, and devices.
In one or more embodiments, computing system 2300 may include one or more output devices 2308, coupled to processor 2302, to facilitate displaying graphics and text. Output devices 2308 may include, but are not limited to, a display, LCD screen, CRT monitor, printer, touch screen, or other device for displaying information. Computing system 2300 may also include a graphics adapter (not shown) to assist in displaying information or images on output device 2308.
One or more input devices 2310, coupled to processor 2302, may be used to facilitate user input. Input devices 2310 may include, but are not limited to, a pointing device, such as a mouse, trackball, or touchpad, and may also include a keyboard or keypad to input data or instructions into computing system 2300.
In one or more embodiments, computing system 2300 may receive input, whether through communications port 2314, network interface 2312, stored data in memory 2304/2306, or through an input device 2310, from a scanner, copier, facsimile machine, or other computing device.
It shall be understood that devices or components (or modules), that may be shown in block diagrams are illustrative of embodiments of the invention and are meant to avoid obscuring the invention. It shall also be understood that devices or components may be described as separate functional units, which may comprise sub-units, but those skilled in the art will recognize that the various devices or components, or portions thereof, may be physically and/or functionally divided into separate devices or components or may be physically and/or functionally integrated together, including integrating within a single system, device, or component.
Furthermore, connections between devices, systems, and components are not intended to be limited to direct connections. Rather, data between these items may be modified, re-formatted, or otherwise changed by intermediary components. Also, additional or fewer connections may be used. It shall also be noted that the terms “coupled” or “communicatively coupled” shall be understood to include direct connections, indirect connections through one or more intermediary devices, and wireless connections.
It shall be noted that the present invention may be implemented in any instruction-execution/computing device or system (or group of devices or systems) capable of processing data, including without limitation, a general-purpose computer and a specific-purpose computer. One skilled in the art will recognize no computing system is critical to the practice of the present invention. The present invention may be implemented on or into other computing devices and systems. Furthermore, aspects of the present invention may be implemented in a wide variety of ways including software, hardware, firmware, or combinations thereof. For example, the functions to practice various aspects of the present invention may be performed by components that are implemented in a wide variety of ways including discrete logic components, one or more application specific integrated circuits (ASICs), and/or program-controlled processors. It shall be noted that the manner in which these items are implemented is not critical to the present invention.
Embodiments of the present disclosure may be encoded upon one or more non-transitory computer-readable media with instructions for one or more processors or processing units to cause steps to be performed. It shall be noted that the one or more non-transitory computer-readable media shall include volatile and non-volatile memory. It shall also be noted that embodiments of the present disclosure may further relate to computer products with a computer-readable medium or media that have computer code thereon for performing various computer-implemented operations. The media and computer code may be those specially designed and constructed for the purposes of the present invention, or they may be of the kind known or available to those having skill in the relevant arts. Examples of computer-readable media include, but are not limited to: magnetic media such as hard disks, floppy disks, and magnetic tape; optical media such as CD-ROMs and holographic devices; magneto-optical media; and hardware devices that are specially configured to store or to store and execute program code, such as application specific integrated circuits (ASICs), programmable logic devices (PLDs), flash memory devices, and ROM and RAM devices. Examples of computer code include machine code, such as produced by a compiler, and files containing higher level code that are executed by a computer using an interpreter.
It shall also be noted that one advantage of the one box entry interface 305 is its compact size. The one box interface's 305 size allows it to be displayed with other items. Consider, for example, the one box entry interface 305 shown in
Interfaces, such as the one shown in
While the invention is susceptible to various modifications and alternative forms, specific examples thereof have been shown in the drawings and are herein described in detail. It should be understood, however, that the invention is not to be limited to the particular forms disclosed, but to the contrary, the invention is to cover all modifications, equivalents, and alternatives falling within the spirit and scope of that disclosed herein.
This application is a continuation of and claims the priority benefit under 35 U.S.C. § 120 to commonly-assigned and co-pending U.S. patent application Ser. No. 16/706,881, entitled “SIMPLIFIED DATA ENTRY,” listing Narendra Rocherolle, Nicholas Wilder, and Julie Davidson Rocherolle as inventors and filed on Dec. 9, 2019, which issued as U.S. Pat. No. 11,625,137 on Apr. 11, 2023, which is a continuation of and claims the priority benefit under 35 U.S.C. § 120 to commonly-assigned U.S. patent application Ser. No. 15/069,676, entitled “SIMPLIFIED CALENDAR EVENT CREATION,” listing Nicholas Wilder, Narendra Rocherolle, and Julie Davidson Rocherolle as inventors and filed on Mar. 14, 2016, which issued as U.S. Pat. No. 10,503,345 on Dec. 10, 2019, which is a continuation of and claims the priority benefit under 35 U.S.C. § 120 to U.S. patent application Ser. No. 12/011,314, entitled “SIMPLIFIED DATA ENTRY,” listing Nicholas Wilder, Narendra Rocherolle, and Julie Davidson Rocherolle as inventors and filed on Jan. 25, 2008, which issued as U.S. Pat. No. 9,286,935 on Mar. 15, 2016, which claimed priority under 35 U.S.C. § 119(e) to: (1) U.S. Provisional Patent Appl. No. 60/887,140, entitled “SYSTEMS AND METHODS FOR SIMPLIFIED EVENT ENTRY,” filed Jan. 29, 2007; (2) U.S. Provisional Patent Appl. No. 60/887,797, entitled “TAG SHARING,” filed Feb. 1, 2007; and (3) U.S. Provisional Patent Appl. No. 60/888,073, entitled “PROFILE GENERATION, USE, AND MANAGEMENT,” filed Feb. 2, 2007. Each of the aforementioned patent documents is incorporated by reference herein in its entirety and for all purposes. This application is related to commonly-assigned U.S. patent application Ser. No. 15/134,079, entitled “CONTENT SHARING,” listing Nicholas Wilder, Narendra Rocherolle, and Julie Davidson Rocherolle as inventors and filed on Apr. 20, 2016, which issued as U.S. Pat. No. 10,073,865 on Sep. 11, 2018, which is a continuation of and claims the priority benefit under 35 U.S.C. § 120 to commonly-assigned U.S. patent application Ser. No. 13/411,317, entitled “CONTENT SHARING,” listing Nicholas Wilder, Narendra Rocherolle, and Julie Davidson Rocherolle as inventors and filed on Mar. 2, 2012, which issued as U.S. Pat. No. 9,336,276 on May 10, 2016, which is a continuation application of and claims priority under 35 USC § 120 to commonly-assigned U.S. patent application Ser. No. 12/020,446, entitled “CONTENT SHARING USING METADATA,” listing Nicholas Wilder, Narendra Rocherolle, and Julie Davidson Rocherolle as inventors and filed on Jan. 25, 2008, which issued as U.S. Pat. No. 8,161,069 on Apr. 17, 2012, which claimed priority under 35 USC § 119(e) to U.S. Provisional Application Ser. No. 60/887,797, entitled “TAG SHARING,” filed Feb. 1, 2007. Each of the aforementioned patent documents is incorporated by reference herein in its entirety. This application is related to commonly-assigned U.S. patent application Ser. No. 12/011,400, entitled “PROFILE GENERATION, USE, AND MANAGEMENT,” listing Nicholas Wilder, Narendra Rocherolle, and Julie Davidson Rocherolle as inventors and filed on Jan. 25, 2008, which issued as U.S. Pat. No. 9,094,469 on Jul. 28, 2015, which claimed priority under 35 USC § 119(e) to U.S. Provisional Application Ser. No. 60/888,073, entitled “Profile Generation, Use, and Management,” filed Feb. 2, 2007; each of the aforementioned patent documents is incorporated by reference herein in its entirety.
Number | Name | Date | Kind |
---|---|---|---|
6047259 | Campbell | Apr 2000 | A |
6175831 | Weinreich | Jan 2001 | B1 |
6262735 | Etelapera | Jul 2001 | B1 |
6571245 | Huang | May 2003 | B2 |
6820204 | Desai | Nov 2004 | B1 |
7069308 | Abrams | Jun 2006 | B2 |
7091959 | Clary | Aug 2006 | B1 |
7146381 | Allen | Dec 2006 | B1 |
7174517 | Barnett | Feb 2007 | B2 |
7370282 | Cary | May 2008 | B2 |
7421660 | Charnock | Sep 2008 | B2 |
7571108 | Leban | Aug 2009 | B1 |
7739597 | Wong | Jun 2010 | B2 |
7747639 | Kasperski | Jun 2010 | B2 |
7757176 | Vakil | Jul 2010 | B2 |
8713418 | King | Apr 2014 | B2 |
20010013043 | Wagner | Aug 2001 | A1 |
20010014859 | Itoh | Aug 2001 | A1 |
20020044687 | Federman | Apr 2002 | A1 |
20020078007 | Herrero | Jun 2002 | A1 |
20020089551 | Hugh | Jul 2002 | A1 |
20020193995 | Case | Dec 2002 | A1 |
20030033296 | Rothmuller | Feb 2003 | A1 |
20030110169 | Zuili | Jun 2003 | A1 |
20030120684 | Zuil | Jun 2003 | A1 |
20030154116 | Lofton | Aug 2003 | A1 |
20030167279 | Smiga | Sep 2003 | A1 |
20040103367 | Riss | May 2004 | A1 |
20040148275 | Achlioptas | Jul 2004 | A1 |
20050070255 | Cass | Mar 2005 | A1 |
20050076037 | Shen | Apr 2005 | A1 |
20050108267 | Gibson | May 2005 | A1 |
20050216300 | Appelman | Sep 2005 | A1 |
20050216550 | Paseman | Sep 2005 | A1 |
20050222971 | Cary | Oct 2005 | A1 |
20050246316 | Lawson | Nov 2005 | A1 |
20060047632 | Zhang | Mar 2006 | A1 |
20060135264 | Shaw | Jun 2006 | A1 |
20060143157 | Landsman | Jun 2006 | A1 |
20060230043 | Sunmer-Moore | Oct 2006 | A1 |
20060242581 | Manion | Oct 2006 | A1 |
20070055656 | Tunstall-Pedoe | Mar 2007 | A1 |
20070073694 | Picault | Mar 2007 | A1 |
20070083552 | Allen | Apr 2007 | A1 |
20070156522 | Carpenter | Jul 2007 | A1 |
20070156912 | Crawford | Jul 2007 | A1 |
20070173325 | Shaw | Jul 2007 | A1 |
20070218900 | Abhyanker | Sep 2007 | A1 |
20070219773 | Roux | Sep 2007 | A1 |
20070219950 | Crawford | Sep 2007 | A1 |
20070220063 | O'Farrell | Sep 2007 | A1 |
20070282595 | Tunning | Dec 2007 | A1 |
20080027893 | Cavestro | Jan 2008 | A1 |
20080077888 | Miksovsky | Mar 2008 | A1 |
20080140384 | Landau | Jun 2008 | A1 |
20090319295 | Kass-Hout | Dec 2009 | A1 |
20100015975 | Issa | Jan 2010 | A1 |
Entry |
---|
“Migrating Data to Oracle Content Management SDK” Oracle, pp. 1-16, 2002. (16 pgs). |
“Who Sees Your Calendar?” Computing at Cornell [online]. Last modified May 25, 2007 [Retrieved on Sep. 2, 2008]. Retrieved from the Internet: <URL: www.cit.cornell.edu/calendar/howto/access>. (5pgs). |
Number | Date | Country | |
---|---|---|---|
20230259247 A1 | Aug 2023 | US |
Number | Date | Country | |
---|---|---|---|
60888073 | Feb 2007 | US | |
60887797 | Feb 2007 | US | |
60887140 | Jan 2007 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 16706881 | Dec 2019 | US |
Child | 18298323 | US | |
Parent | 15069676 | Mar 2016 | US |
Child | 16706881 | US | |
Parent | 12011314 | Jan 2008 | US |
Child | 15069676 | US |