Document processing service for displaying comments included in messages

Information

  • Patent Grant
  • 10204086
  • Patent Number
    10,204,086
  • Date Filed
    Monday, March 30, 2015
    9 years ago
  • Date Issued
    Tuesday, February 12, 2019
    5 years ago
Abstract
A plurality of comments associated with a document is received, and a representation of the document and a representation of a comment thread comprising the plurality of comments are displayed simultaneously on a user device. In one embodiment, a first comment is received from a first user and a second comment is received from a second user. The comment thread may be stored. Systems and apparatus are also disclosed.
Description
TECHNICAL FIELD

This specification relates generally to systems and methods for processing documents, and more particularly to systems and methods for providing online document processing services.


BACKGROUND

Online document processing services allow users to create and manipulate documents via the Internet, and store the documents at a remote location. Typically, a user accesses an online document processing service using a web browser operating on a computer or other device. Many existing document management services offer common word processing functions, including text editing, text searching, etc. By storing a document at the remote location, a user can access the document from any location, using a computer or other user device that has access to the Internet. Some online document processing services allow multiple users to access a document and to collaborate in creating and editing the document.


SUMMARY OF THE INVENTION

In accordance with an embodiment, a method for providing online document processing services is provided. A plurality of comments associated with a document is received, and a representation of the document and a representation of a comment thread comprising the plurality of comments are displayed simultaneously on a user device. In one embodiment, a first comment is received from a first user and a second comment is received from a second user. The comment thread may be stored.


In one embodiment, at least one of the plurality of comments pertains to a change to the document. The document is updated based on the change, and a representation of the updated document and a representation of the comment thread comprising the plurality of comments are displayed simultaneously on the user device.


In another embodiment, a comment associated with the document is received from a first user. It is determined that the comment includes an address associated with a second user, and, in response to determining that the comment comprises the address associated with the second user, a message is transmitted to the address. The address may comprise an email address. The message may comprise a link to a page comprising a representation of the document and a representation of the comment thread.


In another embodiment, a selection of a resolve option is received from a user. In response to the selection of the resolve option, the representation of the comment thread is removed from a display on a user device.


These and other advantages of the present disclosure will be apparent to those of ordinary skill in the art by reference to the following Detailed Description and the accompanying drawings.





BRIEF DESCRIPTION OF THE DRAWINGS


FIG. 1 shows a communication system that may be used to provide document processing services in accordance with an embodiment;



FIG. 2 shows functional components of an exemplary user device;



FIG. 3 shows functional components of an online document processing service in accordance with an embodiment;



FIG. 4 shows a document in accordance with an embodiment;



FIG. 5 shows a web page displaying a document in accordance with an embodiment;



FIG. 6 is a flowchart of a method for providing document processing services in accordance with an embodiment;



FIG. 7A shows a web page displaying a document in accordance with an embodiment;



FIG. 7B illustrates a comment thread in accordance with an embodiment;



FIG. 8 shows a web page displaying a document in accordance with an embodiment;



FIG. 9 shows a web page displaying a document in accordance with an embodiment;



FIG. 10 shows a web page displaying a document in accordance with an embodiment;



FIG. 11 shows a web page displaying a document in accordance with an embodiment;



FIG. 12 shows a web page displaying a document in accordance with an embodiment;



FIG. 13 is a flowchart of a method of providing online document processing services in accordance with an embodiment; and



FIG. 14 shows components of a computer that may be used to implement the invention.





DETAILED DESCRIPTION


FIG. 1 shows a communication system 100 that may be used to provide document processing services in accordance with an embodiment. Communication system 100 comprises a network 105, an online document processing service 130, and user devices 160-A, 160-B, 160-C, etc. For convenience, the term “user device 160” is used herein to refer to any one of user devices 160-A, 160-B, 160-C, etc. Accordingly, any discussion herein referring to “user device 160,” or to a component of a user device, is equally applicable to each of user devices 160-A, 160-B, 160-C, etc. Communication system 100 may comprise more or fewer than two user devices.


In the exemplary embodiment of FIG. 1, network 105 is the Internet. In other embodiments, network 105 may comprise one or more of a number of different types of networks, such as, for example, an intranet, a local area network (LAN), a wide area network (WAN), a wireless network, a Fibre Channel-based storage area network (SAN), or Ethernet. Other networks may be used. Alternatively, network 105 may comprise a combination of different types of networks.


Online document processing service 130 provides document processing services to users via network 105, enabling users to create, display, and edit documents remotely. For example, online document processing service 130 may provide online word processing services, allowing users to create, store, and edit text documents and other types of documents. Online document processing service 130 may be accessible via a World Wide Web page that may be viewed using a conventional Web browser, for example. A user may be required to log into a respective user account to access his or her document(s). Online document processing service 130 may offer common word processing features such as text editing, text searching, table creation and editing, etc. Online document processing service 130 may also provide other functions such as image creation and editing, spreadsheet management, etc. Online document processing service 130 may grant to a user access rights with respect to a document, such as viewing and editing rights.


User device 160 may be any device that enables a user to communicate via network 105. User device 160 may be connected to network 105 through a direct (wired) link, or wirelessly. User device 160 may have a display screen (not shown) for displaying information. For example, user device 160 may be a personal computer, a laptop computer, a workstation, a mainframe computer, etc. Alternatively, user device 160 may be a mobile communication device such as a wireless phone, a personal digital assistant, etc. Other devices may be used.



