Web provisioning software has been developed to build Web sites for the Internet and intranets. Web provisioning generally includes selecting a site template that defines the structure and the content of a Web site. Based on the content of the site template, Web provisioning software populates the initial page, the directories, and the site structures of the Web site. Web provisioning software enables a user to create multiple Web sites from a single, predefined site template. As a result, predefined site templates enable a user to quickly create Web sites without spending a substantial amount of time deciding how the sites should look or function.
In some platforms suitable for Web provisioning, such as Microsoft Windows SharePoint Services®, a Web site can only use provisioning information from the site template that initially provisioned the Web site. While the site template serves as a foundation, the site template limits the functionalities that can be added to the provisioned Web site. The Web site is constrained to the set of functionalities included in the site template. The Web site cannot be modified to support functionalities different from the functionalities provided by the site template. Given that business requirements for a Web site may change from time to time, a Web site may be required to evolve during its lifetime. Part of the evolution may require that the Web site functionalities change. Many types of Web page functionalities are provided by control components (“controls”). Controls are active Web page components that respond to user input requesting the performance of specific tasks, such as the selection of an option, text entry, or search. Controls are modular in nature with well-defined interfaces and may be used in many different Web pages that require the same functionality. The behavior and appearance of Web page controls may be specified using properties. Setting the properties of a control to a predefined value causes the control to appear or behave in certain predefined manners. For example, a property of a control may specify the size of the control. Another property of the control may specify certain default behavior of the control, such as showing a default selection of an item in a list presented by the control to a user. Customizing a Web page to fit a particular need often requires using custom control components.
Web site provisioning software makes it easy to create new Web sites to match end-user needs. However, the large number of Web sites created using such software can create new manageability and extensibility problems. For example, third party Web applications may need to globally replace certain sections or components of a Web page with the third party's own custom section or component. For instance, a third party provider of a search application may want to replace a standard search application component with a more advanced search application component that features more capabilities and better user interface elements. Typically, replacing a standard search application requires that the advanced search application provider modify each instance of a page that contains the standard search application. Because of the large number of Web pages included in many Web sites, this process can be time-consuming and is often error-prone.
This summary is provided to introduce a selection of concepts in a simplified form that are further described below in the Detailed Description. This summary is not intended to identify key features of the claimed subject matter, nor is it intended to be used as an aid in determining the scope of the claimed subject matter.
Disclosed is the replacement of a delegate component associated with a delegate modular software component, i.e., an associate delegate component, at software execution time. In one exemplary form, the replacement comprises: obtaining a delegate modular software component identifier; selecting one of a plurality of candidate modular software components having a higher priority level than other of the plurality of candidate modular software components, wherein the one of the plurality of candidate modular software components has the same identifier as the delegate modular software component identifier; and replacing the associate delegate component with the one of the plurality of candidate modular software components during the execution of software including the delegate modular software component.
In another exemplary form, the replacement comprises: obtaining a delegate modular software component identifier; selecting one of a plurality of candidate modular software components having a higher priority level than other of the plurality of candidate modular software components and a scope, wherein the one of the plurality of candidate modular software components has the same identifier as the delegate modular software component identifier; and replacing the associate delegate component with the one of the plurality of candidate modular software components during the execution of software including the delegate modular software component, the software including the delegate modular software component having a scope of execution within a hierarchical computing system, the scope of execution being associated with the scope of the one of a plurality of candidate modular software components.
The foregoing aspects and many of the attendant advantages of this invention will become more readily appreciated as the same become better understood by reference to the following detailed description, when taken in conjunction with the accompanying drawings, wherein:
A system and method for customizing control components on a Web page are described. While the system and the method are suited for customizing control components in a Web page, the system and method may also find use in other software environments where modular software components are used. Thus, it is to be understood that the present invention should not be construed as limited in application to the exemplary embodiments described herein, and such exemplary embodiments should not be construed as limiting.
Web pages are often part of a hierarchy of Web sites.
A Web site hierarchy, such as the one illustrated in
The method 500 proceeds to block 520, where the scope 416 of search and coverage for a candidate control is determined. For example, the feature registry 402 may be searched for a candidate control with a scope covering a site collection only. Searching a limited scope enhances system performance by limiting the number of candidate controls that are evaluated for replacement of the delegate control associated with delegate control 422, i.e., the associate delegate control. Additionally, as discussed above, scope of candidate controls 408 enables customization of individual sites and site collections by replacing only the associate delegate controls in the Web pages and Web sites that are within the desired scope.
The method 500 next proceeds to block 530, where the identifier 412 for the delegate control 422 to be replaced is obtained. For example, if the identifier of the delegate control 422 is “SmallSearch,” the method 500 records the identifier 412 for further processing. In block 540, the candidate controls 408 with the same identifier 412 as the delegate control 422 that are within the desired scope are obtained from the feature registry 402. In block 550, the candidate controls 408 identified in block 540 are sorted according to priority. In one exemplary embodiment, the priority of the candidate controls 408 is determined by the sequence number 414 in the candidate controls 408. For example, a lower sequence number 414 indicates a higher priority of the candidate control 408 with which the sequence number 414 is associated. In block 560, the delegate control associated with delegate control 422, i.e., the associate delegate control, is replaced with the candidate control 408 with the highest priority. The method 500 terminates in block 570.
The method 500 provides a mechanism that allows software developers and third party vendors to replace “out of the box” Web page controls with preferred Web page controls. Additionally, as discussed above, if a third party removes a Web page control developed by the third party from the feature registry 402, the candidate control 408 with the highest priority will automatically appear in the Web Page 420 in place of the removed third party control. Upon removal of the third party candidate control 408, if the associate delegate control has higher priority than any existing candidate control 408, the associate delegate control will re-appear in the Web page 420. In other words, removing a candidate control automatically returns the Web page to an appropriate working state.
While the embodiments and examples discussed above describe controls that render visible objects on a Web page, those skilled in the art will appreciate that the delegate control can be used to dynamically replace or switch non-rendering (i.e. controls that do not render a visible object on a Web page) controls in a Web page. For example, a data source control that services other controls in the Web page by providing data from a data base or other source of data, may be replaced by another data source control with more advanced or different features.
While the presently preferred embodiment of the invention has been illustrated and described, it will be appreciated by those skilled in the art that various changes can be made therein without departing from the spirit and scope of the invention. For example, while the systems and methods described above are directed towards Web page controls, the system and method may also find use in other software environments where modular software components are used. Thus, the invention should not be construed as limited to the exemplary embodiments described above.
Number | Name | Date | Kind |
---|---|---|---|
5572643 | Judson | Nov 1996 | A |
5586235 | Kauffman | Dec 1996 | A |
6026433 | D'Arlach et al. | Feb 2000 | A |
6093215 | Buxton et al. | Jul 2000 | A |
6134559 | Brumme et al. | Oct 2000 | A |
6304886 | Bernardo et al. | Oct 2001 | B1 |
6343377 | Gessner et al. | Jan 2002 | B1 |
6469714 | Buxton et al. | Oct 2002 | B2 |
6601057 | Underwood et al. | Jul 2003 | B1 |
6601233 | Underwood | Jul 2003 | B1 |
6622168 | Datta | Sep 2003 | B1 |
6684369 | Bernardo et al. | Jan 2004 | B1 |
6697825 | Underwood et al. | Feb 2004 | B1 |
6845503 | Carlson et al. | Jan 2005 | B1 |
6910208 | Zimniewicz | Jun 2005 | B1 |
6931599 | Korenshtein | Aug 2005 | B1 |
6981250 | Wiltamuth et al. | Dec 2005 | B1 |
7039658 | Starkey | May 2006 | B2 |
7047318 | Svedloff | May 2006 | B1 |
7047463 | Organ et al. | May 2006 | B1 |
7152207 | Underwood et al. | Dec 2006 | B1 |
7269664 | Hutsch et al. | Sep 2007 | B2 |
7448022 | Ram et al. | Nov 2008 | B1 |
7558857 | Ammerlaan et al. | Jul 2009 | B2 |
7577661 | Bankston et al. | Aug 2009 | B2 |
7619761 | Bankston et al. | Nov 2009 | B2 |
7640328 | Lele | Dec 2009 | B1 |
20020038256 | Nguyen | Mar 2002 | A1 |
20020049788 | Lipkin et al. | Apr 2002 | A1 |
20020069327 | Chauvel | Jun 2002 | A1 |
20020083097 | Warrington | Jun 2002 | A1 |
20030014442 | Shiigi et al. | Jan 2003 | A1 |
20030074634 | Emmelmann | Apr 2003 | A1 |
20030126202 | Watt | Jul 2003 | A1 |
20030140143 | Wolf et al. | Jul 2003 | A1 |
20030172129 | Moses et al. | Sep 2003 | A1 |
20030225853 | Wang et al. | Dec 2003 | A1 |
20040015476 | Twaddle | Jan 2004 | A1 |
20040046789 | Inanoria | Mar 2004 | A1 |
20040068714 | Deimel et al. | Apr 2004 | A1 |
20040103073 | Blake | May 2004 | A1 |
20040103433 | Regeard | May 2004 | A1 |
20040128618 | Datta | Jul 2004 | A1 |
20040148565 | Davis et al. | Jul 2004 | A1 |
20040168123 | Lomelin-Stoupignan et al. | Aug 2004 | A1 |
20040168153 | Marvin | Aug 2004 | A1 |
20040205572 | Fields et al. | Oct 2004 | A1 |
20040216084 | Brown et al. | Oct 2004 | A1 |
20040268228 | Croney et al. | Dec 2004 | A1 |
20050005261 | Severin | Jan 2005 | A1 |
20050015357 | Shahidi | Jan 2005 | A1 |
20050071758 | Ehrich et al. | Mar 2005 | A1 |
20050075115 | Corneille et al. | Apr 2005 | A1 |
20050102284 | Srinivasan | May 2005 | A1 |
20050149549 | Jaspers et al. | Jul 2005 | A1 |
20050187895 | Zimniewicz | Aug 2005 | A1 |
20060080336 | Zhang et al. | Apr 2006 | A1 |
20060129516 | Bradford et al. | Jun 2006 | A1 |
20060161895 | Speeter et al. | Jul 2006 | A1 |
20070061705 | Ammerlaan et al. | Mar 2007 | A1 |
20070076228 | Apelbaum et al. | Apr 2007 | A1 |
20080120600 | Deimel et al. | May 2008 | A1 |
Number | Date | Country |
---|---|---|
WO 2005062201 | Jul 2005 | WO |
Number | Date | Country | |
---|---|---|---|
20070168961 A1 | Jul 2007 | US |