© 2005 The Cobalt Group. A portion of the disclosure of this patent document contains material that is subject to copyright protection. The copyright owner has no objection to the facsimile reproduction by anyone of the patent document or the patent disclosure, as it appears in the Patent and Trademark Office patent file or records, but otherwise reserves all copyright rights whatsoever. 37 CFR § 1.71(d).
This application pertains to the World Wide Web (hereinafter “the Web”) and, more specifically, it is directed to methods and systems to enable remote or client-side visual editing of web pages, commonly referred to as “what you see is what you get” or WYSIWYG (pronounced “wiz-ee-wig”) editing, within a web browser application without installing any external software.
The “Web” is now well developed and literally millions of Web sites have been deployed, hosted on various servers around the world. Web sites comprises one or more related “pages,” in some cases extending to scores or even hundreds of pages. The subject matter of web sites spans the full range of human interests and endeavors, and many web pages now include dynamic content as well as multi-media content such as audio and video clips, slideshows and the like.
The creation and maintenance of web sites, especially sophisticated sites, requires appropriate software “tools”. In the simplest case, a page designer who is skilled in the use of a known page “markup language” such as HTML can use almost any text editor to create a web page. More specifically, the designer creates an HTML file that defines the desired page layout and content. The page file is stored, often together with other, related page files, in a file system coupled to a web server that is arranged for “hosting” the corresponding site (and potentially other sites as well). When a user “visits” the site, by navigating a web browser to the corresponding address or URL, he can download and view the page (or, the “home page” will simply download automatically when accessed). Typically, the web browser is a program running on the user's computer (or other web-enabled device such as a cell phone). A standard web browser, such as Microsoft's Internet Explorer or Netscape, contains code for interpreting the HTML page and displaying the page. This is a simplified summary as the topic is well known.
Most web sites today are created and maintained using editors better suited to the task than an ordinary text editor or word processor. For example, an HTML editor can specially mark HTML “tags” and enforce compliance with HTML (or other markup language) standards. Some HTML or web page editors will provide several screen displays or “views” for the convenience of the designer, such an a code window showing the HTML code, and a “preview” or browser window showing how the web page will appear when the present code is processed in a web browser. These two views might be available side by side for showing the page designer the effects of various code changes in near-real time. Known web page editors typically also include file “browsing” features for storing and fetching content files for inclusion in a page under construction.
Known web site editors fall into several broad categories. First, there are “full blown” or standalone application programs for building web sites. Popular examples include Macromedia's “Dreamweaver” and Microsoft's “Front Page.” Many of these products provide extensive “visual editing,” which refers to designing a web page using “point and click” or “drag and drop” interfaces that enable selection of layouts and design styles and elements without writing code. The editor generates the code, such as HTML, that will implement the desired page design. Such programs may include various predetermined design “templates” to give the novice designer a “head start”. Standalone web page editors, however, are bulky applications, typically they cost money, and they require installation in a compatible computer to use them. A “compatible” computer here refers to one that runs the operating system on which the editor application was designed to run (and meets other system requirements such as available memory and processor specifications). Standalone editors also require that the user upload or “publish” the completed web page to a server when it is ready for use on the Web (sometimes called “going live”).
A second class of web site (or page) editor are those that run in a web browser. These are typically implemented as “plug-ins” i.e., code that is installed to supplement the web browser's native capability. Usually, plug-ins are acquired by download (via the Web) and then installed on the user's machine. One such plug-in editor is called “eWebEdit”. Once installed, it can be used to create or edit HTML code in a web browser, and then display the resulting web page. While this approach avoids acquiring and installing a complete, standalone web editor application, it still requires a software download, which can be time consuming if the user has a low-bandwidth connection.
Some web editors are implemented as Java applets that are downloaded to a user's web browser. Like the use of plug-ins, this technique requires downloading software (although “installation” may be transparent), which can cause annoying delay especially where the user has a slow connection. Finally, there are web editors deployed on a server for remote client-server operation. These of course impose a traffic burden on the network and may not be suitable for numerous users.
What is needed is a way to allow remote users to edit a web page (or entire site) maintained on a web server without requiring each user to acquire and install web editing software. Put another way, any web user (with permission) using virtually any computer should be able to edit a web page without having to download or otherwise install special web editing software.
In general, the application server 102 provides web site creation, maintenance and hosting services for one or more business entity groups, 110, 112. We will use the automobile industry as one example to illustrate a potential application of the present invention. The invention can be used, however, for user editing of any web page in virtually any environment, as further explained later. Continuing our automotive example, the business entity group 112 might be an automobile dealership or a group of automobile dealerships that maintains one or more web sites on the application server 102. Let us assume, for example, that business entity group 110 is an individual automobile dealership. An authorized individual at the dealership, for example a general manager, can use a PC, for example, to communicate via network 100 with the application server 102 to view the dealership's web site and to exercise high-level controls, for example setting permissions for which employees are authorized to edit the web site.
Continuing our example with the automobile dealership entity 110, it may have, for example, two users who are authorized to edit different pages of the dealership web site. For example, a first user represented by PC 120 might be the manager of the dealership's new car division and who has permission to edit the new car web site (or new car pages) on the dealership web site. A second user represented by PC 122 in
The application server in a presently preferred commercial embodiment is built on a J2EE platform, and includes a web site manager that enables the web site proprietor (business entity) and its authorized users to maintain its web site(s). The web site manager preferably is implemented as a web application, in other words the user accesses that functionality on the application server through their standard web browser. This need not necessarily be the case but it is preferred because it obviates the need for the dealership to deploy special software. For greater detail, see commonly-owned U.S. patent application entitled, METHOD AND APPARATUS FOR PROCESSING A DYNAMIC WEBPAGE, filed Jan. 24, 2003 Appl. No. PCT/US04/02100. The web site manager application enables the authorized user to select the web site of interest using a friendly graphical interface, such as that illustrated in
If the user chooses “Change Design Layout & Color”, the user is presented with a screen like that shown in
Next we assume that the user is authorized to do so and has selected an individual page for editing. Referring now to
Next the user clicks on the specified field to edit the text cell 622. When the user chooses to edit the text cell 622, a new window or panel 700 pops up as indicated in
The edit text cell panel 700 includes a field 702 for entering text, as mentioned, in a “save text as” button 706. As shown in
Referring now to
When the desired editing step is completed, the user clicks the corresponding “OK” button or the like, and the results are submitted to the server, for example using standard HTTP form submission protocols (again, so a standard web-browser can be used for remote editing without supplemental software).
The types of editing activities illustrated in the drawing figures described above can be carried out by the user, in accordance with the present invention, in a standard web browser running on the user's machine, without having to install external software such as JAVA applets or browser plug-ins. This feature is accomplished by enabling the desired editing functionality within the (editable) web page itself, using a markup language. In a presently preferred commercial embodiment, Java Server Page (“JSP”) technology is used in the application server to generate the editable page. The editable page employs a standard markup language so that it will execute properly in a standard web browser, such as Microsoft Internet Explorer, Netscape, or the like.
In one illustrative implementation, the JSP code invokes custom tags to implement the editor in HTML and DHTML standard markup languages. To further describe the invention, sample code is shown below for implementing a text cell edit feature. In view of this description of the technical approach taken in a presently preferred embodiment, those skilled in the art will readily appreciate various ways to implement editing of other types of cells, such a pictures or graphics, as well as other equivalent methods and technologies to implement remote editing generally in accordance with the invention, to implement WYSIWYG editor behavior in a standard web browser without requiring additional software. This has the advantage of enabling editing by a user on virtually any PC or other web-enabled device; no special software is needed. Neither is programming expertise necessary as the editing functionality is a visual-editing paradigm with WYSIWYG feedback in essentially real time.
In the following code example, we assume that a user has logged in to the server platform and has permission to edit the page he selects. The following JSP code creates the HTML that enables editing content at the browser: This is implemented using a custom tag, called text-cell (the text cell editing tag).
The opening tag includes default text for the cell:
The code for the tag (text-cell) begins as follows:
Following is standard format commenting:
Below is the resulting HTML that denotes the text cell at the browser. The initial DHTML “DIV” tag creates the bounding box that is displayed on the browser—see 622 in
The same tag also creates the following HTML when it is invoked with editing turned off(published):
It will be obvious to those having skill in the art that many changes may be made to the details of the above-described embodiments without departing from the underlying principles of the invention. The scope of the present invention should, therefore, be determined only by the following claims.
This is a divisional application of U.S. application Ser. No. 10/351,465, filed Jan. 24, 2003, now U.S. Pat. No. 7,000,184, issued Feb. 14, 2006, which is incorporated herein by reference.
Number | Name | Date | Kind |
---|---|---|---|
6785864 | Te et al. | Aug 2004 | B1 |
6826594 | Pettersen | Nov 2004 | B1 |
6990629 | Heaney et al. | Jan 2006 | B1 |
7152207 | Underwood et al. | Dec 2006 | B1 |
7322007 | Schowtka et al. | Jan 2008 | B2 |
7401289 | Lachhwani et al. | Jul 2008 | B2 |
7536641 | Rosenstein et al. | May 2009 | B2 |
20010054049 | Maeda et al. | Dec 2001 | A1 |
20020023111 | Arora et al. | Feb 2002 | A1 |
20020032701 | Gao et al. | Mar 2002 | A1 |
20020042738 | Srinivasan et al. | Apr 2002 | A1 |
20020046245 | Hillar et al. | Apr 2002 | A1 |
20020116418 | Lachhwani et al. | Aug 2002 | A1 |
20020129054 | Ferguson et al. | Sep 2002 | A1 |
20020138331 | Hosea et al. | Sep 2002 | A1 |
20030023632 | Ries et al. | Jan 2003 | A1 |
20030051022 | Sogabe et al. | Mar 2003 | A1 |
20030069790 | Kane | Apr 2003 | A1 |
20030225853 | Wang et al. | Dec 2003 | A1 |
20040148342 | Cotte | Jul 2004 | A1 |
20040156020 | Edwards | Aug 2004 | A1 |
20040163047 | Nagahara et al. | Aug 2004 | A1 |
20040255233 | Croney et al. | Dec 2004 | A1 |
20040268225 | Walsh et al. | Dec 2004 | A1 |
20040268232 | Tunning | Dec 2004 | A1 |
20050108637 | Sahota et al. | May 2005 | A1 |
20050114764 | Gudenkauf et al. | May 2005 | A1 |
20050171836 | Leacy | Aug 2005 | A1 |
20060031811 | Ernst et al. | Feb 2006 | A1 |
20060064637 | Rechterman et al. | Mar 2006 | A1 |
20060123330 | Horiuchi et al. | Jun 2006 | A1 |
20060129982 | Doyle | Jun 2006 | A1 |
20060161841 | Horiuchi et al. | Jul 2006 | A1 |
20060200751 | Underwood et al. | Sep 2006 | A1 |
20060248442 | Rosenstein et al. | Nov 2006 | A1 |
20060271844 | Suklikar et al. | Nov 2006 | A1 |
20060277588 | Harrington et al. | Dec 2006 | A1 |
20070053513 | Hoffberg | Mar 2007 | A1 |
20070271389 | Joshi et al. | Nov 2007 | A1 |
20080015929 | Koeppel et al. | Jan 2008 | A1 |
20080195932 | Oikawa et al. | Aug 2008 | A1 |
20090024918 | Silverbrook et al. | Jan 2009 | A1 |
Number | Date | Country | |
---|---|---|---|
20050229101 A1 | Oct 2005 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 10351465 | Jan 2003 | US |
Child | 11149909 | US |