FIG. 2 shows functional components of an exemplary user device 160 in accordance with an embodiment. User device 160 comprises a web browser 210 and a display 270. Web browser 210 may be a conventional web browser used to access World Wide Web sites via the Internet, for example. Display 270 displays documents, images, Web pages, and other information to a user. For example, a text document that a user creates or edits may be displayed on display 270.



FIG. 3 shows functional components of online document processing service 130 in accordance with an embodiment. Online document processing service 130 comprises a document process 310 and a document repository 325. Document process 310 manages documents and performs operations requested by users, such as creating documents, editing text, performing text searches, etc. Documents created by users are stored in document repository 325. A document created by a user may be stored in association with his or her user account, for example. Multiple versions of a user's document may be stored in document repository 325. Document process 310 also provides comment and discussion functions allowing users to generate comments relating to documents, and to participate in discussions relating to documents. Information relating to comments and discussions may be stored in document repository 325.


In accordance with the embodiment of FIG. 1, a user may access online document processing service 130 and create and/or edit a document. For example, a user may employ browser 210 to access a World Wide Web site maintained by online document processing service 130. In a well-known manner, the user may be required to log into a user account to access his or her documents. The user may be required to authenticate his or her identity, e.g., by entering a user name and password, before accessing his or her user account and documents associated with the account. Online document processing service 130 may verify the user's access rights with respect to a document before granting the user access to the document.


Suppose, for example, that a first user, employing user device 160-A, accesses online document processing service 130 and creates a new document, such as document 400 illustrated in FIG. 4. In the illustrative embodiment, document 400 comprises text, including paragraphs 410 and 420. In various embodiments, a document may comprise lines of text, images, tables, headers, footers, footnotes, etc. Online document processing service 130 stores document 400, or data representing document 400, in document repository 325, as shown in FIG. 3. Online document processing service 130 may store a document model representing document 400, for example. The user may subsequently employ user device 160-A, or another device, to access document 400 via the Internet.


A well-known technique used by online document processing services to display a document on a user device includes transmitting data adapted to cause the user device to display all or a portion of the document on a Web page. For example, online document processing service 130 may transmit to browser 210 a request, in the form of HyperText Markup Language (HTML), adapted to cause browser 210 to display a representation of document 400. In response, browser 210 displays a representation of all or a portion of document 400. Suppose, for example, that after the first user creates document 400, a second user employs user device 160-B and accesses online document processing service 130 in order to view document 400. Online document processing service 130 transmits to user device 160-B data adapted to cause the user device to display a portion of document 400 on display 270, as shown in FIG. 5. In this illustrative embodiment, a page 560, including paragraphs 410 and 420, is displayed. Browser 210 also displays a toolbar 515 including various options, such as File option 517, and a scroll bar 592 that allows a user to scroll up or down within document 400.


In accordance with an embodiment, multiple comments relating to a particular document, received from one user or from multiple users, may be displayed simultaneously with the document on the display of a user device. FIG. 6 is a flowchart of a method for providing online document services in accordance with an embodiment. At step 610, a plurality of comments associated with a document is received. At step 620, a representation of the document and a representation of a comment thread comprising the plurality of comments is caused to be displayed simultaneously on a user device.


Suppose, for example, that while viewing document 400, the second user wishes to add a comment relating to paragraph 410. In an embodiment, the second user may select an option to add a comment. Referring to FIG. 5, for example, the second user may right-click on a computer mouse to cause a menu of options to appear on display 270. In response, online document processing service 130 causes browser 210 to display a menu 540 including an “Add Comment” option 552. When the second user selects Add Comment option 552, browser 210 transmits the selection to online document processing service 130. In response, online document processing service causes browser 210 to display a region in which the user may compose a comment. Referring to FIG. 7A, browser 210 may display page 560, including paragraphs 410 and 420, in a left-hand portion of display 270, and display, in a right-hand portion of the display, a comment box 720 in which the second user may compose a comment. Comment box 720 comprises an image 752 or other representation of the second user, and an indication 756 of the second user's name, nickname, username, title, etc.


After the second user composes a comment within comment box 720, the second user may either post the comment, by selecting an add option 777, or may choose to cancel the comment, by selecting a cancel option 788. In the illustrative embodiment, the second user selects add option 777. Browser 210 transmits the selection, and the second user's comment, to online document processing service 130. In response, online document processing service 130 stores the second user's comment in document repository 325, as comment 791, as shown in FIG. 3. In the embodiment of FIG. 3, online document processing service 130 defines a comment thread 802 associated with document 400, and stores comment 791 in association with comment thread 802. As used herein, the term “thread” means a data structure comprising information relating to one or more associated comments. In one example, various related comments in a thread may be stored at various memory locations within document repository 325, and the comment thread may comprise pointers to the various comments. FIG. 7B illustrates comment thread 802 in accordance with an embodiment. Comment thread 802 comprises a pointer 767 associated with comment 791, for example. A comment thread may comprise other types of information. Other data structures, such as a database, may be used to define and/or store a comment thread.


Online document processing service 130 transmits to user device 160-B, and to other user devices, data adapted to cause the user device to display simultaneously a representation of document 400 and a representation of comment thread 802. In response, browser 210 may display, on display 270, a page such as that shown in FIG. 8. Page 560 of document 400, including paragraphs 410 and 420, is displayed in a left-hand portion of display 270. Comment thread 802, including the second user's comment 791, is displayed simultaneously in a right-hand portion of display 270.


