1. Field of the Invention
The present invention generally relates to rich text capability for Web based applications and Web browsers, and more specifically, to a system and method for representing and controlling rich text in memory and various text representations.
2. Background Description
Web browser based applications are becoming increasingly popular. These browser based applications necessarily handle documents of various types. However, document handling and management of documents as they change over time to include new or varying content can be very expensive and cumbersome. Flexibility in representing and handling documents, including those stored in relational databases, is limited. One specific example of a major drawback is the lack of a robust rich text capability.
Standard Web browsers do not provide full feature rich text edit functions. This includes, for example, the general lack of ability to change font face, size and color, underline, bold, italic, to create tables and lists (both ordered and unordered), to check spelling, and to add in-line images or file attachments. Further, images and file attachments typically cannot be added as links to other Uniform Resource Locators (URL), or uploaded from a local file system into Binary Large Object (BLOB) data stored on a server.
Some known web browsers have features that allow direct editing of hypertext mark-up language (html) features of a page (i.e., the “content editable” feature) which effectively creates a text area that allows limited rich text editing. These browsers, however, do not provide any method to save changes to rich text that have been made through its editing facilities. Most browsers, however, do not provide any rudimentary text or other type of editing features.
The present invention overcomes the problems set forth.
In an aspect of the present invention, a method is provided for managing rich text applications such as Web based applications and browsers. The method comprises representing the rich text in a memory structure representation and providing one or more classes for use by the applications and browsers to create the memory structure representation representative of rich text. The classes include a rich text list class for managing one or more rich text nodes and a rich text class to create rich text nodes that represent a unit of rich text and its attributes. When editing rich text in a document, the memory structure representation is used that was created by the provided classes.
In another aspect, a method is provided to represent and manage rich text for use by applications and browsers that involves representing the rich text in a memory structure representation and providing classes for use by the application and browsers to create the memory structure representation. A spell checker is additionally provided to facilitate correcting misspelled words. The spell checker utilizes the memory structure representation and the provided rich text classes. The spell checker employs a dictionary wherein each word of the dictionary has a signature associated with the word to facilitate searching for substitute words.
In another aspect, an apparatus of the invention provides components for representing and managing rich text for use by the applications and browsers. The apparatus includes a component for representing rich text in a memory structure representation and a component for providing one or more classes for use by the applications and browsers to create the memory structure representation. A component for editing rich text in a document using the rich text classes is provided, as is a spell-checking component.
In another aspect of the invention, a computer program codes comprising a computer usable medium having a computer readable program code embodied in the medium is provided. The computer program codes include a first computer program code to provide one or more classes for use by applications to at least create and manage one or more rich text nodes in a memory structure representation representative of rich text. Additionally, a second computer program code to represent the rich text in the memory structure representation, and a third computer program code to edit rich text in a document using the memory structure representation to perform editing functions on a document having rich text as managed and created by the one or more classes are provided.
The foregoing and other objects, aspects and advantages will be better understood from the following detailed description of a preferred embodiment of the invention with reference to the drawings, in which:
This invention provides a full feature rich text edit capability for a standard Web browser and other applications. In particular, the present invention provides a method and system to consistently represent rich text in memory structure in order to facilitate editing and managing documents containing such rich text. These memory structures may be resident on a computer, server or other known hardware. The documents may include, for example, html documents presented via a web browser or other web based applications. These documents may contain text, tables, images, links and the like in which the system and method of the present invention represents such elements as rich text in such documents. By utilizing the system and method of the present invention, it is now possible to edit and save such documents in many types of environments thus providing flexibly and robust management and control capabilities. The present invention is described with illustration to the Enterprise Application Development Platform (EADP) developed by International Business Machine Corporation. This environment is shown for illustrative purposes and it should be understood by those of ordinary skill in the art that any other suitable context may be alternatively employed and implemented by the present invention.
System and Structure of the Present Invention
Now referring to
By way of illustration, in memory, each rich text field is represented by a controller class (e.g., the rich text class), and subsidiary classes that hold the rich text content. The most basic of these is the rich text node, which represents a single atomic unit of the rich text (i.e., text with its attributes such as font face, font size, underlining, italics, etc.). The rich text node may also have attributes to determine, for example, if the text is bold, underlined, italic, or another attribute may determine if that text node should start a new paragraph. Essentially any text attribute can be represented.
Memory Structure
Most manipulation of the rich text is performed in its memory format as described above. The present invention also provides methods to transform the text from its memory format into the string representations and vice versa. In embodiments, the rich text is stored as a string in the relational database, and may be stored in a CLOB column due to a potentially large string size. Of course, there are alternative ways that this string can be formatted such as converting the rich text into the html string for storage. Another is to convert into xml. This approach may have some advantages if other applications are able to process the xml directly as it is stored in the relational database. A third alternative, which has the advantage of requiring less storage space, is to use a compressed format where the various attributes of each rich text node are captured, along with the text value for that node. For all three alternatives, the method to convert the rich text to string is similar to the method for generating an html string, except for formatting of each part of the string.
Creating Rich Text Memory Structure from Html
In embodiments, there are two aspects of creating rich text memory structures from html. In a first aspect, the rich text node has the ability to parse a well-formed segment of html and set its attributes accordingly. This includes the ability to create other rich text nodes as needed as the html indicates a change in text attributes or the presence of an image or link. In a second aspect, a function in the rich text list takes html that may not be well formed (i.e., non-well formed html), and preprocesses the html to make it recognizable by the rich text nodes. The rich text list also handles creating the nodes for the table structures included within the html.
The rich text node has the ability to parse a well-formed segment of html. A well formed segment of html may include, for example:
The tags that are of particular interest are table type tags, image and link tags, and the tags for the rich text attributes (e.g., font, italic, bold, underline, break and paragraph tags). A set of these tags can be used to define the attributes for one rich text node. For example a single rich text node may be represented as:
<p><i><strong><u><font face=“verdana” size=“3” color=“black”>Hello world<font></u></strong>-; </i>
which looks like
Hello World
(type size is “3” and color is black)
However, suppose the passed html included a font change, located, for example, in the middle:
<p><i><strong><u><font face=“verdana” size=“3” color=“black”>Hello</font><font face=“verdana” size=“5” color=“red”>world</font></u></strong>cz/i&g-t;
which now looks like this
Hello World
(type size of “Hello is “3” color is black while the type size of “world” is now “5”, and color is red)
In the latter scenario, two rich text nodes would be required to process these attributes. The parsing method for html handles this by creating a structure of rich text nodes using preceding and following node links as shown generally in
Referring now to
In
1. Read the text up to the first tag (i.e., the first occurrence of “<”). If this is not a null string, clone the current rich text node 105b and make the clone a preceding node 105a (S7), and assign to it all the text before the first tag (i.e., first part). Then remove that part of the text and call the resolvetag method 130 again. The html needs to be well formed for the cloning steps to work recursively. The well formed property ensures that the encountered tags are in the proper order so that the text sent to the clone will not miss any tags.
2. If the tag has a matching end tag, check if there is any text beyond that end tag. If there is, clone the current rich text node 150b, make that clone the following node 105c (S8), and assign it the text after the end tag. Then remove that part of the text and call the resolveTag method 130 again.
3. If the tag is an image or link tag, clone the current rich text node 105b and make that clone the following node 105c (S8), and assign it the text after the tag (i.e., last part).
4. Pass the tag information (the text between the “<” and “>”) to resolve the tag and to set up the tag attributes, shown at step S9. If this is an image or link tag, it requires that the attributes are stored in the text. This is the reason for moving the original text to the following node.
5. If the preceding or following nodes are not null, call resolve tag 130 on them, making the preceding or following node (as appropriate) the current node, which recursively propagates more rich text nodes as necessary to fully represent the rich text.
The resolvetag method 130 is relatively straightforward, except for the image tags. For other tag types, the resolveTag method 130 may determine the type of the tag, for <i>, <strong>, <u>, <p>, or <br> it simply sets “on” the corresponding boolean attribute. For font tags, the content of the tag is parsed to determine if it has size, face or color information, and these attributes are set accordingly if they have been specified. Image tags are somewhat more complicated because the rich text editor overloads the file name with other information to set the alt tag, the height, the width, whether the image should float and whether the tag is to be treated as an in-line image, file attachment, or link. If the image size is manipulated within a rich text editor, the browser generates back the resized image with the height and width in a style statement instead of as html tag attributes. A style tag is generated with the float definition. All of this is written to the text attribute of the rich text node (each image tag requires its own rich text node). If the image is defined as a link instead of an image, the full link tag (e.g., <a href= . . .> . . . </a>) is placed in the text field.
Still referring to
At step S15, the table related tags are restored which where ignored previously. At step S16, the html is broken into segments at the <table> tags, and then organized into a new rich text list 132 that includes entries that are either simple strings 133 (for rich text node entries) or vectors 134 (for table entries). The list version of resolveFromHtml method 136 is called to process this list. For the string entries, the resolveFromHtml method 136 for the rich text node 106 is called. These nodes may be added directly to the list of rich text nodes attached to the main rich text list 135. For the vector entries, the resolveFromHtml method 140 for that table node 137 creates a new rich text node 138 in the next position in its main rich text list 135, passing the vector that has the table information.
Converting the Rich Text Memory Structure into Html
Representing the Rich Text Structure in a Relational Database
Rich text is stored as a string in a relational database. Because of the potentially large size of this string, it may be stored in a CLOB column. In order to make this as compact as possible, and to reduce the amount of tag information stored as text (this is to make searching less confusing), most of the tag information in each rich text node may be stored in a compressed format. Arrays are kept of the permitted font face and color values, and the index for those entries is stored into the array. Also, other attributes such as bold, italic, underline and whether the rich text node is an image tag are boolean attributes, and what is stored from them is a null string for false and a one byte string for true. The table nodes are stored in their html tag format, except that the cell nodes may use the relational format for their rich text nodes.
Databody fields can be stored in string, date, or numeric format and comprehensively represent the document contents. Rich text is an added type for the databody field that is stored in string format. An aggregate editor, which is capable of manipulating and editing a databody, recognizes the rich text type, and has a rich text list as one of its attributes to hold the memory representation of the rich text. This is converted into the string format for the relational database and assigned to the column that holds string values.
Retrieving the Rich Text Structure from a Relational Database
A particular consideration is the presentation of image tags that are BLOB references. These are modified to assure that the URL for the servlet is the current one. This is done in the memory representation of the rich text list. Each of its rich text nodes is checked to see if it is an image node representing a BLOB reference, and if so, the servlet portion of the URL is modified to match the current URL.
Presenting Rich Text for Editing Over the Web
In one type of the Web browser 198, the html for the rich text is assigned to a “content editable div” which allows the text to be edited directly. The rich text edit window is a somewhat simple html form. For other browsers 198 that do not provide native support for rich text edit, the rich text edit window is a frame. The frame includes two parts, as shown in
The applet 197 may be linked to the html edit window using the LiveConnect feature of JavaScript. In one browser version, each of the rich text editing functions 208 may call a JavaScript routine that invokes a function for rich text manipulation, and then passes the revised html to the applet 197. The applet 197 then processes the html, and writes the output back out to the “content editable div.” At its simplest, the applet 197 uses the html to create a rich text list structure in its memory, and then converts that rich text structure back into html. This cleans up the html and makes it well formed. In the case of image tags inserted into the rich text by the rich text editor 190, the applet 197 does a great deal more.
There are several functions in the EADP rich text classes to support the plain text editing of the rich text. One is a method on all the rich text nodes to render them into plain text. When a simple rich text node is rendered to plain text, its text is written to the output string, along with a one byte separator (a non-editable break character). The latter serves as a reminder that the plain text is really a representation of rich text, and also makes it easier to parse updates to the plain text representation to render it back into rich text. If the rich text node is an image node it reports itself in the plain text representation as an image or link. If it is the anchor point of a table node, it reports itself as a table. Note that the content of the table consists of titles and data cells, which are themselves rich text nodes, so it is possible to edit the table by editing its plain text representation.
Handling Tables, Lists, Images and File Attachments During Rich Text Editing and Presentations
When editing rich text and presentations using a browser, the memory structures and mechanisms to manage the representations of the rich text are consistently maintained as described above in order to provide overall controls for the editing operation. Examples of browser presentations and rich text editing options, illustrating the relationship between user interaction via a browser and the memory structures, are expanded further in conjunction with
Rich text editing functions of some browsers implementing the present invention, provide two basic types of functions. The first is a variety of ways to change the font and text characteristics (this includes font face, font size, font color, bold, italic, and underlining). The second is the ability to insert an image at the current cursor position by specifying the local file name for that image. The third is the ability to indicate selected text through use of the insert link tag by specifying a special URL for the link that indicates the advanced function to perform. The advanced features of the rich text edit function are built on extensions of the image and link tag facilities. The native function of the browser may be used to create an image or link tag with a file name or URL that is overloaded with additional parameters. This is then intercepted by JavaScript functions or the hidden applet 197, and used to provide additional features.
One example of this is the way EADP-based rich text editing of the present invention allows insertion of table structures and lists into the rich text area. The button labeled “ListsAndTables” (
Referring now to
The file button 218 (
This panel 215 allows the addition of a great deal more formatting of data for the image or attachment. This includes aspects that are needed for well formed and accessible html such as the alt tag, the size of the image, and whether it should float. All this may be added to the file name that is assigned to the image tag. When the OK button is pressed, the file is uploaded if need be, and the image creation function on the parent panel is called. This adds the image tag with the overloaded file name to the html, and invokes the applet 197 to intercept and resolve the html. The applet 197 then creates the rich text structure in memory from the passed html. When it processes each image tag, it resolves the file name by parsing out any information that was added as an overload. This additional information is used to set additional parameters in the image tag, to change the image tag to represent a file attachment, or to indicate that the image tag should write itself out as a simple link, for example.
Providing Spell Checking
As a convenient feature during rich text editing, spell-checking operations is provided in the various embodiments of the present invention. The spell checking solution is optimized for use within a servlet environment. Servlets are typically server-side Java programs that are loaded and run within the framework of a web server. The dictionary functions all reside, preferably, on the server side, and reside as singletons in server memory so that they are extremely fast. The returned html includes all misspelled words and possible replacements so that JavaScript functions on the client side can provide an interactive and responsive spelling correction. The technique for dictionary creation and usage is also unique to this invention.
The spelling dictionary may be created initially from word lists then instantiated and serialized. The serialized hashtable is held as property files in the Java code for the EADP (or equivalent) dictionary class (e.g., EADPSpellCheckController). The structure of the dictionary is a hashtable, where the entries are lists of words. The keys to these entries are unique and provide powerful search ability. In embodiments, each word is assigned a set of characteristic signatures. These characteristics can be simplified or enriched depending on the capabilities of the server holding the dictionary. The possible sets of signatures are:
1. If the word length is less than three, the only signature is the word itself.
2. If the word is greater than eight, one signature is the first half of the word.
3. If the word length is greater than seven, the first three and last three characters are signatures.
4. If the word length is between four and seven, the first two and last two characters are signatures.
5. If the word length is greater than four, the first four and the last four characters are signatures.
6. If the word length equals four the first two characters plus the last character is a signature.
7. If the word length equals four, the first letter plus the last two letters is a signature.
The signatures can be enhanced on more powerful servers. It should be understood that each word may be added to the list keyed by each of its signatures. Also, each word has a primary signature, its first three or four letters (or the entire word if it is short). A word is checked for correctness initially by determining if it is a member of the word list for its primary signature. If a word is not correctly spelled, replacements are determined by using all its signatures to find the words in the list for those signatures.
When a word is checked for correctness, it is first checked to see if it is present in the list for its primary signature. If it is not there, then it is not spelled correctly. In this case, a substitution list is created for the word. That consists of creating a set of signatures for the misspelled word, finding all the words in the lists keyed by those signatures, and then selecting the twenty best matches (ranked as described next) to the word in question.
The ranking is accomplished by creating a common list of all the potential replacements. Each word only appears once in the common list, although it may have been found in more than one on the signature lists. Each word gets a score representing how many times it appeared on a signature list.
The top fifty (or other predetermined number) matches are selected based on this score. This is done by adding all words with a score of eight to the list of fifty, then all the ones with a score of seven and so on until fifty words are on the top fifty list. A consideration is made that if the match score is less than three, an additional criterion (e.g., whether the length of the replacement word is within two of the length of the misspelled word) is used for the selection.
The next filter is to find words in the top fifty list that match first or last parts of the misspelled word. The length to match starts at the length of the misspelled word minus one, and is successively decreased. At each stage, the words on the top fifty list that match for the length are added to the top twenty list, until it is filled. This provides a list of twenty (or possibly another size) replacements that has the most likely replacements at the top.
The EADPRichTextNode class includes a toSpellHtml method, which invokes the dictionary function for each word in its text attribute. If the node is an image tag or table anchor node, the toSpellHtml method returns the standard html for that node. The table nodes also have toSpellHtml methods that just invoke toHtml. The EADPRichTextList toSpellHtml method invokes the same method on each of its rich text nodes, which in turn cascade the method through the rich text structure. The resulting html string has the misspelled words and their replacements isolated by special separator tags. The font tags for the rich text node are repeated for each segment of text outside of the misspelled word.
When the spell check button (e.g.,
These features are not typical, and are supported by JavaScript functions that are unique to the present invention. These functions allow the spell check html to be presented and manipulated. Within the spell html, each misspelled word and its substitution list is isolated from the rest of the html by a separator string. That is, the spell html is split at these separators resulting in an array of strings where some of the entries are regular html and others are the misspelled words with the possible replacements separated by a different separator string. The next JavaScript function now glues this array back into html to present in the rich text area, with the regular html added. The array entries for the misspelled words are added by creating a font tag with a gray background in its style (to highlight the misspelled word) and Courier font, for example. The misspelled word is added, and an end font tag. The first misspelled word is assigned to the text area for the replacement, and its replacement list is parsed out and assigned to the option list. When the “Correct It” button is pressed, the replacement string for the misspelled word is merged into the regular html, and the entire process is repeated (the “next” misspelled word is now the first, so the effect is to work down through the misspelled words). When the “Done” button is pressed, all remaining misspelled words are merged back into the surrounding html and the corrected html string is submitted back to the server, which then assigns it to rich text edit panel.
The software classes described above include methods to instantiated the classes and to access the resulting objects. These software components may exist collectively or separately in libraries, in databases, on networks, on hard or floppy discs, tapes, or resident in various types of memories such as read-only, random access or removable memories.
Referring to
While the invention has been described in terms of preferred embodiments, those skilled in the art will recognize that the invention can be practiced with modifications and in the spirit and scope of the appended claims.
The present application is a continuation application of co-pending application Ser. No. 12/940,462, filed on Nov. 5, 2012, its contents being incorporated by reference in its entirety herein.
Number | Name | Date | Kind |
---|---|---|---|
4029236 | Carson, Jr. et al. | Jun 1977 | A |
4366919 | Anderson | Jan 1983 | A |
4833610 | Zamora et al. | May 1989 | A |
5301842 | Ritter | Apr 1994 | A |
5604897 | Travis | Feb 1997 | A |
5694610 | Habib et al. | Dec 1997 | A |
5765180 | Travis | Jun 1998 | A |
5787451 | Mogilevsky | Jul 1998 | A |
5832268 | Anderson et al. | Nov 1998 | A |
5845306 | Schabes et al. | Dec 1998 | A |
5977967 | Berner et al. | Nov 1999 | A |
5991713 | Unger et al. | Nov 1999 | A |
5999938 | Bliss et al. | Dec 1999 | A |
6047300 | Walfish | Apr 2000 | A |
6085206 | Domini et al. | Jul 2000 | A |
6105036 | Henckel | Aug 2000 | A |
6131102 | Potter | Oct 2000 | A |
6173311 | Hassett et al. | Jan 2001 | B1 |
6182092 | Francis et al. | Jan 2001 | B1 |
6185591 | Baker et al. | Feb 2001 | B1 |
6253228 | Ferris et al. | Jun 2001 | B1 |
6330574 | Murashita | Dec 2001 | B1 |
6336124 | Alam et al. | Jan 2002 | B1 |
6345307 | Booth | Feb 2002 | B1 |
6374210 | Chu | Apr 2002 | B1 |
6381620 | Matsuura et al. | Apr 2002 | B1 |
6454138 | Greenhill et al. | Sep 2002 | B1 |
6456209 | Savari | Sep 2002 | B1 |
6470364 | Prinzing | Oct 2002 | B1 |
6480206 | Prinzing | Nov 2002 | B2 |
6496202 | Prinzing | Dec 2002 | B1 |
6519597 | Cheng et al. | Feb 2003 | B1 |
6601059 | Fries | Jul 2003 | B1 |
6883737 | Girardot et al. | Apr 2005 | B2 |
7047493 | Brill et al. | May 2006 | B1 |
7111011 | Kobayashi et al. | Sep 2006 | B2 |
7178100 | Call | Feb 2007 | B2 |
7222298 | Monterrosas | May 2007 | B2 |
7246060 | Geidl et al. | Jul 2007 | B2 |
7444348 | Fries et al. | Oct 2008 | B2 |
7490292 | Hennum | Feb 2009 | B2 |
7581170 | Baumgartner et al. | Aug 2009 | B2 |
7594168 | Rempell | Sep 2009 | B2 |
8065219 | Haynie | Nov 2011 | B2 |
20010042081 | MacFarlane et al. | Nov 2001 | A1 |
20010054049 | Maeda et al. | Dec 2001 | A1 |
20020029229 | Jakopac et al. | Mar 2002 | A1 |
20020054138 | Hennum | May 2002 | A1 |
20020071139 | Janik | Jun 2002 | A1 |
20020143521 | Call | Oct 2002 | A1 |
20020147724 | Fries et al. | Oct 2002 | A1 |
20020165882 | Zettel et al. | Nov 2002 | A1 |
20030007397 | Kobayashi et al. | Jan 2003 | A1 |
20030014442 | Shiigi et al. | Jan 2003 | A1 |
20030079052 | Kushnirskiy | Apr 2003 | A1 |
20030088410 | Geidl et al. | May 2003 | A1 |
20030200254 | Wei | Oct 2003 | A1 |
20040148307 | Rempell | Jul 2004 | A1 |
20040216591 | Assadi et al. | Nov 2004 | A1 |
20040230550 | Simpson et al. | Nov 2004 | A1 |
20060036448 | Haynie | Feb 2006 | A1 |
Entry |
---|
Notice of Allowance dated Feb. 4, 2016 in related U.S. Appl. No. 13/941,688, 29 pp. |
Chen et al., “A GUI Environment to Manipulate FSMs for Testintg GUI-based Applications in Java”, 2001, IEEE, pp. 1-10. |
Office Action dated Aug. 28, 2017 in related U.S. Appl. No. 15/085,032, 18 pp. |
Final Office Action dated Jan. 10, 2018 in related U.S. Appl. No. 15/085,032, 19 pages. |
Notice of Alloowance dated Mar. 28, 2018 in related U.S. Appl. No. 15/085,032, 29 pages. |
Number | Date | Country | |
---|---|---|---|
20160147732 A1 | May 2016 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 10606547 | Jun 2003 | US |
Child | 12940462 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 13948728 | Jul 2013 | US |
Child | 15009027 | US | |
Parent | 12940462 | Nov 2010 | US |
Child | 13948728 | US |