The present invention relates to the field of website generation, maintenance and, more specifically, to web content management systems.
The majority of websites currently online use a pattern where a limited number of unique designs and page layouts are applied to a multitude of web pages containing different content. The containing text and photos of a page are able to be unique, yet the page shares a theme and template with other pages of the website.
Separating the content from the design has many advantages, and many web content management systems (hereafter abbreviated, “CMS”) today make use of this separation with the use of templates that are built to work for each specific CMS.
The problems start to arise with the way that existing templating systems are implemented in a CMS. The following shortcomings currently exist:
As website owners continue to upgrade their websites to take advantage of superior technology on new platforms, the process of having to re-apply their design template over and over in a proprietary CMS format each time becomes more and more cumbersome.
A method and system is provided that allows for the extraction of design templates and other design information from an existing website through a visual point-and-click interface, requiring no programming knowledge; the detection and application of these templates across a plurality of existing web pages; as well as the application of these templates to newly generated content and newly generated or existing software.
One aspect of the present invention is a point-and-click system to enable a user to generate a transferable design from an existing website or HTML page, thereby allowing non-technical users to generate templates and portable designs that are able to be used across new systems.
Another aspect of the invention is to provide a visual interface for the re-application of the generated templates to pre-existing (X)HTML files, thereby generating a separation between the design information and the data contained in the website.
Another aspect of the invention is a method and system to facilitate use of the designs obtained in the first paragraph above with new CMSs and applications such as blogs, community forums, polls and similar applications.
In another aspect, a computer-implemented method of extracting a design template from a document comprises presenting a rendered page on a first interface to a viewer, enabling the viewer to visually select elements from the rendered page using an interactive element, enabling the viewer to specify how the selected elements relate to one or more template-regions of the design template using a second interface and replacing the selected elements with programming code as dictated by the design template. The rendered page is a rendered HTML page and the elements are HTML elements. The method is performed as a web service wherein a web server is configured to host a program performing the method and the web service is configured to obtain html by performing an http or https request to a second web server and a user interface of the program is a website. User information is associated with the design template. The interactive element is generated by drawing a visual queue around or on top of the selected element upon hovering over the selected element, and upon clicking, a visual indication of the selected element is persisted. The method further comprises generating an iconic representation of the design template as the viewer selects the template-regions of the design template by recording physical dimensions of the selected template-regions, recording total dimensions of the page and using the physical dimensions and the total dimensions to dynamically generate the iconic representation in proportion to the design template. The iconic representation of the design template takes the form of the rendered design template with graphical overlays to illustrate the template's regions. Each template-region of the template-regions are visually differentiated in at least one of color, texture and animation based on a type of the template-region selected. The design template and the template-regions are pre-specified with preferential criteria for the elements required which guide actions of the interactive element to suggest or prevent selections of the elements. The design template utilizes a generic template definition which is defined using at least one of the criteria: types of the template-regions required by the design template, a number of the template-regions required of a certain type, which of the elements act as a container for a template-region of the template regions, which of the elements are contained in the template-region, preferred elements for the template-region, an explicit programming notation existing that indicates that a certain area in the page corresponds with a template-region definition and a model content for each of the template-regions for comparison. The elements are automatically selected based on matching at least one of the criteria. A selectable element includes a first repeated listing of similar elements that correspond with a second repeated listing of template-regions which are selected as a single aggregate template region. The method further comprises proactively asking the viewer to select a specific template-region of the template in a sequential fashion. The viewer proactively selects which type of the template-region corresponds with the element the viewer is selecting.
In yet another aspect, a computer-implemented method of extracting Cascading Style Sheet (CSS) style information out of an existing page comprises presenting a rendered page on a first interface to a viewer, enabling the viewer to visually select elements from the rendered page using an interactive element, enabling the viewer to specify how the selected elements relate to one or more template-regions of a design template using a second interface, replacing the selected elements with programming code as dictated by the design template, storing previous contents of a selected template region of the one or more template-regions, extracting the CSS style information from the selected elements, storing the CSS style information applied to each selected element of a certain type in a template-region of the one or more template-regions and sorting the type of the template-region that contains the CSS style information obtained. The rendered page is a rendered HTML page and the elements are HTML elements. The CSS style information is distilled by finding a most common group of styles that are applied to a same type of element at a same time most frequently. The CSS style information from a specified type of the template-region is stored, while the CSS style information not from the specified type of the template-region is not stored. The CSS style information is collected for a parent element of the element to determine inherited styles.
In another aspect, a computer-implemented method of storing and retrieving design information comprises a repository of style information collected by presenting a rendered page on a first interface to a viewer, enabling the viewer to visually select elements from the rendered page using an interactive element, enabling the viewer to specify how the selected elements relate to one or more template-regions of a design template using a second interface, replacing the selected elements with programming code as dictated by the design template, storing previous contents of a selected template region of the one or more template-regions, extracting the Cascading Style Sheet (CSS) style information from the selected elements, storing the CSS style information applied to each selected element of a certain type in a template-region of the one or more template-regions and sorting the type of the template-region that contains the CSS style information obtained, wherein the style information is programmatically accessible through an application programming interface. The rendered page is a rendered HTML page and the elements are HTML elements.
In another aspect, a computer-implemented method where an external application pulls essential design information as obtained by presenting a rendered page on a first interface to a viewer, enabling the viewer to visually select elements from the rendered page using an interactive element, enabling the viewer to specify how the selected elements relate to one or more template-regions of a design template using a second interface, replacing the selected elements with programming code as dictated by the design template, storing previous contents of a selected template region of the one or more template-regions, extracting the Cascading Style Sheet (CSS) style information from the selected elements, storing the CSS style information applied to each selected element of a certain type in a template-region of the one or more template-regions and sorting the type of the template-region that contains the CSS style information obtained, thereby pulling the template and essential design information from a remote source. The rendered page is a rendered HTML page and the elements are HTML elements.
In another aspect, a computer-implemented method of manually merging an existing web page into a specific design template comprises presenting a rendered page to a viewer, asking the viewer to choose a design template the page is merged into, enabling the viewer to visually select elements using an interactive element, enabling the viewer to specify how the selected element relates to a template-region of the design template using an interface, storing contents of the selected elements cross-referenced with the template-region each belongs to, a name of the page and a selected template. The rendered page is a rendered HTML page and the elements are HTML elements. The method further comprises presenting the viewer with the visual icon of the template, visually highlighting a specific template-region on the icon and requesting the viewer to choose the element on the page that corresponds with a visually highlighted element of the icon.
In another aspect, a computer-implemented method of automatically merging an existing web page into a specific design template comprises acquiring a document, comparing the document with a plurality of templates to determine a closest match by detecting a presence of common XPaths in each, identifying corresponding template-regions appearing in the document with the template-regions of a general design template as determined by corresponding XPath information, and template-definition criteria and storing contents of the selected elements cross-referenced with the template-regions each element contents belongs to, a name of the page and a selected template the page belongs to. The document is an HTML document and the plurality of templates are a plurality of HTML templates. The method switches to a manual merge when a failure to determine likeness to an existing template prompts the viewer with a request to perform one of manually selecting a matching template and generating a new template.
In another aspect, a computer-implemented system for extracting a design template from a document comprises a first interface configured for presenting a rendered page to a viewer, an interactive element operatively coupled to the first interface, the interactive element configured for enabling the viewer to visually select elements from the rendered page, a second interface operatively coupled to the interactive element, the second interface configured for enabling the viewer to specify how the selected elements relate to one or more template-regions of a design template and a display for presenting replacement of the selected elements with programming code as dictated by the design template. The rendered page is a rendered HTML page and the elements are HTML elements. The computer implemented system is selected from the group consisting of a personal computer, a laptop computer, a computer workstation, a server, a mainframe computer, a handheld computer, a personal digital assistant, a cellular/mobile telephone, a smart appliance, a gaming console, a digital camera, a digital camcorder, a camera phone, an iPod®, a video player, a DVD writer/player, a television and a home entertainment system.
In yet another aspect, an apparatus comprises a memory for storing an application, the application configured for storing and retrieving design information comprising a repository of style information collected by presenting a rendered page on a first interface to a viewer, enabling the viewer to visually select elements from the rendered page using an interactive element, enabling the viewer to specify how the selected elements relate to one or more template-regions of a design template using a second interface, replacing the selected elements with programming code as dictated by the design template, storing previous contents of a selected template region of the one or more template-regions, extracting the Cascading Style Sheet (CSS) style information from the selected elements, storing the CSS style information applied to each selected element of a certain type in a template-region of the one or more template-regions and sorting the type of the template-region that contains the CSS style information obtained, wherein the style information is programmatically accessible through an application programming interface and a processing component coupled to the memory, the processing component configured for processing the application. The rendered page is a rendered HTML page and the elements are HTML elements. The apparatus is selected from the group consisting of a personal computer, a laptop computer, a computer workstation, a server, a mainframe computer, a handheld computer, a personal digital assistant, a cellular/mobile telephone, a smart appliance, a gaming console, a digital camera, a digital camcorder, a camera phone, an iPod®, a video player, a DVD writer/player, a television and a home entertainment system.
One objective of the Service 4 is to take an existing HTML document and make the necessary modifications to turn the document into a design template that is able to be used by another web application.
Prior to beginning the conversion of a static HTML file to a template 1 (
Number of each template-region that is required or that is optional 9 (for example, a CMS support system that requires at least one, but that is able to optionally support up to 3 menus).
More or less criteria are able to be included in a template definition.
The preferred way the template definition is embodied is in a configuration file by the Service 4, but is also able to be specified through a user interface within the Service 4 itself that is able to be accessed by an end-user. In this fashion, new generic template definitions are able to be generated, and the design extraction process as described below is able to be tailored to a specific template's needs.
Once the design definition is in place, the Service 4 receives HTML as covered in the above paragraph (illustrated in
At this point, the Service 4 has the HTML and loops through each HTML element in the page (using the Document Object Model). The Service 4 detects the presence of links and references that are specified using non-absolute paths and rewrites them so the page will correctly render to the end user even though the page will be presented on a separate domain (essentially acting as a proxy server).
A visual point-and-click interface is then added to the web page through the use of JavaScript which allows a user to select certain elements on a page.
The page is rendered to the viewer with the above interactive functionality and the viewer is asked to click on which section of that page corresponds with a necessary template-region 18 (for example, a region of editable content).
The viewer identifies a section of the HTML document by clicking on one of the selectable regions 17.
The location of that selected element is saved in the form of an XPath 19 so that it is able to be programmatically referenced again.
This same pattern is repeated for multiple elements of the page so that multiple XPaths are stored which correspond with the different template-specific regions that are asked for, and multiple regions are visually generated on the icon. (The icon is able to show a specific region as having another color or other visual indicator that a template-region is of a certain type—for example: menu, editable content, news list and others).
When the necessary template-regions of a page are chosen, the page is then submitted to the server along with all the selected XPaths and the data for the visual iconic representation of the chosen elements.
As a result of the above steps, template regions are essentially “punched out” of a page, and in their place, the proper server-side code is inserted which is able to display dynamic content.
Prior to inserting the proper server-side code, the service is able to again read and interpret the previous contents of that template-specific node in order to fine-tune the exact correct server-side code to place in that region.
Further style information about the page is obtained in the following manner: As the viewer selects certain portions of the page in the above steps (for example, a main editable area of content), the Service 4 (
The Service 4 (
The Service 4 (
In this fashion, the fundamental design information 30 for that page is extracted in addition to the normal website template as described above.
At the simplest level, the Service 4 (
Another application is in the case of the Service 4 (
Yet another application is the Service 4 (
For the purposes of this description, the term “base template” is used to describe the template that is generated using the process described in the above paragraphs. The term “target page” 35 is used to refer to a new page that does not yet make use of the base template for its design information. The target page is able to or not have similar design characteristics to the base template (for example, in the case of a website redesign), but will usually be a page that inherently is based off of that template, but that does not yet have the template separated from content at the code level.
To merge a target page into a base template, the following steps show one embodiment of this being accomplished. The preferred architecture is that of the “proxy server” arrangement described above:
The viewer is first asked to browse 34 to the page they wish to merge into a template. (They are able to also provide HTML directly using another fashion such as copy/paste, FTP upload, http upload, a bookmarklet or similar means). The page is then merged onto an existing template in one of two ways: manually or automatically.
The viewer is asked to select the template that fits the particular page they wish to merge.
The viewer is then taken through a “visual guide” of choosing the corresponding editable regions of the template. This is done in the following fashion:
On the visual icon of the base template that has been chosen, one of the template-region begins to flash 36 (or provide some other visual indication) and the user is asked to identify in the target page the area which is flashing in the iconic representation of the base template. After the viewer clicks on this region 37 using the same selection mechanism as described above, and indicating to go to the next step (which is able to be just by the action of choosing) another region flashes and the viewer is asked to click on that section, and so on.
The request to click is able to not be prefaced by the application specifying the type of template-area on which to click. (For example, instead of the application specifying: “Please indicate the menu that is shown as the flashing area in the icon,” the user could first click on an area, then subsequently identify the corresponding template area)
The Service 4 (
The Service 4 (
Now that the Service 4 (
The system takes a target page 41 one at a time, and performs an analysis on the page in order to detect what template the page belongs to. An embodiment of this is as follows:
This analysis is repeated for each page in a grouping of HTML pages, and a separation between content, and templates is achieved in this way.
If a page is found that does not match a pre-existing template, one is able to either generate a new template from that page, or merge that page's content into an existing template using the manual method as described above.
In this fashion, a user is able to achieve a separation of presentation and content from their website.
Examples of suitable computing devices include a personal computer, a laptop computer, a computer workstation, a server, a mainframe computer, a handheld computer, a personal digital assistant, a cellular/mobile telephone, a smart appliance, a gaming console, a digital camera, a digital camcorder, a camera phone, an iPod®, a video player, a DVD writer/player, a television, a home entertainment system or any other suitable computing device.
To utilize the method of and system for extraction and reapplication, a viewer/user is presented with an interface which presents a rendered web page to the viewer. An interactive element then enables the viewer to select elements. A second interface enables the viewer to specify how the selected elements relate to one or more template-regions of a design template. The selected elements are then replaced with programming code based upon the design template.
In operation, the method of and system for extraction and reapplication solves the problems of the prior art by enabling a non-technical user to generate a re-usable design template based off of an already existing website so that they are able to easily upgrade systems, add on new systems to their existing websites and/or migrate web content management platforms.
The present invention has been described in terms of specific embodiments incorporating details to facilitate the understanding of principles of construction and operation of the invention. Such reference herein to specific embodiments and details thereof is not intended to limit the scope of the claims appended hereto. It will be readily apparent to one skilled in the art that other various modifications may be made in the embodiment chosen for illustration without departing from the spirit and scope of the invention as defined by the claims.
This application claims the benefit of U.S. Provisional Patent Application Ser. No. 60/959,546, filed Jul. 13, 2007 and entitled CONTENT MANAGEMENT SYSTEM INNOVATIONS; which is hereby incorporated herein by reference in its entirety for all purposes.
Number | Date | Country | |
---|---|---|---|
60959546 | Jul 2007 | US |