As indicated in FIG. 8, a reply option 875 is displayed in association with comment thread 802. Reply option 875 allows a user to reply to comment 791 or otherwise to add an additional comment to comment thread 802.


After the second user's comment 791 is received and posted, as discussed above, additional comments may be received from other users. Suppose, for example, that a third user, employing user device 160-C (shown in FIG. 1), views document 400, and comment 791, and wishes to add a comment in reply to comment 791. The third user may select reply option 875, using a computer mouse, for example. Browser 210 transmits the selection of reply option 875 to online document processing service 130. In response, online document processing service 130 transmits to user device 160-C data adapted to cause the user device to display a comment box allowing the third user to compose a comment. For example, online document processing service 130 may transmit a request that browser 210 display document 400 and comment thread 802 simultaneously, and that browser 210 include an additional comment box in association with comment thread 802. In response, browser 210 may display, on display 270 of user device 160-C, a web page such as that shown in FIG. 9. Page 560 of document 400, including paragraphs 410 and 420, is displayed in a left-hand portion of display 270. Comment thread 802, including the second user's comment 791, is simultaneously displayed in a right-hand portion of display 270. In the illustrative embodiment, a comment box 965 is displayed in which the third user may compose a reply comment.


In the illustrative embodiment, the third user composes a reply comment and selects add option 777. User device 160-C transmits the third user's selection, and the third user's comment, to online document processing service 130. Online document processing service 130 stores the third user's comment in document repository 325, as comment 1015, as shown in FIG. 3. Online document processing service 130 also updates comment thread 802 to include a pointer 768 (and/or other information) associated with the third user's comment 1015, as shown in FIG. 7B. Online document processing service 130 may then transmit to user device 160-C (and to other user devices) a request to display simultaneously document 400 and updated comment thread 802. In response, browser 210 displays, on display 270, a page such as that shown in FIG. 10. Page 560 of document 400, including paragraphs 410 and 420, is displayed in a left-hand portion of display 270. Comment thread 802, including the second user's comment 791 and the third user's comment 1015, are displayed within comment thread 802 in the right-hand portion of display 270.


Enabling users to maintain comment threads associated with a document, and displaying the comment threads simultaneously with the document, as described herein, provides particular advantages in the context of document production and management. Allowing users to view comments in real-time along with the document improves communication among users, provides a more efficient workflow and accelerates document production.


Referring to FIG. 10, a resolve option 1033 is also displayed in association with comment thread 802. In accordance with an embodiment, when a user selects the resolve option, comment thread 802 is removed from the display on each user's device, and is no longer displayed in association with document 400. However, comment thread 802, and the associated comments, remain stored in repository 325 and may be re-opened by a user at a later time. For example, if a particular user selects resolve option 1033, document processing service 130 may transmit a resolve notification message to one or more users associated with document 400 indicating that a user has selected the resolve option. For example, a resolve notification message may be transmitted to all users associated with the comment thread. Upon receipt of a resolve notification message, a user device 160 may display a message such as message 1122 shown in FIG. 11. In this example, notification message 1122 states that “A user has resolved this comment thread.”


Each recipient of the resolve notification message is provided an option to object to the resolution of the comment thread. Referring to FIG. 11, for example, notification message 1122 includes an “OK” option 1138 which a user may select if he or she agrees with the resolution of the comment thread, and a “Re-Open Thread” option 1165, which the user may select if the user does not want the thread to be resolved. If a user selects Re-Open option 1165, comment thread 802 is re-opened and continues to appear on display 270 in association with document 400.


In accordance with another embodiment, a first user may include in a comment an address associated with a second user. The inclusion of the second user's address in the comment causes a message to be generated and sent to the second user. Referring to FIG. 12, suppose that the first user reviewing a page 1227 of a document selects a comment option (in the manner described above) to add a comment associated with a particular paragraph 1274. In response, document processing service 130 displays a comment box 1282.



FIG. 13 is a flowchart of a method of providing electronic messaging services in accordance with an embodiment. In the illustrative embodiment of FIG. 12, a first user composes a comment in box 1282, and includes in the comment an email address 1286 associated with another user, “User5.” In the illustrative example of FIG. 12, the first user types “@user5@add1,” which includes a selected symbol “@” followed by a string of alphanumeric characters representing an email address of User5. It is to be understood that the alphanumeric characters used above to represent an email address are representative only, and that other characters, symbols, and formats may be used.


In one embodiment, when a comment box is displayed and a user is composing a comment, the alphanumeric characters typed by the user within the comment box are monitored, and when the “@” symbol is detected, a list of addresses associated with the document is displayed to the user. For example, a list of email addresses of other users associated with the document may be displayed. The user may select one of the displayed addresses for inclusion in the comment.


At step 1310, a comment relating to a document is received from a first user. When the first user indicates that the comment is complete, by selecting add option 777, for example, document processing service 130 receives the comment from user device 160, establishes a comment thread, if necessary, and adds the comment to the comment thread, in the manner described above.


At step 1320, an address is identified within the comment. Accordingly, document processing service 130 examines the first user's comment and determines that the first user's comment includes the email address “user5@add1,” associated with User5. At step 1330, a message is transmitted to the address. Document processing service 130 generates an email message and transmits the message to the email address “user5@add1.” The email message may notify User5 that a comment has been posted that includes the email address associated with User5, for example. The email message may also include a copy of the first user's comment. The message may include other information. For example, the email message may include a link that enables the recipient of the message to click on the link and post a reply to the first user's comment. Clicking on the link may cause the recipient's user device to connect to document processing service 130, access the document, and display the first user's comment and a relevant portion of the document, for example. While in the illustrative embodiment an email address is included in a comment, in other embodiments, other types of addresses may be used.


