EMBEDDED FOLDER VIEWS
Disclosed are systems, methods, and non-transitory computer-readable storage media for providing an embedded web view of a folder in a content management system on a web page. For example, a user can request from a content management system code for embedding a web view of a content item or group of content items (e.g., folder) into a web page. After the code is embedded into the webpage, the web page can present a web view of the content item or group of content items that is dynamically updated when the content item or group of content items is updated. Thus, the user is relieved of the burden of updating the web page with new links to reflect changes in content items stored in the online content management system.
Latest Dropbox, Inc. Patents:
This application is a continuation of U.S. patent application Ser. No. 14/980,939, filed Dec. 28, 2015, which is incorporated by reference in its entirety.
BACKGROUNDThe Internet is the modern medium for sharing information. Bloggers express opinions in blogs. Teachers share class materials on class web pages. To share information, these Internet users typically create a web page and generate content to present on the web page. The content can be text, images, links to files, or links to other websites, for example. When the user wishes to update the content on their webpage, the user often must spend time personally updating the web page content.
SUMMARYAdditional features and advantages of the disclosure will be set forth in the description which follows, and in part will be obvious from the description, or can be learned by practice of the herein disclosed principles. The features and advantages of the disclosure can be realized and obtained by means of the instruments and combinations particularly pointed out in the appended claims. These and other features of the disclosure will become more fully apparent from the following description and appended claims, or can be learned by the practice of the principles set forth herein.
Disclosed are systems, methods, and non-transitory computer-readable storage media for providing an embedded web view of a folder in a content management system on a web page. For example, a user can have an account with an online content management system. The user's account can include content items (e.g., documents, images, files, folders, etc.). The user may wish to publish the content items stored in the content management system so that other Internet users can access the content items through the web page. Rather than creating individual links to content items on the user's web page, the user can request from the content management system code for embedding a web view of a content item into a web page. After the code is embedded into the webpage, the web page can present a web view of the content item or group of content items that is dynamically updated when the content item or group of content items is updated. Thus, the user is relieved of the burden of updating the web page with new links to reflect changes in content items stored in the online content management system.
The above-recited and other advantages and features of the disclosure will become apparent by reference to specific embodiments thereof which are illustrated in the appended drawings. Understanding that these drawings depict only example embodiments of the disclosure and are not therefore to be considered to be limiting of its scope, the principles herein are described and explained with additional specificity and detail through the use of the accompanying drawings in which:
Various embodiments of the disclosure are discussed in detail below. While specific implementations are discussed, it should be understood that this is done for illustration purposes only. A person skilled in the relevant art will recognize that other components and configurations may be used without parting from the spirit and scope of the disclosure.
The disclosed technology addresses the need in the art for automatically and dynamically updating content on web pages.
With respect to implementing various embodiments of the disclosed technology, an example system configuration 100 is shown in
In system 100, a user can interact with content management system 106 (e.g., an online synchronized content management system) through client devices 1021, 1022, . . . , 102n (collectively “102”) connected to network 104 by direct and/or indirect communication. Content management system 106 can support connections from a variety of different client devices, such as: desktop computers; mobile computers; mobile communications devices, e.g. mobile phones, smart phones, tablets; smart televisions; set-top boxes; and/or any other network enabled computing devices. Client devices 102 can be of varying type, capabilities, operating systems, etc. Furthermore, content management system 106 can concurrently accept connections from and interact with multiple client devices 102.
A user can interact with content management system 106 using a client-side application installed on client device 102i. In some embodiments, the client-side application can include a content management system specific component. For example, the component can be a stand-alone application, one or more application plug-ins, and/or a browser extension. However, the user can also interact with content management system 106 using a third-party application, such as a web browser, that resides on client device 102i and is configured to communicate with content management system 106. In either case, the client-side application can present a user interface (UI) for the user to interact with content management system 106. For example, the user can interact with the content management system 106 using a client-side application integrated with the file system or through a webpage displayed using a web browser application.
Content management system 106 can enable a user to store content, as well as perform a variety of content management tasks, such as retrieve, modify, browse, and/or share the content. Furthermore, content management system 106 can enable a user to access the content from multiple client devices 102. For example, client device 102i can upload content to content management system 106 through network 104. Later, the same client device 102i or some other client device 102j can retrieve the content from content management system 106.
To facilitate the various content management services, a user can create an account with content management system 106. User account database 150 can maintain the account information. User account database 150 can store profile information for registered users. In some cases, the only personal information in the user profile can be a username and/or email address. However, content management system 106 can also be configured to accept additional user information such as birthday, address, billing information, etc.
User account database 150 can include account management information, such as account type (e.g. free or paid), usage information, (e.g. file edit history), maximum storage space authorized, storage space used, content storage locations, security settings, personal configuration settings, content sharing data, etc. Account management module 124 can be configured to update and/or obtain user account details in user account database 150. The account management module 124 can be configured to interact with any number of other modules in content management system 106.
An account can be used to store content items, such as digital data, documents, text files, audio files, video files, etc., from one or more client devices 102 authorized on the account. The content items can also include collections for grouping content items together with different behaviors, such as folders, playlists, albums, etc. For example, an account can include a public folder that is accessible to any user. The public folder can be assigned a web-accessible address. A link to the web-accessible address can be used to access the contents of the public folder. In another example, an account can include: a photos collection that is intended for photos and that provides specific attributes and actions tailored for photos; an audio collection that provides the ability to play back audio files and perform other audio related actions; or other special purpose collection. An account can also include shared collections or group collections that are linked with and available to multiple user accounts. The permissions for multiple users may be different for a shared collection.
The content items can be stored in content storage 160. Content storage 160 can be a storage device, multiple storage devices, or a server. Alternatively, content storage 160 can be a cloud storage provider or network storage accessible through one or more communications networks. Content management system 106 can hide the complexity and details from client devices 102 so that client devices 102 do not need to know exactly where or how the content items are being stored by content management system 106. In some embodiments, content management system 106 can store the content items in the same collection hierarchy as they appear on client device 102i. However, content management system 106 can store the content items in its own order, arrangement, or hierarchy. Content management system 106 can store the content items in a network accessible storage (NAS) device, in a redundant array of independent disks (RAID), etc. Content storage 160 can store content items using one or more partition types, such as FAT, FAT32, NTFS, EXT2, EXT3, EXT4, HFS/HFS+, BTRFS, and so forth.
Content storage 160 can also store metadata describing content items, content item types, and the relationship of content items to various accounts, collections, or groups. The metadata for a content item can be stored as part of the content item or can be stored separately. In one variation, each content item stored in content storage 160 can be assigned a system-wide unique identifier.
Content storage 160 can decrease the amount of storage space required by identifying duplicate content items or duplicate segments of content items. Instead of storing multiple copies, content storage 160 can store a single copy and then use a pointer or other mechanism to link the duplicates to the single copy. Similarly, content storage 160 can store content items more efficiently, as well as provide the ability to undo operations, by using a content item version control that tracks changes to content items, different versions of content items (including diverging version trees), and a change history. The change history can include a set of changes that, when applied to the original content item version, produce the changed content item version.
Content management system 106 can be configured to support automatic synchronization of content from one or more client devices 102. The synchronization can be platform agnostic. That is, the content can be synchronized across multiple client devices 102 of varying type, capabilities, operating systems, etc. For example, client device 102i can include client software, which synchronizes, using a synchronization module 132 at content management system 106, content in client device 102i's file system with the content in an associated user account. In some cases, the client software can synchronize any changes to content in a designated collection and its sub-collections, such as new, deleted, modified, copied, or moved content items or collections. The client software can be a separate software application, can integrate with an existing content management application in the operating system, or some combination thereof. In one example of client software that integrates with an existing content management application, a user can manipulate content items directly in a local collection, while a background process monitors the local collection for changes and synchronizes those changes to content management system 106. Conversely, the background process can identify content that has been updated at content management system 106 and synchronize those changes to the local collection. The client software can provide notifications of synchronization operations, and can provide indications of content statuses directly within the content management application. Sometimes client device 102i may not have a network connection available. In this scenario, the client software can monitor the linked collection for content item changes and queue those changes for later synchronization to content management system 106 when a network connection is available. Similarly, a user can manually start, stop, pause, or resume synchronization with content management system 106.
A user can view or manipulate content through a web interface generated and served by user interface module 122. For example, the user can navigate in a web browser to a web address provided by content management system 106. Changes or updates to content in the content storage 160 made through the web interface, such as uploading a new version of a content item, can be propagated back to other client devices 102 associated with the user's account. For example, multiple client devices 102, each with their own client software, can be associated with a single account and content items in the account can be synchronized between each of the multiple client devices 102.
In some embodiments, user interface module 122 can generate code that can be embedded in other web pages (e.g., third party webpages) to provide a web view or embedded web interface to content items (e.g., folders, documents, images, files, etc.) managed by content management system 106. Changes or updates to content in the content storage 160, such as uploading a new version of a content item, can be reflected in the web view embedded in the third party web pages. For example, the web view of the folder embedded in the third party web pages can be automatically and dynamically updated to reflect changes made to the content items associated with the web view in content management system 106 without requiring a user to make any modifications to the third party web page.
Content management system 106 can include a communications interface 120 for interfacing with various client devices 102, and can interact with other content and/or service providers 1091, 1092, . . . , 109n (collectively “109”) through an Application Program Interface (API). Certain software applications can access content storage 160 through an API on behalf of a user. For example, a software package, such as an app running on a smartphone or tablet computing device, can programmatically make calls directly to content management system 106, when a user provides credentials, to read, write, create, delete, share, or otherwise manipulate content. Similarly, the API can allow users to access all or part of content storage 160 through a web site.
Content management system 106 can also include authenticator module 126, which can verify user credentials, security tokens, API calls, specific client devices, and so forth, to ensure only authorized clients and users can access content items. Further, content management system 106 can include analytics module 134 module that can track and report on aggregate file operations, user actions, network usage, total storage space used, as well as other technology, usage, or business metrics. A privacy and/or security policy can prevent unauthorized access to user data stored with content management system 106.
Content management system 106 can include sharing module 130 for managing sharing content publicly or privately. Sharing content publicly can include making the content item accessible from any computing device in network communication with content management system 106. Sharing content privately can include linking a content item in content storage 160 with two or more user accounts so that each user account has access to the content item. The sharing can be performed in a platform agnostic manner. That is, the content can be shared across multiple client devices 102 of varying type, capabilities, operating systems, etc. The content can also be shared across varying types of user accounts.
In some embodiments, content management system 106 can be configured to maintain a content directory identifying the location of each content item in content storage 160. The content directory can include a unique content entry for each content item stored in the content storage.
A content entry can include a content path that can be used to identify the location of the content item in a content management system. For example, the content path can include the name of the content item and a folder hierarchy associated with the content item. For example, the content path can include a folder or path of folders in which the content item is placed as well as the name of the content item. Content management system 106 can use the content path to present the content items in the appropriate folder hierarchy.
A content entry can also include a content pointer that identifies the location of the content item in content storage 160. For example, the content pointer can include the exact storage address of the content item in memory. In some embodiments, the content pointer can point to multiple locations, each of which contains a portion of the content item.
In addition to a content path and content pointer, a content entry can also include a user account identifier that identifies the user account that has access to the content item. In some embodiments, multiple user account identifiers can be associated with a single content entry indicating that the content item has shared access by the multiple user accounts.
To share a content item privately, sharing module 130 can be configured to add a user account identifier to the content entry associated with the content item, thus granting the added user account access to the content item. Sharing module 130 can also be configured to remove user account identifiers from a content entry to restrict a user account's access to the content item.
To share content publicly, sharing module 130 can be configured to generate a custom network address, such as a uniform resource locator (URL), which allows any web browser to access the content in content management system 106 without any authentication. To accomplish this, sharing module 130 can be configured to include content identification data in the generated URL, which can later be used to properly identify and return the requested content item. For example, sharing module 130 can be configured to include the user account identifier and the content path in the generated URL. Upon selection of the URL, the content identification data included in the URL can be transmitted to content management system 106 which can use the received content identification data to identify the appropriate content entry and return the content item associated with the content entry.
In addition to generating the URL, sharing module 130 can also be configured to record that a URL to the content item has been created. In some embodiments, the content entry associated with a content item can include a URL flag indicating whether a URL to the content item has been created. For example, the URL flag can be a Boolean value initially set to 0 or false to indicate that a URL to the content item has not been created. Sharing module 130 can be configured to change the value of the flag to 1 or true after generating a URL to the content item.
In some embodiments, sharing module 130 can also be configured to deactivate a generated URL. For example, each content entry can also include a URL active flag indicating whether the content should be returned in response to a request from the generated URL. For example, sharing module 130 can be configured to only return a content item requested by a generated link if the URL active flag is set to 1 or true. Thus, access to a content item for which a URL has been generated can be easily restricted by changing the value of the URL active flag. This allows a user to restrict access to the shared content item without having to move the content item or delete the generated URL. Likewise, sharing module 130 can reactivate the URL by again changing the value of the URL active flag to 1 or true. A user can thus easily restore access to the content item without the need to generate a new URL.
While content management system 106 is presented with specific components, it should be understood by one skilled in the art, that the architectural configuration of system 106 is simply one possible configuration and that other configurations with more or fewer components are possible.
In some embodiments, system 200 can include third party server 220. For example, server 220 can be a computing device configured with web server 222. Web server 222 can be configured to serve web pages (e.g., web page 224) to web browsers on various end user devices. For example, web page 224 can be created by a third party content creator to present information to other Internet users. For example, web page 224 can be configured by a blogger-user to present blog posts, including text and images. Web page 224 can be configured by a teacher to present information about a class being taught by the teacher, including links to materials or documents for the class.
In some embodiments, a content creator can embed a web view of content item 212 into web page 224. For example, the content creator (e.g., teacher, blogger, etc.) can have a user account with content management system 106. The content creator can use content management system 106 to manage content item 212. For example, a teacher can add class materials (e.g., documents, files, recordings, etc.) to the teacher's user account with content management system 106. A blogger can add blog materials (e.g., images, documents, files, etc.) to the blogger's user account with content management system 106. Content management system 106 can store the class materials and/or blog materials as content items in folders associated with the blogger's and/or teacher's user accounts within content management system 106.
After the content creator adds the content items to a folder within the content creator's user account within content management system 106, the content creator can request from content management system 106 code (e.g., CMS code 214) for publishing or embedding a web view of the content items (e.g., a folder, a document, an image, etc.) into webpage 224. For example, CMS code 214 can be (e.g., HTML, javascript, etc.) code that can be embedded into webpage 224 to generate a web view of content items in content management system 106.
In some embodiments, system 200 can include user device 230. For example, user device 230 can be a computing device, such as a smartphone, tablet computer, wearable device (e.g., smartwatch, smart glasses, etc.), laptop computer, desktop computer, etc. User device 230 can include web browser 232. For example, a user of user device 230 can invoke web browser 232 and navigate to web server 222 through network 104 using web browser 232 to retrieve web page 224. When web browser 323 receives web page 224, web browser 232 can render web page 224 and display web page 224 on a display of user device 230. When web page 224 includes embedded CMS code 214, web browser 232 can execute the embedded CMS code 214 to retrieve from content management system 106 (e.g., from user interface module 122) information necessary for rendering an embedded web view of content items managed by content management server 106 on web page 224. Thus, although web page 224 is served by web server 222 on third party server 220, web page 224 presents a web view of content items managed by content management system 106 on CMS server 210.
However, should the teacher wish to update the class web page with additional materials or remove existing materials, the teacher will have to edit the class web page (e.g., modify the web page code) to add additional links or remove existing links. Moreover, if the teacher wishes to provide additional information about the linked materials (e.g., descriptions, file sizes, file types, etc.), the teacher will have to edit the class web page to provide this information whenever materials are added to or deleted from the web page.
In some embodiments, GUI 400 can present a folder 402 managed by content management system 106. Continuing the example above, folder 402 can be a folder that the teacher uses to store lecture notes for the class the teacher is teaching. Upon receiving a user selection of folder 402, GUI 400 can present menu 404 that displays options for folder 402. For example, menu 404 can present a “publish” option that when selected by a user (e.g., the teacher) presents GUI 500 of
In some embodiments, graphical element 602 can include graphical element 604. For example, graphical element 604 can present text representing web page code (“embed code”) that when embedded in a web page causes the web page to present a web view of the contents of folder 402. Graphical element 602 can include graphical element 614 for presenting a preview of how the contents of folder 402 will be presented when the code presented in graphical element 604 is embedded into a web page.
In some embodiments, graphical element 602 can include user selectable options for presenting the web view of graphical element 604. For example, each content item in folder 402 can have associated metadata. The metadata can include an identifier (e.g., name) for the content item, a description of the content item, an indication of the size of the content item, a timestamp indicating when the content item was last modified, and/or other descriptive information about the corresponding content item. Graphical element 602 can include selectable options that allow the user (e.g., the teacher, blogger, etc.) to select which metadata items are presented in the embedded web view of the folder generated by the web page code displayed in graphical element 604. If no options are selected, then the web view of folder 402 may present the identifier for each content item.
In some embodiments, a user can select one or more of options 608, 610, and/or 612 to have additional information for each content item presented in the web view for folder 402. For example, the teacher discussed above can select graphical element 608 to generate embed code that generates a web view of folder 402 that includes a description of each content item. The teacher can select graphical element 610 to generate embed code that presents a web view of folder 402 that includes the size of each content item in folder 402. The teacher can select graphical element 612 to generate embed code that presents a web view of folder 402 that includes the last modified time of each content item. In some embodiments, the teacher can select graphical element 606 to adjust how content items are organized in the folder web view. For example, the teacher can select graphical element 606 to generate embed code that generates a web view of folder 402 that organizes content items in a gallery view instead of the default details view (e.g., list view), as described further below.
In some embodiments, the web browser can dynamically update the embed code presented in graphical element 604 based on the embed code options (e.g., options 606, 608, 610, 612) selected by the user. For example, upon invocation of graphical element 602 (e.g., selection of graphical element 504), the web browser can send a request to content management system 106 to receive the embed code for embedding a web view of folder 402 into a web page. Upon receipt of the embed code, the web browser can present the embed code on graphical element 604. When a user selects one or more of the options 606, 608, 610, and/or 612, the web browser can send a request for updated embed code to content management system 106 that identifies the selected options. In response to receiving the request, content management system 106 can generate embed code according to the selected options so that the embed code will cause the embedded web view of folder 402 to display the user selected information. Content management system 106 can return the embed code generated based on the selected options to the web browser and the web browser can display the embed code on graphical element 604. Thus, the web browser can dynamically update the embed code displayed on graphical element 604 in response to a user selecting one or more of options 606, 608, 610, and/or 612.
In some embodiments, the web browser can dynamically update the preview presented in graphical element 614 based on the user-selected options. As described above, the web browser can request updated embed code from content management system 106 in response to receiving a user selection of one or more options 606, 608, 610 and/or 612. When the updated embed code is received, the web browser can generate an updated preview of how the web view of folder 402 will appear when embedded in a web page based on the updated embed code. Thus, the web browser can dynamically update the preview displayed on graphical element 614 in response to a user selecting one or more of options 606, 608, 610, and/or 612.
In some implementations, graphical element 602 can include graphical element 615 for specifying permissions for the web view of folder 402. For example, the web view of folder 402 can be considered a published version of folder 402. The teacher may wish to specify access permissions for the published version of folder 402. For example, the teacher may wish to grant the teacher's assistant read-write permissions to the published version of folder 402 while allowing students only read-write access to the contents of the published version of folder 402. To specify the permissions, the teacher can select graphical element 615 to cause GUI 600 to present a graphical element (not shown) for specifying the permissions for the published version of folder 402. The teacher can provide input to GUI 600 specifying that other general users should be granted read-only access to the published version of folder 402. The teacher can provide input to GUI 600 specifying that specific users (e.g., the teacher's assistant) should be granted read-write access to the published version of folder 402. The teacher can provide input to GUI 600 specifying that all users should be granted read-write access to the published version of folder 402. However, if the teacher does not specify permissions, the permissions for the published version of folder 402 can be set to read-write by default. Thus, when the published version of folder 402 (e.g., through the web view or through a local synchronized copy of the published folder) is accessed by another user, the user may be granted access according to the permissions specified for the published folder by the teacher (e.g., owner of folder 402).
In some embodiments, graphical element 602 can include graphical element 616 for obtaining a copy of the embed code presented on graphical element 604. For example, after the teacher selects the web view folder display options and is satisfied with the look of the web view as illustrated by the preview presented in graphical element 614, the teacher can select graphical element 616 to obtain a copy of the embed code presented on graphical element 604. For example, upon receipt of a user selection of graphical element 616, the web browser can copy the embed code to memory (e.g., a clipboard) of the teacher's computing device. The teacher can then paste the embed code into the web page code for the teacher's web page. For example, the teacher discussed above can paste the embed code into the web page (e.g., GUI 300) for the class that the teacher is teaching to cause the web page to present a web view of folder 402, as illustrated by
In some embodiments, GUI 700 can include folder web view 702. For example, folder web view 702 can present a manipulable representation of each content item in folder 402. Thus, continuing the teacher example above, students of the teacher who have access to the teacher's web page (e.g. web page 300, web page 700) can view and navigate through items in folder 402. However, since the folder web view 702 is read-only to the students, the student may not be able to modify the content items and/or content item metadata represented in folder web view 702.
In some embodiments, web browser 232 can dynamically adjust the appearance of folder web view 702 based on the hosting web page. For example, the third party web page may have a color scheme (e.g., background color, text color, etc.) that may not match the default color scheme (e.g., white background, black text, etc.) of folder web view 702. Folder web view 702 may stand out on the third party web page and look out of place if the colors clash or are too different. Therefore, in some embodiments, the embed code described above (or the HTML, javascript, etc., retrieved as a result of execution of the embed code) can include instructions for determining the color scheme used by the third party web page and adjusting the color scheme of folder web view 702 to match the color scheme of the third party web page. Thus, when web browser 232 renders the third party web page containing the embed code, the folder web view 702 will blend in with the content of the third party web page.
In the example of
In some embodiments, folder web view 702 can be dynamically updated to reflect changes to folder 402 managed by content management system 106. For example, if a content item is added or removed from folder 402, folder web view 702 can be dynamically and automatically updated to present an added content item or hide a removed content item. If a content item in folder 402 is modified, folder web view 702 can be automatically and dynamically updated to show when the corresponding content item was last modified. If the metadata for a content item folder 402 is modified, folder web view 702 can be automatically and dynamically updated to present the modified metadata. For example, if a user adds a description to a content item in folder 402 through content management system 106, then the description of the content item can be presented in folder web view 702.
In some embodiments, folder web view 702 can allow the user to invoke other features of content management system 106. For example, if the user is a registered user of (e.g., has an account with) content management system 106, folder web view 702 can present graphical element 712 that presents options for adding folder 402 represented by folder web view 702 to the user's account on content management system 106. For example, while the user is logged into the user's account on content management system 106, the user can select graphical element 710 (e.g., button, icon, ellipses, etc.) to cause folder web view 702 to present graphical element 712.
Graphical element 712 can be, for example, an options menu that provides an option (e.g., “Join published folder”) to add a published version of folder 402 to the user's account. In response to receiving a user selection of the “Join published folder” option, web browser 232 can send a request to content management system 106 to add folder 402 (e.g., a copy of folder 402, a reference to folder 402, etc.) to the users account as a read-only folder (e.g., a published folder). In this case, the published folder in the user's account can be dynamically updated (e.g., synchronized) whenever content items are added, removed, modified, or otherwise manipulated by users (e.g., the teacher) having read-write access to folder 402. Thus, whenever the owner (e.g., creator, the teacher, the blogger, etc.) adds a new content item to folder 402, the new content items can be synchronized (e.g., added to) the corresponding published folder in the user's content management system account.
In some embodiments, graphical element 712 can include an option to download a compressed copy of folder 402. For example, in response to receiving a selection of the “Download as zip” option, content management system 106 can compress the contents of folder 402 into a single content item (e.g., zip file, compressed file, etc.). Content management system 106 can send the compressed content item to the user's device where the user can decompress the content item and view or manipulate the local copies of content items from folder 402. The compressed content item can be stored, manipulated, etc., externally to content management system 106 and does not require that the receiving user has an account with content management system 106.
In some embodiments, graphical element 712 can include an option to save folder 402 to the requesting user's account. For example, when the user selects the “Save to my account” option, content management system 106 will save a copy of folder 402 to the requesting user's account. In this case, the copy of folder 402 saved to the user's account is a distinct read-write copy of folder 402 that does not get synchronized with folder 402. Thus, any updates made to folder 402 will not get propagated to the copy of folder 402 created when the user selects the “Save to my account” option.
In some embodiments, a user can select subfolder 902 in folder web view 702 to view the contents of subfolder 902. For example, upon receiving a selection of subfolder 902, web browser 232 can send a request to content management system 106 to obtain a web view (e.g., web page code) representing the contents of subfolder 902. Thus, the user can navigate the contents of a first website (e.g., content management system 106) through a webpage provided by a second website (e.g., third party web server 222).
At step 1302, the computing device can present a folder associated with a user account of a content management system. For example, a user can invoke the web browser and navigate to a web page for viewing folders within the user's account on content management system 106.
At step 1304, the computing device can receive an indication that the user wishes to publish a folder on a web page. For example, the web browser can receive user input selecting a folder within the user's account on content management system 106. The user input can indicate that the user would like to obtain embed code for embedding the selected folder into a web page. In response to the user input, the web browser can send a request to content management system 106 to obtain the embed code. When content management system 106 receives the request, content management system 106 can generate the embed code and send the embed code to the web browser.
In some embodiments, the user can specify permissions for the published folder. For example, when the user provides input to publish shared folder 402, the user can specify permissions for the published folder. The user can specify that the published folder is a read-only folder such that other users can only view the contents items in the published folder. The user can specify that the published folder is a read-write folder such that other users can read and modify the content items in the published folder. The user can specify different permissions for different users accessing the published folder. For example, the user can specify that a teacher's assistant has read-write access to the published folder while a student has read-only access to the shared folder.
At step 1306, the computing device can present embed code, embed code options and/or a preview of the folder web view generated by the web code. For example, the web browser can present GUI 600 that includes the received embed code, options for displaying content in the selected folder, and a preview of the received embed code, as described above.
At step 1308, the computing device can receive a selection of options for displaying content in the selected folder. For example, the user can select a gallery view option, a show description option, a show file size option, and/or a show modified time option, as described with reference to
At step 1310, the computing device can dynamically update the embed code and/or preview based on the selected options. For example, in response to receiving input selecting an option, the web browser can send a request to content management system 106 requesting embed code corresponding to the selected options. Content management system 106 can generate the embed code for the selected options and send the updated embed code to the web browser. The web browser can then present the updated embed code on a display of the computing device, as illustrated by
At step 1312, the computing device can receive input to copy the embed code. For example, the web browser can receive user input to copy the embed code to a clip board or a memory location within the computing device.
At step 1312, the computing device can receive input to insert the embed code into a web page. For example, the computing device can receive input to paste the embed code stored in memory into a web page being edited by the user.
At step 1314, the computing device can insert the embed code into the web page. For example, in response to receiving the input to paste the embed code into the web page, the computing device can insert the embed code into a web page being edited by the user.
At step 1402, the computing device can receive a web page having embedded folder code. For example, the user can, through web browser 232, request web page 224 created by a third party (e.g., a teacher, blogger, etc.) from a third party web server 222 that includes embedded code for providing a web view of a folder managed by content management system 106.
At step 1404, the computing device can obtain a folder web view for viewing content items within a folder of content management system 106 using the embedded code. For example, web browser 232 can execute the embedded code (e.g., HTML, JavaScript, a URL, etc.) to request a web view of folder 402 from content management system 106. The folder web view can be, for example, a web page or portion of a web page generated or served by content management system 106 that can be embedded in the third party web page 224.
At step 1406, the computing device can present the third party web page having the embedded folder web view. For example, web browser 232 can render the third party web page including the embedded folder web view of folder 402 and present the web page and folder web view on a display of the computing device.
At step 1408, the computing device can receive an updated folder web view representing changes to the folder. For example, the owner of the folder 402 on content management system 106 may modify the contents of folder 402 by adding, removing, or editing a content item and/or metadata corresponding to a content item in folder 402. Content management system 106 can detect the change to folder 402. In response to detecting the change to folder 402, content management system 106 can send an updated web view (e.g., HTML, javascript, etc.) of folder 402 to web browser 232.
At step 1410, the computing device can present the web page having the updated folder web view. For example, upon receipt of the updated web view of folder 402, web browser 232 can present the updated web view of folder 402 representing the changes made to folder 402 on a display of the computing device.
At step 1502, the computing device can receive a web page having embedded folder code. For example, the user can, through web browser 232, request web page 224 created by a third party (e.g., a teacher, blogger, etc.) from a third party web server 222 that includes embedded code for providing a web view of a folder managed by content management system 106.
At step 1504, the computing device can obtain a folder web view for viewing content items within a shared folder of content management system 106 using the embedded code. For example, web browser 232 can execute the embedded code (e.g., HTML, JavaScript, a URL, etc.) to request a web view of folder 402 from content management system 106. The folder web view can be, for example, a web page or portion of a web page generated and/or served by content management system 106 that can be embedded in the third party web page 224.
At step 1506, the computing device can present the third party web page having the embedded folder web view. For example, web browser 232 can render the third party web page including the embedded folder web view of folder 402 and present the web page and folder web view on a display of the computing device.
In some embodiments, the embedded folder web view can include options for registered users (e.g., account holders) of content management system 106. For example, if the user of the computing device is logged into content management system 106, the embedded folder web view of folder 402 of content management system 106 can present an option that allow account holders of content management system 106 to add a published version of folder 402 represented by folder web view 702 to the user's account on content management system 106.
At step 1508, the computing device can receive a selection of an option for joining the published folder represented by the embedded folder web view. For example, web browser 232 can receive user input to add a published version of folder 402 to the users account on content management system 106, as described above with reference to
At step 1510, the computing device can send a request to content management system 106 to add a published version of folder 402 to the user's account on content management system 106 to shared folder 402. For example, web browser 232 can send a request to content management system 106 to publish folder 402 to the requesting user's account on content management system 106. Upon receiving the request, content management system 106 can make a read-only version of folder 402 available to the user's account on content management system 106, as described above with reference to
At step 1508, the computing device can receive a copy of the published folder in local storage of the computing device. For example, making shared folder 402 available to the requesting user's account on content management system 106 can include copying the published version of folder 402 to the user's account or adding a reference to folder 402 in the user's account. Upon making the published folder available to the requesting user's account on content management system 106, content management system 106 can synchronize the published folder in the user's account with the user's computing device. For example, synchronization of the published folder with the computing device can cause a read-only synchronized version of folder 402 to be stored in memory (e.g., hard drive, persistent storage, etc.) on the computing device. Thus, the user can access the published folder, and content items therein, even when the computing device is not connected to a network (e.g., network 104).
To enable user interaction with the computing device 1600, an input device 1645 can represent any number of input mechanisms, such as a microphone for speech, a touch-sensitive screen for gesture or graphical input, keyboard, mouse, motion input, speech and so forth. An output device 1635 can also be one or more of a number of output mechanisms known to those of skill in the art. In some instances, multimodal systems can enable a user to provide multiple types of input to communicate with the computing device 1600. The communications interface 1640 can generally govern and manage the user input and system output. There is no restriction on operating on any particular hardware arrangement and therefore the basic features here may easily be substituted for improved hardware or firmware arrangements as they are developed.
Storage device 1630 is a non-volatile memory and can be a hard disk or other types of computer readable media which can store data that are accessible by a computer, such as magnetic cassettes, flash memory cards, solid state memory devices, digital versatile disks, cartridges, random access memories (RAMs) 1625, read only memory (ROM) 1620, and hybrids thereof.
The storage device 1630 can include software modules 1632, 1634, 1636 for controlling the processor 1610. Other hardware or software modules are contemplated. The storage device 1630 can be connected to the system bus 1605. In one aspect, a hardware module that performs a particular function can include the software component stored in a computer-readable medium in connection with the necessary hardware components, such as the processor 1610, bus 1605, display 1635, and so forth, to carry out the function.
Chipset 1660 can also interface with one or more communication interfaces 1690 that can have different physical interfaces. Such communication interfaces can include interfaces for wired and wireless local area networks, for broadband wireless networks, as well as personal area networks. Some applications of the methods for generating, displaying, and using the GUI disclosed herein can include receiving ordered datasets over the physical interface or be generated by the machine itself by processor 1655 analyzing data stored in storage 1670 or 1675. Further, the machine can receive inputs from a user through user interface components 1685 and execute appropriate functions, such as browsing functions by interpreting these inputs using processor 1655.
It can be appreciated that example systems 1600 and 1650 can have more than one processor 1610 or be part of a group or cluster of computing devices networked together to provide greater processing capability.
For clarity of explanation, in some instances the present technology may be presented as including individual functional blocks including functional blocks comprising devices, device components, steps or routines in a method embodied in software, or combinations of hardware and software.
Any of the steps, operations, functions, or processes described herein may be performed or implemented by a combination of hardware and software modules, alone or in combination with other devices. In an embodiment, a software module can be software that resides in memory of a client device and/or one or more servers of a content management system and perform one or more functions when a processor executes the software associated with the module. The memory can be a non-transitory computer-readable medium.
In some embodiments the computer-readable storage devices, mediums, and memories can include a cable or wireless signal containing a bit stream and the like. However, when mentioned, non-transitory computer-readable storage media expressly exclude media such as energy, carrier signals, electromagnetic waves, and signals per se.
Methods according to the above-described examples can be implemented using computer-executable instructions that are stored or otherwise available from computer readable media. Such instructions can comprise, for example, instructions and data which cause or otherwise configure a general purpose computer, special purpose computer, or special purpose processing device to perform a certain function or group of functions. Portions of computer resources used can be accessible over a network. The computer executable instructions may be, for example, binaries, intermediate format instructions such as assembly language, firmware, or source code. Examples of computer-readable media that may be used to store instructions, information used, and/or information created during methods according to described examples include magnetic or optical disks, flash memory, USB devices provided with non-volatile memory, networked storage devices, and so on.
Devices implementing methods according to these disclosures can comprise hardware, firmware and/or software, and can take any of a variety of form factors. Typical examples of such form factors include laptops, smart phones, small form factor personal computers, personal digital assistants, and so on. Functionality described herein also can be embodied in peripherals or add-in cards. Such functionality can also be implemented on a circuit board among different chips or different processes executing in a single device, by way of further example.
The instructions, media for conveying such instructions, computing resources for executing them, and other structures for supporting such computing resources are means for providing the functions described in these disclosures.
Although a variety of examples and other information was used to explain aspects within the scope of the appended claims, no limitation of the claims should be implied based on particular features or arrangements in such examples, as one of ordinary skill would be able to use these examples to derive a wide variety of implementations. Further and although some subject matter may have been described in language specific to examples of structural features and/or method steps, it is to be understood that the subject matter defined in the appended claims is not necessarily limited to these described features or acts. For example, such functionality can be distributed differently or performed in components other than those identified herein. Rather, the described features and steps are disclosed as examples of components of systems and methods within the scope of the appended claims.
Claims
1. A method comprising:
- identifying, by a computing system, that a first user account is logged into a content management system;
- requesting, by the computing system via a web browser executing thereon, a web page from a third-party server distinct from the content management system;
- receiving, by the computing system, the web page from the third-party server, the web page comprising embed code for presenting an embedded view of a content item within the web page associated with the third-party server, the content item associated with a second user account associated with the content management system;
- rendering, by the computing system, the web page including the embedded view of the content item, the embedded view presenting a representation of the content item within the web page;
- receiving, by the computing system, a request from the first user account to add the content item to the first user account; and
- responsive to receiving the request, causing, by the computing system, the content management system to save a reference to the content item in the first user account.
2. The method of claim 1, wherein causing, by the computing system, the content management system to save a reference to the content item in the first user account comprises:
- causing the content management system to add a version of the content item, as published in the embedded view, to the first user account, wherein the version of the content item is a different version than a second version of the content item associated with the second user account.
3. The method of claim 1, wherein access controls are placed on the reference to the content item in the first user account.
4. The method of claim 3, wherein the access controls prevent the first user account from modifying the content item.
5. The method of claim 1, wherein the content item is a folder and causing, by the computing system, the content management system to save the reference to the content item in the first user account comprises:
- causing, by the computing system, the content management system to save a plurality of references to a plurality of files stored in the folder in the first user account.
6. The method of claim 5, wherein changes to the folder made by the second user account are reflected in the reference to the content item stored in the first user account.
7. The method of claim 1, wherein rendering, by the computing system, the web page including the embedded view of the content item comprises:
- rendering a graphical element in the embedded view for adding the content item to the first user account.
8. A non-transitory computer readable medium comprising one or more sequences of instructions, which, when executed by one or more processors, causes a computing system to perform operations comprising:
- identifying, by the computing system, that a first user account is logged into a content management system;
- requesting, by the computing system via a web browser executing thereon, a web page from a third-party server distinct from the content management system;
- receiving, by the computing system, the web page from the third-party server, the web page comprising embed code for presenting an embedded view of a content item within the web page associated with the third-party server, the content item associated with a second user account associated with the content management system;
- rendering, by the computing system, the web page including the embedded view of the content item, the embedded view presenting a representation of the content item within the web page;
- receiving, by the computing system, a request from the first user account to add the content item to the first user account; and
- responsive to receiving the request, causing, by the computing system, the content management system to save a version to the content item in the first user account.
9. The non-transitory computer readable medium of claim 8, wherein the version of the content item reflects the content item, as published in the embedded view, wherein the version of the content item is a different version than a second version of the content item associated with the second user account.
10. The non-transitory computer readable medium of claim 8, wherein access controls are placed on the version of the content item in the first user account.
11. The non-transitory computer readable medium of claim 10, wherein the access controls prevent the first user account from modifying the content item.
12. The non-transitory computer readable medium of claim 8, wherein the content item is a folder and causing, by the computing system, the content management system to save the version to the content item in the first user account comprises:
- causing, by the computing system, the content management system to save a plurality of versions of a plurality of files stored in the folder in the first user account.
13. The non-transitory computer readable medium of claim 12, wherein changes to the folder made by the second user account are reflected in the version of the content item stored in the first user account.
14. The non-transitory computer readable medium of claim 8, wherein rendering, by the computing system, the web page including the embedded view of the content item comprises:
- rendering a graphical element in the embedded view for adding the content item to the first user account.
15. A system comprising:
- one or more processors; and
- a memory having programming instructions stored thereon, which, when executed by the one or more processors, causes the system to perform operations comprising:
- identifying that a first user account is logged into a content management system;
- requesting, via a web browser executing thereon, a web page from a third-party server distinct from the content management system;
- receiving the web page from the third-party server, the web page comprising embed code for presenting an embedded view of a content item within the web page associated with the third-party server, the content item associated with a second user account associated with the content management system;
- rendering the web page including the embedded view of the content item, the embedded view presenting a representation of the content item within the web page;
- receiving a request from the first user account to add the content item to the first user account; and
- responsive to receiving the request, causing the content management system to save a reference to the content item in the first user account.
16. The system of claim 15, wherein causing the content management system to save a reference to the content item in the first user account comprises:
- causing the content management system to add a version of the content item, as published in the embedded view, to the first user account, wherein the version of the content item is a different version than a second version of the content item associated with the second user account.
17. The system of claim 15, wherein access controls are placed on the reference to the content item in the first user account.
18. The system of claim 15, wherein the content item is a folder and causing the content management system to save the reference to the content item in the first user account comprises:
- causing the content management system to save a plurality of references to a plurality of files stored in the folder in the first user account.
19. The system of claim 18, wherein changes to the folder made by the second user account are reflected in the reference to the content item stored in the first user account.
20. The system of claim 15, wherein rendering the web page including the embedded view of the content item comprises:
- rendering a graphical element in the embedded view for adding the content item to the first user account.
Type: Application
Filed: Mar 29, 2024
Publication Date: Jul 18, 2024
Applicant: Dropbox, Inc. (San Francisco, CA)
Inventors: Roger Tu (San Francisco, CA), Aisha Ferrazares (San Francisco, CA), Jennifer Lee (San Francisco, CA), Sang Tian (San Francisco, CA)
Application Number: 18/622,390