The availability of shared storage systems for electronic documents has increased the ability of computer end users to share and collaborate in the creation of a variety of electronic documents. End users can cause documents to be stored in shared storage systems on a computer network, such as the internet. End users can instruct such a shared storage system to allow electronic documents to be shared with other end users of the shared storage system. A shared storage system generally has an access control component in a file system that tracks the access rights users have for each electronic document.
After an electronic document has been shared with two or more end users, the shared storage system manages access to the shared electronic document to ensure consistency of the electronic document, especially in the case of collaborative modifications to the electronic document. A kind of collaboration system, typically resident on a server computer that is configured to access the file system of the shared storage system, typically is involved in managing this collaborative modification by tracking which users currently are accessing an electronic document.
This Summary is provided to introduce a selection of concepts in a simplified form that are further described below in the Detailed Description. This Summary is intended neither to identify key or essential features, nor to limit the scope, of the claimed subject matter.
An end user application running on a computer, for the purpose of collaborative modification of shared electronic documents, is configured to provide a graphical user interface that facilitates interactively and collaboratively modifying an electronic document. This graphical user interface includes a graphical element that conveys to an end user both sharing status information and editing status information for the currently accessed electronic document. The graphical element can take any of a number of different forms, such that each different form represents a different combination of the current sharing state and current co-authoring state of the currently accessed electronic document. Through input devices of the end user computer, an end user can manipulate this graphical element. In response to certain manipulations of the graphical element, the end user computer is configured to present further detailed information about such status and to receive further inputs from a user to change such status.
To generate such a graphical element, an application uses an identifier of the electronic document being edited, such as a file name, to access information from a shared storage system and from a collaboration system. The shared storage system provides information from its access control data for the electronic document, indicative of a number of end users with whom the electronic document is shared. The collaboration system provides information about end users that are currently accessing the electronic document. The application generates the graphical element by combining an icon, an indication of the number of users sharing the document and an indication of the number of users currently editing the document.
In the following description, reference is made to the accompanying drawings which form a part hereof, and in which are shown, by way of illustration, specific example implementations of this technique. It is understood that other embodiments may be utilized and structural changes may be made without departing from the scope of the disclosure.
A computer system that is configured to support sharing and collaborative modification of electronic documents by multiple end users includes a shared storage system 100. The shared storage system 100 generally includes storage 102 in which data is stored in data files accessible through a file system 104 that is part of the shared storage system. The file system configures a server computer to maintain information about each file stored in storage 102. The shared storage system 100 can be implemented using one or more general purpose computers, such as described in connection with
Multiple end user computers 110 are connected to the shared storage system for communication over a computer network 112, such as the internet. An end user computer 110 can be a computer such as described in connection with
An end user computer 110 includes one or more applications 120. An application is a computer program executed on the end user computer that configures the computer to be responsive to user input 154 to allow an end user to interactively modify an electronic document 124. An electronic document can include any kind of data, such as text, still images, video and audio. The application processes the electronic document, in response to user input through input devices, by selecting and combining portions of data to create the content of the electronic document, by displaying or otherwise presenting display data 156, such as a graphical user interface including the content the electronic document, through output devices (not shown) to the end user, and by storing the electronic document in memory and/or in a data file in storage of the end user computer.
A variety of kinds of applications can be used on an end user computer. Examples of an application include, but are not limited to, a word processing application, a presentation application, a note taking application, a text editing application, a paint application, an image editing application, a spreadsheet application, a desktop publishing application, a drawing application, a video editing application, and an audio editing application.
An application generates an electronic document that is stored in a data file. Such a data file can be stored in local storage 122 and/or the shared storage system 100. The electronic document, while being modified by an end user on the end user computer, also is temporarily stored in memory on the end user computer.
If an electronic document is stored in a data file in the shared storage system 100, the file system 104 of the shared storage system includes information indicating a sharing state of the electronic document. Such information can be in the form of access controls indicating which end users are authorized to access the electronic document. The file system also can be configured to be responsive to a query to provide this information to another application, such as application 120 on an end user computer. An end user can view and modify the sharing state of an electronic document in a number of ways.
If an electronic document is stored in a data file in the shared storage system 100, and the data file is shared, with modification rights, with at least one more end user, then two or more end user computers may access and attempt to modify the electronic document. To handle such a condition, the shared storage system can include a kind of collaboration system 106. The collaboration system 106 is a computer program that configures the server computer to manage access to shared electronic documents in the shared storage system 100.
The collaboration system 106 is configured to store information about end users that are currently accessing the electronic document. The collaboration system can be configured to be responsive to a query to provide this information to another application on an end user computer, such as application 120.
Using the information about end users currently accessing an electronic document, the collaboration system can implement any of a number of different techniques for coordinating access to the electronic document to ensure consistency of the electronic document. For example, the collaboration system can prevent one user from writing to the data file for the electronic document while another user has the data file open for writing. As another example, the collaboration system can interactively merge changes to the electronic document as such changes are being made collaboratively by multiple users. In such a case, the collaboration system merges changes received from end user computers in memory local to the collaboration system, and then transmits a modified version of the electronic document to each end user computer with an application currently accessing the document.
Having now described the computer system in which an application on an end user computer can be used to interactively modify a shared electronic document, more details of the application will now be described.
In
The graphical user interface for the application in
As shown in
To generate such a graphical element 202, an application uses an identifier of the electronic document being edited, such as a file name, to access information both from the shared storage system 100 and from the collaboration system 106. The shared storage system provides information from its access control data for the electronic document, indicative of a number of end users with whom the electronic document is shared. The collaboration system provides information about end users that are currently accessing the electronic document. The application generates the graphical element 202 by combining an icon, an indication of the number of users sharing the document and an indication of the number of users currently editing the document. An example implementation of the generation of this graphical element is described in more detail below in connection with
In
Similarly, a second selector 310 is configured to select from among graphics indicating a co-authoring state of an electronic document. For example, a co-authoring state can be no co-authors, a number X less than a threshold Y of co-authors, and a number Z over the threshold Y of co-authors. A query module 312 is configured to request the co-authoring state from the collaboration system, and, based on this co-authoring state, control the selection made by the selector 310.
A graphical element generator 320 has inputs configured to receive the outputs of selectors 300 and 310, and a primary graphic 322, such as an icon, and an output configured to provide the graphical element 324 that combines the icon, indication of shared status and indication of co-authoring status. The graphical element 324 is an input to a graphical user interface generator 322 which provides the graphical user interface of the application.
A flowchart of operation of an example implementation of a graphical element generator, in an application which configures the computer to generate a graphical element, will now be described in connection with
In
In response to receiving the instruction to update the graphical element, the graphical element generator obtains 402 sharing information from the shared storage system and obtains 404 co-authoring information from the collaboration system. From this information, the application can generate the graphical element and then display the generated graphical element.
In the example implementation of
Similarly, the graphical element generator determines 416 if the document is currently being edited by more than one end user. If the document is not being edited by more than one user, then the graphical element is configured 420 to indicate the document is being edited by only the current end user. The graphical element generator determines 418 if the number of co-authors is greater than a threshold. Any threshold can be used, and an example is 99. If the number of co-authors is greater than this threshold, then the graphical element is configured 422 to indicate this information. Otherwise, the graphical element is configured 424 to indicate the number of co-authors.
The graphical element is then generated 426 and displayed in the graphical user interface for the application.
It should be understood that this example implementation in
Additionally, the number of co-authors can be computed by the application from information provided by the collaboration system or can be provided by the collaboration system. The co-authoring information can be displayed by the application in the pane 204 or in other part of the graphical user interface. The co-authoring information also can be processed by the application or the collaboration system to eliminate remove duplicate end user information. For example, if an end user accesses the same document on two different end user computers, then the co-authoring information indicates two users are accessing the electronic document. In such a case, the application or the collaboration system can process this information as representing a single user.
Additionally, the number of states to be considered for each of the sharing status and the co-authoring status can be different in different implementations. A threshold on the number of co-authors can be omitted; alternatively, multiple thresholds can be used. The distinction between private and public sharing can be omitted.
Referring now to
In
In
In
In
In
It should be understood that the graphical elements shown in
It should be understood that the foregoing description is merely an example of implementations of a computer system configured to support collaborative modification of electronic documents stored in a shared storage system.
By having an application provide a graphical user interface with a graphical element indicating both sharing and current editing status, user efficiency and productivity in collaborative modification of electronic documents is improved. Such a graphical element facilitates and consolidates access to information about both aspects of collaboration, namely sharing and co-authoring.
Accordingly, in one aspect computer comprises a processing system comprising one or more processing units and storage and a network interface. The network interface is configured to connect the computer to computer network, the computer network being connected to a shared storage system, the shared storage system comprising a file system configured to store a plurality of electronic documents and to make the plurality of electronic documents available to a plurality of users. The shared storage system further comprises a collaboration system configured to manage coauthoring of an electronic document in the file system by a plurality of end users. The storage comprises computer program code that, when executed by the processing system, configures the processing system to be comprising an application configured to process user input to modify an electronic document stored in the shared storage system. The application comprises a graphical user interface including a graphical element representing sharing status and co-authoring status of the electronic document. The application is further configured to obtain the sharing status of the electronic document from the file system and to obtain the co-authoring status of the electronic document from the collaboration system.
In another aspect, an article of manufacture comprises at least one computer storage medium and computer program instructions stored on the at least one computer storage medium which, when processed by a processing system of a computer, configures the computer to be comprising an application. The computer includes a network interface configured to connect the computer to computer network, the computer network being connected to a shared storage system. The shared storage system comprises a file system configured to store a plurality of electronic documents and to make the plurality of electronic documents available to a plurality of users. The shared storage system further comprises a collaboration system configured to manage coauthoring of an electronic document in the file system by a plurality of end users. The application is configured to process user input to modify an electronic document stored in the shared storage system. The application comprises a graphical user interface including a graphical element representing sharing status and co-authoring status of the electronic document. The application is further configured to obtain the sharing status of the electronic document from the file system and to obtain the co-authoring status of the electronic document from the collaboration system.
In another aspect, a computer-implemented process comprises accessing a shared storage system to retrieve an electronic document, the shared storage system comprising a file system configured to store a plurality of electronic documents and to make the plurality of electronic documents available to a plurality of end user computers over a computer network, the shared storage system further comprising a collaboration system configured to manage coauthoring of an electronic document in the file system by a plurality of end user computers over a computer network. Sharing status of the electronic document is received from the file system. Co-authoring status of the electronic document is received from the collaboration system. A graphical user interface is displayed with the electronic document and including a graphical element representing the sharing status and the co-authoring status of the electronic document.
In any of the foregoing aspects, the graphical element can comprises a plurality of different forms, such that each different form represents a different combination of the current sharing status and current co-authoring status of the electronic document currently being displayed through the graphical user interface of the application.
In any of the foregoing aspects, the graphical element can comprises a primary graphic, an indicator of the sharing status and an indicator of the co-authoring status. The application can be further configured to process the sharing status of the electronic document to select a graphic from among a plurality of graphics as the indicator for the sharing status. The application can be further configured to process the co-authoring status of the electronic document to select a graphic from among a plurality of graphics as the indicator for the co-authoring status.
In any of the foregoing aspects, the application can be further configured to process the co-authoring status to compute a number of end users currently accessing the electronic document, wherein the application is further configured to identify an end user accessing the electronic document from a plurality of end user computers, and, in response to identifying an end user accessing the electronic document from a plurality of end user computers, to count the end user as a single co-author.
In any of the foregoing aspects, the application can be further configured to interactively update the graphical element in the graphical user interface for the electronic document currently accessed by the application while the electronic document is accessed by the application.
Any of the foregoing aspects may be embodied as a computer system, as any individual component of such a computer system, as a process performed by such a computer system or any individual component of such a computer system, or as an article of manufacture including computer storage in which computer program instructions are stored and which, when processed by one or more computers, configure the one or more computers to provide such a computer system or any individual component of such a computer system.
Referring to
Examples of general purpose computers include, but are not limited to, personal computers, game consoles, set top boxes, hand-held or laptop devices (for example, media players, notebook computers, tablet computers, cellular phones, personal data assistants, voice recorders), server computers, multiprocessor systems, microprocessor-based systems, programmable consumer electronics, networked personal computers, minicomputers, mainframe computers, and distributed computing environments that include any of the above types of computers or devices, and the like.
The memory 604 may include volatile devices (such as dynamic random access memory (DRAM) or other random access memory device), and non-volatile devices (such as a read-only memory, flash memory, and the like) or some combination of the two. The computer 600 can include additional storage (removable and/or non-removable) including, but not limited to, magnetically-recorded or optically-recorded disks or tape. Such additional storage is illustrated in
A computer storage medium is any medium in which data can be stored in and retrieved from addressable physical storage locations by the computer. Computer storage media includes volatile and nonvolatile memory devices, and removable and non-removable storage media. Memory 604 and 606, removable storage 608 and non-removable storage 610 are all examples of computer storage media. Some examples of computer storage media are RAM, ROM, EEPROM, flash memory, processor registers, or other memory technology, CD-ROM, digital versatile disks (DVD) or other optically or magneto-optically recorded storage device, magnetic cassettes, magnetic tape, magnetic disk storage or other magnetic storage devices. Computer storage media and communication media are mutually exclusive categories of media.
The computer 600 may also include communications connection(s) 612 that allow the computer to communicate with other devices over a communication medium. Communication media transmit data, such as computer program instructions, data structures, program modules or other data, over a wired or wireless substance by propagating a modulated data signal such as a carrier wave or other transport mechanism over the substance. The term “modulated data signal” means a signal that has one or more of its characteristics set or changed in such a manner as to encode information in the signal, thereby changing the configuration or state of the receiving device of the signal. By way of example, and not limitation, communication media includes wired media such as a wired network or direct-wired connection, and wireless media include any non-wired communication media that allows propagation of signals, such as acoustic, electromagnetic, electrical, optical, infrared, radio frequency and other signals. Communications connections 612 are devices, such as a wired network interface, wireless network interface, radio frequency transceiver, e.g., Wi-Fi, cellular, long term evolution (LTE) or Bluetooth, etc., transceivers, navigation transceivers, e.g., global positioning system (GPS) or Global Navigation Satellite System (GLONASS), etc., transceivers, that interface with the communication media to transmit data over and receive data from communication media.
In a computer, example communications connections include, but are not limited to, a wireless communication interface for wireless connection to a computer network, and one or more radio transmitters for telephonic communications over cellular telephone networks, and/or. For example, a WiFi connection 672, a Bluetooth connection 674, a cellular connection 670, and other connections 676 may be present in the computer. Such connections support communication with other devices. One or more processes may be running on the computer and managed by the operating system to enable voice or data communications over such connections.
The computer 600 may have various input device(s) 614 such as a touch-based input device, pen, camera, microphone, sensors, such as accelerometers, gyroscopes, thermometers, light sensors, and the like, and so on. Output device(s) 616 such as a display, speakers, and so on may also be included. All of these devices are well known in the art and need not be discussed at length here. Various input and output devices can implement a natural user interface (NUI), which is any interface technology that enables a user to interact with a device in a “natural” manner, free from artificial constraints imposed by input devices such as mice, keyboards, remote controls, and the like.
Examples of NUI methods include those relying on speech recognition, touch and stylus recognition, gesture recognition both on screen and adjacent to the screen, air gestures, head and eye tracking, voice and speech, vision, touch, gestures, and machine intelligence, and may include the use of touch sensitive displays, voice and speech recognition, intention and goal understanding, motion gesture detection using depth cameras (such as stereoscopic camera systems, infrared camera systems, and other camera systems and combinations of these), motion gesture detection using accelerometers or gyroscopes, facial recognition, three dimensional displays, head, eye, and gaze tracking, immersive augmented reality and virtual reality systems, all of which provide a more natural interface, as well as technologies for sensing brain activity using electric field sensing electrodes (EEG and related methods).
The various storage 610, communication connections 612, output devices 616 and input devices 614 can be integrated within a housing with the rest of the computer hardware, or can be connected through various input/output interface devices on the computer, in which case the reference numbers 610, 612, 614 and 616 can indicate either the interface for connection to a device or the device itself as the case may be.
Each component (which also may be called a “module” or “engine” or the like), of a computer system such as described herein, and which operates on the computer, can be implemented using the one or more processing units or logic devices of the computer and one or more computer programs processed by the computer. Generally speaking, such modules have inputs and outputs through locations in memory or processor registers from which data can be read and to which data can be written when the module is executed by the computer. A computer program includes computer-executable instructions and/or computer-interpreted instructions, such as program modules, which instructions are processed by the computer. Generally, such instructions define routines, programs, objects, components, data structures, and so on, that, when processed by the computer, instruct the computer to perform operations on data or configure the computer to implement various components or data structures.
Alternatively, or in addition, the functionality of one or more of the various components described herein can be performed, at least in part, by one or more hardware logic components. For example, and without limitation, illustrative types of hardware logic components that can be used include Field-programmable Gate Arrays (FPGAs), Program-specific Integrated Circuits (ASICs), Program-specific Standard Products (ASSPs), System-on-a-chip systems (SOCs), Complex Programmable Logic Devices (CPLDs), etc.
It should be understood that the subject matter defined in the appended claims is not necessarily limited to the specific implementations described above. The specific implementations described above are disclosed as examples only.