In various embodiments, the method steps described herein, including the method steps described in FIGS. 6 and/or 13, may be performed in an order different from the particular order described or shown. In other embodiments, other steps may be provided, or steps may be eliminated, from the described methods.


Systems, apparatus, and methods described herein may be implemented using digital circuitry, or using one or more computers using well-known computer processors, memory units, storage devices, computer software, and other components. Typically, a computer includes a processor for executing instructions and one or more memories for storing instructions and data. A computer may also include, or be coupled to, one or more mass storage devices, such as one or more magnetic disks, internal hard disks and removable disks, magneto-optical disks, optical disks, etc.


Systems, apparatus, and methods described herein may be implemented using computers operating in a client-server relationship. Typically, in such a system, the client computers are located remotely from the server computer and interact via a network. The client-server relationship may be defined and controlled by computer programs running on the respective client and server computers.


Systems, apparatus, and methods described herein may be used within a network-based cloud computing system. In such a network-based cloud computing system, a server or another processor that is connected to a network communicates with one or more client computers via a network. A client computer may communicate with the server via a network browser application residing and operating on the client computer, for example. A client computer may store data on the server and access the data via the network. A client computer may transmit requests for data, or requests for online services, to the server via the network. The server may perform requested services and provide data to the client computer(s). The server may also transmit data adapted to cause a client computer to perform a specified function, e.g., to perform a calculation, to display specified data on a screen, etc. For example, the server may transmit a request adapted to cause a client computer to perform one or more of the method steps described herein, including one or more of the steps of FIGS. 6 and/or 13. Certain steps of the methods described herein, including one or more of the steps of FIGS. 6 and/or 13, may be performed by a server or by another processor in a network-based cloud-computing system. Certain steps of the methods described herein, including one or more of the steps of FIGS. 6 and/or 13, may be performed by a client computer in a network-based cloud computing system. The steps of the methods described herein, including one or more of the steps of FIGS. 6 and/or 13, may be performed by a server and/or by a client computer in a network-based cloud computing system, in any combination.


Systems, apparatus, and methods described herein may be implemented using a computer program product tangibly embodied in an information carrier, e.g., in a non-transitory machine-readable storage device, for execution by a programmable processor; and the method steps described herein, including one or more of the steps of FIGS. 6 and/or 13, may be implemented using one or more computer programs that are executable by such a processor. A computer program is a set of computer program instructions that can be used, directly or indirectly, in a computer to perform a certain activity or bring about a certain result. A computer program can be written in any form of programming language, including compiled or interpreted languages, and it can be deployed in any form, including as a stand-alone program or as a module, component, subroutine, or other unit suitable for use in a computing environment.


A high-level block diagram of an exemplary computer that may be used to implement systems, apparatus and methods described herein is illustrated in FIG. 14. Computer 1400 comprises a processor 1401 operatively coupled to a data storage device 1402 and a memory 1403. Processor 1401 controls the overall operation of computer 1400 by executing computer program instructions that define such operations. The computer program instructions may be stored in data storage device 1402, or other computer readable medium, and loaded into memory 1403 when execution of the computer program instructions is desired. Thus, the method steps of FIGS. 6 and/or 13 can be defined by the computer program instructions stored in memory 1403 and/or data storage device 1402 and controlled by the processor 1401 executing the computer program instructions. For example, the computer program instructions can be implemented as computer executable code programmed by one skilled in the art to perform an algorithm defined by the method steps of FIGS. 6 and/or 13. Accordingly, by executing the computer program instructions, the processor 1401 executes an algorithm defined by the method steps of FIGS. 6 and/or 13. Computer 1400 also includes one or more network interfaces 1404 for communicating with other devices via a network. Computer 1400 also includes one or more input/output devices 1405 that enable user interaction with computer 1400 (e.g., display, keyboard, mouse, speakers, buttons, etc.).


Processor 1401 may include both general and special purpose microprocessors, and may be the sole processor or one of multiple processors of computer 1400. Processor 1401 may comprise one or more central processing units (CPUs), for example. Processor 1401, data storage device 1402, and/or memory 1403 may include, be supplemented by, or incorporated in, one or more application-specific integrated circuits (ASICs) and/or one or more field programmable gate arrays (FPGAs).


Data storage device 1402 and memory 1403 each comprise a tangible non-transitory computer readable storage medium. Data storage device 1402, and memory 1403, may each include high-speed random access memory, such as dynamic random access memory (DRAM), static random access memory (SRAM), double data rate synchronous dynamic random access memory (DDR RAM), or other random access solid state memory devices, and may include non-volatile memory, such as one or more magnetic disk storage devices such as internal hard disks and removable disks, magneto-optical disk storage devices, optical disk storage devices, flash memory devices, semiconductor memory devices, such as erasable programmable read-only memory (EPROM), electrically erasable programmable read-only memory (EEPROM), compact disc read-only memory (CD-ROM), digital versatile disc read-only memory (DVD-ROM) disks, or other non-volatile solid state storage devices.


Input/output devices 1405 may include peripherals, such as a printer, scanner, display screen, etc. For example, input/output devices 1405 may include a display device such as a cathode ray tube (CRT) or liquid crystal display (LCD) monitor for displaying information to the user, a keyboard, and a pointing device such as a mouse or a trackball by which the user can provide input to computer 1400.


