The present invention relates to the field of building websites.
Millions of users utilize the Internet every day, in order to read or otherwise consume web content. For example, a user may utilize a personal computer, a laptop computer, a Smartphone or a tablet, typically running a browser, in order to read online news, watch online videos, interact with other users through social networks, play online games, or the like.
Some websites may be built by manually writing code, particularly HTML code and/or JavaScript. However, as websites became more sophisticated and offered a richer and interactive user experience, various “website builder” tools were introduced in order to facilitate and/or automate the constructions of particular web-pages and even entire websites.
The present invention may comprise, for example, devices, systems, and methods for website building by utilizing data lists.
In accordance with some demonstrative embodiments of the present invention, for example, a website building system (WBS) comprises: a pool of content items to be displayed on a website being built; a set of views which can be used to display said items, each view being a template for a section of a web page of said website; a dynamic matching and adaptation module to dynamically provide an appropriate view for each content item for displaying said content item on said website.
In some implementations, for example, the dynamic matching and adaptation module performs at least one of: (a) locating a matching view from said set of views; (b) constructing a matching view on-the-fly; (c) locating a matching view from said set of views and then modifying the located view.
In some implementations, for example, the system supports item types; and at least one view in the set of views is associated with an item type and can be used to display items belonging to said item type.
In some implementations, for example, the dynamic matching and adaptation module performs matching of a view to a content item by matching an appropriate view to an item type of said content item.
In some implementations, for example, the WBS further comprises: a views manager to create a view having one or more conditional elements.
In some implementations, for example, said pool of content items contains at least one item collection updateable via at least one of: a collection updating Application Programming Interface (API), a collection updating web service, an RSS feed, and an interface for collection updating based on external data source.
In some implementations, for example, the WBS further comprises: a website/view converter to utilize a website page directly as a view for content items.
In some implementations, for example, the WBS further comprises: a pre-association module to associate between a given view and a given item; wherein the dynamic matching and adaptation module is to perform dynamic matching based on pre-association between views and items.
In some implementations, for example, the pre-association comprises explicit specification of the pre-association between the given item and the given view.
In some implementations, for example, the pre-association is based on at least one of: a name attribute, a context attribute.
In some implementations, for example, the matching and adaptation module comprises: a view pool searcher to search, in a pool of pre-defined views, for one or more views that match a given item.
In some implementations, for example, the view pool searcher comprises a keyword-based searcher to match between views and items based on one or more keywords.
In some implementations, for example, the view pool searcher comprises an attribute-based searcher to match between views and items based on one or more attribute matches.
In some implementations, for example, the view pool searcher comprises a field-matching searcher to match between views and items based on one or more field matches.
In some implementations, for example, the view pool searcher comprises an application-related parameters searcher to match between views and items based on one or more application-related parameters.
In some implementations, for example, the dynamic matching and adaptation module is to exclude one or more matching view candidates by taking into account a form factor of an electronic device being used for displaying said website.
In some implementations, for example, the system supports inheritance of views through a view inheritance module able to generate a derived view that inherits characteristics from an existing view.
In some implementations, for example, the WBS further comprises: a parent view searcher to search upwardly for a suitable view in a view inheritance tree, if a given view is not suitable for a given content.
In some implementations, for example, the WBS further comprises: a view manager to automatically create a derived view based on an item type.
In some implementations, for example, the system supports inheritance of item types through an item type inheritance module able to generate a derived item type that inherits characteristics from an existing item type.
In some implementations, for example, the WBS further comprises: a view manager to automatically create a derived item type based on a derived view.
In some implementations, for example, the WBS further comprises: a parent searcher to search upwardly in a type inheritance tree to locate a matching view for a parent type of a given item type.
In some implementations, for example, the matching and adaptation module is to adapt a located view, which matches a parent item type, according to modifications made from said parent item type to a derived item type.
In some implementations, for example, the WBS further comprises: a ranking module to rank potential matching views for a given content item.
In some implementations, for example, the ranking module applies ranking to at least one of: matching of fields, matching of keywords, matching of attributes.
In some implementations, for example, the WBS further comprises: a view priority manager to attach a priority value to each view; wherein the dynamic matching module is to find multiple candidate matching views, and to select from said multiple candidate matching view a single view for utilization based on said priority value.
In some implementations, for example, the WBS further comprises: a callback manager to define a view rating callback for selecting a view for utilization out of multiple candidate matching views located by the dynamic matching module.
In some implementations, for example, the dynamic matching module is to find multiple candidate matching views, and to activate an end-user selection interface generator to generate an end-user selection user interface enabling an end-user to switch among said multiple candidate matching views.
In some implementations, for example, the content item is viewable by using a polymorphic display utilizing two or more display formats that are switchable by an end-user; wherein the end-user selection of a particular display format in the polymorphic display affects matching of views to content items.
In some implementations, for example, the WBS further comprises: a view choice persistence enforcer to enforce persistence among views of sequential items displayed from a given set of items of the same item type.
In some implementations, for example, the matching and adaptation module comprises: a dynamic view constructor to dynamically modify a top-ranking candidate among multiple candidate matching views, for a given content item, if the matching and adaptation module does not find any matching pre-defined view that matches said content item with a matching score that is greater than a threshold value.
In some implementations, for example, the matching and adaptation module comprises: a dynamic view constructor to dynamically construct a view, for a given content item, if the matching and adaptation module does not find any matching pre-defined view that matches said content item with a matching score that is greater than a threshold value.
In some implementations, for example, the WBS further comprises: an integrated searcher/constructor module to search a pool of pre-defined views, to locate a matching view, and to modify said view on-the-fly to accommodate one or more characteristics of a given content item.
In some implementations, for example, the WBS further comprises: an in-view regions divider to divide a display into two or more regions accommodating two or more, respective, elements of said content item.
In some implementations, for example, the WBS further comprises: a landing zone placement module to place a new component into a view based on a landing zone defined relative to existing components of said view.
In some implementations, for example, the landing zone placement module is to select an appropriate said landing zone based on properties of components to be placed.
In some implementations, for example, the landing zone placement module is to automatically generate said landing zone based on at least one of: end of container, end of mini-page, end of container having a given type, end of container having a given attribute, following a location of a recent field addition, at a location having at least a given amount of empty screen space, in a newly created page or mini-page.
In some implementations, for example, the WBS further comprises: a dynamic layout manager to apply one or more dynamic layout rules to said particular view.
In some implementations, for example, the dynamic layout manager takes into account said dynamic layout rules and dynamic layout anchors.
In some implementations, for example, the WBS further comprises: a filled-in view creator to create a filled-in version of a view that was either (a) matched or (b) dynamically constructed on-the-fly or (c) dynamically adapted on-the-fly.
In some implementations, for example, the filled-in view creator comprises: a view-to-field matching module to map each data component in said view to a matching field in the item.
In some implementations, for example, the view-to-field matching module utilizes at least one of: (a) pre-association data; (b) common name used by view component and item field; (c) query over matching keywords assigned to view components and items fields.
In some implementations, for example, the filled-in view creator comprises: a component re-sizing module to resize a missing field to zero size.
In some implementations, for example, the filled-in view creator comprises: a view display-size adjuster to optimize dimensions of at least one component in said particular view to accommodate an aspect ratio of a display unit being used.
In some implementations, for example, the view display-size adjuster comprises: a target widths generator to generate a set of possible target widths of said component, and to perform dynamic layout calculation for determining a corresponding height for each target width; a target width selector to select a single target width which best accommodates the aspect ratio of the display unit being used.
In some implementations, for example, the given view comprises a repeater component contained within said view, wherein the repeater component displays a secondary list related to a primary list of content item displayed via said given view.
In some implementations, for example, the WBS further comprises: a repeater component display module to display said secondary list by using same name attributes and context attributes that said primary list has in accordance with said given view.
In some implementations, for example, the WBS further comprises: a linking component manager to define a linking component comprising a container that displays content obtained from said pool of content items.
In some implementations, for example, the linking component manager displays a single mini-page at a time, containing a single content item from said pool of content items.
In some implementations, for example, the linking component manager animates a transition between browsed content items.
In some implementations, for example, wherein the linking component manager displays, concurrently, a gallery of content items.
In some implementations, for example, the linking component manager is to display one or more content items linked by said linking component in response to a direct URL that directly links to said linking component.
In some implementations, for example, the linking component manager is associated with a related list connection manager to inter-connect between two linking components based on a related list of content items.
In some implementations, for example, the linking component manager is associated with an aggregator field connection manager to inter-connect between two linking components based on an aggregation function which calculates an aggregated value based on items in one of said two linking components.
In some implementations, for example, the linking component manager is associated with a tag cloud connection manager to inter-connect between two linking components based on selection of tags from a cloud tag that is associated with one or said two linking components.
In some implementations, for example, the linking component manager is associated with a hierarchy tree connection manager to inter-connect between two linking components based on a hierarchy tree of having at least one parent/child pointer.
In some implementations, for example, the linking component manager is associated with a form display connection manager to inter-connect between two linking components based on a request of a first linking component to display an alternate presentation of a currently-displayed item of the first linking component.
In some implementations, for example, the WBS further comprises: a dynamic layout manager to modify a layout of a linking component, which contains said view, based on a presentation property of a content item in said view.
In some implementations, for example, the WBS further comprises: a specific item adaptation module to adapt a specific content item by performing at least one of: (a) adding one or more components to a displayed content in a context of a specific view being applied; (b) deleting one or more components of a displayed content in a context of a specific view being applied; (c) modifying one or more components of a displayed content in a context of a specific view being applied.
In some implementations, for example, the specific item adaptation module comprises: a local variant creator to create a local variant of a given view as an internal derived view, and to add a layer of modifications to said internal derived view.
In some implementations, for example, the internal derived view is stored together with an identification of the item to which the internal derived view is applied.
In some implementations, for example, the internal derived view is stored in a current list application that comprises the item to which the internal derived view is applied.
In some implementations, for example, the specific item adaptation module comprises: a customization module to apply a view customization to all instances of a given view.
In some implementations, for example, the WBS further comprises: an application store manager module to manage an application store enabling a website designer to obtain one or more objects generated by the website building system; wherein the obtaining comprises at least one of: (a) downloading; (b) obtaining from a storage article; (c) obtaining from a shipped storage article; (d) obtaining from a server computer storing said objects; (e) obtaining from a cloud computing server.
In accordance with some demonstrative embodiments of the present invention, for example, a computerized method for building a website comprises: storing a pool of content items to be displayed on a website being built; storing a set of views which can be used to display said items, each view being a template for a section of a web page of said website; performing dynamic matching and adaptation to dynamically provide an appropriate view for each content item for displaying said content item on said website.
In some implementations, for example, the method comprises performing at least one of: (a) locating a matching view from said set of views; (b) constructing a matching view on-the-fly; (c) locating a matching view from said set of views and then modifying the located view.
In some implementations, for example, the method comprises: associating between a given view and a given item; wherein the dynamic matching and adaptation comprises performing dynamic matching based on pre-association between views and items.
In some implementations, for example, the method comprises: supporting inheritance of views by generating a derived view that inherits characteristics from an existing view.
In some implementations, for example, the method comprises: ranking potential matching views for a given content item.
In some implementations, for example, the method comprises: dynamically modifying a top-ranking candidate among multiple candidate matching views, for a given content item, if the matching and adaptation does not find any matching pre-defined view that matches said content item with a matching score that is greater than a threshold value.
In some implementations, for example, the method comprises: applying one or more dynamic layout rules to said particular view.
In some implementations, for example, the given view comprises a repeater component contained within said view, wherein the repeater component displays a secondary list related to a primary list of content item displayed via said given view.
In some implementations, for example, the method comprises: defining a linking component comprising a container that displays content obtained from said pool of content items.
In some implementations, for example, the method comprises: performing specific item adaptation to adapt a specific content item by performing at least one of: (a) adding one or more components to a displayed content in a context of a specific view being applied; (b) deleting one or more components of a displayed content in a context of a specific view being applied; (c) modifying one or more components of a displayed content in a context of a specific view being applied.
In some implementations, for example, the method comprises: managing an application store enabling a website designer to obtain one or more objects generated by the website building system; wherein the obtaining comprises at least one of: (a) downloading; (b) obtaining from a storage article; (c) obtaining from a shipped storage article; (d) obtaining from a server computer storing said objects; (e) obtaining from a cloud computing server.
Some implementations may comprise, for example, a storage medium having stored thereon instructions that, when executed by a machine, cause the machine to execute a method in accordance with the present invention.
In some implementations, for example, the one or more objects comprise one or more of: a view; a template; an item type; a collection of items; a list application; a linking component.
The present invention may provide other and/or additional benefits or advantages.
For simplicity and clarity of illustration, elements shown in the figures have not necessarily been drawn to scale. For example, the dimensions of some of the elements may be exaggerated relative to other elements for clarity of presentation. Furthermore, reference numerals may be repeated among the figures to indicate corresponding or analogous elements. The figures are listed below.
In the following detailed description, numerous specific details are set forth in order to provide a thorough understanding of some embodiments. However, it may be understood by persons of ordinary skill in the art that some embodiments may be practiced without these specific details. In other instances, well-known methods, procedures, components, units and/or circuits have not been described in detail so as not to obscure the discussion.
The present invention may comprise a website building system (WBS) which may implement list components and list applications as described herein. The WBS may be used by a designer or programmer or other person who desires to build a website. Some implementations of the WBS may be configured to be suitable for novice users or laymen users, or for website creators who do not necessarily have advanced skills (or any skills) in programming, and who may not necessarily be proficient in programming language(s). A direct user of the WBS, who may utilize the WBS for creating a website, may be referred to as a “designer”; whereas the website itself, once it is built and published, may be used by “end-user(s)”.
In accordance with the present invention, the WBS may comprise and/or enable the following features: Items and item collections; Item types; Views (including conditional, calculated and other elements); Templates and inheritance (including derived views and derived types); Linking Components (LC's); Dynamic matching between items, types and views; Support for automatic creation of item types based on derived views, and vice versa; Support for customizations and automatically generated customization dialogs; Support for specific item adaptations; Support for the creation of connections between related LC's; Support for application store integration for all the above features.
Some embodiments of the present invention may be utilized in conjunction with systems, methods, modules and/or components which are described in U.S. patent application Ser. No. 13/771,119, titled “Web Site Design System Integrating Dynamic Layout and Dynamic Content”, filed on Feb. 20, 2013, published as United States patent application publication number 2013/0219263, which is hereby incorporated by reference in its entirety.
Pages, Containers and Components
Reference is made to
Components 120 may be, for example, atomic components 121 and/or container components 122. For example, container components 122 may be single-page containers 123 or multi-page containers 124 (which include multiple mini-pages 125 separate from each other). It is clarified that these are only non-limiting, demonstrative examples. In particular,
Multi-page containers 124 may display a single mini-page 125 at a time (single page display), or may display some or all of the mini-pages 125 (e.g., implemented as a gallery or carousel or collection display, for example, as demonstrated in
When viewing a page containing a multi-page container 124, the user may step between the various mini-pages 125 contained in the given multi-page container 124 using one or more suitable mechanisms, for example, navigation buttons (e.g., first, previous, next, last) and/or visual selection among multiple visible mini-pages 125 (or their thumbnails, scaled-down representations).
Reference is made to
Components 120 may have content 130, for example, text content for text component, an image for image component, video content for a video player component, or the like. Components 120 may have (or may be associated with) attributes 131, for example, display attributes 132 (e.g., color, frames) and layout attributes 133 (e.g., size and position). It is clarified that
The WBS 100 may generate a page definition which may include dynamic layout rules (e.g., anchors connecting multiple component edges) which may be handled by a Dynamic Layout Manager (DLM) 101. For example, DLM 101 may be activated whenever a dynamic layout (DL) trigger is activated, e.g., a change which affects the page layout (for example, adding components, removing components, changing a component's content in a way which affects component size, moving components, resizing components), content change for components which reflect external content, or the like. Other suitable triggers or triggering mechanisms may be used, for example, as detailed in the above-mentioned U.S. patent application Ser. No. 13/771,119.
Inheritance Relationships
Reference is made to
When an entity A inherits from an entity B, the sub-elements of A are copied or imported from the sub-entities of B. For example, entity B may be referred to as “parent entity B” (denoted 141); whereas entity A may be referred to as “child entity A” or “inheriting entity A” (denoted 142). It is noted that entity A may include local modifications to the sub-elements copied over from B, including (without limitation): Addition of new sub-elements; Removal of copied sub-elements; Changes to properties of copied sub-elements. The local modifications would only apply to the inheriting entity A and not to the parent entity B.
Inheritance support manager 102 may comprise, or may utilize, or may be associated with, one or more inheritance-enabling modules, for example, an inheritance-by-copying module 103 and/or a full inheritance module 104 (which may also be referred to as a “continuous inheritance” module, since the inheritance linkage may continuously affect the inheriting entity A when subsequent modifications are made to the parent entity B). It is noted that in some implementations, WBS 100 may support only inheritance-by-copying; whereas in other implementations, WBS 100 may support only full inheritance. Accordingly, in some implementations, WBS 100 may support either full inheritance or inheritance-by-copying, but not both of them.
Inheritance-by-copying module 103 may enable inheritance by copying, such that entity A is a separate entity created based on parent entity B by copying its structure and sub-elements. However, the copy is a separate entity and would not reflect changes that are made to parent entity B after the creation of inheriting entity A.
Full inheritance module 104 may enable full inheritance, such that the inherited entity A remains (even when modified) an instance of parent entity B. For example, if parent entity B is modified after inheriting entity A was created, the changes made to parent entity B would automatically be reflected in inheriting entity A and would be combined with the local modifications made to inheriting entity A.
Inheritance support manager 102 and/or its modules may support (for each inheritance-supporting entity type) any of the following inheritance types, or a combination thereof: (a) Regular inheritance, such that A inherits from B; (b) Multi-level inheritance, such that A inherits from B, and B inherits from C; (c) Multiple inheritance, such that A inherits from both B and C, combining sub-elements from both; (d) Diamond inheritance, such that A inherits from both B and C, and both B and C inherit from another entity D.
Templates
Reference is made to
WBS 100 may further support single-component templates 129, which describe the properties of a single component, and may be used when constructing other templates and pages. It is noted that page templates 128 may be viewed as multiple component templates with additional page-level properties (e.g., dynamic layout anchors).
In some implementations, WBS 100 may enable or may support the following template types: Page templates 128; Single-component templates 129; List application templates 127; and View templates 126. It is noted that the various types of templates that are described above for demonstrative purposes, relate to objects which may have vastly different scope and/or complexity and/or characteristics. For example, list application templates may describe a complete application environment or substantial portion thereof, such as a turnkey restaurant site (e.g., as demonstrated in
Optionally, WBS 100 may support or enable inheritance relationship between templates, such that modified templates may be derived from base templates. This feature of the present invention may be in addition to the inheritance relationship between pages and templates (e.g., a particular page inheriting from one or more templates).
Item Types
Reference is made to
An item type 135 may inherit from other item types 135, optionally with additions, deletions and modifications applied to them. For example, a “shirt” item type may inherit from a “garment” item type, and may have the additional field “sleeves (short/long)”.
The pool of item types 135 may be defined at the collection level, application level, designer level, or WBS level. Optionally, WBS 100 may support one or more item type pool(s) 138, at one or more suitable levels.
Collections and Items
Reference is made to
Collection Updating
Collections 144 of items 145 may be updated, for example, by adding items 145, deleting items 145, and/or modifying items 145. For example, WBS 100 may optionally comprise a Collections Manager 146 able to provide automatically-generated screens which may be used by users (e.g., designers, developers, website creators) to update or edit a collection 144; for example, as demonstrated in
In some implementations, WBS 100 may provide a programmatic interface (e.g. a collection updating API 148) through which the created website may interface directly with the collections manager 146 and update the collection 144. Optionally, WBS may provide an interface (e.g., a collection updating web service 149) allowing an external application (e.g. web application, mobile application, desktop application, cloud-based application, or the like) to access the collection 144 and update it directly, without the need to access the collection 144 through the constructed website. In some implementations, WBS 100 may provide an interface 150 for collection updating based on external data source (e.g., RSS feed) to be attached to a given collection 144, and the WBS itself may be responsible for updating the collection 144 based on the incoming data feed.
Optionally, a collection 144 may be constructed such that it represents (or points to) data present in an external system or data set, for example, as a “virtual collection” 151. In this case, changes in the underlying system or data set would be automatically reflected in the virtual collection 144.
Linking Components
Reference is made to
Optionally, an LC may be associated with: a specific item directly; or a single collection of items; or a set of collections (e.g., which may be displayed one after the other or hierarchically using a table-of-content like structure). For example (as demonstrated in
In some implementations, a virtual mini-page generator 107 may automatically generate a virtual mini-page for each item in the one or more collection(s) associated with an LC 152. It is clarified that a single LC 152 may be associated with multiple collections, some of which may be virtual and some may not. When an LC 152 is displayed, designers and users may manually navigate between the multiple displayed mini-pages of that LC, for example, by using a scroll bar or navigation buttons (e.g., First, Previous, Next, Last). The designers and users may also perform additional operations, as detailed herein.
In accordance with the present invention, WBS 100 may comprise a LC direct access module 153 which may enable direct linking to an LC 152; for example, allowing a page containing LC(s) to be directly accessed using a URL. Such demonstrative direct URL's may be, for example:
www.MySite.com/prefix/MyPage.html?MyItem
www.MySite.com/prefix/MyPage.html?LC1=MyItem1&LC2=MyItem2
www.MySite.com/prefix/MyPage.html?LC1=MyFilterQueryString
The use of such direct links may cause WBS 100 to open the specific page (containing the LC(s) 152) with the LC(s) 152 already displaying the requested items, or with a given query being used to filter items, similar to the way queries and parameters are added to regular URL's (e.g., to be passed for processing by PHP programs).
When WBS 100 opens a page containing an LC 152, with the LC 152 displaying the result of a URL-originated query, the LC 152 would display the query results as a query results structure 108, which may be detailed or summarized. The result list by itself is not necessarily a page or mini-page, but rather, may have an arbitrary or predefined structure as defined by WBS 100. A detailed result list may optionally include multiple mini-pages (e.g., one mini-page for each result found); this may differ from the regular situation in which an LC 152 displays one or more mini-pages at any time.
Optionally, WBS 100 may be configured to limit such direct linking or deep linking to specific LC's 152, or to specific LC types. For example, an LC linking constraints module 154 may be used for defining constraints or limitations on direct linking to LC's or LC types; and may further be responsible for enforcing such LC linking constraints.
In some implementations, WBS 100 may comprise alternative interfaces (e.g. a web-service based interface, or a message-passing based interface) to access one or more of the functions described above.
WBS 100 may optionally define and utilize specialized LC's 152 for specific uses, for example: Displaying only a filter search box (with the result being displayed elsewhere); Displaying a result list; Displaying a “tag cloud” or a group of tags which qualify the items in a given collection.
A demonstrative use of LC's 152 may include one or more of the following: (a) The LC 152 is directly associated with (and displays) a single pre-specified top-level item (see
In addition to list navigation (as described above), WBS 100 may enable additional operations which may be activated when a list is displayed in an LC 152, depending on the designer/user permissions and privileges. Such additional operations may include, for example: (a) Go to add item form (e.g., a view used in item adding mode, as described herein); (b) Go to an expanded item page; (c) Go to related list; (d) Go to item editing.
Views
Reference is made to
WBS 100 may comprise a Views Manager 156, able utilize different views 155 for different items in the same collection. For example, if a user steps between blog records which have multiple formats (e.g., text entries, image entries, video entries), the view 155 used for display may change from item to item, altering the displayed format along the way.
The view 155 may include fixed view elements 157, which always apply to (or are included in) the displayed view; and/or conditional view elements 158 which may be associated with view conditions 159. For example, conditional view elements 158 may depend on one or more of the following: (a) The existence of a given data field in the underlying item; (b) The value of a given data field in the underlying item; (c) A pre-specified formula involving data fields values and relationships between them; (d) Parameters of the displaying LC 152 (e.g. display a given field only when displaying in a list-type gallery); (e) Attributes of the user, obtained from the user profile or other sources (e.g. display a particular field only to internal users within an organization, or to users located in a certain region only); (f) Usage mode (e.g., is the view 155 being used for creation, editing or display).
In a demonstrative implementation, view 155 may comprise one or more of the following elements: (a) Regular or fixed view elements 157 (e.g., page titles, background images); (b) Data components 162 which are filled with data from the displayed item (e.g., the price of a house offered for sale, the image of such house, a descriptive text); (c) Repeater components 163 used to display related lists inside the view (as detailed herein); (d) Calculated components 164 which display information calculated based on content from the displayed item (e.g. the Value Added Tax (VAT) value for a price taken from a numerical price field); (e) Conditional view elements 158 whose inclusion in the display (or whose attributes) depends on view conditions 159 (e.g. a colored ribbon displayed for restaurant items which have a predefined value in the field “offer of the day”); (f) data validation rules 161, which may depend on view conditions 159; (g) Conditional dynamic layout elements 165, which may be dynamic layout rules and anchors which may depend on view conditions 159.
WBS 100 may comprise a view inheritance module 166 enabling a view 155 to inherit from one or more other views 155, with additions, deletions and changes applied. For example, a “shirt” view may inherit from a “garment” view, and may have the additional component “sleeves (short/long)”, thereby creating a derived view 167.
It is noted that views and item types are different entities and reside in different pools, although both of them may comprise field-like sub-entities and may have inheritance relationships (items may inherit from other items in the item pool, and views may inherit from other views in the views pool). The item type defines which fields are included in the item, whereas the view defines how these fields are displayed. WBS 100 may comprise a dynamic view constructor 169 enabling dynamic construction of views based on underlying template-type information and the specific item being displayed.
One or more pool(s) of views 168 may be implemented at the application level, at the designer level, or at the WBS level. Optionally, views 155 may be pre-defined to be associated with item types, such that a particular view 155 must always “belong” to a given item type (or to item types inheriting there from).
Using Views for Item Display
WBS 100 may comprise an item display module 170, which may display an item by using a predefined algorithm. Firstly, a matching view for the item display is located (or created on-the-fly); for example, item display module 170 may locate a view pre-associated with the item, or a view selected by searching the pool of available views; and if a suitable view is not located, then item display module 170 may automatically construct a suitable view “on-the-fly” based on the item definition. Secondly, item display module 170 may create a filled-in version of the selected view, by: (a) Matching each data component to a field in the item (if possible) and using the matching fields' content; (b) Determining the value of all calculated components; (c) Determining whether or not conditional view elements should be included. Subsequently, item display module 170 may perform dynamic layout on the filled-in view, thereby applying layout modifications resulting from changes to field content, conditional view elements, or the like; and may proceed to display the filled-in view.
It is noted that the process may be performed for multiple collection items; for example, when displaying an LC 152 which is a gallery-type multi-page container which displays multiple collection items simultaneously.
Repeater Components, and Using Views Inside Views
View 155 may contain one or more repeater component(s) 163. Each repeater component 163 may be generally similar to LC 152, but is contained inside the view 155. Each repeater component 163 displays a given list, and may typically display a list related to the main item being displayed in the view 155. For example, a person item may be related to other person items (e.g., friends of that person) and to car items (e.g., cars owned by that person). The person view may contain two repeater components 163 which display these lists (the “friends” list and the “cars” list). These two repeater components 163 would display the specific lists associated with the current person being viewed or highlighted in the primary person viewing LC 152. Note that repeater LC's should be differentiated from composite LC's as described above (and demonstrated in FIG. 23A)—repeater LC's display different related lists in different LC's, whereas composite LC's include multiple lists displayed inside a single LC.
Unless overridden by specific configuration parameters, a repeater component display module 171 may ensure that a repeater component 163 displays a list using the same view attributes (e.g. name, context) as the view 155 used to display the main component. For example, a view named XYZ for the type A may be used to display items of the type A; each of the items of type A may be linked to a set of items of type B; the list of type B items (related to the current type A) would be displayed in the repeater component 163 (as a default, unless configured otherwise) using a view named XYZ for the type B.
Using Website Pages for Item Display
In some embodiments of the present invention, instead of views which are used to display items inside LC's, the system may utilize website pages directly as if they are views. In such case, the system may display data taken from the associated items directly inside data components included in the website page. For example, the designer may include data components inside a regular website page, and may specify from which item their data should be taken. Optionally, a webpage/view converter 172 may be comprised in WBS 100 in order to implement the conversion or adjustments for utilizing a webpage as a view.
The item to be used as the data source may be selected in one or more suitable ways, for each data component; for example, out of these candidate items: (a) An item specifically associated with the website page (and thus, if this item is changed, such as in another page inheriting from the current page, then this would affect all data components); (b) An item pre-associated for this specific component; (c) An item answering a query specified for at the page or component level. The data component may also specify the data field to be used directly, or may use a field discovery/query mechanism.
Optionally, such page may be built and made into a template, to be re-used to display different items within a manually constructed page set. The designer may only need to specify which component would change when an alternate item is associated with the page.
Three-Stage Process
Reference is made to
Stage 1: Locate a Matching View for the Item (or Item Type)
Reference is made to
The stage of locating a matching view for item(s) may be performed, for example: (i) by a View pre-association module 112A for pre-associating views with items and/or with item types; (ii) by a view searcher module 112B for searching the pool of available views; and/or (iii) by an on-the-fly dynamic view constructor 112C for dynamically constructing a suitable view “on-the-fly”.
Pre-Associating Views with Items and/or with Item Types
Reference is made to
Single view association may be performed by the designer who may explicitly associate a view with any given item type, and the association will be used for all items having the given item type. The association may further be used for all item types inheriting from the given item type, unless they have their own explicitly assigned view. The designer may also explicitly associate a view with any specific item, thereby overriding the view associated with the item type of the given item.
Optionally, an attribute-based pre-association module 113A may enable a view to be pre-associated via attribute parameters 113D (including the use of context-based association, type-specific names and inheritance-adapted association as further described below). For example, attribute-based pre-association may be used when the system needs to link to views according to generic name, context, class, or other parameters. The attribute-based pre-association module 113A may support attribute-based pre-association as follows: (a) The system defines specific attributes to views (e.g. name, context); (b) The view creator assigns values to these attributes; (c) The designer (using the list and the view) specifies the value for the given attribute; (d) The view would be selected based on the provided attribute values (e.g. name, context).
In a demonstrative example, the system may include a name attribute 113E for each view, unique for each item type. The designer may specify the view name to use when defining the LC (or webpage). For each item type, the view having the given name and associated with the given item type would be used. It is noted that there may be multiple views with the same name for different item types; and thus, specifying the view name may actually create multiple association relationships (e.g., as noted herein for repeater components).
In another demonstrative example, the system may assign a context attribute 113F, with the possible values of “thumbnail-mode” and “zoom-mode”. The designer may specify for a given LC (or repeater component or webpage) the context for view selection (e.g., thumbnail-mode or zoom-mode), and the selected view (for each type) would be the view having the given context. Demonstrative examples are shown in
Alternatively, multiple views may be explicitly associated with a given item or item type. In such cases, a conditional selector module 173B may define and/or enforce one or more conditions under which one of the associated views is selected. Such conditions may include, for example: (a) the type of LC used to display the item (e.g., a large area container may use a detailed view (displaying many fields), whereas a gallery type container may use a smaller view which includes a thumbnail and a descriptive text only); (b) The content of a specific “selector” field in the item being displayed; (c) The identity of the user accessing the collection, or specific properties in the user profile of the accessing user (e.g., an online store employee may be able to view more information in additional fields, relative to the content displayed to a visiting guest user).
Optionally, a view-per-function association module 173C may be used to associate different views for different functions, and to enforce such association. For example, WBS 100 may assign different views for item viewing, item creation, and item updating. The designer may define these views, and may also specify that a given view will be used for multiple functions (e.g., used for both item creation and item updating).
Searching the Pool of Available Views
Reference is made to
The view pool searcher 174 may utilize one or more suitable query types, for example, keyword based, field matching, attribute matching, application-related parameters, or other suitable types of query. The view pool searcher 174 may combine two or more of the query methods, for example, to select among the views having matching fields while applying a particular condition to the view attributes.
In keyword based view search, which may be implemented by using a keyword-based view searcher 174A module or sub-module, both item types and views may have attached or associated keywords (e.g., one or more keywords, possibly selected from a pre-defined list). The matching algorithm attempts to locate views having the largest keyword match with the item type keyword list.
In field matching view search, a field matching searcher 174B module or sub-module may search for the view which has the component set best matching to the set of fields in the item. The matching may be performed according to field names, attributes, or special matching ID's. The grading or scoring or ranking of matches may be performed by a scoring/ranking module 175, for example, by comparing the number of matching fields, or by using a per-field weight to calculate a weighted score.
Optionally, a field data dictionary 176 may be defined and used (e.g., at the system level, application level, or another level) for creation of both item type fields and view components. The matching may be done by using the field data dictionary 176, for example, by utilizing a dictionary searcher 177 for locating view components and item fields having a matching underlying data dictionary field.
An attribute-based searcher 178 may perform attribute-based searching. For example, views may have additional attributes assigned to them in order to assist in matching views to items. The item type (or the item) may include a query (using a suitable query or expression language) which is applied to the relevant or available views to select which views are the best match for this item based on the one or more of the view attributes. The query may be completely specified (e.g., include all conditions), or may be parameterized to include one or more parameters, for example: (a) Item-specific values (e.g., the query is specified at the item type level, but has specific parameters filled in by the item); (b) Item data field values (e.g., parameters based on data fields in the specific item); (c) LC type (e.g., parameters depending on the specific LC in which the view is to be displayed), for example, such that the LC size and container-type may determine which view size is optimal; and/or (d) General environment values (e.g., the user classification and privileges). The attribute-based searching may be implemented as a generalized version of the view attribute pre-association (e.g., via name/context) described above.
Optionally, view and item type matching may be performed by based on application-related parameters, by utilizing an application-related parameters searcher 179. The view searching may thus take into account application-related parameters; for example, different views may be selected dynamically for the first and last item in a filter query result. This way, “next” and “previous” navigation buttons may be displayed dynamically as needed.
A multiple matching results handler 180 may handle multiple results, since some of the matching techniques described above may yield multiple candidate views for the display of a particular item. In such case, match rating may be used (e.g., generally similar to search engine ranking) to select the best view to use among the candidate results. Furthermore, the multiple matching results handler 180 may elect to use the best match found, but may retain the list of candidate views, and may provide a GUI element which allows the user to switch the display in order to utilize one of the other view candidates that were found.
A fallback handler 181 may ensure fallback to parent item type. For example, item types may be created through an inheritance process based on other item types and a set of modifications. If no result (or no “good” result, or high-quality match, or high-scoring match) was found for the given item and item type, then the fallback handler 181 may command to re-execute the matching process using the same item data values (if relevant) but use the item type which is the parent of the current item type. For example, a “shirt” item type may be a derived from the parent item type “product”; if no matching view (or no high-scoring matching view) was found for an item of the type “shirt”, then the matching process may be automatically repeated, this time using the parent item type “product” rather than the item type “shirt”.
Dynamic View Construction
Reference is made to
In a demonstrative implementation, for example, dynamic view constructor 182 may implement a number of abstract, generic view templates which only divide the display area into multiple regions, implemented using an in-view regions divider 182A module or sub-module. Each item type may specify which such generic template to use. Each field may specify, for example, the region into which the field should be placed, and an alignment code indicating where the field should be added (e.g., top left, bottom center), as well as how the field may be related to the previous field(s) in the same area of the region (e.g., join after previous field; new line; below but aligned to the left in the same way). A field may also specify dynamic layout type anchors or other layout rules (e.g., specifying that two particular fields should be vertically aligned). Dynamic view constructor 182 may thus create an appropriate view for each item type automatically based on the provided directives and rules. This may be particularly useful for automatic creation of data entry forms, updating forms, and/or other forms.
Integrated View Searching/Dynamic Construction
As described above, the WBS 100 may locate views (using pre-association or searching) or may create views dynamically. Furthermore, WBS 100 may also integrate the two methods, by locating a base view, and then expanding it (when needed) or otherwise modifying it (via a located-view modifier module 182B) using the dynamic view construction techniques noted above (e.g., landing zones). This may be implemented by using a searcher/constructor module 183, and may be particularly useful for items having a relatively fixed base format (and set of fields), which also have additional fields added dynamically (e.g., RSS feed with optional fields).
View Selection and Polymorphic Display
Reference is made to
In such cases, WBS 100 may provide one or more options to the designer, for example: (a) To utilize a View priority manager 184A in order to attach priority value to the various views (assuming that they are known in advance), such that WBS 100 would select the view having the highest priority value; (b) To use a hook/callback manager 184B in order to define a hook or callback into the application, which would allow the application to select the right view to use; (c) To use an end-user selection UI generator 184C in order to expose the multiple view options to the end-user, allowing him or her to select the view to be used for the given item (e.g., using a default view and including a “change view” drop down menu or combo box widget in the display).
In a first demonstrative example, a view choice persistence enforcer 184D may ensure that view choice is persistent. For example, item display typically allows the end-user to step between the displayed items in the collection (e.g., navigating to the previous or the next item). The displayed items may have different views used to display them. The view choice persistence enforcer 184 may allow the designer to specify that the choice of a view to display a given item type is persistent. Accordingly, if the end-user steps over the items in the collection, and returns to the same item type, the same view (among the multiple possible views) would be used; unless there is a specific reason not to re-use it (such as, a separate distinct view association for the viewed item).
In a second demonstrative example, a polymorphic display generator 185 may enable polymorphic display. For example, the end-user may affect the selection of view by changing the main display type (e.g., multi-page container type) used by the LC to display the items. The designer may allow the end-user to determine if a given list would be viewed in a “list mode” (displaying 1-2 lines of information per item) or in a “page mode” (display a full page of information from the given item). Similarly, a designer may allow the end-user to switch a LC display between a grid-type gallery (which shows the items arranged in a grid) to a slider-type gallery (which shows the item in a slideshow-like arrangement). The choice of LC display mode may affect the view chosen for display as well. The polymorphic display generator 185 may be used to ensure that the user may switch among multiple views (or LC displays) that the designer designated in advance for this purpose.
Stage 2: Create a Filled-In View Based on View and Item's Fields
Reference is made to
First, the filled-in view creator 186 may utilize a view-to-field matching module 186A or sub-module, to map each data component in the view to a matching field in the item type (and underlying item). This may be done, for example, using one or more of the following methods: (a) Explicit pre-association by the designer; (b) Common name used by view component and item field; (c) Special association ID; (d) Query over matching keywords assigned to view components and item fields; (e) A query defined for a data component which searches pre-specified attributes in the fields of the matching item. For non-data components (e.g., title text), such matching may not be required.
A missing fields handler 187 may handle missing fields—view fields (which should be filled with content) for which no matching item field was found. For example, if no matching field was found, the missing fields handler 187 may display the appropriate text or image in-place of the view component (provided by the data component itself or by WBS 100). This could occur during design-time or during run-time (e.g., when items are provided by RSS feeds and some required fields may be missing). Optionally, an unobtrusive message or low-key warning message may be provided or displayed or logged. The actual display message shown may depend on the URL used for the call or the user login; such that, for example, the designer may receive a more comprehensive message.
If the component has anchors or other DL-related association, the missing fields handler 187 may not remove the component, but rather, may utilize a component re-sizing module 187A to resize it to zero size. If the component does not have anchors or other DL-related association, then the missing fields handler 187 may remove the component together with any layout related spacers attached to it, such that no extra space may remain which would have been added if the field was present.
Second, the filled-in view creator 186 may utilize a component value calculator 186B to determine the value of all calculated components; for example, calculated based on the values of the fields, including in particular the value filled into the data components. Third, the filled-in view creator 186 may determine whether or not conditional components should be included; for example, the view may contain conditional components whose inclusion depends on one or more conditions.
Stage 3: Apply Dynamic Layout to the Filled-In View
Reference is made to
The DL processing may take into account specific DL rules 101A and/or DL anchors 101B, for example, originating from the following: (a) The underlying item containing the LC; (b) Fixed DL information contained in the view definition; (c) Conditional DL information contained in the view definition applicable depending on the specified view conditions.
The DL processing may affect the entire page containing the LC. For example, if the LC is used to view a new item in which a given text field is larger than the currently displayed item, then DLM 101 may cause the entire displayed mini-page (containing the view) to grow or increase in size, thereby causing the LC to grow and causing movement or relocation of components in the containing page.
DLM 101 may apply animation and transition effects, so that the changes resulting from switching items (and possibly views) in the LC would be presented via smooth, animated changes, rather than abrupt changes.
Determining and Adjusting the Display Size of a View
The display area required by a specific filled-in view instance may vary, and may be determined and/or adjusted (e.g., modified) by a view display-size adjuster 188, since the data components in the view (e.g., text, image) may include different amount of data for different instances of the view. The view is typically displayed using the size defined for it in the WBS 100. However in some cases, the size may be optimized to a specific screen, browser or device configuration. In such cases, view display-size adjuster 188 may adjust the area allocated to the view, while taking into account the specific fill-in view data.
For example, changes in the view width may affect view height. In particular, text display components which are required to fit a narrower area (horizontally) may grow vertically in order to display the same amount of text (e.g., breaking it into more lines).
The view display-size adjuster 188 may optimize the displayed view for the best aesthetically pleasing result. For example, view display-size adjuster 188 attempts to find the best size (and resulting layout) for the view, to achieve or optimize one or more for the following (possibly contradictory) targets: (a) Getting the displayed view to have an aspect ratio as close as possible to the browser display window for the application; (b) Minimizing the amount of scrolling needed to watch the entire view (e.g., if it expands vertically down and requires scrolling); (c) Complying with all DL rules and anchors specified for the view.
In a demonstrative implementation, view display-size adjuster 188 may perform the following operations: (a) Take original view instance width; (b) utilize a Target Widths generator 188A to create a set of possible target widths, starting with the original width and going down until a pre-defined value parameter (e.g., 100 pixels), thereby creating a set of possible “target widths” (e.g., computed by limiting the set size by minimal difference between the sizes); (c) Perform DL calculation for the view instance for each of the target widths, and obtain the resulting height for each of the target widths; (d) Find and select, using a Target Width selector 188B module or sub-module, the resulting height-width set which is closest to the aspect ratio of the enclosing page display window, but does not exceed the available screen height; (e) If, for each one of the target widths, the height exceeds the available screen height, then select the target width which has the smallest height.
View Modification and Derived Views
A view modification module 189 may enable the designer to modify a view by adding, removing and/or modifying the displayed components. The system may allow the designer to apply the modification “in-place” (e.g., affect the actual view and all items using it), or to create a derived (inherited) view from the edited (modified) view.
A derived view may be regarded as inheritance-based variant of a parent view. For example, a “shirt” view is a derived child of the “product” view, but may have an additional “color” attribute/field. If the view is associated with a given item type (or types), the creation of a derived view may also create a similarly modified item type (or types) which may be used to create items in the associated collection or other collections.
In accordance with the present invention, WBS 100 may use the given view if it is relevant to the item; and if this is not possible, then WBS 100 may invoke a parent view searcher 190 in order to go up the inheritance tree (or inheritance chain) and may use the higher level view(s) to display the given item. In some implementations, if no matching view is found, then WBS 100 may go up the Item Type inheritance tree (e.g., using fallback handler 181); whereas, in other implementations, if no matching view is found, then WBS 100 may go up the View inheritance tree (e.g., using the parent view searcher 190). Other implementations may utilize a combination of both methods, with a mechanism to determine on-the-fly which matching method to prefer, or which matched result to prefer and to utilize.
The created (modified) view is available for other items as well. When a derived view is created or modified, it may be applied to (or pre-associated with) existing items or item types.
WBS 100 may further provide the inverse option, allowing the designer to create derived types and have the WBS 100 automatically invoke a derived view generator 191 in order to automatically create a matching derived view as well; for example, creating a derived view based on derived type (instead of the other way around).
The designer may create the new component based on a single-component template. The view creator may further include such single-component templates together with the created view, and such component templates may be suggested to designers who wish to modify the template.
Component Landing Zones
Reference is made to
The landing zones may include designer-specified attributes which define rules for finding matching component templates. For example, if the designer specified that the new component is to be added to a wide column, the system may recommend a wide-format component template. This effect may operate in both directions, such that the landing zone selection may affect the recommended component templates, and vice versa.
Optionally, a landing zone generator 194 may generate landing zones automatically, including (for example): (a) At the end of each container or mini-page; (b) At the end of containers having a given type or attribute; (c) Following places where recent field additions were made; (d) At locations having at least given amount of empty screen space; (e) in a newly created page or mini-page (e.g., by adding component to an additional page in a multi-page container). When a component is added to a view (using a landing zone or otherwise), the view's layout is recalculated through the use of dynamic layout.
Applying a Derived View
Reference is made to
For example, the “bulk search and re-associate” module 195 may scan all types and/or items that are directly or indirectly associated with the existing view; and may re-associate them with the derived view. The criteria for re-association may include, for example: (a) Conditions based on item fields' content; (b) Conditions based on item fields' existence; (c) Condition based on type/item attributes; (d) a combination of the above criteria. Optionally, manual confirmation may be requested from the designer, with regard to which types/items to re-associate (e.g., requested on a per-type or per-item basis).
In a demonstrative example, when creating a “shirt” item type derived from the “product” item type, the designer may specify that the products collection would be scanned, and that all “product” items having the word “shirt” in their title and which have been created in the last two months would be automatically converted to the “shirt” type.
Customizations and Customization Dialogs
WBS 100 may comprise a customization module 201, which provides for the creation of customization dialogs which can be used by the designer (and possibly the end-user) to customize various parameters and attributes in the displayed list application.
It will be appreciated that customization module 201 may include, or may be associated with, or may utilize or implement, various features and/or technologies and/or sub-modules and/or processes, for example, as described in U.S. patent application Ser. No. ______, titled “A System and Method for Dialog Customization”, attorney docket number P-12939-US, which is being filed on the same day herein (Mar. 13, 2014) and which is hereby incorporated by reference in its entirety.
Such customization may be applied to website elements, including views, items and view/item combinations (e.g., a given item is customized in some way, but only when displayed in a given view). It may also be applied to third-party applications included in the created website. The customization option may be available to the designer, or possibly to down-stream users of the application having specific design/modification privileges.
The customization may affect attributes and elements of the specific items or views involved, as well as other objects related to them (e.g., through containment or inheritance). It may include customizations such as (for example): (a) Should the system display a given component at all (yes or no); (b) Fixed content (e.g., title text); (c) The display attributes (e.g., font, size, color) of a specific component; (d) Screen distances (e.g. distance between dish name and its description); (e) Counts (e.g. number of columns in multi-column display); (f) Generic parameters—which are handed over to the component/element handling the display; and/or other suitable customizations.
The WBS 100 supports customization through the use of generated dialogs which include attributes to be customized. Such dialogs are generated using a customization dialog builder 201A, displayed to the user (and able to interact with the user) using a customization dialog displayer 201B and are then applied to the affected elements using a customization dialog result applicator 201C;
In many cases, a single customization value should affect multiple elements. For example, the same color adaptation should apply to multiple components in the display view which need to remain harmonious; the distances between the right edge of the view and two separate components may be adjusted, but must remain the same for both components. Furthermore, a customization may affect (for example) a specific displayed view, all displayed views (of a given type, or of all types), all instances of a given view or views in a given scope (even if not currently displayed), or specific view instances as explicitly selected by the designer.
The effect of customization might not be identical on all affected objects. For example, components A and B may be required to maintain a particular layout, such as, that the distance of component B from the top of the view would be twice that of the distance of component A from the top of the view. In such case, the customization may be applied individually as required (using an object-specific formula).
An example customization dialog is shown in
Following this example,
The generated dialog may be pre-specified or automatically generated. It may also be a stand-alone UI element or integrated with the rest of the WBS 100 UI. It may also be automatically displayed, or require explicit invocation by the designer.
Specific Item Adaptation
WBS 100 may comprise a specific item adaptation module 196 to create adaptations to a specific item, for example, by adding (e.g., via drag-and-drop) specific components to a displayed item at the item level and in the context of a specific view. This may be used, for example, to add “decoration” elements to specific items, or to add additional information which is only available to certain specific items, without having to create separate item types and views.
For example, the WBS 100 may utilize a local variant creator 196A to automatically create a local variant of the view, or an “internal” derived view. The adaptations may be stored as a “layer” of modifications to the existing view inside this local variant of derived view. The WBS 100 may store this derived view at the site level or page level or LC level, together with an ID of the item for which this adaptation is applied. The adaptation may also be stored with the same list application whose instance is used in the site. The same LC or page may store multiple adaptations to multiple items. The WBS 100 applies the adaptation every time that the item is displayed with the specific view in the specific LC.
In some embodiments, optionally, the specific item adaptation module 196 may offer the capability to apply the same adaptations to other items in the same LC which use the same view, or to other views.
If adaptations are stored at the site level, then the adaptation will apply to instances of the same item being displayed in the same view in different LC's (or repeater components). It is noted that adaptations are different from item customization; for example, adaptations involve adding additional elements and components to an existing item, whereas customizations involve changing the parameters and attributes of one or items (or views) based on pre-defined possible customizations. It is noted that customizations may include “display component X or not”—which may make it appear similar to new component addition.
Filters and Search Box
Optionally, a search box creator 197 may enable the designer to specify that a given LC will display a subset of the associated collection items, selected according to given search criteria (e.g., a given query applied to the fields, or other filters). The designer may further specify that such search box would be shown to the end-user when viewing the LC, thereby allowing the end-user to selectively filter or search the displayed content. An example for such search box is shown in
LC Connections
Reference is made to
In a related list connection, which may be managed or handled by a related list connection manager 198A, a first LC “A” displays a “master items” collection (e.g., a hotel list); whereas a second LC “B displays a “subordinate items” collection (e.g., guest reviews for each hotel). A pre-specified field in the current item in LC “A” may be used to query the collection being displayed in LC “B” and select the subordinate items. The LC “B” would only display the selected items that match the current item in LC “A”. The designer may define additional filtering and/or sorting criteria to query on the subordinate items collection; for example, to select only the first K reviews, to select only reviews which include a specific rating range, or the like. This may be implemented in any suitable manner, including using a full query language (e.g., SQL). A single “master items” LC may be connected to multiple related list LC's; for example, allowing to add a related list display of the ten best reviews and/or the ten worst reviews. This may be achieved using repeater components contained in the view, rather than separate related LC's.
An aggregator field connection, which may be managed or handled by an aggregator field connection manager 198B, may be suitable when a related list connection has been defined. The designer may add a calculated field to the display in master items LC “A” which displays the value of an aggregation function applied to a specific field in the items in the subordinate list. Such aggregation function may include, for example, count, total, average, median, minimum, maximum, or other suitable function.
A tag cloud connection, which may be managed or handled by a tag cloud connection manager 198C, may connect a tag cloud LC to a regular LC, with both LC's being associated with the same collection(s). The tag cloud LC may be automatically filled with tags derived from the existing items in the associated list (or a portion thereof, based on filtering criteria). The user may multi-select a number of tags from the tag cloud LC. The selected tags are used to form a query, which serves as a filter and determines which items are shown in the second LC “B”. This may be a private case of “related query LC” (a related LC which is only used for querying).
In an item tree connection, which may be managed or handled by an item tree connection manager 198D the LC may display a sub-hierarchy of items (e.g., an item tree), such as an organizational chart or a family tree. The hierarchy may be defined through the existence of pointer fields in the items, for example, a pointer to parent item, or a set of linked pointers to sibling items. Other than the use of tree-like structure to display mini-pages (each of which containing a view which is used to view an item), the structure may be similar to other carousel—type LC's (which also display multiple items).
In a form display connection, which may be managed or handled by a form display connection manager 198E, an LC [a] may request that a given item [b] be opened in a given secondary LC [c], using either an automatically selected view or a specific view [d]. This may be used, for example, to display an alternative version of an item currently displayed in the LC [a]; such as, to display a detailed version of the same item with a more detailed view, or to display an alternative presentation of the same information (e.g., display location on a pop-up map instead of displaying a textual street address). Similarly, this method may be used to display an “add item” in order to create a new item; or to display an “update item” or “delete item” form.
AppStore Integration
Reference is made to
The developer may further define or attach icons, marketing material, price, search keywords, and various attributes to the objects offered in the AppStore 199. The offered objects may contain an encapsulated version of other objects required for them; for example, a view object may contain a number of item type objects which may be required for its operation.
The offered objects may optionally reference non-included objects; for example, a list application may rely on a particular view which is not included with it, and such a view would be provided by the including web site. The WBS 100 may utilize a missing reference handler 117 to resolve such missing reference upon inclusion by one or more suitable ways, for example: (a) Automatic resolution by missing reference name and type; (b) requesting the designer to provide explicit resolution; (c) Creating a “draft version” of the missing referenced object, based on the available information (type, name, attribute values) and marking it so the designer would have to complete it later, before publishing. The missing reference handler 117 may also perform a search for likely candidates (e.g., based on similar name, similar properties, specific search attributes) and may provide to the designer a ranked list of possible matches.
Discussions herein utilizing terms such as, for example, “processing,” “computing,” “calculating,” “determining,” “establishing”, “analyzing”, “checking”, or the like, may refer to operation(s) and/or process(es) of a computer, a computing platform, a computing system, or other electronic computing device, that manipulate and/or transform data represented as physical (e.g., electronic) quantities within the computer's registers and/or memories into other data similarly represented as physical quantities within the computer's registers and/or memories or other information storage medium that may store instructions to perform operations and/or processes.
Some embodiments of the present invention may take the form of an entirely hardware embodiment, an entirely software embodiment, or an embodiment including both hardware and software elements. Some embodiments of the present invention may be implemented in software, firmware, resident software, microcode, an application which may be downloaded and/or installed by a user, an application which may run in a browser, a client-side application, a server-side application, a client-server application, or the like. Some embodiments of the present invention may take the form of a computer program product accessible from a computer-usable or computer-readable medium providing program code for use by or in connection with a computer or any instruction execution system. For example, a computer-usable or computer-readable medium may be or may include any apparatus that can contain, store, communicate, propagate, or transport the program for use by or in connection with the instruction execution system or device. Some embodiments of the present invention may be implemented, for example, using a machine-readable medium or article which may store an instruction or a set of instructions that, if executed by a machine, cause the machine (e.g., a computer or an electronic device) to perform a method and/or operations described herein.
Some embodiments of the present invention may include or may utilize, for example, a processor, a central processing unit (CPU), a digital signal processor (DSP), a controller, an integrated circuit (IC), a memory unit, a storage unit, input units, output units, wired and/or wireless communication units, an operating system, and other suitable hardware components and/or software modules.
Some embodiments may be implemented as, or by utilizing, an application or “app” for a Smartphone or tablet or portable computing device, which may be downloaded and/or installed onto such electronic device from an “app store” or an online marketplace for applications.
Functions, operations, components and/or features described herein with reference to one or more embodiments of the present invention, may be combined with, or may be utilized in combination with, one or more other functions, operations, components and/or features described herein with reference to one or more other embodiments of the present invention.
While certain features of the present invention have been illustrated and described herein, many modifications, substitutions, changes, and equivalents may occur to those skilled in the art. Accordingly, the claims are intended to cover all such modifications, substitutions, changes, and equivalents.
This application claims priority and benefit from U.S. provisional patent application No. 61/781,866, filed on Mar. 14, 2013, which is hereby incorporated by reference in its entirety.
Number | Date | Country | |
---|---|---|---|
61781866 | Mar 2013 | US |