The following U.S. patent applications, filed concurrently herewith, are assigned to the same assignee hereof and contain subject matter related to the subject matter of the present application:
U.S. patent application Ser. No. 09/752,120 filed 29 Dec. 2000, entitled “Method and System for Creating a Theme of a Place to be Used as a Template for Other Places”;
U.S. patent application Ser. No. 09/752,115 filed 29 Dec. 2000, entitled “Method and System for Automatically Accessing, Processing, and Managing the Data In a Place”;
U.S. patent application Ser. No. 09/752,121 filed 29 Dec. 2000, entitled “Method and System for Importing HTML Forms”;
U.S. patent application Ser. No. 09/752,172 filed 29 Dec. 2000, entitled “Method and System for Importing MS Office Forms”;
U.S. patent application Ser. No. 09/752,934 filed 29 Dec. 2000, entitled “Method and System for Identifying and Displaying Information That Is New or Has Been Updated In a Place”;
U.S. patent application Ser. No. 09/752,961 filed 29 Dec. 2000, entitled “Method and System for Providing Task Information in a Place”;
U.S. patent application Ser. No. 09/752,745 filed 29 Dec. 2000, entitled “Method and System for Providing Synchronous Communication and Person Awareness In a Place”;
U.S. patent application Ser. No. 09/752,962 filed 29 Dec. 2000, entitled “Method and System for Providing a Separate Browser Window With Information From the Main Window In a Simpler Format”;
U.S. patent application Ser. No. 09/752,935 filed 29 Dec. 2000, entitled “Method and System for Allowing In Place Editing of Office Documents In a Place”.
The present application is also an improvement upon the following copending, previously filed applications, assigned to the same assignee:
Ser. No. 09/473,745 filed 28 Dec. 1999, entitled “System and Method for Interconnecting Secure Rooms”;
Ser. No. 09/473,630 filed 28 Dec. 1999, entitled “System and Method for Dynamic Management of Web Site”;
Ser. No. 09/473,640 filed 28 Dec. 1999, entitled “System and Method for Presentation of Room Navigation”;
Ser. No. 09/473,098 filed 28 Dec. 1999, entitled “System and Method for Independent Room Security Management”;
Ser. No. 09/477,477 filed 4 Jan. 2000, entitled “System and Method for Dynamically Generating Viewable Graphics”;
Ser. No. 09/477,471 filed 4 Jan. 2000, entitled “System and Method for Dynamic Browser Management of Web Site”;
Ser. No. 09/477,474 filed 4 Jan. 2000, entitled “System and Method for Room Decoration and Inheritance”;
Ser. No. 09/477,469 filed 4 Jan. 2000, entitled “System and Method for Online/Offline Uninterrupted Updating of Rooms in Collaboration Space”;
Ser. No. 09/477,473 filed 4 Jan. 2000, entitled “System and Method for Client Replication of Collaboration Space”;
Ser. No. 09/477,476 filed 4 Jan. 2000, entitled “System and Method for Browser Creation and Maintenance of Forms”;
Ser. No. 09/478,238 filed 4 Jan. 20001, entitled “System and Method for Browser Definition of Workflow Documents”.
The above-identified patent applications are incorporated herein by reference.
1. Technical Field of the Invention
This invention relates to web technology. More particularly, it relates to the creation and use of collaboration sites on the Internet or on an Intranet client/server system and to the graphical user interface used in Internet communications.
2. Background Art
The Internet and the World Wide Web (WWW) provide intra-enterprise connectivity, inter-enterprise connectivity and application hosting on a larger scale than ever before. By exploiting the broadly available and deployed standards of the Internet and the WWW, system users and designers can leverage a single architecture to build client/server applications for internal use that can reach outside to customers, business partners and suppliers.
Collaboration requires simultaneous communication between individuals on a project team. Typically, this has required that the team members work in the same location. Phone and video conferencing has enabled some remote work on the part of team members. Also, because of the growth of the Internet, collaboration using web technologies has been attempted, primarily using electronic mail (E-mail), Internet chat rooms, electronic whiteboards, and conferencing software. The most useful has been E-mail, but this approach results in a large trail or thread of notes as collaboration on a project advances, and these notes have no home or place to reside which is accessible by all team members substantially instantaneously and simultaneously. People often enter such a thread at different points, and such threads are not efficient in coordinating the work of many different people on a team which may include in-house developers and others, such as remote contractors, outside of an enterprise's firewall.
In order for such disperse teams to have the same, or substantially the same, collaboration environment as individuals working in the same physical office, a system is required which facilitates instant messaging, voice conferencing, electronic white boarding, and text and non-text file exchange. Such a system needs to provide a collaborative electronic room, or space, which is easily configured for use by team members without substantial administrative or application development support, and preferably include both groupware and project oriented applications such as shared folders, file exchange, workflow, group calendars, threaded conversations, version control, file locking, file merging, and security.
There is a need in the art for such a system which is easy to set up and which enables diverse and remote teams to become immediately productive in a secure environment. It would be, further, most desirable to allow such a collaborative environment to be set up without administrative support, that is by members of the team itself, using a familiar and easy to use browser user interface. Members of the team, acting with manager or author authority, and using such a browser interface without involving administrative or application development support, need to be able to set up a folder or room for each project element, such as a source code component, with version control, workflow elements, and group calendaring for tracking the project or project element with respect to approvals and deadlines. Such a room needs to receive from team members reports and have them routed to appropriate team members for review, resolution, and approval.
The WWW is a collection of servers on an IP (Internet Protocol) network, such as the Internet, an Intranet or an Extranet, that utilize the Hypertext Transfer Protocol (HTTP). Hereinafter, “Internet” 100 will be used to refer to any IP network.
HTTP is a known application protocol that provides users with access to files, which can be in different formats, such as text, graphics, images, sound, and video, using a standard page description language known as Hypertext Markup Language (HTML). Among a number of basic document formatting functions, HTML allows software developers to specify graphical pointers on displayed web pages, commonly referred to as “hyperlinks,” that point to other web pages resident on remote servers. Hyperlinks commonly are displayed as highlighted text or other graphical image on the web page. Selection of a hyperlink with a pointing device, such as a computer mouse, causes the local computer to download the HTML associated with the web page from a remote server. The browser then renders the HTML into the displayed web page.
Web pages accessed over the Internet, whether by a hyperlink, opening directly via an “open” button in the browser, or some other means, are commonly downloaded into the volatile cache of a local computer system. In a computer system, for example, the volatile cache is a high-speed buffer that temporarily stores web pages from accessed remote web sites. The volatile cache thus enables a user to quickly review web pages that were already downloaded, thereby eliminating the need to repeat the relatively slow process of traversing the Internet to access previously viewed web pages. This is called local caching.
It is an object of the invention to provide a collaboration space application model for creating web applications that are aesthetically pleasing and present the user with a simple interface.
It is a further object of the invention to provide for creating web applications that are instantly created, instantly archived, team and project oriented, easy to use, created, accessed and administered via the Web, reusable, and extensible.
It is a further object of the invention to provide a method and system for creating a place in collaboration space by creating a first place; and saving the first place as a place type template from which other places may be created in collaboration space having the same look and feel.
A method and system is provided for creating a place in collaboration space by creating a first place; and saving the first place as a place type template from which other places may be created in the collaboration space.
In accordance with an aspect of the invention, there is provided a computer program product or computer program element for creating a place in collaboration space by creating a first place; and saving said first place as a place type template from which other places may be created in said collaboration space.
Other features and advantages of this invention will become apparent from the following detailed description of the presently preferred embodiment of the invention, taken in conjunction with the accompanying drawings.
Referring to
Server 100 includes a Domino server 104, HTTP server 106, QuickPlace extensions 108, and open storage 130. Client 102 includes a QuickPlace user interface 110 and browser 112.
QuickPlace open storage 130 includes all the databases and templates that implement the collaboration space. Domino 132 and active directory 134 define the collaboration process. The user interfaces with the system through browser 112. NSF agents 114, 116, Java 118 and LotusScript 120 represent components and templates downloaded from server 100 in support of collaboration space at client 102. All the extensions 108 are keyed off the URL, as will be further explained hereafter.
Notes API 136, Notes designer 138 and client 140, external applications 142, including Java agents 144 and LotusScript 146, are located off of open storage 130. Open storage 130 is storage where a document can be communicated, such that external applications 142 may manipulate it. QuickPlaces, pages, folders, can be created and changed, and data 148 can be imported and exported, using agents in Java 144 or LotusScript 146.
QuickPlace is primarily concerned with representing the collaboration space. Consequently, designers and consultants are able to integrate into that space custom features and data from other applications. HTML forms 122, written using an HTML editor 124, skins 248 (HTML 244 and QP tags), external files written using Java 118, and MS office documents 250 from MS office 228, may be imported to server 100 by dragging and dropping 111 from local storage 502 into an upload control panel 240 in browser 112.
An alternate client 126 and encapsulated place types 128 may be provided from which other collaboration spaces 129 can be created that take advantage of the QuickPlace storage model, providing functionality which can be manipulated using browser 112, including the integration of external technology providing opportunity for deep customization.
Referring to
QuickPlace is built on top of the Domino server 104. In the case of a stand alone installation, a subset of the Domino server is installed. Server 100 also includes HTTP server 106, or the optional MS IIS server 150. QuickPlace extension 108 is where we built most of the collaboration space implementing code exists the server 100. Server 100 also includes a spell checker 152 and a text to GIF converter (Limerick).
Client 102 includes rich text edit control 162, and applet 164 with which to apply various attributes and is a key component of the QuickPlace experience. Upload control 166 is used to attach and upload files, such as bringing in an agent and uploading it to a place. This is also used to bring in an imported HTML form or a different skin. Upload control is implemented to allow ease of use via drag and drop. Java script 118 includes code downloaded to the client to complete the generation of HTML pages.
Referring to
Referring to
Folders 176 add more complexity to the model, but bring a lot of benefit as well. Pages 182 are organized within folders. Two further objects are primarily visible to the designer of the place. And these are forms 178 and fields 180.
Place type 196 is a more advanced object, and is an object from which a place 172 is created. Place type 196 represents the foundation for building true collaborative applications. Everything created in building collaboration space is done in a place 172. Once such a place is created, it can be made a template 266 (
This is illustrated in
Room type 198 is an object provided for creating rooms 174 which are of a given type.
The last two objects illustrated in
Referring further to
Place 172 is represented as a file system directory. So whenever a place called Acme is created, a file system directory 202 called Acme will be instantiated. Within that directory 202, there are a number of objects. Each room 174 is a Notes database 204. Folders 176 are implemented as Notes folders or views 206 depending on what's more convenient for the particular folder.
Pages 182 are a combination of data notes, forms and sub-forms 208. A member 190 is a data note 190 in a context room 174. Forms 178 and fields 180 are data notes. Place type 196 is a directory* 216 that contains all the rooms 174 that make up that place type. A room type 198 is a template 218. Skins 200 are a note 220 and PlaceBot 184 is an agent 222.
Developers familiar with the Domino Object Model (Domino OM) will be able to leverage their existing skills when developing on the QuickPlace platform. “PlaceBots” for example are actually implement Domino Agents, and it is possible to create and test them on Domino Databases. Within the QuickPlace object model (OM), however, there are some divergences from the Domino OM. For example, QuickPlace forms 178 are not the same as Domino Forms. QuickPlace forms more closely resemble Domino Documents, because they are created using a Domino form, and contain a Domino text field with a value of “h_Form”. The value of “h_form” tells QuickPlace that this Domino document should be rendered in a browser as a QuickPlace form 178.
This structure provides flexibility for Web applications with less complexity than if Domino Forms were used. For example, in a default QuickPlace, EL user can create a new QuickPlace form 178. The user chooses which fields to include in form 178, in what order they should appear and what text and or graphics should appear near them. To create this sort of instant structure on the Web using Domino Forms would be very complex indeed. QuickPlace has extended this concept of being able to use HTML to define forms 178 by enabling the creation of custom QuickPlace forms using imported HTML 122. These Forms not only make use of Web authoring technologies such as Java Script, but also have the back end support of Domino. This back end logic is implemented via tools such as PlaceBots (Domino Agents) 184. This means that forms 178 have the ability to not only to define the look and feel of visible parts of an application, they also have the potential to initiate workflow and many other powerful automated features.
QuickPlace forms 178 have been optimized by stripping away many of the Notes features not required when used on the Web. A another advantage of this structure is that it enables the use of Web authoring tools to extend the objects. For example, with respect to QuickPlace forms, it is possible to modify forms using XML, Java Script and HTML and any other Web tools. Knowledge of Java Script and HTML are more common than Domino Designer skills, thus making the QuickPlace a very open platform. Some parts of the QuickPlace OM implement Domino/Notes functionality in different ways to a standard Domino application. For example, QuickPlace uses Domino's security and authentication model as a basis for its management of access to QuickPlaces. However, instead of primarily utilizing the Domino Directory, QuickPlace also uses a Contacts1.nsf database for each QuickPlace.
Referring to
The highest level of the model is the QuickPlace Server 170. Within server 170 are all of the QuickPlaces 172 as well as the resources they access to finally render Web applications.
This
QuickPlace uses notes for many of its objects 182, 190, 178, 180 and 200, so that objects in the Place can be organized more easily. Table 1 sets forth the QP objects and their Notes/Domino equivalents. As an example of how design Notes are implemented consider the Table Of Contents (TOC). The Table Of Contents is a list of pages, folders and tools such as the Customize Area. Domino Folders may be listed using a link document, or Note.
QuickPlace Server 170 is a file directory containing all Places and Resources. The Domino equivalent is a file directory 202 named “quickplace”. This identifies the main folder 176 for a QuickPlace server 170. If the QPServer 170 is running as a stand alone, this folder will be in the QuickPlace data folder. For example
D:\QuickPlace\Data\quickplace.
If the QPServer 170 is running on top of a Domino server the folder will be the Domino Data folder. For example
D:\Lotus\Domino\Data\quickplace.
To locate QuickPlace Server 170 in PlaceBots and get access to all of its databases, a LotusScript method GetDbServer is executed together with a test that the Path to databases starts with “QuickPlace”.
Place object 172 is a directory in the “QuickPlace” directory grouping resources for a Place. The Domino equivalent is a file directory bearing the name of the QuickPlace. Place object 172 is a directory that brings together a Place for organizational purposes. It also identifies the NSFs 114 as belonging to the place 172 by bearing the name of the QuickPlace. As distinguished from a place object 172, the main room 174 in a QuickPlace is a database called Main.nsf. Place object 172 groups and identifies the Main.nsf resources for the Place and any subrooms 194 in the Place. Place object 172 contains several files. There is a Main.nsf, Contacts1.nsf and a Search.nsf file. If the QuickPlace has a Subroom 194 there will also be an NSF file with its name starting with “PageLibrary”. Each of these page library files is a Room 174.
The place object in PlaceBots 184: place object (directory) 172, contains the databases which form a place. When writing PlaceBots, one can search for this directory by using the name of the QuickPlace. In this directory will be found all the databases will belong to that place 172. This file directory's name is the name of the QuickPlace. For example, if the QuickPlace is called “Millennia”, this directory has the following path within the QuickPlace server 170:
\millennia
To find the place object 172 for the Millennia Place in LotusScript the script procedure of Table 2 may be used:
Room object 174 is the main container for a Place, containing a collection of pages and tools. The Domino Equivalent an NSF Database. The room 174 is the main container for a QuickPlace's content. For example, when using the Millennia Place, most of what is seen is contained in the Room object. The Room object is always called Main.nsf, and holds folders 176 and pages 182 for the QuickPlace, as well as managing links to any subrooms 194 in the place object 172. Room object 174 uses elements held in other databases. For example many of the standard images QuickPlace displays are in a resources object (not shown). Each room 174 has its own security and authentication, and the information required to do this is contained in databases such as Contacts1.nsf. A room 174 breaks down a place 172 into smaller areas to help define structure. Each room 174 has its own security and authentication. This allows separate user groups. It also means that subrooms 194 can be created for separate projects, forming a separate shared space. The room object 174 then forms a common entry point where shared resources can be stored.
The room object in PlaceBots: to locate a room 174, one looks in the main QuickPlace Server 170 directory, then looks into the room object (a directory bearing the name of the QuickPlace), then looks for a database called “Main.nsf”.
Returning to previous LotusScript example of locating a Place 172 (Table 2), the match string can be extended from
“quickplace\millennia” to
“quickplace\millennia\main.nsf” to find the room object 174, as set forth in Table 3.
To access elements contained in a room 174, the views and folders 176 in the room are accessed. For example to find the elements visible in the Table Of Contents (TOC), the “h_TOC” view is used.
The Room object 174 in HTML is visible in URLs as the “main.nsf”. To access room object 174 most easily, a relative path is used from the current object if it is in the same Place 172. For example, when creating a URL link from a subroom 194 to a room 174, the URL begins as follows:
<a href=“../../Main.nsf/
where the “dot dot slash dot dot slash” syntax is a part of the URL, not an abbreviation for this example. Using this relative URL makes the URL more robust. In other words, this URL can be used to find the (Main.nsf) room 174 for any place 172.
Room fields 180 used to define rooms 174 are set forth in Table 4.
A folder object 176 is an object for indexing content, grouping related pages 182, and dividing a room 174 into sections without imposing new security. The Domino equivalent is Notes folder or view 206, and Notes folders 206 have three functions. For the user, they provide a logical grouping of related documents. This makes it easier for the user to find documents, and allows people with a shared interest to work an area of a QuickPlace. The other way of using folders is in the user interface, or “User” folders. Within user folders there are seven different types:
1. Standard List
2. Headline
3. Slide Show
4. Response List
5. Ordered List
6. Table Of Contents
7. Index
Folder types 1 to 5 are all available as styles for new, custom folders. From the a site manager's perspective, a Folder allows a QuickPlace to be divided into areas for separate groups of people, without having to be concerned about access control which would be necessary if a Subroom 194 were used.
Fields include the following:
The third way that folders 176 are used is to allow developers to locate elements in a QuickPlace. To a developer, folders are indexes that allow look ups, therefore giving programmatic access to elements.
When any page renders in a Browser, the time it takes to render is directly dependant on the amount of information to be downloaded. The amount of information required to render a Folder is less than for a Page. When Pages appear in Edit mode, there is yet more information required to render it. Therefore, the quickest load time for a QuickPlace by first using a folder 176 as the first page the user sees when upon selecting a place. Once users have visited a folder 176, a subset of the resources used to render a page 182 will already have been downloaded. The folders used by developers are slightly different to than the folders users would use. The h_Index lists the published pages in the Place and appears as the standard index of a Place, and the h_TOC is the table of contents list.
Some of the folders in look ups by developers are set forth in Table 5.
The Place Object in PlaceBots: Internally, default QuickPlace Folders have readable titles. For example the response folder discussion” has the internal name of “h_Discussion” in the “h_SysName” field. A new response list style folder is called “SchwatzRaum” (“chat room” in German). The internal name of the SchwatzRaum Folder is: “h_F49791727035ACD1C12569510063087C” (which means (“h_F49791727035ACD1C12569510063087C” in German). This unique identifier can be used in PlaceBots to locate the Folder. A lookup can be done in the “h_Folders” view of a QuickPlace to find the readable name of the folder. Another solution is to retrieve the name of the field by accessing the value in the h_SysName field. The Table of contents and the Index are special user Folders 176. Only one TOC and one h_Index exists per Room 174 or Subroom 194. They exist from the moment the Place or Room is instantiate, and change them.
The following Fields are used to define data notes that render as Folders. Folders exist in a visible form within a QuickPlace. In other words they can be viewed by opening the NSF file in the Notes Client or Domino Designer. In conjunction with this view, a data note exists, providing information about that Domino View or Folder. Table 6 lists the fields are contained in the data note and provide information about the Domino View or Folder.
A form object 178 is a document used to create new QuickPlace content. The Domino equivalent is a data note of type “h_Form”. Form object 178 is a resource used to create, manage and display content, therefore defining the schema of the application. Forms contain fields to hold data, therefore creating and displaying content. Forms can also contain scripts within them to provide logic within the Page. For example, a form can contain form validation to make sure that a field contains only numbers. Forms can also initiate processes outside the page. This is done by creating a PlaceBot 184 and associating the PlaceBot with a Form 178. PlaceBots 184 are not contained by the Form but there is a association between them.
Forms are created with the Domino Form “h_PageUI” with the field h_Type set to “h_Form”. New forms 178 with custom structure and logic can be created by room managers.
Table 7 sets forth the fields 180 used to define the structure of a form 178.
Field object 180 is used to construct (HTML formatted) input fields in forms 178. The Domino equivalent is a Data note of type “h_Field”. Fields are constructed from the Domino Form “h_PageUI” with a the field h_Type set to “h_Field”.
QuickPlace field object 180 defines the structure of the container, not the content. The values contained in a page 182 are contained by the page, not the fields 180. The h_FieldType attribute to a field 180 determines what sort of field it is. This determines what the field will do when it is rendered in a browser. For example, a field 180 of type h_DateControl will provide the user with a date picker widget.
Domino fields are used to define the attributes of QuickPlace fields 180 are set forth in Table 8. QuickPlace fields 180 are drawn to the screen as HTML, they are not created by a Domino Field in a Domino Form.
Page object 182 is a basic building block for content. The Domino equivalent is a data note, form and subform. Pages form the basic units of content, relying on the structure of QuickPlace to create, manage and render them in a Web browser. It differentiates structure and content cleanly. Notes structural elements such as Forms Views and so on provide structure, whereas Notes Documents provide pure data content. In the Domino environment the division between structure and content becomes blurred. This is because when the data in a document is being represented in a Web browser, it is possible to use the data to format itself using HTML. The data is able to start defining structure by creating HTML links, tables, references to images and so on. In the QuickPlace OM, the same is true. Pages can be created in a number of ways. Table 9 sets forth the fields used for defining page objects.
Page Object in LotusScript and Java Script: developers wanting to customize pages 182 will generally want to manipulate the page's field 180 values. Fields existing in a Page are generally rendered to the HTML document in the background as Java Script variables. They are then visibly rendered via document.write( ) functions. If a field exists, it can be accessed in the browser via a variable with the same name as the field.
The PageBody Field holds the main content or “body” of the page.
Table 10 sets forth the fields 180 used to define page 182 documents in QuickPlaces.
The Java Script “document.write” method is used when using the PageBody to write out HTML content in a QuickPlace page. This field can be printed onto the screen via a document.write (PageBody) method called in a QuickPlace document. The following is an example of using this technique.
In a Placebot, write the contents of the document into the PageBody field. If the PlaceBot has not run, or not run correctly, the PageBody field will be empty. If the document is displayed in a form where the PageBody Java Script variable is not declared, an error will be reported. To avoid an error through an undefined variable, use the “typeof” operator. This test assigns a message string to the sPageBodyMessage variable and prints that instead of the PageBody. To customize this message, the text in quoted on the PageBodyMessage line is changed. Then the following is included in the HTML document:
Page Object in HTML: some of the most commonly referenced Java Script variables in Pages are set forth in Table 11.
Using Notes name format in pages can be done with the following Java Script Function:
This Java Script will return the string “Doug Mudge”
A PlaceBot object 184 is a Java or LotusScript Domino Agent, used to create or manipulate QuickPlace objects automatically. Domino Equivalent: Domino Agent.
For Java and LotusScript programmers, the PlaceBot is the main way of implementing sophisticated functionality to a QuickPlace. Within the bounds of an HTML document, industry standard authoring tools such as HTML are used. To make links between Objects and manipulate QuickPlace Objects, PlaceBots are used. The PlacelBot object is further described in copending U.S. patent application Ser. No. 09/752,115.
A theme object 186 is a group of files which defines the look and feel of a QuickPlace. The Domino equivalent is a group of data notes.
Themes are a mechanism for determining the layout and appearance of a QuickPlace. They also help introduce functionality, and although not their primary function, some content. There are two types of themes 186 in QuickPlace. User defined or custom themes and default themes.
The subroom theme object 188 is a subset of themes 186 in a QuickPlace. The Domino equivalent is a data note. By default, subrooms 194 inherit the theme 186 being used by the (main) room 174. Only when the theme being used in the subroom 194 has been modified, does it act independently of the room 174.
A member object 190 is a data note listing a user in the Contacts1.nsf. The Domino equivalent is a note in contacts1.nsf. Members 190 are records specifying user-access to a room 174. A member note contains information about a team member of a QuickPlace. In addition to this data, the member must be listed in the access control list (ACL) of main.nsf and in a group in names.nsf to pass authentication.
Table 12 sets forth the fields 180 used to define members 190.
Table 13 sets forth the fields 180 used to define Groups.
A subroom member object 192 is a subset of entries in the main room 174 of a QuickPlace. The Domino equivalent is a Data note in contacts1.nsf. Subroom member 192 has a similar structure to a room member 174, but specifies user-access to the SubRoom. These SubRoom members 192 are a subset of the (main) room 174 members list. This means that to grant access to new users, they must first be added as readers (or greater) in the main room 174.
A subroom object 194 is a container within a QuickPlace with separate security to main Room. The Domino equivalent is an NSF Database. Subrooms 194 are similar in structure to Rooms and are used to create discreet meeting places for subset of the Members in a Place.
The subroom object in PlaceBots: To locate a room, look in the main QuickPlace Server directory, then look into the Place Object (a directory bearing the name of the QuickPlace). The Subroom will be named “PageLibrary” followed by a 16 digit hexadecimal time stamp number, such as “0123456789ABCDEF” then the “.nsf” suffix. By way of example, the following script looks for a Subroom to the Millennia place:
The Instr method has been used to look for this database, down to the PageLibrary part of the string, because it is difficult to know what the 16 digit number will be.
Page Object in HTML: To create URLs to reference Subrooms, the URL is built in the Main Room using either the “h_Area” view or the “h_TOC” view to create the path. This View contains the “h-LocDbName” field as the first sorted column.
A resources object (not shown) is database of shared resources, having as its Domino equivalent NSF Database. It serves as a centralized container for resources required in all QuickPlaces on a server. Images, layout files and fonts are stored in this database. For example resources such as the button that appears beside the simple search image “Go.gif” is stored in this database. The easiest way to find items in this database is by scrolling through the h_SystemNameView. A dummy form may be used to view such elements.
In Tables 14 through 18, fields and Java Script variables in the h_PageUI form are set forth. These include general fields which can be customized for each layout, fields to define publishing status, fields for defining locations, fields for defining security, fields for defining workflow status, fields for defining calendars, respectively.
System objects have special meaning depending on the type of object. The following tables describe fields in various QuickPlace Object types.
While much of a QuickPlace can be customized via a browser, there are some parts of QuickPlace which can only be customized using a Notes Client and or the Domino Designer.
Changes that can be made via a browser, using Web authoring tools such as an HTML editor relate more to the user interface. For example, editing a skin can be done using an HTML editor. Changes made to QuickPlace Objects are done through the Notes client and in Domino Designer. For example, inspecting and customizing the images appearing in default QuickPlace pages must be done via the Notes Client.
Building URLs in a QuickPlace is an important issue, due to the fact that QuickPlace is a browser based application. Understanding QuickPlace URLs is also a good way of understanding the object hierarchy in QuickPlace. The relationship between URLs and the QuickPlace Object model flows in both directions. Understanding the structure of URLs helps understanding the QuickPlace Object model. Conversely, once the QuickPlace object model is understood, how to use URLs to manipulate a QuickPlace becomes apparent.
URLs in QuickPlace use the same structure as in Domino. Domino URLs allow locating documents by using the key value of the first sorted column of a view, then generate a URL to link to a document using this key. Once the documents are located, they are not always opened in the browser. Sometimes they are read and their contents exposed and used by other objects.
An example of locating a file without opening it is when a QuickPlace skin accesses a Java Script LSS file. The user never sees the LSS page, but its contents are used by the visible page to render objects and perform functions. To locate a document in Domino, the initial part of the URL is pointed to the host server, then the database containing the required document. The next part of the URL must point to a view with the first column specified as being sorted. This first, sorted column becomes the key column. Then a URL is used to open the document, as in the following example:
The structure of URLs in a QuickPlace is the same as in any Domino database. QuickPlace objects are quite often referred to via relative URLs. For example, to reference a page that has been created, the following syntax is used:
Many QuickPlace objects in QuickPlace have internal names beginning with “h_”. This is refers to the internal name of QuickPlace which is “Haiku”. To reference images, Java Script library files or files other than pages, the following syntax can be used . . .
The following section deals with the issue of using images in QuickPlace. Referring to
Described hereafter are techniques involved for fully automated importing procedures within QuickPlace. An example of an automated importing would be when creating and uploading a Microsoft Word file 250. When this is done the images are imported without any interventions.
There are also instances where some developer intervention is required, such as when creating a Skin file 230, or writing an importable HTML file 254, or referencing files required to display the results of PlaceBot and so on.
Creating skin files are fully described hereafter in connection with themes.
Three methods are used for importing images. These are:
Method 1: Provide a URL to an image and let QuickPlace upload the image. This method is used when creating skins and imported HTML documents that do not use Java Script to reference images.
Method 2: Create a URL, have QuickPlace upload it, then reference it using HTML or Java Script. This method is used when rendering image using Java Script.
Method 3: Manually upload images into a document and reference them via URLs from a separate document. This method is used if the image is very large and it desired to have the user's browsers be able to cache the image; or if the image is referenced within a Java Script function (QuickPlace does not import images when they appear within Java Scripts); or the image is referenced within a PlaceBot which creates new pages.
The solutions selected for a particular application may be a mixture of all three. For example:
Referencing Images: Method 1. Create a Skin file or HTML imported page and let QuickPlace import it. This works in skins and imported HTML, and is the easiest way of importing images into Skins and HTML Pages. When a valid link to an image within an HTML page or a Skin is created, QuickPlace will upload it automatically when the Skin or HTML file is uploaded. For this to work, a valid URL must be created. This may be done as follows:
Referencing Images: Method 2. Prompt QuickPlace to import the file into the current document, then reference the file using Java Script. This method is the most efficient method to use when referencing an image via a Java Script function (in a Skin for example) or when updating a document via a PlaceBot.
To force QuickPlace to upload the image, a valid URL to the image at the top of the page must be created. By rendering it in a 1 pixel×1 pixel size, making it too small to see, the image is still uploaded, but the user will not notice the image. The images must also be named when they appear in their 1×1 pixel format. By using this name, the image is made available to Java Scripts below it on the page. This is done by adding the image to the source code near the top of the page. To force QuickPlace to upload the image, it is rendered in HTML format, then the uploaded image referenced in the Java Script.
In accordance with a preferred embodiment of the invention, skins provide (1) a method for controlling the layout of QuickPlace user interface components, and (2) a method for controlling the style of the Quickplace user interface. Layout defines where components should appear, and look defines font, color, and background images.
Referring to
Each component of a QuickPlace user interface is individually addressable and placed on an html page 244. A style page 246 enables the user to define look by dragging and dropping the html pages and style sheet to the output control 240. A developer can code 256 an html page 244 that addresses the QuickPlace user interface components and style sheet 246 and upload to QuickPlace 172 to convert them into a skin 260.
In accordance with the preferred embodiment of the invention, html pages and style sheets are rendered responsive to QuickPlace tags to allow an end user to import these into a place and instruct that place to use these to instantiate the user interface.
In accordance with a further embodiment of the invention, a QuickPlace may be converted into a template from which new QuickPlaces may be created. In accordance with this method, a QuickPlace is created, including a configuration of membership, forms, PlaceBots and skins to match the needs of team project. The resulting QuickPlace, an entire web site collaborative space, then is converted into a template from which new QuickPlaces can be created with the same configuration.
A skin provides the layout, and look and feel of a QuickPlace. Layout refers to the positioning of components on a page, and which to include. Referring to
A browser user experiences skins at the QuickPlace user interface. That is, the QuickPlace is presented through a skin, which define the layout of components of a page, and its look and feel (including styling of colors, fonts and images).
There are several audiences for skins (aka, themes). (A skin refers to the user interface embodiment, and a theme to the developer kit embodiment of the same object.) First, end users can choose a theme from a gallery of themes in the UI, allowing them to choose a visual site design to express identity of the team or project, thus to choose a look and feel that suits the work to be done. Second, developers may use a theme to rebrand a QuickPlace for an in house application; to integrate the QuickPlace with other network resources by including a link to a support page; and to integrate QuickPlace seamlessly with an existing web site design.
Thus, skins provide a site template which allow developers to provide themes for embedding of a QuickPlace in a larger web based service. QuickPlace can be used as a team collaboration component of a web site.
A skin or theme is implemented as some HTML code with QuickPlace HTML tags, and a style sheet (CSS, or cascading style sheet), including five HTML layouts and one CSS. In accordance with the preferred embodiment of the invention, skins not only deal with look and feel, but adding links to other resources are used as a development tool both by end users and developers.
Technically, a skin has five designer layouts comprising a skin group which define different display modes supported by QuickPlace, including (1) page read mode, (2) page edit mode, (3) folder list/response, (4) folder headline, and (5) folder slide show.
In accordance with the invention, developers are provided an underlying, server-based architecture which allows caching and dealing with themes. The five layouts and their interaction with the style sheet provide a custom theme user interface, flexibility is defining and selecting user specific themes and client specific themes, decorating by choosing a them, and decorating by tweeking a theme.
A user can choose a theme from a gallery of themes built on top of an underlying themes architecture, which provides the users the ability to subsequently modify the HTML from the user interface. Also, an administrator of a QuickPlace can build customized user interfaces to a corporate style. Tweeking allows users to change basic properties like fonts and colors through a user interface to specific classes in the style sheet. Such a user selects colors and fonts, for example, and QuickPlace feeds those selections into the theme style sheet.
Thus, the underlying themes architecture enables a very simple user interface enabling end users selection and tweeking of themes.
Custom themes provide a powerful user interface to developers. A web developer with HTML and CSS skills can learn to create a theme. A theme is simply HTML and support for Java Applets (logic that processes information and conditionally displays one or a different picture depending upon some decision, such as user group, for example). A custom theme is a simple UI, and upload control, which allows importing of pages into QuickPlaces, has been enhanced to allow developers to pull a theme into a QuickPlace using HTML tags that refer to different components in the layout. The theme is created at the server by QuickPlace, and the user can use the QuickPlace UI at the browser without learning new skills beyond existing web skills.
A user specific theme are used by a program at the server which, upon detecting the identity of the browser user, selects the theme for that user. An example would be an accessibility theme tailored to the reading machines that blind people use. In such a case, the server would provide to the browser a user interface which is nicely structured with content that reading machines can use.
A client specific theme has application, for example, with a personal computer or palm pilot, by which the server provides a PC or Palm specific theme. A theme specify XML content, which allows for selective processing of the QuickPlace: a theme skin in html can act on that content differently. xml allows for logic to be applied to the content of the QuickPlace.
Tweaking and choosing themes use existing browser functions, with a layouts architecture mapped to skin components. This allows for tweaking of custom themes. Each piece of the user interface is implemented as a component. The style sheet controls style, and tweaks only modify the style sheet (not the layout).
Referring to
In step 280, the server determines if the selected skin is a skin group 286, 288 cached in memory 284. If so, in step 292 the selected skin group is processed to produce the HTML, including picking the skin and processing the tags, which are then sent to browser 112.
If in step 280 it is determined that the required skin is not cached, in step 282 the server accesses database 276 to retrieve the skin group, checking the current database and parents in order (through nested databases in a room). If the skin is not located in database 276, server goes to resources 278, which are shared across QuickPlaces. Upon finding the skin group, in step 290 it is cached to memory 284, and processed in step 292 as discussed above.
For the style sheet, the processing is a little different. The QuickPlace server builds four pieces: common style sheet, skins style sheet (from
See print screen version of table of contents of devzone description of skins.
As previously noted, a QuickPlace theme controls the look and the layout of a QuickPlace—that is, its fonts and background colors, how an element looks when it is selected, where the navigational controls appear, and so on. When creating a QuickPlace, a theme may be selected by choosing from a gallery of predefined themes, an existing theme may be selected, or a new theme created.
Using a custom theme can give a new QuickPlace a strong brand identity, designing it to look like other corporate sites, or supplying additional functionality as well as a unique look.
Themes are implemented using the QuickPlace skins architecture and are defined using HTML 244, so to customize a theme, the HTML 244 is created or modified using any HTML editor 124 and then the modified files uploaded to QuickPlace. QuickPlace provides a set of custom HTML tags to use to define the elements in each layout. A skin, therefore, comprises HTML and QP tags.
When customizing a theme, all of the power of HTML is available to add functionality to a QuickPlace. Following are some ways to enhance a QuickPlace using custom themes:
When a theme is customized, it may be kept as part of a template from which to build similar QuickPlace applications. To do this, the QuickPlace is saved containing the custom theme as a custom Place type, which can then be used for creating new QuickPlace applications.
Each theme is composed of a group of layouts that define the appearance of specific QuickPlace components. For example, the layout for a page differs from the layout of a folder, but they will probably share some style elements as part of a common theme. Table 18 sets forth the layouts and style sheet of a QuickPlace theme.
In most cases, a single theme can be used to customize the look of page, list folder, and slideshow folder. Additonally, JPEG or GIF graphic files can be imported to represent a theme in the Custom Theme Gallery.
Table 19 shows the components that can be customized for each layout.
In accordance with a preferred embodiment of the invention, a QuickPlace theme is customized by beginning with the theme closest to what is desired, extracting the HTML source files for the theme, customizing them, and uploading the modified files as a custom theme.
This process is as follows, from the QuickPlace user interface:
To view or modify the source code for a layout, the file is dragged to the desktop and opened in an HTML editor. If using an editor such as HomeSite that supports in-place editing, right-click a file name and choose the editor from the right-click menu. This opens the editor within QuickPlace. Changes you made to the HTML file are automatically uploaded when saving and exiting the editor.
The original source file can also be modified in an HTML editor, and the Reload button clicked from the Edit Theme page to reload the modified file.
To create a custom theme, the existing layout files are modified or new layout files created. In either case, a name is assigned and the layout files upload. The procedure is as follows:
As a theme is developed, QuickPlace can take the code from one layout and apply it to all layouts for which a file has not been explicitly supplied. This is a shortcut for applying a common look and feel to multiple layouts.
This feature also allows one to develop a custom theme in stages, replacing generated layouts with custom files as the theme progresses.
To generate layout files based on a layout:
The HTML tag that controls the style and placement of elements in a QuickPlace layout is the <QuickPlaceSkinComponent tag>. The basic syntax for the <QuickPlaceSkinComponent> tag is as follows:
Table 20 sets forth skin component tag attributes.
The <QuickPlaceSkinComponent> tag identifies a element or piece of the QuickPlace user interface for which to modify the look and placement. Customize the look and functionality of a QuickPlace application is done by modifying various elements and adding HTML or Java Script within the <QuickPlaceSkinComponent> tag.
The attributes PrefixHTML, PostfixHTML, Emptyformat, and Delimiter work together to help control what displays in a particular context. For example, an HTML string may to offer a set of instructions that go with a set of action buttons. When the action buttons are hidden, the text should be hidden as well.
This example defines the layout and style of a Table of Contents.
Many of the components will contain a list of values, such as the items in a Table of Contents. In these cases, the HTML tag <Item> within the <SkinComponent> tag is used to iterate through the values in a list.
Syntax
The attribute describing the HTML link can take one of the following forms:
T <Item> tag is used to select a value in a list. The attribute for the value identifies all or part of the HTML link that describes a particular value in a list. Use the class attribute to add styles defined as a class in an associated style sheet.
This example defines the look and style of a Table of Contents.
Because the Page, ListFolder, and Slideshow layouts share so many common components, one HTML file that applies styles to these three layouts can be created. HTML for the Slideshow Folder is created, which contains the superset of components used in the three layouts. To control how the non-applicable components display for a layout—for example, the Jump component for the Page layout, and the AuthorAndModified and Revision components for the ListFolder—various results are achieved by setting the emptyFormat, prefixHTML, and postfixHTML parameters.
For example, to have the empty components occupy the same vertical space as they do when in use, set the parameter as follows:
emptyFormat=“ ”
By placing each component in a separate table row, the component's row “collapse” when it is empty, so that it occupies no space. Given that the prefixHTML and postfixHTML parameters are not output when the component is empty, these parameters can be used to provide the following table structure:
emptyFormat=“ ”
prefixHTML=“<tr><td>”
postfixHTML=“</td></tr>”
Referring to
A standard default style sheet is always output with any theme, so that one need only to specify the selectors that are to be changed. Undefined properties will fall back to those defined in the default style sheet.
Tables 21 through 26 describe Style Sheet (CSS) Selectors.
In accordance with the preferred embodiment of the invention, every new QuickPlace created gets its own directory under the QuickPlace master directory. The name of that directory is same as the name of the QuickPlace. Each additional room in the QuickPlace is another file (.nsf) in the QuickPlace directory. During the QuickPlace server installation, the default QuickPlace (also called the “Welcome” QuickPlace) with the name of QuickPlace is automatically created. This is the entry point to the QuickPlace server including the server administration.
For example if Millennia is the a current QuickPlace, then the basic infrastructure of the Millennia QuickPlace resides under
\lotus\domino\data\quickplace\millennia
(on Domino server—given that
\lotus\domino\data
is the data directory) or
\lotus\quickplace\data\quickplace\millennia
(on stand-alone—given that
\lotus\quickplace
is the QuickPlace installation directory).
When QuickPlace server is installed, the “Welcome” region or the “Administrator's Place” is pre-configured to allow an entry point to the QuickPlace server. An administrator can then administer the newly installed QuickPlace server from this entry point. This so called administrative QuickPlace resides under the QuickPlace directory which in turn is under the data directory. For an example it is
c:\lotus\domino\data\QuickPlace\QuickPlace
when installed under Domino, and
c:\lotus\QuickPlace\data\QuickPlace
when in stand-alone mode. It contains the following files: Main.nsf, Contacts1.nsf, CreateHaiku.nsf, Admin.nsf. The templates for these Domino databases reside in the directory named AreaTypes. The “Welcome” page may be configured to suit the needs of an organization.
Some QuickPlaces can be reused over and over again. For example, a QuickPlace to track a project. To avoid tailoring each QuickPlace from scratch, popular QuickPlaces can be saved as templates called Place types in the QuickPlace environment.
Referring to
Referring to
The security can be controlled at two levels: (1) from the server's administration perspective—Managing the QuickPlace server; and (2) from each QuickPlace's perspective—Managing a QuickPlace.
A server administrator can restrict who can create a new QuickPlace on the server and also who can administer the QuickPlace server. The SSL encryption can also be controlled by the server administrator. The SSL encryption is effective server wide and cannot be controlled at a QuickPlace level. All this can be accomplished via security screen. At the QuickPlace level, the administrator can control who can read the information, which users can create the information, and who can administer the particular QuickPlace. Anonymous allows everyone access without authentication.
An existing QuickPlace may be used as a model, or template, for a new QuickPlace. A QuickPlace used as a template for a new QuickPlace is called a Place type. For example, suppose a QuickPlace named “Meeting Place” is created and decorated that includes two pages, a folder called Issues, and an inner room. When Meeting Place is designated as a Place type on the QuickPlace server, users with the proper access can create one or more identical copies of Meeting Place, each including copies of the two pages, the Issues folder, and the inner room in the original Meeting Place. If Meeting Place is set up to allow it, a user who uses the Meeting Place Place type to create a new QuickPlace can then modify the new QuickPlace just as they would one they created “from scratch.”
To create a QuickPlace using a Place type, a user clicks Create a QuickPlace, selects the name of the Place type from a list, and enters the name for the new QuickPlace, a user name, and a password. A manager of a QuickPlace designated as a Place type may limit the types of changes QuickPlace creators can make in QuickPlaces based on that Place type. For example, the manager of a QuickPlace called Marketing Projects could dictate that the Decorate options not appear in any Place type based on the Marketing Projects QuickPlace.
In accordance with a preferred embodiment of the invention, collaboration space users may:
To create a Place type based on a QuickPlace on the current QuickPlace server:
Referring to
A Place type description is created as follows:
In the dialog box that appears on the screen, choose the folder that contains the image file to use, and then select the name of the file.
In the dialog box on the screen, click Open.
If the Web page that contains the detailed information is on the current QuickPlace server, enter an abbreviated address that begins with a/(forward slash). For example, if the current QuickPlace server is called TestServer and the address /QuickPlace/acme/main.nsf is entered, the address will be interpreted as
One can display the name and address of the QuickPlace on which an existing Place type is based. If a description is provided for the Place type, the description appears when displaying source information for a Place type. One cannot display source information for the default Place type. The default Place type is the Place type QuickPlace installs automatically when installing QuickPlace. The default Place type defines the structure of all QuickPlaces on the server if no user-created Place types exist on that server.
Editing the Description of a Place Type
One can edit the description 494 of an existing Place type; specify a new image file 496 to display next to the Place type name that appears when a user clicks Create a QuickPlace; and change the link 498 users can click to display a detailed description of the Place type. The description of the default Place type QuickPlace installs on the QuickPlace server cannot be edited.
One can hide the name of a Place type in the list of Place types users see when they click Create a QuickPlace, for example, if experimenting with the contents of the Place type and not yet ready to make it available to QuickPlace creators. The word “hidden” appears next to the name of the Place type in the list of Place types seen as the QuickPlace server administrator.
If the manager of a QuickPlace on which a Place type is based changes that QuickPlace—for example, by adding a room to the QuickPlace—the Place type can be updated to reflect those changes.
One can use operating system commands to copy a Place type from one QuickPlace server to another. A Place type consists of a set of Notes database files (.NSF files) in a subdirectory of the AreaTypes subdirectory on the QuickPlace server. Suppose, for example, QuickPlace is installed on drive C together with a Place type called Rapid Response. The NSF files for Rapid Response would be stored in one of the following locations, depending on the type of QuickPlace installation:
If operating system commands have been used to copy files for a Place type to the Place types directory on the current QuickPlace server, that new Place type can be added to the list of Place types on the current server. One sees the list of Place types upon signing into the current server as the server administrator and clicking Place types in the sidebar. The new Place type also becomes available to QuickPlace creators until or unless the name of the Place type is hidden.
Add a Place type copied from another server to the list of Place types on the current server, as follows:
When one deletes a Place type, QuickPlace deletes the Place type from the QuickPlace server and removes the name of the Place type in the following places: in the list seen when a user signs into the current server as the server administrator and click Place types; in the list a QuickPlace creator sees when he or she clicks Create a QuickPlace. One cannot delete the default Place type.
It is an advantage of the invention that there is provided a collaboration space application model for creating web applications that are aesthetically pleasing and present the user with a simple interface.
It is further advantage of the invention that there is provided a method and system for creating web applications that are instantly created, instantly archived, team and project oriented, easy to use, created, accessed and administered via the Web, reusable, and extensible.
It is a further advantage of the invention that there is provided a method and system for creating a place in collaboration space by creating a first place; and saving the first place as a place type template from which other places may be created in collaboration space having the same look and feel.
It will be appreciated that, although specific embodiments of the invention have been described herein for purposes of illustration, various modifications may be made without departing from the spirit and scope of the invention. In particular, it is within the scope of the invention to provide a computer program product or program element, or a program storage or memory device such as a solid or fluid transmission medium, magnetic or optical wire, tape or disc, or the like, for storing signals readable by a machine, for controlling the operation of a computer according to the method of the invention and/or to structure its components in accordance with the system of the invention.
Further, each step of the method may be executed on any general computer, such as an IBM System 390, AS/400, PC or the like and pursuant to one or more, or a part of one or more, program elements, modules or objects generated from any programming language, such as C++, Java, Pl/1, Fortran or the like. And still further, each said step, or a file or object or the like implementing each said step, may be executed by special purpose hardware or a circuit module designed for that purpose.
Accordingly, the scope of protection of this invention is limited only by the following claims and their equivalents.
Number | Name | Date | Kind |
---|---|---|---|
5894554 | Lowery et al. | Apr 1999 | A |
6052730 | Felciano et al. | Apr 2000 | A |
6070185 | Anupam et al. | May 2000 | A |
6081788 | Appleman et al. | Jun 2000 | A |
6151020 | Palmer et al. | Nov 2000 | A |
6230185 | Salas et al. | May 2001 | B1 |
6233600 | Salas et al. | May 2001 | B1 |
6278449 | Sugiarto et al. | Aug 2001 | B1 |
6314408 | Salas et al. | Nov 2001 | B1 |
6317777 | Skarbo et al. | Nov 2001 | B1 |
6401085 | Gershman et al. | Jun 2002 | B1 |
Number | Date | Country | |
---|---|---|---|
20040070609 A1 | Apr 2004 | US |