Any or all of the systems and apparatus discussed herein, including online document processing service 130, user device 160, and components thereof, including web browser 210, display 270, document process 310, and document repository 325, may be implemented using a computer such as computer 1400.


One skilled in the art will recognize that an implementation of an actual computer or computer system may have other structures and may contain other components as well, and that FIG. 14 is a high level representation of some of the components of such a computer for illustrative purposes.


The foregoing Detailed Description is to be understood as being in every respect illustrative and exemplary, but not restrictive, and the scope of the invention disclosed herein is not to be determined from the Detailed Description, but rather from the claims as interpreted according to the full breadth permitted by the patent laws. It is to be understood that the embodiments shown and described herein are only illustrative of the principles of the present invention and that various modifications may be implemented by those skilled in the art without departing from the scope and spirit of the invention. Those skilled in the art could implement various other feature combinations without departing from the scope and spirit of the invention.

Claims
  • 1. A method comprising: receiving a first comment for an electronic document from a first user via a first user device, wherein the first comment comprises a particular symbol followed by one or more characters representing a user address of a second user;storing the first comment in a comment thread associated with the electronic document;transmitting data to the first user device to display a first representation of the comment thread on the first user device;extracting, by a server, the user address from the first comment stored in the comment thread;automatically sending a first email message to a second user device of the second user, by the server, based on the extracted user address, wherein the first email message comprises the first comment, and a link to a page that, when selected, causes a representation of the electronic document and a second representation of the comment thread to be displayed simultaneously on the second user device;receiving a selection of a resolve option from the second user via the second user device responsive to sending the first email message; andtransmitting, responsive to the selection of the resolve option, a plurality of notifications to remove the first representation and the second representation of the comment thread with the first comment from a display of the first user device and a display of the second user device.
  • 2. The method of claim 1, further comprising: receiving a second email message in reply to the first email message, wherein the second email message comprises a second comment; andtransmitting data to cause display of the second comment on the display of the first user device.
  • 3. The method of claim 2, further comprising: associating the second comment with the comment thread; and transmitting, to the first user device, data to first representation of the comment thread on the first user device, wherein the updated first representation comprises the first comment from the first user and the second comment.
  • 4. The method of claim 3, further comprising: receiving a third comment responsive to the updated first representation of the comment thread; associating the third comment with the comment thread; and transmitting, to the first user device, data to further update the updated first representation of the comment thread on the first user device to comprise the third comment.
  • 5. The method of claim 4, further comprising: transmitting, to the second user device, data to update the displayed second representation of the comment thread on the second user device to comprise the second comment and the third comment.
  • 6. A method comprising: displaying, on a display device at a first user device, a representation of an electronic document;receiving a request to add a comment related to a portion of the displayed representation of the electronic document from a first user at the first user device;in response to receiving the request, displaying, on the display device, a region in which the first user may input one or more characters for the comment;monitoring the characters for a particular character as the characters are received from the first user at the first user device;in response to detecting that the particular character has been received, displaying, on the display device, one or more user addresses of users associated with the electronic document;receiving, at the first user device from the first user, a selection of a user address, for a second user, among the displayed user addresses and an indication that the comment is complete; andin response to receiving the indication, sending, from the first user device and to a server, the comment comprising the characters, and wherein the characters comprise the particular character followed by the selected user address, wherein sending the comment to the server causes the server to extract the selected user address from the comment and send a first email message to the second user at a second user device based on the extracted user address, wherein the first email message comprises the comment and a link to a page that, when selected, causes a the representation of the portion of the electronic document related to the comment and a representation of a comment thread to be displayed simultaneously on a display device of the second user device, and wherein the comment thread comprises the comment and a resolve option that allows the second user to remove the representation of the comment thread from a display device of at least one other user device.
  • 7. The method of claim 6, further comprising: receiving, from the second user at the second user device, a selection of a the resolve option to remove the representation of a the comment thread from the display device of the other user device.
  • 8. The method of claim 7, further comprising: removing the representation of the comment thread from the display device of the other user device.
  • 9. A system comprising: a memory that stores instructions: anda processor configured to execute the instructions to:receive a first comment for an electronic document from a first user via a first user device, wherein the first comment comprises a particular symbol followed by one or more characters representing a user address of a second user;store the first comment in a comment thread associated with the electronic document;transmit data to the first user device to display a first representation of the comment thread on the first user device;extract, by a server, the user address from the first comment stored in the comment thread;automatically send a first email message to a second user device of the second user, by the server, based on the extracted user address, wherein the first email message comprises the first comment, and a link to a page that, when selected, causes a representation of the electronic document and a second representation of the comment thread to be displayed simultaneously on the second user device;receive a selection of a resolve option from the second user via the second user device responsive to having sent the first email message; and transmit, responsive to the selection of the resolve option, a plurality of notifications to remove the first representation and the second representation of the comment thread with the first comment from a display of the first user device and a display of the second user device.
  • 10. The system of claim 9, wherein the processor is further configured to execute the instructions to: receive a second email message in reply to the first email message, wherein the second email message comprises a second comment; andtransmit data to cause display of the second comment on the display of the first user device.
  • 11. The system of claim 10, wherein the processor is further configured to execute the instructions to: associate the second comment with the comment thread; and transmit, to the first user device, data to update the displayed first representation of the comment thread on the first user device, wherein the updated first representation comprises the first comment from the first user and the second comment.
  • 12. The system of claim 11, wherein the processor is further configured to execute the instructions to: receive a third comment responsive to the updated first representation of the comment thread;associate the third comment with the comment thread; and transmit, to the first user device, data to further update the updated first representation of the comment thread on the first user device to comprise the third comment.
  • 13. The system of claim 12, wherein the processor is further configured to execute the instructions to: transmit, to the second user device, data to update the displayed second representation of the comment thread on the second user device to comprise the second comment and the third comment.
  • 14. A system comprising: a memory that stores instructions; anda processor configured to execute the instructions to:display, on a display device at a first user device, a representation of an electronic document;receive a request to add a comment related to a portion of the displayed representation of the electronic document from a first user at the first user device;in response to the receipt of the request, display, on the display device, a region in which the first user may input one or more characters for the comment;monitor the characters for a particular character as the characters are received from the first user at the first user device;in response to a detection that the particular character has been received, display, on the display device, one or more user addresses of users associated with the electronic document;receive, at the first user device from the first user, a selection of a user address, for a second user, among the displayed user addresses and an indication that the comment is complete; andin response to the receipt of the indication, send, from the first user device and to a server, the comment comprising the characters, and wherein the characters comprise the particular character followed by the selected user address, wherein sending the comment to the server causes the server to extract the selected user address from the comment and send an email message to the second user at a second user device based on the extracted user address, wherein the email message comprises the comment and a link to a page that, when selected, causes the representation of the portion of the electronic document related to the comment and a representation of a comment thread to be displayed simultaneously on a display device of the second user device, and wherein the comment thread comprises the comment and a resolve option that allows the second user to remove the representation of the comment thread from a display device of at least one other user device.
  • 15. The system of claim 14, wherein the processor is further configured to execute the instructions to: receive, from the second user at the second user device, a selection of the resolve option to remove the representation of the comment thread from the display device of the other user device.
  • 16. The system of claim 15, wherein the processor is further configured to execute the instructions to: remove the representation of the comment thread from the display device of the other user device.
Parent Case Info

This application is a continuation of U.S. patent application Ser. No. 13/249,442 (currently pending) filed Sep. 30, 2011, entitled “System and Method for Providing Document Processing Services,” which claims the benefit of provisional patent application Ser. No. 61/453,238, filed Mar. 16, 2011, the entire contents of each of which are hereby incorporated by reference.

US Referenced Citations (209)
Number Name Date Kind
5231577 Koss Jul 1993 A
5408470 Rothrock et al. Apr 1995 A
5557722 DeRose et al. Sep 1996 A
5708826 Ikeda et al. Jan 1998 A
5758358 Ebbo May 1998 A
5761669 Montague et al. Jun 1998 A
5781732 Adams Jul 1998 A
5793966 Amstein et al. Aug 1998 A
5799325 Rivette et al. Aug 1998 A
5819304 Nilsen et al. Oct 1998 A
5999932 Paul Dec 1999 A
6049664 Dale et al. Apr 2000 A
6061697 Nakao May 2000 A
6073144 van Hoff Jun 2000 A
6243706 Moreau et al. Jun 2001 B1
6327584 Xian et al. Dec 2001 B1
6341305 Wolfe Jan 2002 B2
6349308 Whang et al. Feb 2002 B1
6349314 Patel Feb 2002 B1
6377957 Jeyaraman Apr 2002 B1
6418441 Call Jul 2002 B1
6438564 Morton et al. Aug 2002 B1
6501779 McLaughlin et al. Dec 2002 B1
6525747 Bezos Feb 2003 B1
6544294 Greenfield et al. Apr 2003 B1
6766333 Wu et al. Jul 2004 B1
6907565 Huang Jun 2005 B1
6988241 Guttman et al. Jan 2006 B1
7017112 Collie et al. Mar 2006 B2
7031954 Kirsch Apr 2006 B1
7035910 Dutta et al. Apr 2006 B1
7069502 Numata et al. Jun 2006 B2
7107518 Ramaley Sep 2006 B2
7162693 Yamanaka et al. Jan 2007 B2
7213199 Humenansky et al. May 2007 B2
7222156 Gupta May 2007 B2
7263497 Wiser et al. Aug 2007 B1
7305613 Oezgen Dec 2007 B2
7325199 Reid Jan 2008 B1
7328243 Yeager et al. Feb 2008 B2
7350142 Kraft et al. Mar 2008 B2
7437421 Bhogal et al. Oct 2008 B2
7478330 Branson et al. Jan 2009 B1
7491399 Vakharia Feb 2009 B2
7506242 Kotler et al. Mar 2009 B2
7529778 Dewey et al. May 2009 B1
7536633 Faraday et al. May 2009 B2
7634728 Kraft Dec 2009 B2
7656543 Atkins Feb 2010 B2
7667862 Ziegler et al. Feb 2010 B2
7680932 Defaix et al. Mar 2010 B2
7698379 Dutta et al. Apr 2010 B2
7737996 Gerhard et al. Jun 2010 B2
7761796 Faraday et al. Jul 2010 B2
7769810 Kaufman Aug 2010 B1
7774703 Junuzovic et al. Aug 2010 B2
7818678 Massand Oct 2010 B2
7818679 Clarke Oct 2010 B2
7890928 Patrudu Feb 2011 B2
7937663 Parker et al. May 2011 B2
7941399 Bailor et al. May 2011 B2
8019780 Pinkerton et al. Sep 2011 B1
8108464 Rochelle et al. Jan 2012 B1
8151204 Lusen et al. Apr 2012 B2
8266534 Curtis et al. Sep 2012 B2
8464164 Hon Jun 2013 B2
8621012 Jackson Dec 2013 B2
8621021 Provo Dec 2013 B2
8966362 Smetters Feb 2015 B2
9292481 Mangini Mar 2016 B2
20010037346 Johnson Nov 2001 A1
20020032701 Gao et al. Mar 2002 A1
20020035580 Tanabe Mar 2002 A1
20020042838 Tabayoyon et al. Apr 2002 A1
20020051185 Yamaguchi et al. May 2002 A1
20020133492 Goldstein et al. Sep 2002 A1
20020156803 Maslov et al. Oct 2002 A1
20020174085 Nelson et al. Nov 2002 A1
20020188631 Tiemann et al. Dec 2002 A1
20020194302 Blumberg Dec 2002 A1
20030014406 Faieta et al. Jan 2003 A1
20030037076 Bravery et al. Feb 2003 A1
20030037303 Bodlaender et al. Feb 2003 A1
20030070176 Parker et al. Apr 2003 A1
20030084078 Torii et al. May 2003 A1
20030105719 Berger et al. Jun 2003 A1
20030145279 Bourbakis et al. Jul 2003 A1
20030208541 Musa Nov 2003 A1
20040030697 Cochran et al. Feb 2004 A1
20040044965 Toyama et al. Mar 2004 A1
20040051736 Daniell Mar 2004 A1
20040059783 Kazui et al. Mar 2004 A1
20040064733 Gong Apr 2004 A1
20040085354 Massand May 2004 A1
20040088374 Webb et al. May 2004 A1
20040088653 Bell et al. May 2004 A1
20040133444 Defaix et al. Jul 2004 A1
20040172450 Edelstein et al. Sep 2004 A1
20040205664 Prendergast Oct 2004 A1
20040215672 Pfitzner Oct 2004 A1
20040215825 Pfitzner Oct 2004 A1
20040215826 Pfitzner Oct 2004 A1
20040216090 Kaler et al. Oct 2004 A1
20040248612 Lee et al. Dec 2004 A1
20040255005 Spooner Dec 2004 A1
20040267871 Pratley et al. Dec 2004 A1
20050055337 Bebo et al. Mar 2005 A1
20050091291 Kaler et al. Apr 2005 A1
20050097061 Shapiro et al. May 2005 A1
20050125461 Filz Jun 2005 A1
20050131887 Rohrabaugh et al. Jun 2005 A1
20050144256 Blumberg Jun 2005 A1
20050185636 Bucher Aug 2005 A1
20050198305 Pezaris Sep 2005 A1
20050198612 Gonzalez Sep 2005 A1
20050200896 Narusawa et al. Sep 2005 A1
20050209914 Nguyen et al. Sep 2005 A1
20050216827 Mochizuki Sep 2005 A1
20050273695 Schnurr Dec 2005 A1
20060020670 Anderson Jan 2006 A1
20060031751 Ehud Feb 2006 A1
20060036692 Morinigo et al. Feb 2006 A1
20060075332 Fairweather et al. Apr 2006 A1
20060080432 Spataro et al. Apr 2006 A1
20060095527 Malik May 2006 A1
20060101071 Henderson May 2006 A1
20060129627 Phillips et al. Jun 2006 A1
20060136513 Ngo et al. Jun 2006 A1
20060149831 Dutta et al. Jul 2006 A1
20060168044 Chen et al. Jul 2006 A1
20060200755 Melmon et al. Sep 2006 A1
20060206500 Komamura et al. Sep 2006 A1
20060230344 Jennings et al. Oct 2006 A1
20060235933 Baluja et al. Oct 2006 A1
20060248129 Carnes et al. Nov 2006 A1
20060282762 Diamond Dec 2006 A1
20070033654 Wilson Feb 2007 A1
20070061714 Stuple et al. Mar 2007 A1
20070070066 Bakhash Mar 2007 A1
20070106729 Adams et al. May 2007 A1
20070118598 Bedi et al. May 2007 A1
20070143425 Kieselbach et al. Jun 2007 A1
20070162840 Rochelle et al. Jul 2007 A1
20070186157 Walker et al. Aug 2007 A1
20070208992 Koren Sep 2007 A1
20070220068 Thompson et al. Sep 2007 A1
20070233459 Perronnin Oct 2007 A1
20070233811 Rochelle et al. Oct 2007 A1
20070288637 Layton et al. Dec 2007 A1
20080010372 Khedouri et al. Jan 2008 A1
20080028302 Meschkat Jan 2008 A1
20080040659 Doyle Feb 2008 A1
20080059417 Yamada et al. Mar 2008 A1
20080059539 Chin et al. Mar 2008 A1
20080082604 Mansour et al. Apr 2008 A1
20080126943 Parasnis et al. May 2008 A1
20080127212 Nakamizo et al. May 2008 A1
20080222273 Lakshmanan et al. Sep 2008 A1
20080301560 Rogers et al. Dec 2008 A1
20090070306 Stroe et al. Mar 2009 A1
20090089293 Garritano et al. Apr 2009 A1
20090089664 Wagner et al. Apr 2009 A1
20090112953 Barsness et al. Apr 2009 A1
20090112990 Campbell et al. Apr 2009 A1
20090119572 Koivunen May 2009 A1
20090129596 Chavez May 2009 A1
20090132907 Shao et al. May 2009 A1
20090164620 Ziegler et al. Jun 2009 A1
20090249224 Davis et al. Oct 2009 A1
20090307585 Tranchant et al. Dec 2009 A1
20100005398 Pratley et al. Jan 2010 A1
20100017694 Wick et al. Jan 2010 A1
20100030578 Siddique et al. Feb 2010 A1
20100050089 Kim et al. Feb 2010 A1
20100083096 Dupuis-Latour et al. Apr 2010 A1
20100095198 Bultrowicz Apr 2010 A1
20100205230 Simeonov et al. Aug 2010 A1
20100205520 Parish et al. Aug 2010 A1
20100218099 van Melle et al. Aug 2010 A1
20100229086 Howell et al. Sep 2010 A1
20100235763 Massand Sep 2010 A1
20100241968 Tarara et al. Sep 2010 A1
20100245256 Estrada et al. Sep 2010 A1
20100251122 Lee et al. Sep 2010 A1
20100281076 Pan et al. Nov 2010 A1
20100309436 Allen, Jr. et al. Dec 2010 A1
20100318894 Billharz et al. Dec 2010 A1
20110035661 Balinsky et al. Feb 2011 A1
20110066957 Prats et al. Mar 2011 A1
20110078246 Dittmer-Roche Mar 2011 A1
20110085211 King et al. Apr 2011 A1
20110099093 Mills Apr 2011 A1
20110164043 Arora et al. Jul 2011 A1
20110179427 Krishnamoorthy et al. Jul 2011 A1
20110209052 Parker et al. Aug 2011 A1
20110219331 DeLuca et al. Sep 2011 A1
20110252299 Lloyd et al. Oct 2011 A1
20110252335 Lloyd et al. Oct 2011 A1
20110252339 Lemonik et al. Oct 2011 A1
20110264712 Ylonen Oct 2011 A1
20110282933 Schmier Nov 2011 A1
20110296299 Parker Dec 2011 A1
20120023392 Cierniak et al. Jan 2012 A1
20120117406 Eun May 2012 A1
20120117452 Lloyd et al. May 2012 A1
20120131483 Archer et al. May 2012 A1
20130246901 Massand Sep 2013 A1
20130262574 Cohen Oct 2013 A1
20140082093 Savage Mar 2014 A1
Non-Patent Literature Citations (17)
Entry
“Comment Email Responder,” from website Ugh's Greymatter Honeypot, retrieved from Internet Archive Wayback Machine capture on Mar. 4, 2010, p. 1-2, available at https://web.archive.org/web/20100304221737/http://www.u-g-h.com/wordpress-plugins/wordpress-plugin-comment-email-responder.
Rowse, “5 Comment Management Plugins for WordPress,” Aug. 21, 2007, p. 1-19, retrieved from https://problogger.com/5-comment-management-plugins-for-wordpress.
“Simultaneously edit a presentation with other authors,” by MicrosoftTM Office: MAC, published Nov. 11, 2010, pp. 1-4.
“User Levels,” WordPress, retrieved from the internet at http://codex.wordpress.org/User_Levels, Jul. 1, 2005, 2 pages.
Bibi et al., “A Platform for Delivering Multimedia Presentations on Cultural Heritage,” 2010 14th Panhellenic Conference on Informatics, pp. 175-179.
Ellis et al., “Concurrency Control in Groupware Systems,” ACM 1989, pp. 399-407.
Huang et al., “A General Purpose Virtual Collaboration Room,” Google 1999, pp. 1-9.
Kindberg, “Mushroom: A Framework for Collaboration and Interaction across the Internet,” Google 1996, pp. 1-11.
Krieger, “Documents, Presentations, and Workbooks: Using Microsoft® Office to Create Content That Gets Noticed,” published May 2011, pp. 1-104.
Mulvany, “What's Going on in Indexing,” ACM 1997, pp. 10-15.
Munteaunu et al., “Collaborative Editing for Improved Usefulness and Usability of Transcript-Enhanced Webcasts,” ACM Apr. 5-10, 2008, pp. 373-382.
Pacull et al., “Duplex: A Distributed Collaborative Editing Environment in Large Scale,” ACM Oct. 1994, pp. 165-173.
Raggett, Dave, “Slidy—a web based alternative to Microsoft PowerPoint,” published 2006, pp. 1-13.
Taylor, “Cool Apple Keynote Presentation Tricks and Tips,” published Apr. 2011, p. 1-5.
McCue, Acrobat Production Tips. Real World Print Production with Adobe Creative Suite Applications, copyright 2009, Chapter 12, pp. 1-40.
Wikipedia “Help: Using talk pages”, retrieved by Internet Archive Wayback Machine Jul. 1, 2010, http://web.archive.org/web/20100701123005/http://en.wikipedia.org/wiki/Help:Using_talk_pages (pp. 1-4).
Wikipedia “Signatures”, retrieved by Internet Archive Wayback Machine Mar. 2, 2010, http://web.archive.org/web/20100302130336/http:/!en.wikipedia.org/wiki/Wikipedia:Sign_your_posts_on_talk_pages (pp. 1-4).
Provisional Applications (1)
Number Date Country
61453238 Mar 2011 US
Continuations (1)
Number Date Country
Parent 13249442 Sep 2011 US
Child 14673809 US