US20160103820A1 - Authoring tool for the authoring of wrap packages of cards - Google Patents
Authoring tool for the authoring of wrap packages of cards Download PDFInfo
- Publication number
- US20160103820A1 US20160103820A1 US14/740,539 US201514740539A US2016103820A1 US 20160103820 A1 US20160103820 A1 US 20160103820A1 US 201514740539 A US201514740539 A US 201514740539A US 2016103820 A1 US2016103820 A1 US 2016103820A1
- Authority
- US
- United States
- Prior art keywords
- card
- wrap
- authoring
- tool
- cards
- Prior art date
- Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
- Abandoned
Links
Images
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F16/00—Information retrieval; Database structures therefor; File system structures therefor
- G06F16/20—Information retrieval; Database structures therefor; File system structures therefor of structured data, e.g. relational data
- G06F16/28—Databases characterised by their database models, e.g. relational or object models
- G06F16/284—Relational databases
- G06F16/285—Clustering or classification
-
- G06F17/248—
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F16/00—Information retrieval; Database structures therefor; File system structures therefor
- G06F16/20—Information retrieval; Database structures therefor; File system structures therefor of structured data, e.g. relational data
- G06F16/24—Querying
- G06F16/245—Query processing
- G06F16/2457—Query processing with adaptation to user needs
- G06F16/24575—Query processing with adaptation to user needs using context
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F16/00—Information retrieval; Database structures therefor; File system structures therefor
- G06F16/20—Information retrieval; Database structures therefor; File system structures therefor of structured data, e.g. relational data
- G06F16/28—Databases characterised by their database models, e.g. relational or object models
- G06F16/284—Relational databases
- G06F16/285—Clustering or classification
- G06F16/287—Visualization; Browsing
-
- G06F17/2247—
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F3/00—Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
- G06F3/01—Input arrangements or combined input and output arrangements for interaction between user and computer
- G06F3/048—Interaction techniques based on graphical user interfaces [GUI]
- G06F3/0484—Interaction techniques based on graphical user interfaces [GUI] for the control of specific functions or operations, e.g. selecting or manipulating an object, an image or a displayed text element, setting a parameter value or selecting a range
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F3/00—Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
- G06F3/01—Input arrangements or combined input and output arrangements for interaction between user and computer
- G06F3/048—Interaction techniques based on graphical user interfaces [GUI]
- G06F3/0484—Interaction techniques based on graphical user interfaces [GUI] for the control of specific functions or operations, e.g. selecting or manipulating an object, an image or a displayed text element, setting a parameter value or selecting a range
- G06F3/04842—Selection of displayed objects or displayed text elements
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F3/00—Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
- G06F3/01—Input arrangements or combined input and output arrangements for interaction between user and computer
- G06F3/048—Interaction techniques based on graphical user interfaces [GUI]
- G06F3/0484—Interaction techniques based on graphical user interfaces [GUI] for the control of specific functions or operations, e.g. selecting or manipulating an object, an image or a displayed text element, setting a parameter value or selecting a range
- G06F3/0485—Scrolling or panning
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F40/00—Handling natural language data
- G06F40/10—Text processing
- G06F40/103—Formatting, i.e. changing of presentation of documents
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F40/00—Handling natural language data
- G06F40/10—Text processing
- G06F40/103—Formatting, i.e. changing of presentation of documents
- G06F40/106—Display of layout of documents; Previewing
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F40/00—Handling natural language data
- G06F40/10—Text processing
- G06F40/12—Use of codes for handling textual entities
- G06F40/14—Tree-structured documents
- G06F40/143—Markup, e.g. Standard Generalized Markup Language [SGML] or Document Type Definition [DTD]
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F40/00—Handling natural language data
- G06F40/10—Text processing
- G06F40/166—Editing, e.g. inserting or deleting
- G06F40/186—Templates
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06Q—INFORMATION AND COMMUNICATION TECHNOLOGY [ICT] SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES; SYSTEMS OR METHODS SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES, NOT OTHERWISE PROVIDED FOR
- G06Q30/00—Commerce
- G06Q30/02—Marketing; Price estimation or determination; Fundraising
- G06Q30/0241—Advertisements
- G06Q30/0276—Advertisement creation
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06Q—INFORMATION AND COMMUNICATION TECHNOLOGY [ICT] SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES; SYSTEMS OR METHODS SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES, NOT OTHERWISE PROVIDED FOR
- G06Q30/00—Commerce
- G06Q30/06—Buying, selling or leasing transactions
- G06Q30/0601—Electronic shopping [e-shopping]
- G06Q30/0633—Lists, e.g. purchase orders, compilation or processing
- G06Q30/0635—Processing of requisition or of purchase orders
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06Q—INFORMATION AND COMMUNICATION TECHNOLOGY [ICT] SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES; SYSTEMS OR METHODS SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES, NOT OTHERWISE PROVIDED FOR
- G06Q30/00—Commerce
- G06Q30/06—Buying, selling or leasing transactions
- G06Q30/0601—Electronic shopping [e-shopping]
- G06Q30/0641—Shopping interfaces
- G06Q30/0643—Graphical representation of items or shoppers
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L67/00—Network arrangements or protocols for supporting network services or applications
- H04L67/01—Protocols
- H04L67/02—Protocols based on web technology, e.g. hypertext transfer protocol [HTTP]
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04W—WIRELESS COMMUNICATION NETWORKS
- H04W4/00—Services specially adapted for wireless communication networks; Facilities therefor
- H04W4/02—Services making use of location information
- H04W4/021—Services related to particular areas, e.g. point of interest [POI] services, venue services or geofences
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04W—WIRELESS COMMUNICATION NETWORKS
- H04W4/00—Services specially adapted for wireless communication networks; Facilities therefor
- H04W4/02—Services making use of location information
- H04W4/025—Services making use of location information using location based information parameters
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04W—WIRELESS COMMUNICATION NETWORKS
- H04W40/00—Communication routing or communication path finding
- H04W40/24—Connectivity information management, e.g. connectivity discovery or connectivity update
- H04W40/244—Connectivity information management, e.g. connectivity discovery or connectivity update using a network of reference devices, e.g. beaconing
Definitions
- This invention relates to a media-authoring tool, and more particularly, to an authoring tool for the authoring of wrapped packages of cards.
- wrap packages a new media content type, referred to as “wrap packages”.
- wrap packages are interchangeably used herein to refer to wrap packages.
- a wrap package is a collection of cards that are each selectively authored to include (i) one or more types of media content such as text, images, photos, video, etc., (ii) application functionality and/or (hi) e-commerce related services.
- the cards in a wrap are also typically authored to define one or more linear sequence(s) when consumed.
- wrap packages an author thus has the ability to select media content, combined with application-like and website functionality, and combine them all into an elegant, card-based, narrative. As a result, the author can create compelling stories using media, interwoven with interactive functionality and/or e-commerce services.
- Wrap packages are, therefore, ideal, but not necessarily limited to, delivering a unique, interactive, “book-like”, experience to the mobile web, which previously has been not possible.
- the cards of wrap packages are navigation metaphors. Each card can be authored to group related information that can be easily consumed within a user interface experience by swipe (or other simple gesture) navigation from card-to-card.
- Cards have a visual representation intended to evoke similarities to their physical counterparts. They have a fixed portrait aspect ratio that makes them ideally suited to current mobile computing devices as well as easy to scale up to and arrange to fit other display form factors, such as provided on laptop and desktop computers as well as smart TVs.
- the physical card metaphor can also extend to the interactive behavior of cards in a wrap, as the user can use gestures that evoke the “flipping” of cards in a deck or bound booklet to navigate between them.
- each card in a wrap has defined content that is displayed in a predefined layout.
- the cards in a wrap have the same size and aspect ratio.
- the aspect ratio is preferably device independent and is preferably maintained regardless of device orientation and/or display window size.
- Cards are like containers for holding and distributing media content, such as text, images, photos, audio, video and the like.
- cards may also contain or hold executable objects that provide or enable real-time features, such as application functionality (i.e., the ability to schedule appointments, engage in online chats or conversations) and support e-commerce related services (i.e., the ability to purchase goods and/or services).
- application functionality i.e., the ability to schedule appointments, engage in online chats or conversations
- e-commerce related services i.e., the ability to purchase goods and/or services.
- the multimedia content and/or interactive services contained by any given card can be determined entirely in advance or as late as the moment the wrap is consumed by the end-user.
- Such media content and executable objects are sometimes referred to herein as card “assets.”
- a gallery card provides the ability to present an expanded amount of content in a vertically stacked orientation such that the overall length (i.e., the number of cards or in a horizontal sequence) of the wrap is not affected by the amount of content in the wrap. This aids in navigation since the user can flip to the previous or next card regardless of their current position in the gallery.
- Wrap packages are delivered and rendered in a browser as a sharable and savable message. Wrap packages thus provides an app-like user experience that is delivered as a live, interactive, message from a cloud-based platform, using for example, the Software as a Service (SaaS) model.
- SaaS Software as a Service
- a wrap is thus a portable container of multimedia content, and interactive services, designed for ease of delivery, exchange, and consumption.
- Wrap packages are also consumable anywhere, meaning they have the ability to be resolved and displayed on just about any type of device (mobile phones, laptops, tablets, wearable computing devices such as smart watches, desktop computers, smart TVs, etc.), regardless of the platform (e.g., iOS, Android, Microsoft, etc.). Wrap packages are thus platform and device independent. Wraps do not have to be written for any specific platform, such as iOS or Android, or for any specific device or class of devices (e.g. smart phones, tablets, desktops, etc.).
- Wrap packages are thus a mobile-first marketing and commerce platform that ideally provides a beautiful world of storytelling in bite-size moments that get and hold attention.
- unique characteristics of (i) authoring once and running on almost any device, regardless of the operating system or the type and (ii) the ability to easily distribute wrap packages similar to messages, together are a powerful construct that potentially can make the use of wrap packages near universal.
- wrap packages Businesses and other organizations can simply and cheaply create, distribute, and manage storytelling mobile web user experiences, app like functionality and e-commerce, all in the context of wrap packages delivered directly to consumers.
- businesses used to have to build destinations (websites) or use monolithic systems (apps) they can now provide consumers, particularly mobile device users, with a user experience that delivers the content they want combined with a complementary palette of functions and/or e-commerce related services.
- wrap packages thus solves a number of current problem with the mobile web. Unlike web sites, wrap packages are easy to consume on mobile devices and offer the opportunity to create compelling narratives and user experiences. In addition, the ability to incorporate app-like functionality into wraps provides a multi-function app-like experience, without having to develop an app, be in an app, download an app, or open several apps.
- wrap packages creates opportunities for business and other organizations alike to innovate and improve marketing efforts, customer support, and user experiences in ways previously not possible, because an enabling interface and platform did not exist. Wrap packages can thus potentially define the next generation interactive web paradigm, particularly for mobile, although for desktop and other types of devices as well.
- the present invention is directed to an authoring tool for authoring wrap packages of cards.
- the authoring tool includes a set of tools that enable an author to create a new card of a wrap selected from a variety of card templates.
- the card templates include textual, video, image/photo, document, gallery, chat, location/GPS, transact, appointment, and end-of-wrap card templates.
- the template is then duplicated to create the new card.
- the author may author the card to include various components, content, attributes, layouts, styles triggers and/or behaviors.
- the authoring tool provides the author with the ability to order the sequence of the cards.
- the authoring tool thus enables authors to selectively create wrap packages that include media that conveys a narrative story and application functionality. Wrap packages are thus conducive for conducting e-commerce in a manner that has not previously been possible.
- the authoring tool is further configured to generate (i) a wrap descriptor that specifies the set of cards associated with the wrap package as authored, (ii) a structure, layout and content of the set of cards suitable for display on a computer display separately from their presentation, and (iii) a plurality of card descriptors, each card descriptor arranged to define the content, structure and layout of an associated one of the cards.
- the wrap descriptor and/or the card descriptor is/are a data object(s), such as, but not limited to JSON or BSON data objects.
- the authoring tool is also configured to generate the wrap descriptor that defines the wrap package at runtime.
- the authoring tool generates the wrap descriptor by (i) generating one or more data objects for the cards of the wrap package respectively and (ii) generating the wrap descriptor from the one or more data objects for the cards of the wrap package respectively.
- the wrap descriptor defines the wrap package at runtime.
- the authoring tool enables the authoring of a gallery card among the plurality of cards of the wrap package.
- the authoring tool enables the author to (i) select a gallery card among all the different types of cards for authoring, (ii) select a frame template among one or more frame template types, (iii) a new frame from the selected frame template by duplicating the frame template, (iv) author the new frame, (v) repeat steps (i) through (iv) for each frame in the gallery card and (vi) define a sequence order for all the frames of the gallery card.
- FIG. 1 is a diagram illustrating a wrap package layout that includes a plurality of cards threaded together so as to be viewable in linear arrays in accordance with the principles of the present invention.
- FIG. 2 is a diagram depicting the design, functionality and data integration capabilities of a representative card in a digital companion wrap package according to the principles of the present invention.
- FIG. 3 is a diagram illustrating the media content and distribution model for distributing digital companion wrap packages in accordance with the principles of the present invention.
- FIG. 4 is a block diagram of a representative system for authoring, storing, distributing, and consuming wrap packages in accordance with the principles of the present invention.
- FIG. 5A diagrammatically illustrates selected components associated with defining and rendering a representative wrap package.
- FIG. 5B diagrammatically illustrates selected components associated with defining and rendering a representative wrap package in accordance with another embodiment that utilizes state descriptors and/or behavior extensions.
- FIG. 6 is a diagram illustrating the hierarchy of a wrap descriptor in accordance with the principles of the present invention.
- FIG. 6A is a diagram illustrating the hierarchy of a particular card descriptor in accordance with the principles of the present invention.
- FIG. 6B is a diagram illustrating the hierarchy of a second card descriptor embodiment.
- FIG. 6C is a diagram illustrating the hierarchy of a gallery card wrap descriptor embodiment.
- FIG. 6D is a diagram illustrating the hierarchy of a trigger component descriptor embodiment.
- FIG. 6E is a diagram illustrating a feed card in accordance with another non-exclusive embodiment of the present invention.
- FIG. 7 is a home screen for an authoring tool used for authoring wrap packages in accordance with a non-exclusive embodiment of the invention.
- FIG. 8 illustrates an exemplary window for defining a title for a new wrap to be authored according to a non-exclusive embodiment.
- FIG. 9 illustrates a non-exclusive embodiment for an authoring workspace space for the authoring of wrap packages using the authoring tool of the present invention.
- FIGS. 10A through 10C illustrate a header of the workspace for the authoring of wrap packages using the authoring tool of the present invention.
- FIGS. 11A through 11C illustrates the authoring of a textual card using the authoring tool of the present invention.
- FIGS. 12A through 12C illustrate the authoring of an image card using the authoring tool of the present invention.
- FIGS. 13A through 13B illustrate the authoring of a video card using the authoring tool of the present invention.
- FIGS. 14A through 14C illustrate the authoring of a document card using the authoring tool of the present invention.
- FIGS. 15A through 15C illustrate the authoring of a chat card using the authoring tool of the present invention.
- FIGS. 16A and 16F illustrate the authoring of an appointment card in accordance with multiple embodiments using the authoring tool of the present invention.
- FIGS. 17A through 17F illustrate the authoring of a location/GPS card in accordance with multiple embodiments using the authoring tool of the present invention.
- FIGS. 18A through 18E illustrate the authoring of a transact card using the authoring tool of the present invention.
- FIGS. 19A through 19E illustrate the authoring of a gallery card using the authoring tool of the present invention.
- FIGS. 20A through 20B illustrate the authoring of an end of wrap card using the authoring tool of the present invention.
- FIG. 21 is a flow chart illustrating the steps of authoring a wrap package in accordance with a non-exclusive embodiment of the present invention.
- FIG. 22 is a flow chart illustrating the steps of a background process run by the authoring tool during the authoring of a wrap package in accordance with a non-exclusive embodiment of the present invention.
- FIG. 23 is a flow chart illustrating the steps of generating a card descriptor for a card in accordance with a non-exclusive embodiment of the invention.
- FIG. 24 is a flow diagram illustrating the steps of generating a wrap descriptor from one or more card descriptors in accordance with a non-exclusive embodiment of the invention.
- the cards of the wrap packages are ideally authored in one or more linear sequences so that a book-like narrative unfolds, not only through the cards themselves, but also by the transition between the cards, as they are sequentially browsed.
- the wrap packages are portable objects that may exist within a social feed or within a custom application. Wrap packages are also readily distributed, similar to electronic messages, through e-mail, messaging, social-media, or via a variety of other electronic communication platforms. As a result, wrap packages are consumable, sharable and savable objects.
- the cards are browsed in the one or more linear sequences during consumption, the user experiences the unfolding of the authored narrative, including the defined media content interwoven with the complementary application functionality and/or e-commerce related services.
- the entire user experience including any application functionality and/or e-commerce related services is substantially contained within the context of the wrap package itself, typically (but not necessarily) without the need to navigate to other sites.
- the wrap package 10 includes a plurality of cards 14 that are threaded together so as to enable browsing by swiping in one or more linear sequences.
- Any of the cards 14 may optionally include various types of media, such as text, images or photos, audio, video, a live or streaming feed of media, 3-D objects, or content from other wrap packages (not illustrated).
- Any of the cards 14 may also optionally provide application functionality, such as the ability to receive input data or display dynamically generated data, a calendar for scheduling or booking appointments or making reservations for goods and/or services, location/GPS, etc.
- any of the cards 14 may optionally provide or support e-commerce services, such as the ability to browse products in a catalog, communicate with an online sales representative, and/or purchase product(s).
- card 14 A includes text
- card 14 B presents a gallery
- card 14 C includes images or pictures
- card 14 D includes a video
- card 14 E includes e-commerce related service(s)
- card 14 F includes a calendar function for scheduling appointments and/or booking reservations
- card 14 G includes a user approval function
- 14 n-1 includes a data entry function
- card 14 N includes location or GPS services, etc.
- the cards 14 of wrap packages 10 can be navigated linearly by swiping or by using other suitable interfaces, such as a stylus or pen.
- swiping In devices without a touch sensitive screen, alternative user interfaces are provided to facilitate transition (e.g., flipping) from one card to the next.
- swipe-browsing or “swiping” is intended to mean the navigation from one card to an adjacent next card.
- swipe browsing is typically implemented by the sliding of a finger or other input device across the display.
- other navigation tools such as a mouse, keyboard or remote control, can be used for swipe browsing.
- the content of the next card in the sequence is displayed. For example, by swiping either right to left or vice versa, the next card, depending on the swipe direction, in the horizontal sequence is displayed. Similarly, by swiping up and/or down, the next card in either the up or down sequence is displayed.
- the user experience when consuming a wrap package is the wrap package itself (as opposed to a remote web site for example), viewable via a swipe-able interface.
- some cards may also include one or more embedded link(s) that, when selected, enable navigation to either a non-adjacent card not in linear sequence or to another wrap package, a web page or some other location entirely outside of the wrap package.
- cards 14 in the wrap package 10 illustrated in FIG. 1 is merely illustrative. Both the number of rows and/or columns, and the number of sequential cards 14 within any given row or column, may vary widely as appropriate to deliver the desired user experience, narrative, content, functionality and services of the wrap package 10 .
- swiping allows for the scrolling through of the contents of a card 14 , which are typically too voluminous to be displayed within the size of a fixed screen display, such as that provided on a mobile phone.
- a particular wrap package 10 may include a plurality of cards organized in a horizontal sequence. By swiping right to left or vice versa, the next card 14 or the previous card 14 in the horizontal sequence is displayed. In the vertical direction, however, one or more selected cards 14 B may be configured in the gallery format, allowing the viewer to scroll up or down by swiping through media content of the gallery.
- a wrap package 10 authored and distributed by a car rental business may include a horizontal sequence of cards 10 , each dedicated to a category of information pertinent to a traveler (i.e., cards dedicated to local hotels, restaurants, local tourist attractions respectively).
- a traveler i.e., cards dedicated to local hotels, restaurants, local tourist attractions respectively.
- relevant material within each category is displayed in a gallery format. For instance by swiping up or down the hotel card (not illustrated), a gallery of a number of local hotels is displayed.
- the behavior invoked by an up or down swipe may differ. For example, swiping up or down my result in a continuous “rolling” of the content of the gallery card.
- an up or down swipe may result in a “snap” action with the next item of content appearing after the snap, for example, as illustrated as cards 14 Y and 14 Z in FIG. 1 .
- the wrap package 10 is identified, as described in more detail below, through the use of a unique identifier (wrap ID 42 ) assigned to the package 10 .
- the wrap ID 42 may take the form of a Uniform Resource Identifier (URL).
- URL Uniform Resource Identifier
- the wrap ID may thus be provided as a link, which can readily be used to effectively send or retrieve the wrap package. That is, the wrap package may effectively be “sent” to a potential viewer as a link using any of the wide variety of mechanism that can currently—or in the future—be used to send a link or convey the URL.
- this may include e-mail messages, text messages, SMS messages, via a Twitter tweet, as a post on social media such as Facebook, etc., discussion forums, walls or the like, as a link embedded in a document, an image, or a web page or any other media type, in a blog or micro blog (e.g. Tumblr), or any other messaging or electronic content distribution mechanism or communication platform currently known or developed in the future.
- social media such as Facebook, etc., discussion forums, walls or the like
- a blog or micro blog e.g. Tumblr
- Wrap packages are therefore significantly different and more powerful than web sites. For example with wrap packages, they can be consumed “on the spot” where it is located (i.e., when delivered to a mobile device for example). In contrast with the selection of a banner ad appearing within a web site, where the viewer is taken to a new web page that is not (a) necessarily designed for mobile devices and (b) is self navigating, making it very difficult for a narrative to be conveyed. As a result, the user experience, particularly on mobile devices, may be very poor. Hence, the friction of providing a compelling user experience with wrap packages is far less than with web site.
- the cards 14 of a wrap 10 can be displayed on the screen of virtually any type of computing device. It should be appreciated that the card metaphor is particularly well suited for use on mobile devices such as smart phones, tablet computers, etc., which makes the format particularly powerful for authors interested in developing content tailored for mobile devices.
- wrap packages 10 By delivering wrap packages 10 to mobile devices, users and potential customers can be won over at their point of intimacy, where they spend their time and consciousness. Wrap packages thus allow authors, merchants and other content providers to create compelling narratives and provide ongoing application functionality and/or e-commerce support directly delivered anytime and anywhere to users, transforming their mobile devices into a powerful business tool that enhances mobile engagement and relationships. As a result, higher customer satisfaction, better brand engagement, and a higher conversion (i.e., click-through rates) and repeat e-commerce related activity compared to other forms of after sale promotions and merchandising will likely result.
- FIG. 2 a diagram depicting the design, functionality and data integration capabilities of a representative card 14 in a wrap package 10 is shown.
- the author By using card templates, authoring tools and media collaboration tools, beautiful, content-rich, cards 14 may be created either by automation or by individuals with even minimal design skills and experience.
- the author either a person or an automated process, has the ability to easily create beautiful content-rich cards 14 that can selectively include text, images, photos, and other media similar to PDF files, but optionally, with the added benefit of additional application functionality and/or e-commerce related services, either embedded in the same card 14 , or other cards 14 , in the wrap package 10 .
- the content of a card 14 can be populated by a data processing system that automatically uploads predefined content into various defined fields of a card template.
- component libraries and the authoring tools allow for the authoring of cards 14 with a diverse, easy to use, reusable, set of component modules that provide a wide variety of application functions and e-commerce services.
- application functions include, but are not limited to, for example, calendar functions, scheduling of an appointment functions, reserving or booking goods and/or services, such as a car rental, hotel room, or table at a restaurant, map or GPS related functions, support for online conversations, streaming live video or other media feeds, etc.
- e-commerce related services include displaying product and/or service offerings, displaying user account information, engaging a sales representative in an online chat session, and enabling the purchase of goods and/or services, etc.
- a calendar plugin could be configured to communicate with a reservation booking database plugin, which could communicate with a chat plugin.
- the communication among the various plug-in services is accomplished through a common set of APIs.
- the interactivity, functionality and usefulness of wrap packages 10 are significantly enhanced by such an ecosystem of connected plug-in services.
- a card 14 can be integrated with the back end software system for a large online retailer, which will automatically populate the content of a card 14 with product images, user account information, prior purchase information, and a host of other user-related information.
- a card 14 can be used to capture data input from a user and provide it to a retailer's back end e-commerce software system.
- a card 14 may display a one-click “Buy Now” function for a displayed item. When the Buy Now function is selected, previously saved user account information is automatically delivered to the back end software system of the online merchant, which then processes the information to complete the transaction.
- the data entered by the user and/or the data presented via a card 14 of a wrap package 10 may thus be integrated with the back-end database, cloud computing services, web sites, etc., regardless if managed by an author and/or distributor of the wrap package or by a third party.
- the data processing for the purchase of goods and/or services, appointments, and/or other application functionality and e-commerce related services may, therefore, be performed either within the wrap packages 10 itself or integrated with a remote data processing resource.
- cards 14 can also be shared among other cards 14 in the same wrap package 10 , with other wrap packages, with web sites, or just about any other data processing system.
- the content that may be included in the various cards 14 of a wrap package 10 may include photos and/or images, audio, video, text, 3-D objects, various types of streaming media (e.g., audio, video, audiovisual, data, biometric information, tickers, sensor outputs, etc.), other data types, application functionality and/or e-commerce services.
- This content may further be combined with content mixed from other wrap packages 10 as well as live or streaming content.
- the cards 14 of the wrap package 10 may be further modified based on analytics, intelligent personalization based on the demographics of targeted users or viewers, as well as the integration of either data input or data output to/from with other cards 14 , other wrap packages 10 , or remote data processing systems and processes, as explained above.
- wrap packages are “light-weight”, meaning content of the wrap package 10 is delivered over a network to a user only when the wrap ID 42 for the wrap package 10 and/or each card 14 is identified.
- the media content, application functionality, and/or e-commerce related services is delivered only when needed.
- the cards 14 of wrap packages 10 can be written once and are viewable on a display associated with almost any computing device running a browser. Accordingly, unlike applications, multiple version of a wrap package 10 need not be authored for multiple platforms.
- wrap package 10 is thus essentially a cloud based portable object that may be readily distributed in a number of ways.
- wrap packages 10 may be distributed by email, SMS messaging, ad networks, Twitter, merchant/retailer web sites, photo and/or video sharing web sites that support messaging, social networking web site such as Facebook, through the down-loading of applications from aggregators such as the Apple App Store or Google Play, or just about any means for electronically distributing data over a network, currently known or developed in the future.
- the system 20 includes a server node 22 , a plurality of computing devices 12 , including but not limited to a desktop computer 12 A, a laptop computer 12 B, a tablet computer 12 C, a mobile “smart” phone 12 D, a wearable computing device, such as a smart watch 12 E or smart glasses 12 F and “smart” TVs 12 G.
- the server node 22 and the computing devices 12 A- 12 G communicate with one another over a network 24 .
- the network 24 may be the Internet, an intranet, a wired or wireless network, a Wi-Fi network, a cellular network, other types of communication networks, or any combination thereof.
- the server node 22 includes a “wrap” engine 26 , which defines a web application framework 28 , a storage device 30 and cache 32 , each for storing wrap packages 10 and other data.
- the server node 22 also may include a suite of tools, such as an authoring tool (as described in detail below), an analytic engine tool, a media collaboration tool and a data transformation tool, for authoring wrap packages 10 .
- the web application framework 28 is a software platform designed to support the manual and/or automated authoring of wrap packages 10 .
- the framework 28 is designed to alleviate the overhead associated with common activities performed during the authoring of many wrap packages 10 .
- the framework 28 may include one or more libraries to help with the authoring of common tasks, and modularizes and promotes the reuse of code designed to perform specific tasks, such as implementing application functionality and/or supporting e-commerce.
- the web application framework 28 may be implemented using, but is not limited to, Ruby, Rails, JavaScript, Angular-JS, and/or any other language or framework currently known or developed and used in the future.
- the web application framework 28 of the wrap engine 26 also performs content management as a way of organizing, categorizing, and structuring the media and other content resources such as text, es, documents, audio files, video files and modularized software code so that the content of wrap packages 10 can be stored, published, reused and edited with ease and flexibility.
- the content management function is also used to collect, manage, and publish content, storing it either as components or whole documents, while maintaining dynamic links between the components and/or cards 14 of a wrap package 10 .
- the web application framework 28 of the wrap engine 26 is structured around multiple tiers, including but not limited to a client tier, an application tier and a database tier.
- the client tier refers to the browser enabled communication devices 12 that execute and display cards 14 of wrap packages 10 , as well as web pages written in HTML or another mark-up language.
- the database tier which is maintained in storage 30 , contains the one or more libraries of user and/or platform provided media content, software components, modules, etc. used for the authoring of wrap packages 10 .
- the application tier contains the software that runs on the server node 22 and that retrieves and serves the appropriate wrap package 10 from storage 30 and/or cache 32 when requested by a computing device 12 .
- wrap packages 10 are essentially data objects, they can be both cached and delivered over a Content Delivery Network Interconnection (CDN), both of which can be effectively used to deliver wrap packages 10 with minimal delay.
- CDN Content Delivery Network Interconnection
- commonly requested wrap packages 10 may be cached in the cache 32 , which provides faster access and delivery times than storage 30 .
- other caching techniques such as pre-caching, may be used with popular wrap packages 10 , to speed up delivery times. Since the amount of storage in the cache is typically limited, cached wrap packages 10 and other data may be periodically replaced by any known replacement algorithm, such as first-in, first-out or least recently used for example.
- one or more author(s) 34 may access the server node 22 over a network 36 , which may be different or the same as network 24 .
- the author(s) 36 interact with the wrap engine 26 , including the web application framework 28 , and the above-mentioned suite of tools for the creation, editing, optimization and storing of wrap packages 10 .
- the one or more author(s) 34 can also access third party content 38 for inclusion into a wrap package 10 .
- wrap packages 10 can be authored manually by one or more individuals or electronically in an automated process.
- wrap engine 26 fetches the corresponding wrap package 10 from storage 30 or the cache 32 and serves it to the requesting computing device 12 for consumption in a format customized for the viewing device.
- FIG. 4 the authoring and distribution diagram of FIG. 4 is merely representative and should not be construed as limiting.
- multiple server nodes 22 for the authoring and/or distribution of wrap packages 10 may be provided at the same or different locations.
- multiple instantiations of a given wrap package can 10 be stored at multiple server nodes 22 , typically located at different geographic locations.
- the server node 22 that is most capable of quickly delivering a requested wrap package 10 is the node 22 that will deliver the wrap package to the requesting device 12 .
- a wrap package 10 includes a set of one or more cards 14 .
- Each card 14 may contain one or more components 16 that serve as containers for content objects 17 .
- the content objects 17 together with the behaviors associated with the cards and components 16 , define the content and functionality of the cards.
- the content objects 17 may be simple or complex.
- Simple content objects 17 include standard web-based content types such as text, images, video clips, etc.
- More complex content objects 17 may include objects having more complicated structures and/or behaviors, as will be described in more detail below.
- the structure of the wrap 10 including the structure, layout and components 16 of each of its cards 14 is preferably defined by a wrap descriptor 40 .
- the actual structure of the descriptor 40 may vary widely and a few different suitable descriptor structures are described in more detail below with respect to FIGS. 6-6D .
- Some content objects 17 such as text, may be directly included (in-line) in the component 16 .
- Other content objects 17 such as images or video clips, may be included by reference, e.g., through simple URL references, or in-line through an encoding method such as MIME (Multi-Purpose Internet Mail Extensions).
- Complex content objects 17 may be specified in-line or by reference and may (a) contain other components 16 or content objects 17 and/or (b) specify abstract behaviors.
- Referenced content objects 17 stored outside of the wrap descriptor 40 are sometimes referred to herein as assets 65 .
- the referenced assets 65 may take the form of almost any type of content that can be included in the wrap package. This can include text, photos, images, 3-D objects, audio, video, and other media content or streams and/or a variety of executable objects, services and/or other functionality.
- an asset may take the form of a stream and the wrap descriptor 40 is arranged to identify the source of the stream (i.e., the feed).
- the stream could be a live audio or video stream, a data feed such as a stock ticker, sensor outputs, biometric information, etc.
- some or all of the assets 65 associated with a wrap 10 may be stored and accessible from a dedicated wrap server. However, that is not a requirement. Rather, an asset can be retrieved from any location that would be accessible by the consuming device (e.g., through the Internet, an intranet or private network or any other reliable means), and there is no need for the various assets 65 to be located in a single asset store, although that may be desirable in many circumstances.
- the wrap package 10 has an associated identifier, the wrap ID 42 , that uniquely identifies the wrap 10 .
- the wrap ID is preferably a globally unique identifier (GUID).
- GUID globally unique identifier
- the wrap ID 42 takes the form of a URL, or any other identifier that can be converted to, or extracted from, a URL, which facilitates access to the wrap 10 over the Internet using conventional mechanisms.
- An example of a conversion of the wrap ID to a URL might be adding a domain as a prefix to the wrap ID to form a URL (e.g., www.wrap.com/wrap/ ⁇ wrapID>).
- FIG. 5A also diagrammatically illustrates selected components associated with defining and rendering a representative wrap package 10 .
- the illustrated components may optionally include one or more covers 15 , a wrap descriptor 40 , a wrap runtime viewer 50 and various referenced external assets 65 .
- the wrap descriptor 40 defines the structure, layout and components 16 of each of the cards 14 within the wrap package 10 .
- the wrap descriptor 40 typically includes the wrap ID 42 and a set, deck or array of card definitions or card descriptors 46 , each defining the structure of an associated card (as described with respect to FIG. 6 for example).
- the wrap descriptor 40 may also include other information of interest such as a wrap name/title 44 and optionally one or more cover identifier(s) 43 and/or other information or metadata 45 about the wrap package 10 .
- the wrap is preferably stored in a data format that separates the data from the presentation.
- JavaScript Object Notation JSON
- JSON JavaScript Object Notation
- the definition of the wrap package 10 may be stored as a JSON data object at the server(s) 22 . That is, the descriptor 40 may take the form of a JSON object.
- a BSON (Binary JSON) data object may be used.
- JSON or BSON data objects is described, it should be appreciated that in other embodiments, the wrap package 10 may be stored in a variety of other suitable formats, whether now existing or later developed.
- the optional cover 15 of the wrap package 10 is typically a graphic object that contains an embedded hyperlink to the wrap (e.g., the URL used as wrap ID 42 ) and can be placed in any suitable type of electronic media to represent the wrap package 10 .
- a wrap 10 may be accessed by clicking on or otherwise selecting the cover 15 or by clicking on, or otherwise selecting any other type of link containing the wrap ID 42 .
- either the cover 15 or a link can be distributed to potential viewers of the wrap package 10 using any available tool.
- the wrap package 10 may be distributed by: (i) placing the cover 15 or a link on a webpage, in an ad or in any other location that can be accessed by a potential viewer via a browser; (ii) by posting the cover 15 or a link on a blog, a micro blog, a forum, a wall etc. or any social media distribution mechanism such as Facebook, Twitter, etc.; (iii) by including the cover 15 or a link in a message such as e-mail, SMS message, a Twitter Tweet, text messages, etc.; or (iv) using any other available distribution mechanism or platform, either known now or developed in the future.
- the cover 15 may take the form of an image from the wrap package 10 itself (e.g., the first card); however, that is not a requirement.
- the wrap package 10 is configured to be rendered on a consuming device 12 in conjunction with a wrap runtime viewer 50 , which is also sometimes referred to as the wrap run-time engine or simply the viewer.
- the runtime viewer 50 provides a set of tools and functionalities that are helpful for viewing and/or interacting with the wrap.
- the viewer 50 will take the form of a dedicated, platform specific, wrap viewer application (e.g., an applet or app in the context of a mobile device), a plug-in (e.g. a browser plug-in) or other mechanism installed on the viewing device that provides the necessary functionality.
- the wrap viewer functionality may be incorporated into other types of applications.
- the delivery of a wrap packages 10 may optionally be accompanied by a run-time viewer 50 that includes a set of associated tools and functionalities suitable for use by a conventional browser to generate and/or render the runtime instance of the wrap based on the wrap descriptor 40 and to facilitate user interaction with the wrap package 10 .
- These tools and functionality can be thought of, and are often referred to herein as a wrap toolset that is part of the wrap runtime viewer 50 .
- the wrap package 10 can be consumed on a wide variety of different devices and operating system platforms (e.g., iOS, Android, Microsoft, etc.) without requiring the users to download and install a device and/or platform specific viewer application.
- This is a powerful construct for enhancing the portability and viral distribution of wrap packages among a myriad of devices and operating system platforms
- the viewer toolset provided with the wrap viewer 50 includes navigational tools 51 , sharing tools 52 , storing tool 53 , various e-commerce tools 54 , presentation engine/tools 55 , security and access control tools 56 , a rendering engine 57 , and application functionality tools 58 .
- the navigational tools 51 facilitate navigation within the wrap package 10 .
- the sharing tools 52 provide mechanisms by which a consumer of the wrap 10 may share the wrap with others, e.g., by e-mail, by SMS message, via a social media post, etc.
- Storing tool 53 allows a user to persistently store the wrap and/or when applicable, the wrap state, either locally or remotely.
- the e-commerce tools 54 may include a variety of functionalities that can help facilitate a variety of e-commerce tasks including purchasing, making reservations, etc.
- Application functionality tools 58 enable “app-like” functionality within the wrap package 10 , such as conducting online chats, GPS functionality, etc.
- Presentation engine 55 controls the presentation. In some embodiments, the presentation engine 55 may be arranged to present the wrap on the consuming device at a scale and in an aspect ratio that is at least somewhat optimized for the device.
- Security and access control tools 56 provide security and access control functionality, which might include encryption functionality and user authentication services.
- the publisher of a wrap may want to limit the circulation of the wrap to specific users or groups of users.
- a few, nonexclusive examples of such circumstances include when the wrap is created for use as: (i) an active receipt for a purchase as described in U.S. Provisional Application Nos. 62/062,056 and 62/075,172 (both incorporated by reference herein for all purposes) and (ii) a ticket for an event as described in U.S. Provisional Application No.
- the viewer 50 may optionally also include a rendering engine 57 arranged to create and/or render a runtime instance of the wrap on a consuming device 12 based on the descriptor 40 .
- the rendering engine is arrange to dynamically generate the HTML (or other markup language) use by a browser or other viewing mechanism on the device 12 to render the wrap at runtime.
- the rendering engine 57 is arranged to create an object graph based on the descriptor 40 and a document object model (DOM) based on the object graph. The browser or other suitable app or application may then use the DOM to render the wrap package 10 .
- DOM document object model
- the viewer 50 may also optionally have any number of card behaviors definitions 60 .
- different cards can be designed to exhibit a wide variety of different behaviors.
- various desired behaviors can be defined separately from the cards themselves.
- the behaviors are known to or accessible by the wrap viewer 50 (e.g., desired behaviors may be defined through behavior definitions 60 or may be accessible as behavior extensions 62 as seen in FIG. 5B ).
- desired behaviors may be defined through behavior definitions 60 or may be accessible as behavior extensions 62 as seen in FIG. 5B ).
- the descriptor for any particular card or component may simply declare the desired behavior and the viewer 50 will know how to impart such behavior to the wrap/card/component and/or how to obtain an extension that imparts such behavior.
- the behavior definitions and the various tools are illustrated as separate items to facilitate their description. However, in practice, some of the illustrated tools are simply sets of associated behaviors, and therefore, the illustrated distinction between the behaviors and such tools is/are largely for emphasis.
- the wrap package 10 may be rendered on a wide variety of different devices 12 A through 12 G. These devices may have a wide variety of different screen sizes, capabilities, and viewing mechanisms.
- a particular device 12 requests a wrap package 10
- the browser compatible run-time viewer may be written in any format that is appropriate for execution by a browser.
- JavaScript JavaScript
- JS JavaScript
- wrap viewer 50 may be implemented using a wide variety of other now existing or future developed frameworks and/or languages.
- the DOM rendering may be replaced with a React framework or another suitable framework currently known or developed in the future.
- the card descriptor 46 within a wrap 10 can be arranged to declare the behavior of the card 14 without internally defining that behavior. Rather, in such circumstances, the desired card 14 behaviors are defined within the wrap viewer 50 as part of the behavior definitions 60 or through behavior extensions 62 .
- a card template designer can define the behavior for cards 14 authored using the template, or can define a set of available behaviors from which a card author can choose. If a set of behaviors are available to the card author, then the authors selects the desired behavior from the available set. In either case, the desired behavior is declared as part of the card.
- the card descriptor 46 for the gallery card includes a behavior declaration that identifies the desired behavior for the card, which can then be bound to the card at run-time by the wrap viewer (e.g., browser based viewer, native viewer, etc.). For example, this could take the form of a statement such as:
- the developer of the wrap viewer 50 can define any number of card behaviors that are supported by the viewer, such as but not limited to the different scrolling techniques in the example above.
- Third parties can provide extensions that define still other behaviors (e.g., a scrolling behavior in which a two finger swipe reacts differently than a one finger swipe, etc.).
- the developer of a card template can define which of the available behaviors are available for use with the template (e.g., a subset, or all of the defined scrolling behaviors). Wrap and card authors using the template can then select which of the behaviors available to the template they would like to associate with the card, and the chosen behavior is declared as part of the card descriptor 46 .
- the actual structure of the descriptor used to define a gallery card may vary significantly.
- a representative card descriptor structure suitable for implementing a gallery card is described in more detail below and is illustrated in FIG. 6C .
- a card can have one or more triggers embedded therein. Triggers are hooks associated with displayed items that can cause an action or behavior in response to an event (e.g. a user input). That is, a predetermined user action or other event (such as the selection of the displayed item) triggers a defined action.
- a trigger is a component 16 of a card.
- the trigger has associated behaviors and one or more associated handlers. When a triggering event is detected, the associated handler causes execution of the desired behavior.
- the triggering event may be a user input such as the selection of a displayed trigger component (e.g., by tapping or performing another appropriate gesture relative to a displayed item configured as a trigger component).
- the activating event may be system generated.
- System generated events can include sensor input based events, time or timer based events, the receipt of a particular message, the determination that a particular navigational sequence has occurred within a wrap, geo-location or proximity based events (e.g., the viewing device is located within a particular store or geographic area, or near to other users viewing the same wrap) or any of a wide variety of other computer detectable events.
- a trigger may exhibit any desired behavior which can be associated with the trigger through appropriate behavior declarations 95 .
- Virtually any type of computer implementable behavior can be associated with a trigger.
- a linking trigger may be used to link the user to another card within the current wrap, to send the user to another wrap, webpage or other destination.
- the linking trigger may also be arranged to define a desired linking behavior (e.g., open in same tab, open in new tab, etc.).
- Other triggers may initiate a wide variety of other action.
- triggers can be used to enable a wide variety of actions, including invoking of a number of different application-like functionalities or e-commerce related services.
- a trigger may be used to initiate an action (e.g., order a product, conduct an online chat, sharing the wrap with others, book or reserve a table at a restaurant, a hotel room, a rental car, etc.).
- an action e.g., order a product, conduct an online chat, sharing the wrap with others, book or reserve a table at a restaurant, a hotel room, a rental car, etc.
- wrap component/asset can be associated with a trigger, which gives authors tremendous flexibility in guiding the user experience.
- the wrap 310 illustrated in FIG. 7 has a number of triggers. These include purchasing trigger 340 ( FIGS. 7F-7K ), subscription trigger 360 ( FIG. 7L ) and social media triggers 381 , 382 , 383 ( FIG. 7M ).
- the purchasing trigger 340 is arranged to facilitate a user purchase of the displayed product.
- the trigger 340 of FIG. 7F is associated with a generally rectangular region that bounds the text and graphic located at the bottom of the card, including the text “pomegranate $18 for 12 16-ounce bottles” and the adjacent “Buy Now” button.
- the region that involves the trigger is generally shown by a dashed box in FIG. 7F .
- Selection of the trigger 340 links the user to a mechanism that facilitates the purchase of the identified item.
- the other above-identified triggers in the wrap 310 are characterized by and operate in a manner similar to the Buy Now trigger 340 of FIG. 7F .
- a purchase mechanism within a wrap package 10 may be widely varied.
- the user may be linked to the vendor's website, where the purchase may be made in a conventional manner through the website. If this approach is taken, it is often desirable to access the target website through a “Cul-de-sac” so that the user is returned to the wrap when finished with any transactions they wish to make (a Cul-de-sac has the property of returning to the initiating wrap card/page when the user closes the target website).
- the selection of the trigger causes the wrap to transition to a purchasing card (or sequence of cards) within the same wrap where the desired transaction can occur.
- a purchasing card or sequence of cards
- the transition could be to a separate purchasing wrap.
- the transaction can be completed without leaving the current card—particularly when the user is using a secure viewer that knows the user's identity and relevant purchase related information.
- the transaction can be completed using a “one-click” purchasing option, where previously stored customer billing, shipping and other account information is used to process the purchase.
- the specific behavior associated with the link may be declared in the same manner described above. For example, consider a situation where the trigger activates a link to an external website. There are several ways that such a link could be implemented. One approach might be to link to the target web page in the currently active browser tab, which has the effect of navigating away from the wrap. A second approach might be to open a new browser tab and open the target webpage in that new browser tab. A third approach might be to initiate a Cul-de-sac in the current browser tab and open the target webpage in the Cul-de-sac (a Cul-de-sac has the property of returning to the initiating wrap card/page when the user closes the target website).
- the card template developer can make these three link behaviors available to the trigger and the card author can select the desired behavior.
- the card developer can also define a default link behavior selection in the event that the card author does not affirmatively make a selection.
- trigger 340 in card 316 has these three possible linking behaviors in response to activation of a trigger.
- the ability to direct a user to a target website to complete a transaction can be helpful in many scenarios.
- a drawback is that it can be more difficult to track or guide user behavior after the user has navigated away from the wrap. Therefore, it is often preferable to design the wrap in a manner that facilitates handling user side interactions involved with a transaction from within the wrap itself.
- the actual structure of the descriptor used to define a trigger may vary significantly.
- a representative trigger component descriptor structure is described in more detail below and is illustrated in FIG. 6D .
- descriptor structures suitable for use in defining various wraps, cards and/or components will be described. Although specific descriptor structures are illustrated, it should be appreciated that the structure of the various descriptors can be widely varied. In general, the descriptors are arranged to define the structure, layout, content and behaviors of the wrap without details of its presentation on a particular device. That is, the descriptors capture the functional and behavioral intent of the author, in a platform independent way, such that the runtime may implement the described structures and behaviors in a way optimal for the platform in question.
- a wrap generally will include multiple cards and the corresponding wrap descriptor will typically have discrete descriptors for each of the cards.
- the card descriptors each include a unique card identifier and define the structure, behavior, layout and content of the corresponding card. Behaviors associated with any particular card can be applied at the card level (i.e., associated with the card as a whole), at a component level (i.e., associated to a particular component alone—which may or may not include subcomponents) or at any subcomponent level. Since the card descriptors are discrete, self-contained, units with a unique identifier, it is very easy to mix wraps (i.e., use cards created for one wrap in a second wrap). When cards are mixed, their components and associated behaviors remain the same—although it is possible to define behaviors that are context or state aware and therefore exhibit different states/properties/responses/etc. in different circumstances.
- the components are encapsulated units that may have defined content (although such content may be dynamic) and, when desired, specific defined behaviors, styles and/or other attributes.
- each component has a unique identifier and could optionally also have an associated type and/or name.
- the use of encapsulated components with unique component identifiers makes the components highly modular such that an authoring tool can readily use and reuse the same components in different cards and/or wraps. Behaviors can be associated with the component and any component can be composed of one or more subcomponents which themselves are fully defined components.
- the behaviors are preferably declared in the descriptor rather than being explicitly defined within the descriptor. In that way, the behavior declaration acts as a hook which can be used to associate virtually any programmable logic with a card/component/etc.
- the behaviors are preferably defined (or at least obtainable) by the runtime viewer.
- FIG. 6 diagrammatically illustrates the structure of a first representative wrap descriptor 40 .
- the wrap descriptor 40 includes the wrap ID 42 , the wrap title 44 , and a card descriptor 46 for each of the cards 14 .
- Each card descriptor 46 describes of the structure, layout and content of the associated card.
- the wrap descriptor 40 may also optionally include cover identifier(s) 43 and/or any other desired information or metadata 45 relevant to the wrap.
- the cover identifier(s) 43 identify any cover(s) 15 associated with the wrap.
- Other information and metadata 45 may include any other information that is deemed relevant to the wrap, as for example, an indication of the creation date and/or version number of the wrap, attributions to the author(s) or publisher(s) of the wrap, etc.
- each card descriptor 46 may be arranged in an array, deck, or in any other suitable format.
- each card descriptor 46 includes: a unique card identifier (card ID 71 ); a card layout 75 ; and optionally, an associated card type 73 .
- the card layout 75 preferably includes at least one of a layout identifier (layout ID 76 ) and a layout definition 78 and optionally, a layout name 77 .
- layout definition may be provided in a variety of different format. By way of example, Cascading Style Sheets (CSS) works well.
- CSS Cascading Style Sheets
- CSS is a style sheet language used for describing the look and formatting of a document.
- style sheets and/or other now existing or future developed constructs may be used to define the layout of the cards.
- the card ID 71 is preferably a unique identifier that uniquely identifies the associated card 14 .
- An advantage of using unique identifiers as card IDs 71 is that the cards 14 are not wed to a particular wrap package 10 , but rather, can to be used in or shared among a plurality of wrap packages. That is, once a card is created it can be used in any number of different wraps by simply placing that card's descriptor 46 at the appropriate locations in the card decks of the desired wrap package.
- the unique card IDs 71 can be used to help streamline the process of using one or more cards 14 from one wrap package 10 in a second wrap (sometimes referred to as the “mixing” of cards 14 and/or wrap packages 10 ), which can help simplify the process of creating the second wrap package.
- the card IDs 71 may also take the form of URLs, although this is not a requirement.
- a potential advantage of using URLs as the card IDs 71 is that the URLs can potentially be used to allow a card in the middle of the wrap to be more directly accessed from outside of the wrap.
- the card layout 75 defines the layout of the components 16 of the associated card 14 .
- the card layout 75 includes a card layout ID 76 which uniquely identifies the associated layout.
- the descriptor itself defines the layout using a conventional web presentation definition mechanism such as Cascading Style Sheets (CSS).
- the layout definition may be accessed from a server using the layout ID 76 .
- CSS is a style sheet language used for describing the look and formatting of a document written in a markup language. CSS enables separation of document content from the document presentation, including elements such as the layout, colors and fonts. Thus, CSS is very well adapted for inclusion within the wrap descriptor 40 .
- the layout ID 76 is also useful in the context of the aforementioned authoring tool used to create and author wrap packages 10 .
- the authoring tool is provided with a number of pre-defined templates (card layouts) from which an author of a new card can choose.
- Each template has one or more containers/components 16 , which are arranged on the card in a predetermined manner for holding card content 17 .
- the template itself can have any particular layout, or can be used to create a particular layout. In either case, the particular layout can be assigned a unique layout ID 76 , and thereafter, be used and reused in conjunction with different cards thereby simplifying the card creation process.
- the card type 73 (which is optional in the descriptor) relates primarily to such an authoring tool.
- the templates may be categorized into different groups or classes.
- the classes/groups may relate to their intended uses, the entity for which the templates are to be used, to the creator of the templates or any other logical grouping of templates.
- card type 73 can be assigned to one or more predefined card templates, depending on their intended function.
- an authoring tool may include one or more card templates, each centric for the display of text, visual media such as photos or images, the playing of video, live or streaming media, application functionality (e.g., scheduling appointments, GPS, etc.), or supporting e-commerce (e.g., displaying products and/or services for purchases, chatting with online sales representative, etc.) respectively.
- application functionality e.g., scheduling appointments, GPS, etc.
- supporting e-commerce e.g., displaying products and/or services for purchases, chatting with online sales representative, etc.
- the author(s) of a wrap package 10 can easily select a desired template/card layout that meets their need from a set of available templates and create a new card by readily inserting the desired content, functionality and/or services into the predefined containers.
- Such a template based approach can greatly simplify the authoring of cards 14 and wrap packages 10 , since the author(s) need not be an expert in HTML, scripting or other typical web page language constructs required in order to create the card(s) 14 as typically required with creating conventional web pages. Rather, those details are embodied in the selected template itself, which translates to a specific layout 75 , which in turn is identified by the layout ID 76 .
- layout 75 is used to format the associated card 14 .
- pins 80 The associations between components 16 and their contained content objects 17 , whether explicit in the card descriptors, or implicit and anonymous, are sometimes referred to herein as “pins” 80 .
- pins 80 are identified in the card descriptors 46 by a universally unique Pin ID 81 , and by a symbolic pin name 82 .
- pins are anonymous at runtime, but may at design time be instantiated in order to provide operable constructs to the authoring tools, in which case they will share the name and ID of the component they bind and associate.
- the symbolic name of a pin (pin name 82 ) or component is both Human and Machine-Readable, for example, “Headline”, “Glyph”, “Body”, “Image”, “Video”, “Cul-de-sac”, or any other heading that the template designer deems appropriate.
- the symbolic name is used to identify its function; can be used and bound to by constraints and layouts to further constrain their display, behavior and function; and is used by the authoring tools to identify the role of the thus-associated component and map fields from one layout to another when changing the layout associated with a card.
- Multiple pins or components can share the same symbolic name. When they do, it implies that they serve the same role in the system, and that the same rules will apply to them.
- Components 16 contain there associated content 17 and may also contain or reference zero or more attributes or constraint objects, specifying metadata to manage or modify the display of, or behavior of, that component.
- Constraint objects may specify abstract symbolic data used by the runtime to determine how to display or manage the object containing it, (the Constrained Object,) or the behavior of that object. Examples of such abstract symbolic data are CSS class names, behavior names, or other symbolic names acted on by other objects in the system.
- Constraints may also contain concrete specifications to modify the display or behavior of the object, or its container or any contained objects.
- An example of the former is containing CSS rules applied to the content.
- An example of the latter is inclusion inline or by reference of JavaScript code that acts on the constrained object.
- the various constraint objects may be thought of as attributes that define the style, format, behaviors, source/feed, and/or constraints associated the corresponding content 17 .
- these attributes include style attributes 86 , source attributes 87 and other constraint objects such as behaviors 60 , 62 .
- style attributes 86 include style attributes 86 , source attributes 87 and other constraint objects such as behaviors 60 , 62 .
- source attributes 87 include style attributes 86 , source attributes 87 and other constraint objects such as behaviors 60 , 62 .
- other attributes of a component can be defined and declared as appropriate for the associated content.
- the style attributes associate various styles with the content 17 and may take the form of style sheets (e.g. CSS) or other conventional style definition mechanisms.
- style sheets e.g. CSS
- the style attributes 86 may include features such as the font, size, case, color, justification, etc. of the text.
- the style attributes may include the color of the glyph, the size, etc.
- the source attributes 87 indicate the source of the associated content 17 .
- the source attribute may simply be a reference or pointer (e.g. a URL) that identifies the location of a static content object (e.g., an image, a photo, a video, etc.).
- a static content object e.g., an image, a photo, a video, etc.
- the content can also be dynamic.
- the content object associated with a component of a wrap could be the current price of a particular stock.
- the source attribute identifies the feed from which the current price will be retrieved when the card is rendered.
- a feed is a structured source having content that can be dynamically updated after the wrap has been rendered.
- a live streaming feed may present a live stream that is progressively rendered as the stream is received. Examples of live streams include live video streams, audio streams, biometric streams, stock ticker streams, etc.
- Other feeds are server side event driven as is commonly used to facilitate live updates—as for example, sports score updates, stock price updates, etc.
- Still other feeds are polling feeds in which the wrap periodically polls a source.
- the source attribute 87 may take the form a feed descriptor that defines the nature and structure of the feed as well as its feed characteristics including source location, data format(s), update semantics, etc. For example, some feeds (e.g. live feeds and live update feeds) require that a socket be opened and kept open as long as the feed is active. Polling feeds require the identification of the desired polling frequency.
- the source attribute may include a reference to a feed object (note shown) that defines the feed.
- a wrap author may desire have updated dynamically while a wrap is being displayed. These might include items that may be expected to update frequently and others that may update very slowly.
- items that may be desirable to update dynamically include sports scores, stock prices, the number of tickets still available for purchase for an event, number of units of a product that are available or simply an indication of whether a product is in our out of stock, breaking news headlines, etc.
- a number of services can also benefit from the ability to dynamically update content based on information that can change while a wrap is displayed such as, the user's geographic location, social networking group information (e.g. friends or peers that are nearby, online, etc.), featured information, etc.
- a card in a wrap for a sports stadium could show the nearest concession stands, restrooms, etc. which can vary as the user roams around the stadium.
- Another card could show the stats of a baseball player currently at bat.
- a social networking card may inform a user when their friends or others sharing similar interests are nearby.
- a retailer may wish to run special offers that update periodically.
- the types of content that an author may wish dynamically update is limited only by the creativity of the author.
- Other constraint objects may include declarations of specific behaviors that are intended to be associated with the component 16 and/or content 17 . Such behaviors may include behaviors 60 , 62 known to or accessible by the runtime viewer 50 as discussed above.
- FIG. 6A diagrammatically illustrates an alternative pin based card descriptor structure 46 A.
- Appendix II of U.S. Provisional Application No. 62/133,574 illustrates a representative wrap descriptor 40 A that takes the form of a JSON object that utilizes the pin based card descriptor structure 46 A illustrated in FIG. 6A .
- FIGS. 14A-14E illustrate the wrap defined by the wrap descriptor of Appendix II of the referenced provisional.
- various descriptor elements are labeled with corresponding reference numbers in Appendix II of the referenced provisional.
- the card descriptor 46 includes a unique card ID, 71 , a card name 72 , card type 73 and a card layout 75 .
- the layout 75 includes a layout ID 76 , optionally a layout name 77 and an explicit layout definition 78 .
- the layout definition takes the form of style sheets (e.g., cascading style sheets (CSS)).
- CSS cascading style sheets
- the illustrated embodiment includes both the layout ID 76 and an explicit layout definition 78 , it should be appreciated that either could be eliminated from the descriptor if desired.
- the explicit layout definition is not part of the descriptor structure, it could be accessed through the use of the layout ID.
- the layout definition 78 is explicitly provided, the explicit use of the layout ID 76 may be eliminated.
- the descriptor 46 A also includes an array of zero or more pins 80 , with each pin 80 corresponding to a first level component 16 .
- Each pin 80 includes a pin ID 81 , a pin name 82 and an associated component 16 .
- the component 16 includes a component ID 88 , a component type 89 , and the component content 17 . As indicated above, the content may be provided in-line or by reference. Any desired attributes and behaviors may then be associated with the component through a set of zero or more component attributes 86 which potentially include any desired component style class declarations 91 , component style sheets (CSS) 93 and component behavior declarations 95 .
- CCS component style sheets
- the style class declarations 91 refer and bind to CSS classes defined in the layout definition 78 that are used to define the format of the associated component 16 . Numerous examples of this binding can be seen in the Appendix II of the referenced provisional.
- the first pin 80 ( 1 ) in Appendix II has an associated component style class declaration 91 ( 1 ) that refers to and binds the font size style “font size-x1” 96 defined in layout 78 to the associated text content 17 ( 1 ).
- Component style sheets 93 provide an alternative component level mechanism for associating specific styles and formatting with a component 16 .
- the card layout definition 78 will define the styles and formats associated with each component in a robust manner that is satisfactory to the card author.
- there is no need to include any component level style sheets 93 and it is expected that in many (indeed most) such card implementations, no component style sheets would be provided. Rather, the associated styles may be bound through the use of class declarations 91 .
- the component style sheets 93 provide a mechanism by which the style assigned to the component by the layout definition 78 may be overwritten, which gives card authors great flexibility in defining the stylistic presentation of their content without altering the card layout definition.
- style sheet are used to assign styles to the components since they are currently a popular format for associating different styles with HTML content.
- style sheet are used to assign styles to the components since they are currently a popular format for associating different styles with HTML content.
- Behaviors 60 , 62 can be associated with a component on the component level in the same manner as the style sheets. This can be accomplished, for example, through the use of behavior declarations 95 which declare specific behaviors 60 , 62 with their associated component. It should be appreciated that the ability to associate specific behaviors with specific components in a general manner provides tremendous flexibility in the card creation process that facilitates the creation of cards having an incredibly wide range of functionality and behaviors while maintaining a simple, compact, and highly portable wrap structure. Even though there is an ability to associate behaviors with specific components, it is expected that the behavior set may be null for many components because they would have no need to have any specific behaviors associated therewith.
- the card descriptor 46 A also associates any desired card level attributes and/or behaviors with the card through a set of zero or more attributes 86 C that are associated with the card at the card level.
- the card attributes 86 C potentially include any desired card level style class declarations 91 C, card level style sheets 93 C and/or card level behavior declarations 95 C which work in substantially the same way as the component attributes, except that they operate at the card level.
- the wrap descriptor 40 can also have similar wrap level attributes 86 W.
- the various subcomponent(s) may have their own associated component attributes 86 regardless of the tier of the component/subcomponent.
- attributes can be associated with groups of components.
- FIG. 6B diagrammatically illustrates an alternative card descriptor structure 46 B that does not utilize pins 80 .
- the structure of card descriptor 46 B is generally similar to the structure of card descriptor 46 A described above with respect to FIG. 6A except for the use of pins. Therefore, the attributes (e.g., styles and behaviors) are associated with their corresponding components 16 rather than with pins 80 .
- the card descriptor 46 B includes a card ID 71 , a card name 72 and a layout 75 .
- the layout 75 includes a layout ID 76 , layout name 77 and layout definition 78 .
- the descriptor then includes an array of zero to many components 16 .
- Each component 16 includes a component ID 88 , a component name 84 , a component type 89 , the associated content 17 and the associated attributes 86 .
- the associated attributes may include associated classes 91 , component style sheets or definitions 93 , behavior declarations 95 and/or their associated behaviors 60 , 62 .
- Appendix III of U.S. Provisional Application No. 62/133,574 illustrates a representative wrap descriptor 40 B that takes the form of a JSON object that utilizes the component based card descriptor structure 46 B illustrated in FIG. 6B .
- various descriptor elements are labeled with corresponding reference numbers in the Appendix.
- the attributes container 86 is labeled “Styles” in the JSON code of Appendix III.
- FIG. 6C illustrates a representative gallery card descriptor 46 G.
- the illustrated embodiment uses the component based descriptor approach of FIG. 6B although it should be appreciated that other card descriptor hierarchies (such as those illustrated in FIGS. 6 and 6A can be used as well.
- Gallery card descriptor 46 G includes card ID 71 G, card name 72 G (in this case “Gallery Card”), and card layout 75 G with layout ID 76 G, layout name 77 G and CSS layout definitions 78 G, which together define a layout suitable for a gallery card.
- the initial component is gallery component 16 G, which has a component ID 88 G, a component name 84 G, a component type 89 G, gallery component content 17 G, and any associated attributes 86 G (including class declarations 91 G, style sheets 93 G and behavior declarations 95 G).
- both the component name 84 G and the component type 89 G are “Gallery.”
- the “content” of the gallery component 16 G is a set of one or more gallery item components 116 .
- Each of the gallery item components 116 typically, although not necessarily, has the same component structure previously described and can be thought of as subcomponents. This introduces a powerful feature of the described architecture. That is, the “content” of any particular component may be one or more “subcomponents”. Similarly, the content of any of these “subcomponents” may also include one or more next tier components and so on, with the components at each tier having the same generic structure.
- each gallery item component 116 includes: a component ID 88 , which may be thought of as a gallery item ID; a component name 84 , a component type 89 , content and any associate attributes 86 (potentially including class declarations 91 , style sheets 93 and behavior declarations 95 ).
- the component name 84 and component type 89 for the gallery item 116 is “Gallery Item”.
- the content of the gallery item 116 is a set of components (subcomponents) that make up the gallery item (that is, gallery items 116 , which are subcomponents of the gallery component 16 G, themselves have subcomponents which might be thought of as third tier components).
- Each of these gallery item components has the same structure as any other component.
- the gallery item components may include a headline component 16 H, and an image component 16 I (shown in Appendix III of U.S. Provisional Application No. 62/133,574). Only the headline component 16 H is shown illustrated in FIG. 6C , but the corresponding JSON descriptor is shown and labeled in Appendix III.
- a behavior can be associated at the card level, the gallery item level, the component of a gallery item level or at any other level at which components are used.
- An example of a card level behavior might be the aforementioned gallery card “snap to item” behavior 60 C, which can be seen in the aforementioned Appendices I, II and III.
- An example of a gallery item subcomponent level behavior might be a trigger as described below.
- the trigger component 16 T includes an optional trigger component ID 88 T, a component type 89 T, a component name 84 T, content 17 T and any associated attributes 86 T (including any class declarations 91 T, style sheets 93 T and behavior declarations 95 T).
- the component type 89 T is labeled “trigger” and the component name 84 T is labeled “transact” indicating that the trigger is a transaction trigger.
- the content 17 T of the trigger component 16 T in this illustrative example includes three subcomponents.
- the subcomponents include a text box 16 TT, an image 16 TI that takes the form of a “buy button” and a link 16 L.
- the link 16 L has an associated behavior “open-in-new-tab”, which causes the browser to open the target URL in a new tab when the trigger is activated by tapping on a touch sensitive display anywhere within the region defined by the trigger or by otherwise activating the trigger.
- the described link trigger behavior is a good example of a component level behavior.
- the link component 16 L is a first level component of the trigger and therefore the link is activated by tapping on (or otherwise selecting) any component within the trigger—as for example either the text box 321 or the buy button 327 . If the card creator preferred to have the link activated only by selection of the buy button 327 , that can readily be accomplished by making the link 327 a component of the buy button rather than a first level component of the trigger—or, by moving the text box component definition out of the trigger—as for example to the same component level as the trigger itself. Any tap or click in the bounding rectangle of the trigger, as defined by the components contained by the trigger, results in the trigger being activated.
- the trigger component may be included as a first tier component in the card descriptor or as a subcomponent at any level within the card descriptor hierarchy. Although a particular trigger descriptor structure is illustrated, it should be appreciated that equivalent functionality can be obtained using a variety of different descriptor arrangements. It should further that FIG. 6D is illustrative for providing an example for the purchase of an item for sale. It should be understood, however, the cards can be authored with triggers for a wide variety of actions besides purchasing an item, such as the reservation or booking of goods and/or services, online chats, GPS related services and functionality, etc.
- any wrap descriptor 40 or individual card descriptor 46 may include one or more feed descriptors.
- each feed descriptor has a number of descriptive elements that together define an associated feed in a manner that can be used by the runtime to integrate information from the feed into a rendered wrap instance in the manner desired by the wrap author.
- feed descriptor 187 in accordance with a nonexclusive embodiment will be described.
- the descriptive elements of feed descriptor 187 include a feed type 105 , a feed source 107 , a desired lifecycle 109 , a feed target 111 , an update frequency indicator 113 and any required feed parameters 115 .
- the feed descriptor 187 may also optionally include a feed ID 103 and/or a feed name 104 .
- the feed type 105 indicates the type of the associated feed. In general, most feeds can be categorized into categories or “types” that share similar traits and/or requirements. As previously discussed, some of the feed types might include “live” (server side event driven) feeds, polling feeds, streaming video feeds, streaming audio feeds, etc. When the feed descriptor is processed by the runtime, the feed type can be used to help identify the resources that may be required to support the feed. For example live streaming feeds and server side event driven feeds may require the opening of a socket for the feed and keeping the socket open for the duration of the defined feed lifecycle 109 .
- the feed source 107 indicates the location from which the feed can be obtained. Often, the feed source 107 takes the form of a URL, although other endpoints or source identifiers may be used in alternative embodiments.
- the lifecycle 109 indicates the feed's lifecycle semantics. That is, when and how the feed in activated, the conditions under which it remains active and potentially, when it is closed.
- a few potential lifecycles might include: (a) “while-card-visible” which opens the feed when that associated card is displayed and keeps the feed active as long as the associated card is the visible card within the wrap; (b) “always” which opens the feed when the associate wrap is rendered and keeps the feed active as long as the wrap is displayed; (c) “on-card-open”—which activates a feed any time the wrap transitions to the associated card; (d) “on-wrap-load” which opens the feed when the wrap is loaded; (e) “on-user-selection” which opens and/or updates the feed in response to a user input (e.g., the selection of a displayed button or other user activated trigger).
- lifecycles such as “while-card-visible” and “always” may be more appropriate for live and streaming feeds, or feeds that affect globally-visible wrap state (e.g. in a globally visible sports score ticker or stock ticker) whereas others, such as “on-card-open” or “on-wrap-load” may be more appropriate for polling feeds.
- Which type of feed is most appropriate is highly context-dependent, and will be determined by wrap authors.
- the lifecycle 109 may optionally include functionality to terminate the feed.
- the termination may occur in any number of ways.
- the feed may “time-out” after a predetermined period of time or manually in response to an input from the viewer of the wrap. For example, if the viewer closes and is no longer consuming the wrap, then the feed may be terminated.
- the feed may automatically terminate 10 minutes after a baseball game that is being streamed has ended. Again, these are just a few examples.
- the terms and/or conditions for termination of a feed may widely vary.
- the target 111 indicates the callback endpoint for the feed—which may be the method to call when an event happens.
- the target will be a container within the wrap that the feed is to be associated with.
- the intended container will be the component or other structure (e.g., card/wrap) within which the feed descriptor 187 is defined within the wrap descriptor 40 . That is, when the feed descriptor 187 is included as part of a particular component definition, it might be assumed that the feed is intended to be bound to that particular component. Alternatively, if the feed descriptor 187 is included as part of a card descriptor 46 outside of any of the associated component descriptions, it might be assumed that the feed is intended to be bound to the associated card. Still further, if the feed descriptor is included as a part of a wrap descriptor 40 outside of any of the associated card descriptors 46 , it might be assumed that the feed in intended to be bound to the wrap as opposed to any particular card or component.
- the frequency 113 is particularly relevant to polling feeds and indicates how often the feed should be polled. In some circumstances it will only be desirable to poll the feed once—e.g., when the associated card is opened, which can be uniquely defined by the combination of Lifecycle: on-card-open and Frequency: once. In other circumstances it may be desirable to periodically poll the feed, as for example, every minute, every 15 seconds, every 5 minutes, etc. In still other circumstances it may be desirable to poll when the card or wrap is first opened and thereafter only poll in response to user inputs or other events, as for example in response to the user selection of an “update” button (not shown). Of course, a very wide variety of other update rules can be defined through the use of different frequency and lifecycle constraints, and the feed may itself update the polling frequency for subsequent reads, over the life of the interaction.
- Feed parameters 115 can be used to pass such parameters to the feed server.
- the feed parameters take the form of name/value pairs although other data structures can be used in other embodiments.
- the feed parameters 115 may be static and explicitly included in the wrap descriptor. For example, if a card employing a feed is associated with a particular ad campaign, it may be desirable to identify the ad campaign through the use of campaign identifier passed a feed parameter. In other circumstances the feed parameters may be variables.
- a card arranged to provide current MLB scores sports may use team identifier parameters to identify the teams of interest to the user, with the user being given the ability to select the teams of interest—as for example, through a menu of teams provided on the card.
- team identifier parameters to identify the teams of interest to the user, with the user being given the ability to select the teams of interest—as for example, through a menu of teams provided on the card.
- specific parameters that are appropriate for any given feed and the manner in which the parameters are obtained may vary widely and will often depend in large part on the APIs associated with the feed.
- state information associated with a user of a wrap 10 and/or state information associated with a wrap 10 may be shared state information that is relevant to a number of different wraps.
- Other state information may be specific to a particular wrap (e.g., a particular user selection or input within a wrap, etc.).
- Still other relevant state information can be more global state information that is relevant to all instances of a particular wrap independent of the specific user.
- State information can be stored in a number of ways and the appropriate storage techniques will vary in part based on the nature of the state information.
- general information about a user and other user specific shared state data can be maintained in a cookie, or when the user has a persistent viewer application, the user state information can be persistently stored locally in association with the viewer application.
- any or all of the shared state information can also be stored on the server side.
- the shared state information may be useful to support a wide variety of different services including: user login and/or authentication; e-commerce applications where the identity, contact info, mailing address, credit card information etc. of the user may be necessary; integration with other applications (e.g. a calendar application, a chat application, etc.); and many other services.
- User specific shared state information can also be used to affect the navigation within a wrap. For example, user demographic information can be used to determine which card to display next in a set of cards.
- a state descriptor 68 is created and used to maintain state information associated with a particular wrap as illustrated in FIG. 5B .
- the state descriptor 68 is associated with both a specific wrap and a specific user and thus can be used to store state information relevant to that specific user's interaction with the wrap.
- the state descriptor 68 may be stored with the wrap on the publication server 22 .
- the state information can additionally or alternatively be stored locally in association with the viewer application either in the state descriptor form or in other suitable forms.
- a state descriptor 68 will include a wrap ID 42 and a user ID that identify the wrap and user that the descriptor is associated with respectively.
- the state descriptor 68 also stores the relevant state information in association with the card and component IDs for which the state information applies.
- Wrap packages 10 are composed by authors 34 using an authoring tool 100 .
- the authoring tool may operate in a desktop computing environment or a mobile communication environment, such as on a mobile or cellular phone, a tablet, or other mobile device, such as a laptop computer.
- the home page includes a number of existing wrap packages 104 A through 104 N.
- options are provided to “Copy”, “Preview”, “Edit” and “Share”. By selecting any of these options, the corresponding wrap package 104 may be copied, previewed, edited or shared respectively.
- a window 108 for assigning a title for the new wrap appears on the screen of the computing device running the authoring tool 100 after the icon 106 is selected.
- a text field 110 is provided for entering an appropriate name or title for the new wrap package.
- the author 34 selects the “Create” icon 112 to begin the authoring process for the new wrap package.
- an exemplary authoring workspace 114 is shown, which appears on the display screen of the computing device executing the tool 100 after the title for the new wrap has been defined.
- the author 34 is provided a work area and a set of tools for the composing of wrap packages.
- the workspace 114 includes a header field 116 , a card type selector field 117 for specifying the type of card to be authored, an authoring space 118 for defining the components and content of cards the of the wrap package as they are authored, an add component field 119 for adding component(s) to the cards appearing in the space 118 , a preview and configure space 120 for previewing and configuring the card defined in the authoring space 118 , and a layout selector space 122 for defining various card templates used for creating and configuring the various card types of the wrap package.
- FIGS. 10A through 10C features of the header field 116 of the workspace 114 are illustrated.
- the header field includes the previously defined title of the wrap package 10 , a title editing tool 124 for revising or changing the title of the wrap package, a save tool 126 , a publish tool 128 , and a discard tool 130 .
- the tools 126 , 128 and 130 are respectively used for saving, publishing and discarding cards 14 of the wrap package 10 as they are authored.
- the header field 116 also includes a card sequencing space 132 . Within this space 132 , the author can arrange the cards and define the one or more linear sequences in which the cards are to be rendered when the wrap package is consumed.
- the individual cards of the wrap package are authored, they are added to the sequencing space 132 in the numerical order (e.g., 1, 2, 3, 4, etc.) in which they are created. In the event the author 34 wishes to re-order the sequence, one of several operations may be used.
- FIG. 10B an exemplary re-sequencing operation is illustrated.
- Card 2 is moved after Card 3 using a drag and drop operation.
- the cards are renumbered to reflect their new sequence order.
- cards can be copied and pasted.
- cards can be moved or re-sequenced using any technique.
- the horizontal sequence of the cards can be arranged in any order as determined by the author 34 .
- one or more of the cards can also be configured as a gallery card(s), which are navigable in the vertical direction.
- the horizontal and/or vertical sequence for rendering the cards when the wrap package is consumed is defined by the author 34 .
- the header 116 also includes left and right scrolling icons 131 .
- left and right scrolling icons 131 When either the left or right scrolling icon 131 is selected, the cards appearing in the card sequencing space 132 scroll in either the left or right direction respectively.
- the scrolling icons 131 thus allow the author 34 to navigate, view and edit all of the cards of the wrap package.
- the header 116 also includes a “New Card” tool 134 .
- this tool two actions occur. First, a new card 140 is created in space 132 . Implicitly, the new card 140 appears next in the horizontal sequence order in space 132 . However, as noted above, the sequence order of the card can be changed by the author 34 if desired. Second, a new card type selector tool 136 , which lists a number of different possible card types, appears.
- the types of cards that are provided within the card type selector tool 136 include, but not limited to, a textual card, an image/photo card, a video card, a gallery card, a document card, a chat card, a transact card, an appointment card, a feed card and an end of wrap card.
- the new card 140 appears as card 4 in the sequence order.
- a number of examples are provided below illustrating the authoring of the new card 140 for each of the card types listed above.
- FIG. 11A through 11D the authoring of an exemplary textual card 140 is illustrated.
- a number of textual card templates are provided in the layout selector space 122 .
- Each of the templates is labeled Template 1, Template 2, through Template N.
- Each of the various templates include a different structure and layout. For example, each may include different arrangement of predefined headlines, sub-headlines, and/or components.
- Template 2 is selected, resulting in a card having the same structure and layout as the selected template appearing in the authoring space 118 and preview and configure space 120 .
- the selected template includes a headline 142 and a sub-headline 144 .
- the author 34 types text into the headline 142 and the sub-headline 144 within the authoring space 118 . As the text is typed, it appears in the corresponding headline 142 and sub-headline 144 of the card appearing in the space 120 . In this particular example, the author has typed “Wrap” into the headline component 142 and “The narrative web . . . ” into the sub-component 144 . Since this card includes text components, a set of style tools 146 are provided to enable the author to configure the font, size, justification and color of the text contained in the components 142 and 144 respectively. It should be understood, however, that the style tools 146 may optionally not be provided for cards that do not contain text. The style tools 146 are, therefore, not necessarily constrained to all the different card types.
- Additional tools enable the author to further modify the selected card template if desired.
- a headline tool 148 enables the author to modify the card template with another header and sub-headline tool 158 enables the author to create another sub-heading.
- a text box appears in the image of the cards appearing in space 118 and space 120 .
- the author can then type into the text box(es), similar to that described above.
- the text box(es) can be positioned or moved in the image of the card appearing in space 120 to any location desired by the author and the style tools 146 can be used to define the style of the entered text.
- FIG. 11C a number of exemplary textual cards are illustrated.
- a different card each derived from a template with different layouts, structures, headers and/or sub-components, is illustrated.
- the style tools 146 are available to the author to define the different fonts, sizes, justification and potentially color (not visible) of the text in each of the cards. It should be noted that these examples are not exhaustive.
- Various templates of different structures, layouts and/or arrangements of components can be used to create an almost infinite number of textual card styles.
- FIGS. 12A through 12C a series of diagrams showing how the new card 140 is configured as an image card is illustrated.
- the author selects a particular image template from space 122 .
- a card corresponding to the selected template with an image box 154 appears in spaces 118 and 120 respectively.
- the author selects the select image icon 156 .
- an “Add Image” box 158 appears in response to the selection of the select image icon 156 .
- the author may selectively either (i) drag and drop or otherwise select and image or photo from an existing library (i.e., image 1, image 2, image 3, etc.), upload and image, or provide a URL or other identifier for accessing the image from a remote location when the card is rendered when the wrap is consumed.
- the defined image is then inserted into the component box 152 when the Add icon 160 is selected.
- the added image appears in both the card template provided in space 118 and space 120 .
- the author 34 may further stylize the image by adjusting its size and/or location within the card, as represented by author manipulating the image box containing the image.
- FIGS. 13A and 13B diagrams showing how the new card 140 is configured as a video card is illustrated.
- the author selects a particular video template from space 122 .
- a card corresponding to the selected template including a video component box 162 , appears in the preview and configure space 120 .
- the author 34 selects the icon 164 for defining the video for insertion into the component box 162 .
- a box 166 for inserting a URL or other identifier for a chosen video appears.
- a preview icon 168 and add icon 170 and a clear icon 172 also appear.
- the preview icon 168 the selected video defined in box 166 can be previewed in the component box 162 of the video card 160 appearing in the space 120 .
- the add icon 170 results in the video being inserted into the card 160
- the clear icon 172 will remove the URL.
- the author may resize and position the video within the card in the space 120 as illustrated.
- an add component tool 119 appears in the space 118 .
- the add component tool 119 allows the author to add a new component to a card that was not previously defined by whatever template was used to create the card in the first place.
- the author 34 has the option to add additional text, an image, video or other action component beyond what was originally defined in the starting template, as described in more detail below.
- FIGS. 14A through 14C a series of diagrams showing how the new card 140 can be configured as a document card is illustrated.
- the author selects a particular document template from space 122 .
- a card 170 corresponding to the selected template including a document component box 172 , appears in the preview and configure space 120 .
- the author can define the document for insertion into the component box 172 .
- the author has selected a PDF document, which appears within the component box 172 of the document card 170 .
- the author may also elect to add an additional component to the document card 170 , for example, a descriptor or title for the uploaded PDF file. To do so, the author selects the Add tool 119 , as also illustrated in FIG. 14A .
- an add component window 182 appears in response to the selection of the Add component tool 119 .
- the author may select text, image or some other action component. In this particular example, the author selects the text component.
- a text box 184 in the authoring space 118 and a text box 184 appearing within the card 170 in the space 120 appear in response to the selection of the text option in box 182 .
- text box 184 e.g., “User Manual”
- the author may adjust the style of the card 170 by resizing and positioning both the PDF document and/or the text box in space 120 .
- the author may change the font, size, justification and color of the text using style tools 146 .
- behaviors or tools may also be inherently provided within document templates that enable or facilitate navigation of any inserted document within a card.
- document templates For example, for PDF, Word or PowerPoint documents, scrolling bars, pointers, or a page flipping behavior may be embedded in the card templates so that a view of the wrap package can flip from page to page within the document when the card is consumed.
- FIGS. 15A through 15C a series of diagrams illustrating how new card 140 is configured as a chat card is illustrated.
- the author selects a particular chat template from space 122 .
- a chat card 190 corresponding to the chat template, appears in the preview and configure space 120 .
- the card 190 includes a chat function that enables a chat session to take place between a consumer of the wrap package and a remote person when the card 190 is rendered.
- the chat functionality of card 190 can be implemented in a number of different ways.
- the chat function can be embedded as a widget that appears in an i-frame within the card 190 .
- a chat server is accessed, and the viewer may engage in a chat session with another party via the chat server.
- the chat may be implemented using a cul-de-sac method.
- the chat functionality can be built into as a component of the card 190 .
- the chat card 190 may include feed functionality as described herein.
- the author may also elect to add an addition component to the chat card 190 by selecting the Add tool 119 , which causes the add component box 194 to appear. Within the component box 194 , the author may select text, image or some other action component.
- the author in this example selects the add image component, which results in an image box 196 appearing in the authoring space 118 and a corresponding image box 198 appearing within the card 190 in the space 120 .
- an image into box 196 e.g., a Nieman Marcus store
- the corresponding image appears in the image box 198 of the card 190 .
- the author may resize and position image box 198 within the card 190 .
- other components may be added in a similar manner.
- the author 34 may also elect to ad a text component, such as “Chat with an online sales representative” (not illustrated), by selecting the Text option within the add component window 194 , similar to that described above.
- FIGS. 16A through 16F a number of diagrams showing the new card 140 authored as an appointment card for making an appointment is illustrated.
- the author selects a particular appointment template with a built-in calendaring function from space 122 .
- an appointment card 220 corresponding to the selected appointment template, appears in the preview and configure space 120 .
- the card 200 as shown has already been authored to include text (i.e., “Rancho Relaxo Spa”), and image, and a “Book and Appointment” button using the Add tool 119 , as described above.
- the card 200 may implement the appointment booking/reservation function in a number of ways.
- the function can be implemented via a widget embedded in the card and that allows interaction with a remote reservation/booking server.
- a number of calendar related icons appear in the authoring area 118 when the appointment function 202 is selected.
- the author can specify the year, month and time increments for receiving appointment requests from a consumer of the wrap package.
- the selected parameters are set into the appointment function of the card 200 .
- a session is established between the wrap package and the remote reservation or booking database when the card 200 is being consumed.
- state information is exchanged, meaning the remote database provides the wrap package with appropriate feed information, such as booked and/or available time-slots for reservations.
- the feed information is presented within the card 200 , allowing the viewer of the wrap to book an available time-slot.
- the card 200 captures the required information, such as the date and time specified by the viewer, along with optionally user information (name, contact information, credit card, etc.), and provides it to the remote database for reserving the requested time slot.
- FIGS. 16C through 16F an alternative embodiment of authoring the “cul-de-sacing” to a remote reservation-booking location is illustrated.
- the author 34 selects the add component tool 119 , which results in the appearance of the add component window 194 , as illustrated in FIG. 16D .
- the author 34 selects the “Action” icon, which results in the appearance of a set of tools in space 118 , including a button tool 202 and a link tool 204 , as illustrated in FIG. 16E .
- the button tool 202 the user can create a “Book Now” trigger within the card 200 .
- the link tool 204 as illustrated in FIG.
- the author can define a URL of the remote reservation booking database.
- a web page associated with the remote reservation booking system appears. Once a reservation is made, or the viewer opts to not make a reservation, the viewer is returned back to card 16 F of the wrap package.
- FIGS. 17A through 17C diagrams showing new card 140 configured as a location/GPS card is illustrated.
- GPS/location card 220 corresponding to the selected template, appears in the preview and configure space 120 .
- the author 34 can add additional components to the GPS/location card 210 by selecting the add component tool 119 .
- the author can add text and/or image component(s) as described above.
- the author can add a location component, as is provided in this example.
- a component box 212 appears in the authoring space 118 and in the card 210 in the space 120 .
- the component box 212 enables the author 34 to define GPS functionality in the card 210 .
- the wrap package may be authored on behalf of a merchant located at 923 Elm Street in San Francisco.
- the card 210 is configured to interact with the GPS functionality of the consuming device, such as the Google Maps application running on the device, to provide GPS related services.
- the viewer of the wrap may enter their current location into the card 210 , which would result in the card providing directions to the location of the merchant, located at 923 Elm Street in San Francisco.
- FIGS. 17D through 17F illustrate a sequence of diagrams for authoring a cul-de-sacing” action to a remote web site providing GPS/location functionality, such as Mapquest or the like.
- the author 34 selects the add component tool 119 , which results in the appearance of window 194 , as illustrated in FIG. 17E .
- the author selects the Action item, which enables the insertion of a URL to a remote web page providing GPS/location functionality.
- the GPS/location functionality can also be implemented using a widget or by building the functionality into the card itself.
- FIG. 18A through 18F a sequence of diagrams illustrating new card 140 authored as a transact card 220 is shown.
- the author selects a particular transact template from space 122 .
- a transact card 220 corresponding to the selected template, appears in the preview and configure space 120 .
- a number of options for adding component(s) specific to transactions are provided in the authoring space 118 .
- an image component 222 a headline component 224 , a button component 226 and a link component 228 are provided.
- the image component 222 is selected.
- the author may add an image to the card 220 , similar to that described above.
- the headline component 224 is selected.
- the author may add headline to the card 220 , similar to that described above.
- the button component 226 is selected.
- the author may add a “Buy Now” button similar to that described above.
- the link component 228 is selected.
- the author can then enter a URL into box 230 , which will result in the cul-de-sacing to a remote web site location when the Buy Now icon is selected. For instance, a web page that allows the consumer of the wrap to purchase goods and/or services appears. When the transaction is complete, the viewer is returned to the wrap package.
- transact cards are not necessarily limited to cul-de-sacing for the processing of transactions.
- transactions can also be conducted within the context of a transact card while it is being consumed.
- the transact card can be configured with a bi-directional feed of data and the ability to synchronize data during a session with a remote data processing center used for handling online transactions.
- the viewer may peruse a number of items for purchase. While viewing the wrap, current data pertinent to the items, such as number in stock, size information, color choices, etc., are synchronized and presented to the viewer while consuming the wrap. The viewer may then elect to place one or more items into a shopping cart for purchase.
- the viewer When ready to complete the transaction, the viewer prompted to enter the appropriate user information, such as mailing address, billing address and credit card information, to complete the transaction. Alternatively, all this information may be previously stored, in which case, the purchase can be completed with a “one-click” operation or the like.
- the processing of a transaction within a card can be implemented using a widget as a component in the card.
- the widget appears inline an i-frame of the card.
- the content from a remote location referenced using for example a URL, is presented in the i-frame, enabling the viewer to complete the transaction.
- FIGS. 19A through 19D diagrams illustrating the authoring of new card 140 as a gallery card is shown.
- the layout selector space 122 is modified to include a vertical frame sequencing area 123 , a new frame icon 125 and a behavior declaration 250 that enables the author to define if the individual frames of the gallery card will have a “snap” action or “rolling” scroll action when swipe navigated.
- the icon 123 is selected. Thereafter, the author selects a template for the new frame, which could be any of the above-listed card types.
- the vertical sequence of the individual frames of the gallery card can be changes using a drag and drop or analogous operation, similar to that described above with regard to the horizontal sequence. Consequently, the author 34 may compose a gallery card by creating, authoring and sequencing new frames one after the other.
- a first frame 230 (1) of the gallery card is illustrated.
- the first frame 230 (1) is selected from a text-based frame template that has been authored to include the text component “See the New 2015 Mustang”.
- the same first frame 230 (1) of the gallery card is illustrated.
- the second frame 230 (1) is selected from an image-based frame template that has been authored to include an image of the 2015 Mustang.
- a second frame 230 (2) of the gallery card is illustrated.
- the second frame 230 (2) is selected from a document-based template that has been authored to include an PDF article about the 2015 Mustang published by the magazine Car & Driver.
- a third frame 230 (3) of the gallery card is illustrated.
- the third frame 230 (3) was selected from a video based frame template that has been authored to include a video of the 2015 Mustang.
- an “N” and final frame 230 (N) of the gallery card is illustrated.
- the fourth frame 230 (N) was selected from an end-of-gallery template and has been authored to include a link to the Ford Motor Company web site as well as icons for sharing the wrap package.
- frame templates used for authoring the individual frames of gallery cards are similar to card templates. As such, frame templates having the same features and functionality as described herein with respect to cards.
- FIGS. 20A and 20B diagrams showing the authoring of new card 140 as an end of wrap card is shown.
- the end of wrap card is selected within the card type selector 136 .
- a number of appropriate templates appear in the space 122 .
- the author can then select one of the templates and begin the process of defining the last card 240 in the wrap package.
- the author may select a template with “Share”, “Like” and “Tweet” functionality built-in to the card, as illustrated in FIG. 20A .
- the wrap package may be shared like a message, and included for example in a Facebook feed or a Twitter feed.
- the author may, by selecting the add component tool 119 , add image, text, video or other media, actions and/or behaviors to the card, as described above. For example as illustrated in FIG. 20B , the author has added an image of a woman in a dress and text in a sub-header that reads “Fall Fashion at the Gap”. This is just one example of an almost infinite number of different card arrangements that can be authored as the last card in a wrap.
- the new card 140 can be either saved using 126 , discarded using icon 130 , or published using icon 128 .
- the card 140 is stored in its current state and can be later accessed for additional authoring.
- the card 140 is removed from the sequence space 132 .
- the card 160 is included in the wrap package.
- the wrap package, or any particular card in the package can be edited, removed, re-ordered, etc., using the above-described tools.
- the authoring tool 100 may use an almost limitless number of different card templates, components, styles and attributes, functionality and card types, resulting in an almost infinite number of different cards that may be used in wrap packages.
- FIG. 21 a flow chart 300 illustrating the steps of authoring a wrap package from the perspective of the author is illustrated.
- the author elects to create a new wrap package by selecting the new wrap tool 106 as provided in FIG. 7 .
- step 304 the author titles the wrap in the text field 110 appearing in window 108 as illustrated in FIG. 8 .
- the author creates a new card using the new card tool 134 and then defines the card type using the card type selector tool 136 as illustrated in FIG. 10C .
- a card template is selected.
- the resulting card (or frame in the case of a gallery card) is authored in step 310 to selectively include, as described above, one or more text, image/photo, or action components (GPS/location, appointments, transactions, and/or triggers to cul-de-sac to a remote location, etc.).
- one or more text, image/photo, or action components GPS/location, appointments, transactions, and/or triggers to cul-de-sac to a remote location, etc.
- a behavior may be associated with the card.
- a gallery card may be assigned a “snap” or “scroll” behavior to the next frame in response to an up or down swipe when the card is being consumed.
- step 314 the author may keep the current card (or frame) in its implicit order when it was created, or re-arrange the card (or frame) or other cards within the horizontal sequence of cards.
- decision 316 the author determines if a new card should be added to the wrap package or not. If yes, the process of steps 306 through 314 described above are repeated.
- the author has the option to save the wrap using tool 126 (or alternatively discard the wrap using tool 130 ), preview the wrap in step 320 , assign any covers to the wrap in step 322 and optionally set any permission(s) that define who may or may not access and view the wrap in step 324 .
- step 326 the author may publish or share the wrap the publishing using tool 128 , which enables the wrap to be distributed in or through any of the above-mentioned distribution channels.
- FIG. 22 a flow chart 400 illustrating the steps of a background process run by the authoring tool 100 during the authoring of a wrap package is shown.
- a wrap identifier 42 and title 44 are defined when the author elects to create a new wrap.
- the tool 100 waits until a new card is created using tool 134 .
- a card identifier 71 and card type 73 are assigned in step 406 .
- step 408 the components and attributes from a selected card template are copied and assigned to the newly created card.
- components of the card may be optionally added in step 410 .
- the style(s) and/or attribute(s) of the components and/or card may be modified.
- any triggers associated with a component or the card can be added or modified.
- behaviors may optionally be assigned during the authoring process in step 416 , such as with gallery cards as described above. For example, either the “snap” or “scroll” behavior will be assigned to the card, depending on the selection by the author.
- step 418 the sequence order of the card within the wrap is defined, either implicitly in the order in which the card was created, or explicitly by the author re-arranging the card order in the space 132 .
- the authoring tool 100 determines if the wrap has been saved using tool 126 , for example when an editing session is complete.
- the tool 100 waits until the author defines another card in step 404 , in which case, the steps 406 through 418 are repeated.
- the authoring tool 100 if saved, then the authoring tool 100 generates the card descriptor(s) for each of the defined cards in the wrap package in step 422 .
- step 424 the tool 100 generates the wrap descriptor from all of the card descriptor(s).
- the authoring tool 100 essentially performs the background steps outlined above with respect to FIG. 22 , except on a frame-by-frame basis (as opposed to a card-by-card basis). Accordingly, any component(s), attribute(s), style(s), trigger(s) and/or behaviors assigned to the frames of a gallery card, as well as the sequence order of the frames, are all defined during the authoring process of the gallery card.
- a flow chart 450 illustrating the steps of generating a card descriptor (i.e., step 422 of FIG. 22 ) for a card of a wrap in accordance with a non-exclusive embodiment is shown.
- a card descriptor is a data object (e.g., JSON or BSON).
- generating the card descriptor generally involves generating and assembling individual data objects for every feature and content contained in the card.
- a first component of the card is selected.
- data object(s) are generated for the component itself (step 454 ) along with content (step 456 ), attribute(s) (step 458 ), style(s) (step 460 ), trigger(s) (step 462 ) and/or defined and/or declared behavior(s) (step 464 ) associated with the component.
- decision step 466 it is determined if there are any additional components associated with the card. IF yes, then steps 454 through 466 are repeated for each component. If not, then any meta data is associated with the card in step 470 .
- the card descriptor is generated from all the data object(s) and meta data (step 472 ). The card descriptor thus contains everything needed to render the card at runtime.
- a flow diagram 480 illustrating the steps of generating a wrap descriptor (step 424 of FIG. 22 ) is illustrated.
- the first card of the wrap is selected and its card descriptor is generated (step 484 ) using, for example, the process described above with respect to FIG. 23 .
- decision 486 it is determined if there are any additional cards in the wrap package. If yes, then next card in the wrap is incremented (step 488 ) and the card descriptor for that card is generated in step 486 . This process is repeated until a card descriptor is generated for all the cards in the wrap, as determined in decision 486 .
- the wrap descriptor is generated from the wrap descriptor and any media data associated with the wrap as provided in step 490 .
- the wrap descriptor thus contains everything needed to render the wrap at runtime.
- generating the wrap descriptor generally involves combining the collection of data objects for each card, along with any meta data, to generate the wrap descriptor.
- the wrap descriptor will also be defined in terms of data objects (e.g., JSON, BSON, or any other suitable data object format). Consequently, the wrap descriptor includes everything needed to render the wrap package 10 at runtime by the runtime viewer.
- the flow chart 450 described above similarly applies to gallery cards.
- the above process is repeated for each component in the frame, resulting in essentially a “frame” descriptor, which is similar to a card descriptor.
- the process is repeated for the next frame, until frame descriptors have been generated for all the windows.
- a card descriptor is then generated for the gallery card from each of the frame descriptors and any meta data.
- the wrap descriptor is thus a collection of card descriptors, each specified in terms of a collection of data objects (e.g., JSON or BSON) defining each of the cards of the wrap package respectively.
- the wrap descriptor includes everything necessary to render the wrap upon runtime.
- the described wrap packages 10 are essentially cloud based portable data objects that can readily be distributed using a wide variety of electronic techniques including messaging, posting and inclusion as links in documents, articles or other electronic communications.
- the wrap package 10 thus allows authors to take applet and website functionality and make them consumable as a message, delivered in a narrative storytelling format. This allows the transformation of an app or website functionality into a portable, sharable, and savable wrap package 10 , that can be distributed like electronic messages (e.g. email, SMS, text) are disseminated today.
- the media triggers 381 and 383 can be used to share the wrap package 310 with others via Facebook Twitter.
- the cover 15 that includes a URL associated with the wrap can be posted on a social media site or feed, email to others, or otherwise distributed using an electronic communication protocol or platform.
- wrap packages 10 easy for publishers and others to distribute, but viewers and other recipients of a wrap may also readily share a wrap with their friends, family, coworkers, colleagues, etc. This is a powerful construct that can greatly extend or enhance the market (or other target segment) reach and penetration of a well designed wrap since a “message” from a friend or acquaintance is often more favorably received than a message from an unknown party. Neither applets nor websites are well suited for such viral distribution.
- the wrap package 10 can also readily be stored on a viewer's device if the viewer so desires. Contrast this with a conventional multi-page website which is not designed to be persistently stored on a viewer's device as a unit, even if individual pages may sometimes be cached. It also eliminates third party aggregator (e.g., the Apple App Store; Google Play, etc.) control over the delivery of a company's services/messages to its customers as occurs in the distribution of conventional apps.
- third party aggregator e.g., the Apple App Store; Google Play, etc.
- Wrap packages 10 offer a number of benefits and attributes currently not available with conventional methods of distributing content, such as with ME's, web sites, or stand-alone apps. Since cards 14 can be sequenced and authored to include media content, application functionality, and e-commerce related services, wrap packages 10 have the unique ability to narrate a story, in a book-like format, that captures and holds the attention of the viewer, while also offering an “app” like user experience. As such, wrap packages 10 offer a new web-based platform for storytelling, communicating ideas, and delivering highly visual and functional user experiences.
- Wrap packages 10 thus enable a new business paradigm for selling, advertising, publishing, increasing brand loyalty, offering services, and contacting and engaging new and old customers alike, all ideally delivered to consumers on their mobile devices, where they spend their time and consciousness.
- businesses used to have to build destinations (e.g., websites) or monolithic systems (e.g., “apps”) they can now, instead, provide consumers with wrap packages 10 , that are delivered like messages, and that provide the user experiences and functionality they really want and need.
- wraps 10 create opportunities for business to innovate and improve products and services, leveraging the mobile web in ways not before possible, because a convenient, enabling interface and platform did not previously exist.
- Wrap packages 10 are also like interactive messages that can be easily shared, delivered over the mobile web, and locally stored. With the ability to share, distribute over the mobile web and locally store, popular wrap packages can readily go viral.
- Wrap packages 10 are also preferably delivered using a SaaS (Software as a Service) model, meaning wrap packages are delivered only on an as-needed basis.
- SaaS Software as a Service
- Wrap packages can be authored by anyone, from an individual with little technical or design skills, to large and sophisticated enterprises.
- Wrap packages 10 can be distributed narrowly to a specific or targeted person or persons or widely distributed to many, many persons.
- Wrap packages 10 can be written once and can run on just about any browser enabled device. As a result, wraps are not platform, operating system, or device dependent.
- wrap packages 10 can be easily generated and optionally dynamically updated with new content
- wrap packages can be used as a digital “corollary” or “companion”, accompanying the sale or rental of goods and/or services.
- wrap packages can be created and distributed as an “Active Receipt” accompanying the sale or rental of a good or service.
- the merchant can thus provide through the wrap package 10 ongoing contact and support to on-board, up-sell and/or cross-sell the customer with ancillary goods and/or services, potentially for the entire life cycle of the product or service, all delivered in a digital format that never gets lost or misplaced.
- wrap packages can be used as an essential component of any product or service, delivering better customer service and creating new selling opportunities.
- wrap packages 10 introduce the “narrative web”, which is a storytelling mobile user interface, delivered over a cloud-based platform, ushering in a digital evolution of mobile marketing and customer relationship management.
- wrap packages 10 have the unique ability to increase mobile engagement, lead generation, and conversion, enabling businesses to increase sales, improve loyalty, and enhance customer relationships and loyalty.
- Wrap packages 10 thus offer a compelling business proposition by solving one of the biggest problems in the mobile space of today; namely the lack of connectivity between apps. With wrap packages 10 , however, consumers and other users can enjoy a multi-function app-like experience, without having to be in an app, download an app, or open any apps.
- wrap packages 10 are realized on mobile devices operating on the mobile web, it should be made clear that there is nothing inherent with wrap packages 10 that limit their usefulness or functionality in non-mobile environments. On the contrary, wrap packages 10 can also be used, and all the same benefits and attributes realized, on non-mobile devices, such as desktop computers and/or smart TVs for example.
- the present invention is thus intended to be broadly construed to cover any system and method, such as carousel ads for example, that enables publishers and marketers to tell sequenced stories with (i) a combination of images, photos, text, video and other types of media, (ii) a swipe-able format that enables viewers to navigate the media displayed in one screen shot or frame to the next, and (iii) includes embedded app-like functionality and/or links to other locations that provide additional information or such functionality and/or services. Consequently, the present application should not be construed to just those specific embodiments as described herein.
- all of the behaviors are declared rather than being stored in-line within the descriptor.
- the descriptor itself does not have any programmable logic.
- the declared behavior are all defined within the runtime viewer such that the runtime view can readily associate the desired behavior with the wrap, card or component as appropriate in a runtime instance of the wrap. It should be appreciated that this is a particularly powerful framework for enhancing portability of the wraps. With the descriptor/runtime viewer approach, a single item (the descriptor) can be used to define all of the content and functionality of a set of cards that can be rendered on virtually any platform.
- the declared functionality is provided (or obtained) by the runtime viewers when the wrap is to be rendered so that the author of the wrap is not required to know or understand any of the idiosyncrasies of any particular platform.
- the runtime viewer may be a generic runtime viewer (e.g., a viewer executable by a conventional browser) or may be native viewer customized for a particular platform. Regardless of the underlying platform, the runtime viewer handles the tasks of associating the declared behaviors with the wrap/cards/components which frees the wrap author and/or authoring tool from having to ensure that desired behaviors are programmed correctly for all of the different platforms that the wrap may be rendered on.
- all of the sizeable assets that serve as content of the wrap are referenced in the wrap by appropriate identifiers rather than being stored directly in the wrap. This again significantly enhances portability by keeping the size of the descriptor small while facilitating the use of rich media content.
- wrap packages provide businesses with a powerful tool for engaging their customers, suppliers, employees or other constituents in a format that is particularly well tailored for display on mobile devices.
- wrap descriptor structures have been described. Although such descriptor structures work well, it should be appreciated that the actual descriptor structure may vary widely. For example, in some embodiments some special behaviors can be defined within a wrap descriptor if desired. Such in-line behavior definition might be particularly useful in association with certain behavior extensions that are not otherwise readily available. For example, JavaScript can be included within a JSON object and various other descriptor structures. Thus, when JSON descriptors are used, selected behaviors or behavior overrides can be defined in-line using JavaScript if desired. Although programmed functionality can be included in some circumstances, it should be appreciated that liberal definition of behaviors within a wrap tends to defeat some of the primary advantages of the described descriptor/runtime viewer framework.
- in-line storage and references to external assets in any particular wrap descriptor may be widely varied anywhere from 100% referenced content to (at least theoretically) 100% in-line content—although the later is less desirable for media rich content and again, begins to defeat some of the advantages of using the descriptor approach.
- the choice between in-line and referenced content will typically be dictated in large part by the relative size of the content. For example, text, which tends to be very compact, is generally more suitable for inclusion in-line, whereas more graphic media, images, videos and/or audio files are typically more efficiently referenced.
Landscapes
- Engineering & Computer Science (AREA)
- Theoretical Computer Science (AREA)
- Physics & Mathematics (AREA)
- General Physics & Mathematics (AREA)
- Business, Economics & Management (AREA)
- General Engineering & Computer Science (AREA)
- Finance (AREA)
- Accounting & Taxation (AREA)
- Databases & Information Systems (AREA)
- Development Economics (AREA)
- Strategic Management (AREA)
- Computational Linguistics (AREA)
- Economics (AREA)
- Marketing (AREA)
- General Business, Economics & Management (AREA)
- Signal Processing (AREA)
- Computer Networks & Wireless Communication (AREA)
- Audiology, Speech & Language Pathology (AREA)
- General Health & Medical Sciences (AREA)
- Artificial Intelligence (AREA)
- Health & Medical Sciences (AREA)
- Data Mining & Analysis (AREA)
- Human Computer Interaction (AREA)
- Game Theory and Decision Science (AREA)
- Entrepreneurship & Innovation (AREA)
- Information Transfer Between Computers (AREA)
Abstract
An authoring tool for authoring wrap packages of cards. The authoring tool includes a set of tools that enable an author to create a new card of a wrap selected from a variety of card templates. In various embodiments, the card templates include textual, video, image/photo, document, gallery, chat, location/GPS, transact, appointment, and end-of-wrap card templates. When a particular card template is selected, the template is then duplicated to create the new card. Thereafter, the author may author the card to include various components, content, attributes, layouts, styles triggers and/or behaviors. As the cards of the wrap are created, the authoring tool provides the author with the ability to order the sequence of the cards. The authoring tool thus enables authors to selectively create wrap packages that include media that conveys a narrative story and application functionality.
Description
- This application claims the benefit of U.S. Provisional Patent Application Nos. 62/062,056 (P001P) and 62/062,061 (P002P), both filed on Oct. 9, 2014 and both entitled “Wrapped Packages of Cards for Conveying a Narrative With Media Content, Providing Application Functionality, and Engaging Users in E-Commerce”. This application further claims priority of U.S. Provisional Patent Application Nos. 62/084,171 (P005P), filed Nov. 25, 2014; 62/091,866 (P005P2), filed Dec. 15, 2014; 62/114,675 (P005P3), filed Feb. 11, 2015, and 62/133,574 (P005P4) filed Mar. 16, 2015, each entitled “Card Based Package for Distributing Electronic Media and Services. This application also claims the benefit of U.S. Provisional Application No. 62/144,139 (P016P), entitled “Authoring Tool for Creating Wrap Packages”, filed Apr. 7, 2015; U.S. Provisional Application No. 62/170,438 (P016P2), entitled “Authoring Tool for the Authoring of Wrap Packages of Cards”, filed Jun. 3, 2015 and U.S. Provisional Application No. 62/170,569 (P018P), entitled “Integration of Social Media with Card Packages”, filed Jun. 3, 2015. Each of these priority applications is incorporated herein by reference for all purposes.
- This invention relates to a media-authoring tool, and more particularly, to an authoring tool for the authoring of wrapped packages of cards.
- The above-listed related applications describe a new media content type, referred to as “wrap packages”. The terms “wrap” or “package” are interchangeably used herein to refer to wrap packages.
- A wrap package is a collection of cards that are each selectively authored to include (i) one or more types of media content such as text, images, photos, video, etc., (ii) application functionality and/or (hi) e-commerce related services. The cards in a wrap are also typically authored to define one or more linear sequence(s) when consumed. With wrap packages, an author thus has the ability to select media content, combined with application-like and website functionality, and combine them all into an elegant, card-based, narrative. As a result, the author can create compelling stories using media, interwoven with interactive functionality and/or e-commerce services. Wrap packages are, therefore, ideal, but not necessarily limited to, delivering a unique, interactive, “book-like”, experience to the mobile web, which previously has been not possible.
- The cards of wrap packages are navigation metaphors. Each card can be authored to group related information that can be easily consumed within a user interface experience by swipe (or other simple gesture) navigation from card-to-card.
- Cards have a visual representation intended to evoke similarities to their physical counterparts. They have a fixed portrait aspect ratio that makes them ideally suited to current mobile computing devices as well as easy to scale up to and arrange to fit other display form factors, such as provided on laptop and desktop computers as well as smart TVs. The physical card metaphor can also extend to the interactive behavior of cards in a wrap, as the user can use gestures that evoke the “flipping” of cards in a deck or bound booklet to navigate between them.
- In addition, each card in a wrap has defined content that is displayed in a predefined layout. In general, the cards in a wrap have the same size and aspect ratio. The aspect ratio is preferably device independent and is preferably maintained regardless of device orientation and/or display window size.
- Cards are like containers for holding and distributing media content, such as text, images, photos, audio, video and the like. In addition, cards may also contain or hold executable objects that provide or enable real-time features, such as application functionality (i.e., the ability to schedule appointments, engage in online chats or conversations) and support e-commerce related services (i.e., the ability to purchase goods and/or services). The multimedia content and/or interactive services contained by any given card can be determined entirely in advance or as late as the moment the wrap is consumed by the end-user. Such media content and executable objects are sometimes referred to herein as card “assets.”
- Cards, however, can differ from their physical counter-parts in ways that provide for unique presentations of content or the aforementioned application functionality and/or e-commerce services. For example, a gallery card provides the ability to present an expanded amount of content in a vertically stacked orientation such that the overall length (i.e., the number of cards or in a horizontal sequence) of the wrap is not affected by the amount of content in the wrap. This aids in navigation since the user can flip to the previous or next card regardless of their current position in the gallery.
- Wrap packages are delivered and rendered in a browser as a sharable and savable message. Wrap packages thus provides an app-like user experience that is delivered as a live, interactive, message from a cloud-based platform, using for example, the Software as a Service (SaaS) model. A wrap is thus a portable container of multimedia content, and interactive services, designed for ease of delivery, exchange, and consumption.
- Wrap packages are also consumable anywhere, meaning they have the ability to be resolved and displayed on just about any type of device (mobile phones, laptops, tablets, wearable computing devices such as smart watches, desktop computers, smart TVs, etc.), regardless of the platform (e.g., iOS, Android, Microsoft, etc.). Wrap packages are thus platform and device independent. Wraps do not have to be written for any specific platform, such as iOS or Android, or for any specific device or class of devices (e.g. smart phones, tablets, desktops, etc.).
- Wrap packages are thus a mobile-first marketing and commerce platform that ideally provides a beautiful world of storytelling in bite-size moments that get and hold attention. In addition, the unique characteristics of (i) authoring once and running on almost any device, regardless of the operating system or the type and (ii) the ability to easily distribute wrap packages similar to messages, together are a powerful construct that potentially can make the use of wrap packages near universal.
- By creating wrap packages, businesses and other organizations can simply and cheaply create, distribute, and manage storytelling mobile web user experiences, app like functionality and e-commerce, all in the context of wrap packages delivered directly to consumers. Where businesses used to have to build destinations (websites) or use monolithic systems (apps), they can now provide consumers, particularly mobile device users, with a user experience that delivers the content they want combined with a complementary palette of functions and/or e-commerce related services.
- Wrap packages thus solves a number of current problem with the mobile web. Unlike web sites, wrap packages are easy to consume on mobile devices and offer the opportunity to create compelling narratives and user experiences. In addition, the ability to incorporate app-like functionality into wraps provides a multi-function app-like experience, without having to develop an app, be in an app, download an app, or open several apps.
- The uniqueness of wrap packages creates opportunities for business and other organizations alike to innovate and improve marketing efforts, customer support, and user experiences in ways previously not possible, because an enabling interface and platform did not exist. Wrap packages can thus potentially define the next generation interactive web paradigm, particularly for mobile, although for desktop and other types of devices as well.
- Given all their features, advantages and benefits, an authoring tool that enables the easy creation of wrap packages is therefore needed.
- The present invention is directed to an authoring tool for authoring wrap packages of cards. The authoring tool includes a set of tools that enable an author to create a new card of a wrap selected from a variety of card templates. In various embodiments, the card templates include textual, video, image/photo, document, gallery, chat, location/GPS, transact, appointment, and end-of-wrap card templates. When a particular card template is selected, the template is then duplicated to create the new card. Thereafter, the author may author the card to include various components, content, attributes, layouts, styles triggers and/or behaviors. As the cards of the wrap are created, the authoring tool provides the author with the ability to order the sequence of the cards. The authoring tool thus enables authors to selectively create wrap packages that include media that conveys a narrative story and application functionality. Wrap packages are thus conducive for conducting e-commerce in a manner that has not previously been possible.
- In a non-exclusive embodiment, the authoring tool is further configured to generate (i) a wrap descriptor that specifies the set of cards associated with the wrap package as authored, (ii) a structure, layout and content of the set of cards suitable for display on a computer display separately from their presentation, and (iii) a plurality of card descriptors, each card descriptor arranged to define the content, structure and layout of an associated one of the cards. In a non-exclusive variations, the wrap descriptor and/or the card descriptor is/are a data object(s), such as, but not limited to JSON or BSON data objects.
- In other embodiments, the authoring tool is also configured to generate the wrap descriptor that defines the wrap package at runtime. The authoring tool generates the wrap descriptor by (i) generating one or more data objects for the cards of the wrap package respectively and (ii) generating the wrap descriptor from the one or more data objects for the cards of the wrap package respectively. As a result, the wrap descriptor defines the wrap package at runtime.
- In yet another embodiment, the authoring tool enables the authoring of a gallery card among the plurality of cards of the wrap package. When creating a gallery card, the authoring tool enables the author to (i) select a gallery card among all the different types of cards for authoring, (ii) select a frame template among one or more frame template types, (iii) a new frame from the selected frame template by duplicating the frame template, (iv) author the new frame, (v) repeat steps (i) through (iv) for each frame in the gallery card and (vi) define a sequence order for all the frames of the gallery card.
- The invention and the advantages thereof, may best be understood by reference to the following description taken in conjunction with the accompanying drawings in which:
-
FIG. 1 is a diagram illustrating a wrap package layout that includes a plurality of cards threaded together so as to be viewable in linear arrays in accordance with the principles of the present invention. -
FIG. 2 is a diagram depicting the design, functionality and data integration capabilities of a representative card in a digital companion wrap package according to the principles of the present invention. -
FIG. 3 is a diagram illustrating the media content and distribution model for distributing digital companion wrap packages in accordance with the principles of the present invention. -
FIG. 4 is a block diagram of a representative system for authoring, storing, distributing, and consuming wrap packages in accordance with the principles of the present invention. -
FIG. 5A diagrammatically illustrates selected components associated with defining and rendering a representative wrap package. -
FIG. 5B diagrammatically illustrates selected components associated with defining and rendering a representative wrap package in accordance with another embodiment that utilizes state descriptors and/or behavior extensions. -
FIG. 6 is a diagram illustrating the hierarchy of a wrap descriptor in accordance with the principles of the present invention. -
FIG. 6A is a diagram illustrating the hierarchy of a particular card descriptor in accordance with the principles of the present invention. -
FIG. 6B is a diagram illustrating the hierarchy of a second card descriptor embodiment. -
FIG. 6C is a diagram illustrating the hierarchy of a gallery card wrap descriptor embodiment. -
FIG. 6D is a diagram illustrating the hierarchy of a trigger component descriptor embodiment. -
FIG. 6E is a diagram illustrating a feed card in accordance with another non-exclusive embodiment of the present invention. -
FIG. 7 is a home screen for an authoring tool used for authoring wrap packages in accordance with a non-exclusive embodiment of the invention. -
FIG. 8 illustrates an exemplary window for defining a title for a new wrap to be authored according to a non-exclusive embodiment. -
FIG. 9 illustrates a non-exclusive embodiment for an authoring workspace space for the authoring of wrap packages using the authoring tool of the present invention. -
FIGS. 10A through 10C illustrate a header of the workspace for the authoring of wrap packages using the authoring tool of the present invention. -
FIGS. 11A through 11C illustrates the authoring of a textual card using the authoring tool of the present invention. -
FIGS. 12A through 12C illustrate the authoring of an image card using the authoring tool of the present invention. -
FIGS. 13A through 13B illustrate the authoring of a video card using the authoring tool of the present invention. -
FIGS. 14A through 14C illustrate the authoring of a document card using the authoring tool of the present invention. -
FIGS. 15A through 15C illustrate the authoring of a chat card using the authoring tool of the present invention. -
FIGS. 16A and 16F illustrate the authoring of an appointment card in accordance with multiple embodiments using the authoring tool of the present invention. -
FIGS. 17A through 17F illustrate the authoring of a location/GPS card in accordance with multiple embodiments using the authoring tool of the present invention. -
FIGS. 18A through 18E illustrate the authoring of a transact card using the authoring tool of the present invention. -
FIGS. 19A through 19E illustrate the authoring of a gallery card using the authoring tool of the present invention. -
FIGS. 20A through 20B illustrate the authoring of an end of wrap card using the authoring tool of the present invention. -
FIG. 21 is a flow chart illustrating the steps of authoring a wrap package in accordance with a non-exclusive embodiment of the present invention. -
FIG. 22 is a flow chart illustrating the steps of a background process run by the authoring tool during the authoring of a wrap package in accordance with a non-exclusive embodiment of the present invention. -
FIG. 23 is a flow chart illustrating the steps of generating a card descriptor for a card in accordance with a non-exclusive embodiment of the invention. -
FIG. 24 is a flow diagram illustrating the steps of generating a wrap descriptor from one or more card descriptors in accordance with a non-exclusive embodiment of the invention. - In the drawings, like reference numerals are sometimes used to designate like structural elements. It should also be appreciated that the depictions in the figures are diagrammatic and not to scale.
- The invention will now be described in detail with reference to various embodiments thereof as illustrated in the accompanying drawings. In the following description, specific details are set forth in order to provide a thorough understanding of the invention. It will be apparent, however, to one skilled in the art, that the invention may be practiced without using some of the implementation details set forth herein. It should also be understood that well known operations have not been described in detail in order to not unnecessarily obscure the invention.
- The cards of the wrap packages are ideally authored in one or more linear sequences so that a book-like narrative unfolds, not only through the cards themselves, but also by the transition between the cards, as they are sequentially browsed. In addition, the wrap packages are portable objects that may exist within a social feed or within a custom application. Wrap packages are also readily distributed, similar to electronic messages, through e-mail, messaging, social-media, or via a variety of other electronic communication platforms. As a result, wrap packages are consumable, sharable and savable objects. As the cards are browsed in the one or more linear sequences during consumption, the user experiences the unfolding of the authored narrative, including the defined media content interwoven with the complementary application functionality and/or e-commerce related services. As a result, the entire user experience including any application functionality and/or e-commerce related services is substantially contained within the context of the wrap package itself, typically (but not necessarily) without the need to navigate to other sites.
- Referring to
FIG. 1 , a diagram of a non-exclusive embodiment of awrap package 10 viewable on acomputing device 12 is illustrated. Thewrap package 10 includes a plurality ofcards 14 that are threaded together so as to enable browsing by swiping in one or more linear sequences. Any of thecards 14 may optionally include various types of media, such as text, images or photos, audio, video, a live or streaming feed of media, 3-D objects, or content from other wrap packages (not illustrated). Any of thecards 14 may also optionally provide application functionality, such as the ability to receive input data or display dynamically generated data, a calendar for scheduling or booking appointments or making reservations for goods and/or services, location/GPS, etc. In addition, any of thecards 14 may optionally provide or support e-commerce services, such as the ability to browse products in a catalog, communicate with an online sales representative, and/or purchase product(s). - By way of example, in the schematically illustrated
wrap package 10,card 14 A includes text,card 14 B presents a gallery,card 14 C includes images or pictures,card 14 D includes a video,card 14 E includes e-commerce related service(s),card 14 F includes a calendar function for scheduling appointments and/or booking reservations,card 14 G includes a user approval function, 14 n-1 includes a data entry function,card 14 N includes location or GPS services, etc. - On computing devices with touch sensitive screens, the
cards 14 of wrap packages 10 can be navigated linearly by swiping or by using other suitable interfaces, such as a stylus or pen. In devices without a touch sensitive screen, alternative user interfaces are provided to facilitate transition (e.g., flipping) from one card to the next. In the context of the present application, the terms “swipe-browsing” or “swiping” is intended to mean the navigation from one card to an adjacent next card. With devices with touch sensitive screens, swipe browsing is typically implemented by the sliding of a finger or other input device across the display. With devices without touch-sensitive screens, other navigation tools such as a mouse, keyboard or remote control, can be used for swipe browsing. When a swipe is performed, the content of the next card in the sequence is displayed. For example, by swiping either right to left or vice versa, the next card, depending on the swipe direction, in the horizontal sequence is displayed. Similarly, by swiping up and/or down, the next card in either the up or down sequence is displayed. Thus, the user experience when consuming a wrap package is the wrap package itself (as opposed to a remote web site for example), viewable via a swipe-able interface. - Additionally, some cards may also include one or more embedded link(s) that, when selected, enable navigation to either a non-adjacent card not in linear sequence or to another wrap package, a web page or some other location entirely outside of the wrap package.
- It should be noted that the particular layout of
cards 14 in thewrap package 10 illustrated inFIG. 1 is merely illustrative. Both the number of rows and/or columns, and the number ofsequential cards 14 within any given row or column, may vary widely as appropriate to deliver the desired user experience, narrative, content, functionality and services of thewrap package 10. - With gallery cards, such as
card 14 B ofFIG. 1 , swiping allows for the scrolling through of the contents of acard 14, which are typically too voluminous to be displayed within the size of a fixed screen display, such as that provided on a mobile phone. In an illustrative example, aparticular wrap package 10 may include a plurality of cards organized in a horizontal sequence. By swiping right to left or vice versa, thenext card 14 or theprevious card 14 in the horizontal sequence is displayed. In the vertical direction, however, one or moreselected cards 14 B may be configured in the gallery format, allowing the viewer to scroll up or down by swiping through media content of the gallery. In an illustrative but non-exclusive example, awrap package 10 authored and distributed by a car rental business may include a horizontal sequence ofcards 10, each dedicated to a category of information pertinent to a traveler (i.e., cards dedicated to local hotels, restaurants, local tourist attractions respectively). By swiping up or down for a given card, relevant material within each category is displayed in a gallery format. For instance by swiping up or down the hotel card (not illustrated), a gallery of a number of local hotels is displayed. In variations of the gallery card format, the behavior invoked by an up or down swipe may differ. For example, swiping up or down my result in a continuous “rolling” of the content of the gallery card. In other embodiments, an up or down swipe may result in a “snap” action with the next item of content appearing after the snap, for example, as illustrated ascards FIG. 1 . - The
wrap package 10 is identified, as described in more detail below, through the use of a unique identifier (wrap ID 42) assigned to thepackage 10. By way of example, thewrap ID 42 may take the form of a Uniform Resource Identifier (URL). As such, the wrap ID may thus be provided as a link, which can readily be used to effectively send or retrieve the wrap package. That is, the wrap package may effectively be “sent” to a potential viewer as a link using any of the wide variety of mechanism that can currently—or in the future—be used to send a link or convey the URL. By way of example, this may include e-mail messages, text messages, SMS messages, via a Twitter tweet, as a post on social media such as Facebook, etc., discussion forums, walls or the like, as a link embedded in a document, an image, or a web page or any other media type, in a blog or micro blog (e.g. Tumblr), or any other messaging or electronic content distribution mechanism or communication platform currently known or developed in the future. - Wrap packages are therefore significantly different and more powerful than web sites. For example with wrap packages, they can be consumed “on the spot” where it is located (i.e., when delivered to a mobile device for example). In contrast with the selection of a banner ad appearing within a web site, where the viewer is taken to a new web page that is not (a) necessarily designed for mobile devices and (b) is self navigating, making it very difficult for a narrative to be conveyed. As a result, the user experience, particularly on mobile devices, may be very poor. Hence, the friction of providing a compelling user experience with wrap packages is far less than with web site.
- The
cards 14 of awrap 10 can be displayed on the screen of virtually any type of computing device. It should be appreciated that the card metaphor is particularly well suited for use on mobile devices such as smart phones, tablet computers, etc., which makes the format particularly powerful for authors interested in developing content tailored for mobile devices. By deliveringwrap packages 10 to mobile devices, users and potential customers can be won over at their point of intimacy, where they spend their time and consciousness. Wrap packages thus allow authors, merchants and other content providers to create compelling narratives and provide ongoing application functionality and/or e-commerce support directly delivered anytime and anywhere to users, transforming their mobile devices into a powerful business tool that enhances mobile engagement and relationships. As a result, higher customer satisfaction, better brand engagement, and a higher conversion (i.e., click-through rates) and repeat e-commerce related activity compared to other forms of after sale promotions and merchandising will likely result. - Referring to
FIG. 2 , a diagram depicting the design, functionality and data integration capabilities of arepresentative card 14 in awrap package 10 is shown. - By using card templates, authoring tools and media collaboration tools, beautiful, content-rich,
cards 14 may be created either by automation or by individuals with even minimal design skills and experience. As such, the author, either a person or an automated process, has the ability to easily create beautiful content-rich cards 14 that can selectively include text, images, photos, and other media similar to PDF files, but optionally, with the added benefit of additional application functionality and/or e-commerce related services, either embedded in thesame card 14, orother cards 14, in thewrap package 10. In the automated authoring embodiments, the content of acard 14 can be populated by a data processing system that automatically uploads predefined content into various defined fields of a card template. - By authoring (i) the horizontal and/or vertical sequence order for swipe-browsing the
cards 14, (ii) the media content in eachcard 14, (iii) application functionality and/or (iv) the e-commerce services for eachcard 14, it is possible to author Wrap packages 10 that are content-rich, highly interactive, and that define a palette of services, functions and experiences related to thewrap package 10, all within the context of a story book-like narrative that unfolds as thecards 14 are browsed in their sequence order(s). - In addition, the use of component libraries and the authoring tools allow for the authoring of
cards 14 with a diverse, easy to use, reusable, set of component modules that provide a wide variety of application functions and e-commerce services. Such application functions include, but are not limited to, for example, calendar functions, scheduling of an appointment functions, reserving or booking goods and/or services, such as a car rental, hotel room, or table at a restaurant, map or GPS related functions, support for online conversations, streaming live video or other media feeds, etc. In addition, e-commerce related services include displaying product and/or service offerings, displaying user account information, engaging a sales representative in an online chat session, and enabling the purchase of goods and/or services, etc. These card services or “plugins” are all part of an ecosystem supported by a Wrap run-time engine viewer (described in more detail below), which allows the various plug-in services to all communicate and inter-operate together. For example, a calendar plugin could be configured to communicate with a reservation booking database plugin, which could communicate with a chat plugin. The communication among the various plug-in services is accomplished through a common set of APIs. As a result, the interactivity, functionality and usefulness of wrap packages 10 are significantly enhanced by such an ecosystem of connected plug-in services. - Finally, the integration capabilities of
cards 14 enable the bi-directional flow of data from users browsing awrap package 10 toother cards 14 in thesame wrap package 10, to anotherwrap package 10, or a remote data processing system. For example, acard 14 can be integrated with the back end software system for a large online retailer, which will automatically populate the content of acard 14 with product images, user account information, prior purchase information, and a host of other user-related information. Alternatively, acard 14 can be used to capture data input from a user and provide it to a retailer's back end e-commerce software system. For example, acard 14 may display a one-click “Buy Now” function for a displayed item. When the Buy Now function is selected, previously saved user account information is automatically delivered to the back end software system of the online merchant, which then processes the information to complete the transaction. - The data entered by the user and/or the data presented via a
card 14 of awrap package 10 may thus be integrated with the back-end database, cloud computing services, web sites, etc., regardless if managed by an author and/or distributor of the wrap package or by a third party. The data processing for the purchase of goods and/or services, appointments, and/or other application functionality and e-commerce related services may, therefore, be performed either within the wrap packages 10 itself or integrated with a remote data processing resource. - The data integration capabilities of
cards 14 can also be shared amongother cards 14 in thesame wrap package 10, with other wrap packages, with web sites, or just about any other data processing system. - Referring to
FIG. 3 , a diagram summarizing the content and distribution model for wrap packages 10 is shown. As illustrated in the left most column, the content that may be included in thevarious cards 14 of awrap package 10 may include photos and/or images, audio, video, text, 3-D objects, various types of streaming media (e.g., audio, video, audiovisual, data, biometric information, tickers, sensor outputs, etc.), other data types, application functionality and/or e-commerce services. This content may further be combined with content mixed fromother wrap packages 10 as well as live or streaming content. Thecards 14 of thewrap package 10 may be further modified based on analytics, intelligent personalization based on the demographics of targeted users or viewers, as well as the integration of either data input or data output to/from withother cards 14, other wrap packages 10, or remote data processing systems and processes, as explained above. - All of the above are then combined during the authoring process into a group of digital objects, defined herein as the
wrap package 10. In non-exclusive embodiments where URLs are used as identifiers (i.e., wrap ID 42), the wrap packages are “light-weight”, meaning content of thewrap package 10 is delivered over a network to a user only when thewrap ID 42 for thewrap package 10 and/or eachcard 14 is identified. As a result, the media content, application functionality, and/or e-commerce related services is delivered only when needed. Also, by authoring thecards 14 using a widely supported language such as HTML, thecards 14 of wrap packages 10 can be written once and are viewable on a display associated with almost any computing device running a browser. Accordingly, unlike applications, multiple version of awrap package 10 need not be authored for multiple platforms. - The
wrap package 10 is thus essentially a cloud based portable object that may be readily distributed in a number of ways. In non-exclusive examples, wrappackages 10 may be distributed by email, SMS messaging, ad networks, Twitter, merchant/retailer web sites, photo and/or video sharing web sites that support messaging, social networking web site such as Facebook, through the down-loading of applications from aggregators such as the Apple App Store or Google Play, or just about any means for electronically distributing data over a network, currently known or developed in the future. - Referring to
FIG. 4 , a block diagram of a non-exclusive system for authoring, storing, distributing and consuming wrap packages 10 is illustrated. Thesystem 20 includes aserver node 22, a plurality ofcomputing devices 12, including but not limited to adesktop computer 12A, alaptop computer 12B, atablet computer 12C, a mobile “smart”phone 12D, a wearable computing device, such as asmart watch 12E orsmart glasses 12F and “smart”TVs 12G. Theserver node 22 and thecomputing devices 12A-12G communicate with one another over anetwork 24. In various embodiments, thenetwork 24 may be the Internet, an intranet, a wired or wireless network, a Wi-Fi network, a cellular network, other types of communication networks, or any combination thereof. - The
server node 22 includes a “wrap”engine 26, which defines aweb application framework 28, astorage device 30 andcache 32, each for storingwrap packages 10 and other data. Theserver node 22 also may include a suite of tools, such as an authoring tool (as described in detail below), an analytic engine tool, a media collaboration tool and a data transformation tool, for authoring wrap packages 10. - The
web application framework 28 is a software platform designed to support the manual and/or automated authoring of wrap packages 10. Theframework 28 is designed to alleviate the overhead associated with common activities performed during the authoring of many wrap packages 10. For example, theframework 28 may include one or more libraries to help with the authoring of common tasks, and modularizes and promotes the reuse of code designed to perform specific tasks, such as implementing application functionality and/or supporting e-commerce. In various embodiments, theweb application framework 28 may be implemented using, but is not limited to, Ruby, Rails, JavaScript, Angular-JS, and/or any other language or framework currently known or developed and used in the future. - In a non-exclusive embodiment, the
web application framework 28 of thewrap engine 26 also performs content management as a way of organizing, categorizing, and structuring the media and other content resources such as text, es, documents, audio files, video files and modularized software code so that the content of wrap packages 10 can be stored, published, reused and edited with ease and flexibility. The content management function is also used to collect, manage, and publish content, storing it either as components or whole documents, while maintaining dynamic links between the components and/orcards 14 of awrap package 10. - In yet another non-exclusive embodiment, the
web application framework 28 of thewrap engine 26 is structured around multiple tiers, including but not limited to a client tier, an application tier and a database tier. The client tier refers to the browser enabledcommunication devices 12 that execute anddisplay cards 14 of wrap packages 10, as well as web pages written in HTML or another mark-up language. The database tier, which is maintained instorage 30, contains the one or more libraries of user and/or platform provided media content, software components, modules, etc. used for the authoring of wrap packages 10. The application tier contains the software that runs on theserver node 22 and that retrieves and serves theappropriate wrap package 10 fromstorage 30 and/orcache 32 when requested by acomputing device 12. - Since wrap packages 10 are essentially data objects, they can be both cached and delivered over a Content Delivery Network Interconnection (CDN), both of which can be effectively used to deliver
wrap packages 10 with minimal delay. For example, commonly requestedwrap packages 10 may be cached in thecache 32, which provides faster access and delivery times thanstorage 30. Also other caching techniques, such as pre-caching, may be used with popular wrap packages 10, to speed up delivery times. Since the amount of storage in the cache is typically limited, cached wrap packages 10 and other data may be periodically replaced by any known replacement algorithm, such as first-in, first-out or least recently used for example. - During the composing of a
wrap package 10, one or more author(s) 34 may access theserver node 22 over anetwork 36, which may be different or the same asnetwork 24. The author(s) 36 interact with thewrap engine 26, including theweb application framework 28, and the above-mentioned suite of tools for the creation, editing, optimization and storing of wrap packages 10. In yet other embodiments, the one or more author(s) 34 can also accessthird party content 38 for inclusion into awrap package 10. As previously noted, wrappackages 10 can be authored manually by one or more individuals or electronically in an automated process. - For more details on the authoring of
cards 14 of wrap packages, see U.S.provisional applications 62/062,056 and 62/062,061, both entitled “Wrapped Packages of Cards for Conveying a Narrative With Media Content, Providing Application Functionality, and Engaging Users in E-commerce”, both filed Oct. 9, 2014, and both incorporated by reference herein for all purposes. - Once the authoring of a
wrap package 10 is complete, it is maintained instorage 30 and possibly cached incache 32. In response to receiving an identifier, thewrap engine 26 fetches thecorresponding wrap package 10 fromstorage 30 or thecache 32 and serves it to the requestingcomputing device 12 for consumption in a format customized for the viewing device. - It should be noted that the authoring and distribution diagram of
FIG. 4 is merely representative and should not be construed as limiting. For example,multiple server nodes 22 for the authoring and/or distribution of wrap packages 10 may be provided at the same or different locations. In addition, multiple instantiations of a given wrap package can 10 be stored atmultiple server nodes 22, typically located at different geographic locations. With this arrangement, theserver node 22 that is most capable of quickly delivering a requestedwrap package 10, sometimes referred to as the “publication server”, is thenode 22 that will deliver the wrap package to the requestingdevice 12. - As diagrammatically illustrated in
FIG. 5A , awrap package 10 includes a set of one ormore cards 14. Eachcard 14 may contain one ormore components 16 that serve as containers for content objects 17. The content objects 17, together with the behaviors associated with the cards andcomponents 16, define the content and functionality of the cards. The content objects 17 may be simple or complex. Simple content objects 17 include standard web-based content types such as text, images, video clips, etc. More complex content objects 17 may include objects having more complicated structures and/or behaviors, as will be described in more detail below. - The structure of the
wrap 10, including the structure, layout andcomponents 16 of each of itscards 14 is preferably defined by awrap descriptor 40. The actual structure of thedescriptor 40 may vary widely and a few different suitable descriptor structures are described in more detail below with respect toFIGS. 6-6D . Some content objects 17, such as text, may be directly included (in-line) in thecomponent 16. Other content objects 17, such as images or video clips, may be included by reference, e.g., through simple URL references, or in-line through an encoding method such as MIME (Multi-Purpose Internet Mail Extensions). Complex content objects 17 may be specified in-line or by reference and may (a) containother components 16 or content objects 17 and/or (b) specify abstract behaviors. - Referenced content objects 17 stored outside of the
wrap descriptor 40 are sometimes referred to herein asassets 65. The referencedassets 65 may take the form of almost any type of content that can be included in the wrap package. This can include text, photos, images, 3-D objects, audio, video, and other media content or streams and/or a variety of executable objects, services and/or other functionality. Sometimes an asset may take the form of a stream and thewrap descriptor 40 is arranged to identify the source of the stream (i.e., the feed). By way of example, the stream could be a live audio or video stream, a data feed such as a stock ticker, sensor outputs, biometric information, etc. - In certain circumstances, some or all of the
assets 65 associated with awrap 10 may be stored and accessible from a dedicated wrap server. However, that is not a requirement. Rather, an asset can be retrieved from any location that would be accessible by the consuming device (e.g., through the Internet, an intranet or private network or any other reliable means), and there is no need for thevarious assets 65 to be located in a single asset store, although that may be desirable in many circumstances. - The
wrap package 10 has an associated identifier, thewrap ID 42, that uniquely identifies thewrap 10. The wrap ID is preferably a globally unique identifier (GUID). In some embodiments, thewrap ID 42 takes the form of a URL, or any other identifier that can be converted to, or extracted from, a URL, which facilitates access to thewrap 10 over the Internet using conventional mechanisms. An example of a conversion of the wrap ID to a URL might be adding a domain as a prefix to the wrap ID to form a URL (e.g., www.wrap.com/wrap/<wrapID>). -
FIG. 5A also diagrammatically illustrates selected components associated with defining and rendering arepresentative wrap package 10. The illustrated components may optionally include one or more covers 15, awrap descriptor 40, awrap runtime viewer 50 and various referencedexternal assets 65. As previously noted, thewrap descriptor 40 defines the structure, layout andcomponents 16 of each of thecards 14 within thewrap package 10. Thewrap descriptor 40 typically includes thewrap ID 42 and a set, deck or array of card definitions orcard descriptors 46, each defining the structure of an associated card (as described with respect toFIG. 6 for example). Thewrap descriptor 40 may also include other information of interest such as a wrap name/title 44 and optionally one or more cover identifier(s) 43 and/or other information ormetadata 45 about thewrap package 10. - To facilitate rendering the
wrap package 10 on various different devices, the wrap is preferably stored in a data format that separates the data from the presentation. At the time of this writing, JavaScript Object Notation (JSON) is a popular, light-weight, data-interchange format that can be used to describe thewrap package 10. Thus, by way of example, the definition of thewrap package 10 may be stored as a JSON data object at the server(s) 22. That is, thedescriptor 40 may take the form of a JSON object. In other embodiments, a BSON (Binary JSON) data object may be used. Although the use of JSON or BSON data objects is described, it should be appreciated that in other embodiments, thewrap package 10 may be stored in a variety of other suitable formats, whether now existing or later developed. - The
optional cover 15 of thewrap package 10 is typically a graphic object that contains an embedded hyperlink to the wrap (e.g., the URL used as wrap ID 42) and can be placed in any suitable type of electronic media to represent thewrap package 10. Thus, awrap 10 may be accessed by clicking on or otherwise selecting thecover 15 or by clicking on, or otherwise selecting any other type of link containing thewrap ID 42. As such, in order to “distribute” awrap package 10, either thecover 15 or a link can be distributed to potential viewers of thewrap package 10 using any available tool. For example, thewrap package 10 may be distributed by: (i) placing thecover 15 or a link on a webpage, in an ad or in any other location that can be accessed by a potential viewer via a browser; (ii) by posting thecover 15 or a link on a blog, a micro blog, a forum, a wall etc. or any social media distribution mechanism such as Facebook, Twitter, etc.; (iii) by including thecover 15 or a link in a message such as e-mail, SMS message, a Twitter Tweet, text messages, etc.; or (iv) using any other available distribution mechanism or platform, either known now or developed in the future. Therefore, in many circumstances, it is desirable to create acover 15 that is attractive and entices viewers to access the associatedwrap package 15. In some instances, thecover 15 may take the form of an image from thewrap package 10 itself (e.g., the first card); however, that is not a requirement. - The
wrap package 10 is configured to be rendered on a consumingdevice 12 in conjunction with awrap runtime viewer 50, which is also sometimes referred to as the wrap run-time engine or simply the viewer. Theruntime viewer 50 provides a set of tools and functionalities that are helpful for viewing and/or interacting with the wrap. In some circumstances, theviewer 50 will take the form of a dedicated, platform specific, wrap viewer application (e.g., an applet or app in the context of a mobile device), a plug-in (e.g. a browser plug-in) or other mechanism installed on the viewing device that provides the necessary functionality. In other circumstances the wrap viewer functionality may be incorporated into other types of applications. However, limiting the rendering of wraps to devices which have preinstalled wrap viewing applications/functionality would greatly reduce their portability since users are not always motivated to install such applications unless or until they see a compelling need. Therefore, as will be explained in more detail below, the delivery of a wrap packages 10 may optionally be accompanied by a run-time viewer 50 that includes a set of associated tools and functionalities suitable for use by a conventional browser to generate and/or render the runtime instance of the wrap based on thewrap descriptor 40 and to facilitate user interaction with thewrap package 10. These tools and functionality can be thought of, and are often referred to herein as a wrap toolset that is part of thewrap runtime viewer 50. By providing the wrap construction, viewing and interaction toolset in a browser executable form together with thewrap descriptor 40, thewrap package 10 can be consumed on a wide variety of different devices and operating system platforms (e.g., iOS, Android, Microsoft, etc.) without requiring the users to download and install a device and/or platform specific viewer application. This is a powerful construct for enhancing the portability and viral distribution of wrap packages among a myriad of devices and operating system platforms - In the embodiment illustrated in
FIG. 5A , the viewer toolset provided with thewrap viewer 50 includesnavigational tools 51,sharing tools 52, storingtool 53,various e-commerce tools 54, presentation engine/tools 55, security andaccess control tools 56, arendering engine 57, andapplication functionality tools 58. Of course, it should be appreciated that not all of these tools are required in all implementations and that in other implementations, a variety of other tools and functionalities may be provided as well. Thenavigational tools 51 facilitate navigation within thewrap package 10. Thesharing tools 52 provide mechanisms by which a consumer of thewrap 10 may share the wrap with others, e.g., by e-mail, by SMS message, via a social media post, etc. Storingtool 53 allows a user to persistently store the wrap and/or when applicable, the wrap state, either locally or remotely. Thee-commerce tools 54 may include a variety of functionalities that can help facilitate a variety of e-commerce tasks including purchasing, making reservations, etc.Application functionality tools 58 enable “app-like” functionality within thewrap package 10, such as conducting online chats, GPS functionality, etc.Presentation engine 55 controls the presentation. In some embodiments, thepresentation engine 55 may be arranged to present the wrap on the consuming device at a scale and in an aspect ratio that is at least somewhat optimized for the device. - Security and
access control tools 56 provide security and access control functionality, which might include encryption functionality and user authentication services. For example, in some circumstances, the publisher of a wrap may want to limit the circulation of the wrap to specific users or groups of users. A few, nonexclusive examples of such circumstances include when the wrap is created for use as: (i) an active receipt for a purchase as described in U.S. Provisional Application Nos. 62/062,056 and 62/075,172 (both incorporated by reference herein for all purposes) and (ii) a ticket for an event as described in U.S. Provisional Application No. 62/079,500; (also incorporated by referenced herein for all purposes)(iii) an item customized for a customer such as a travel itinerary; (iv) an employee manual as described in U.S. Provisional Application No. 62/114,731 (also incorporated by reference herein for all purposes); etc. Encryption services may be desirable to protect confidential information. Of course, there are a very wide variety of other circumstances where security and/or access control/permission functionality may be desired. - With certain embodiments, the
viewer 50 may optionally also include arendering engine 57 arranged to create and/or render a runtime instance of the wrap on a consumingdevice 12 based on thedescriptor 40. In such embodiments, the rendering engine is arrange to dynamically generate the HTML (or other markup language) use by a browser or other viewing mechanism on thedevice 12 to render the wrap at runtime. In some implementations, therendering engine 57 is arranged to create an object graph based on thedescriptor 40 and a document object model (DOM) based on the object graph. The browser or other suitable app or application may then use the DOM to render thewrap package 10. - With yet other embodiments, the
viewer 50 may also optionally have any number ofcard behaviors definitions 60. As will be described in more detail below, different cards can be designed to exhibit a wide variety of different behaviors. In order to simplify the card, and card template creation processes, various desired behaviors can be defined separately from the cards themselves. The behaviors are known to or accessible by the wrap viewer 50 (e.g., desired behaviors may be defined throughbehavior definitions 60 or may be accessible asbehavior extensions 62 as seen inFIG. 5B ). Thus, the descriptor for any particular card or component may simply declare the desired behavior and theviewer 50 will know how to impart such behavior to the wrap/card/component and/or how to obtain an extension that imparts such behavior. - In
FIG. 5A , the behavior definitions and the various tools are illustrated as separate items to facilitate their description. However, in practice, some of the illustrated tools are simply sets of associated behaviors, and therefore, the illustrated distinction between the behaviors and such tools is/are largely for emphasis. - As discussed above, the
wrap package 10 may be rendered on a wide variety ofdifferent devices 12A through 12G. These devices may have a wide variety of different screen sizes, capabilities, and viewing mechanisms. When aparticular device 12 requests awrap package 10, a determination is effectively made as to whether a suitable wrap runtime viewer is already present on the requesting device. If not, a browsercompatible runtime viewer 50 is provided in addition to the wrap or wrapdescriptor 40. The browser compatible run-time viewer may be written in any format that is appropriate for execution by a browser. By way of example, JavaScript (JS) is a dynamic programming language that is currently popular and supported by most general purpose browsers and many other rendering mechanisms. Thus, JavaScript works well for the browser compatible viewer since the same wrap viewer can be used for a wide variety of different browsers. However, it should be apparent that in other embodiments, thewrap viewer 50 may be implemented using a wide variety of other now existing or future developed frameworks and/or languages. For example, the DOM rendering may be replaced with a React framework or another suitable framework currently known or developed in the future. When the wrap viewer is incorporated into a native application, it will sometimes be desirable to write the viewer (or portions of the viewer) in a format that executes more efficiently or is otherwise preferred for execution on the underlying operating system, etc. -
Different cards 14 within awrap 10 can be designed to exhibit a wide variety of different behaviors. To simplify the card authoring process, thecard descriptor 46 within awrap 10 can be arranged to declare the behavior of thecard 14 without internally defining that behavior. Rather, in such circumstances, the desiredcard 14 behaviors are defined within thewrap viewer 50 as part of thebehavior definitions 60 or throughbehavior extensions 62. With this arrangement, a card template designer can define the behavior forcards 14 authored using the template, or can define a set of available behaviors from which a card author can choose. If a set of behaviors are available to the card author, then the authors selects the desired behavior from the available set. In either case, the desired behavior is declared as part of the card. With this arrangement,different cards 14 within awrap 10 can exhibit different behaviors and such behavior remains with the card even if the card is used in a different wrap. If a new card behavior is desired, the new behavior can be created and added to thebehavior definitions 60. In this manner, the newly defined behavior becomes available to other template designers and/or card authors. - The
card descriptor 46 for the gallery card includes a behavior declaration that identifies the desired behavior for the card, which can then be bound to the card at run-time by the wrap viewer (e.g., browser based viewer, native viewer, etc.). For example, this could take the form of a statement such as: -
- “Behaviors”: [“vertical-snap-to-card”]
Further examples are shown in Appendix I of U.S. Provisional Application No. 62/133,574.
- “Behaviors”: [“vertical-snap-to-card”]
- The developer of the
wrap viewer 50 can define any number of card behaviors that are supported by the viewer, such as but not limited to the different scrolling techniques in the example above. Third parties can provide extensions that define still other behaviors (e.g., a scrolling behavior in which a two finger swipe reacts differently than a one finger swipe, etc.). The developer of a card template can define which of the available behaviors are available for use with the template (e.g., a subset, or all of the defined scrolling behaviors). Wrap and card authors using the template can then select which of the behaviors available to the template they would like to associate with the card, and the chosen behavior is declared as part of thecard descriptor 46. - Although the specific example of scrolling behavior in a gallery card has been given, it should be appreciated that virtually any desired type of card behavior can be defined and declared in a similar manner. It should be appreciated that differences in card behavior may take a wide variety of different forms. For example, different types of cards may have different accompanying behaviors; the behavior of a particular type of card may be different based on its position within the
wrap 10; and/or the animations associated with transitions may vary with respect to card position. - The actual structure of the descriptor used to define a gallery card may vary significantly. By way of a representative card descriptor structure suitable for implementing a gallery card is described in more detail below and is illustrated in
FIG. 6C . - A card can have one or more triggers embedded therein. Triggers are hooks associated with displayed items that can cause an action or behavior in response to an event (e.g. a user input). That is, a predetermined user action or other event (such as the selection of the displayed item) triggers a defined action. In general, a trigger is a
component 16 of a card. The trigger has associated behaviors and one or more associated handlers. When a triggering event is detected, the associated handler causes execution of the desired behavior. - Virtually any type of computer detectable event can be used to activate a trigger. In many circumstances, the triggering event may be a user input such as the selection of a displayed trigger component (e.g., by tapping or performing another appropriate gesture relative to a displayed item configured as a trigger component). However, in other circumstance, the activating event may be system generated. System generated events can include sensor input based events, time or timer based events, the receipt of a particular message, the determination that a particular navigational sequence has occurred within a wrap, geo-location or proximity based events (e.g., the viewing device is located within a particular store or geographic area, or near to other users viewing the same wrap) or any of a wide variety of other computer detectable events.
- Once activated, a trigger may exhibit any desired behavior which can be associated with the trigger through
appropriate behavior declarations 95. Virtually any type of computer implementable behavior can be associated with a trigger. By way of example, a linking trigger may be used to link the user to another card within the current wrap, to send the user to another wrap, webpage or other destination. The linking trigger may also be arranged to define a desired linking behavior (e.g., open in same tab, open in new tab, etc.). Other triggers may initiate a wide variety of other action. - The ability to generally define triggering events and the resulting behaviors is an extremely versatile construct that provides wraps with tremendous flexibility and power. Thus, triggers can be used to enable a wide variety of actions, including invoking of a number of different application-like functionalities or e-commerce related services. For example, a trigger may be used to initiate an action (e.g., order a product, conduct an online chat, sharing the wrap with others, book or reserve a table at a restaurant, a hotel room, a rental car, etc.). Almost any type of wrap component/asset can be associated with a trigger, which gives authors tremendous flexibility in guiding the user experience.
- The
wrap 310 illustrated inFIG. 7 has a number of triggers. These include purchasing trigger 340 (FIGS. 7F-7K ), subscription trigger 360 (FIG. 7L ) and social media triggers 381, 382, 383 (FIG. 7M ). The purchasing trigger 340 is arranged to facilitate a user purchase of the displayed product. As an illustrative example, the trigger 340 ofFIG. 7F , is associated with a generally rectangular region that bounds the text and graphic located at the bottom of the card, including the text “pomegranate $18 for 12 16-ounce bottles” and the adjacent “Buy Now” button. The region that involves the trigger is generally shown by a dashed box inFIG. 7F . Selection of the trigger 340 links the user to a mechanism that facilitates the purchase of the identified item. The other above-identified triggers in thewrap 310 are characterized by and operate in a manner similar to the Buy Now trigger 340 ofFIG. 7F . - The implementation of a purchase mechanism within a
wrap package 10 may be widely varied. For example, in some implementations, the user may be linked to the vendor's website, where the purchase may be made in a conventional manner through the website. If this approach is taken, it is often desirable to access the target website through a “Cul-de-sac” so that the user is returned to the wrap when finished with any transactions they wish to make (a Cul-de-sac has the property of returning to the initiating wrap card/page when the user closes the target website). In another approach, the selection of the trigger causes the wrap to transition to a purchasing card (or sequence of cards) within the same wrap where the desired transaction can occur. One such approach is described below with respect toFIGS. 8A-8C . Alternatively, the transition could be to a separate purchasing wrap. Regardless of the mechanism, it is often desirable (although not necessary) to use a cul-de-sac approach so that the user is returned to the card from which the transaction was initiated after the transaction is completed. In still other implementations, the transaction can be completed without leaving the current card—particularly when the user is using a secure viewer that knows the user's identity and relevant purchase related information. In such an embodiment, the transaction can be completed using a “one-click” purchasing option, where previously stored customer billing, shipping and other account information is used to process the purchase. - In a non-exclusive embodiment, the specific behavior associated with the link may be declared in the same manner described above. For example, consider a situation where the trigger activates a link to an external website. There are several ways that such a link could be implemented. One approach might be to link to the target web page in the currently active browser tab, which has the effect of navigating away from the wrap. A second approach might be to open a new browser tab and open the target webpage in that new browser tab. A third approach might be to initiate a Cul-de-sac in the current browser tab and open the target webpage in the Cul-de-sac (a Cul-de-sac has the property of returning to the initiating wrap card/page when the user closes the target website). In such an arrangement, the card template developer can make these three link behaviors available to the trigger and the card author can select the desired behavior. The card developer can also define a default link behavior selection in the event that the card author does not affirmatively make a selection. As can be seen in Appendix I of U.S. Provisional Application No. 62/133,574, trigger 340 in
card 316 has these three possible linking behaviors in response to activation of a trigger. - The ability to direct a user to a target website to complete a transaction can be helpful in many scenarios. However, a drawback is that it can be more difficult to track or guide user behavior after the user has navigated away from the wrap. Therefore, it is often preferable to design the wrap in a manner that facilitates handling user side interactions involved with a transaction from within the wrap itself.
- The actual structure of the descriptor used to define a trigger may vary significantly. By way of example, a representative trigger component descriptor structure is described in more detail below and is illustrated in
FIG. 6D . - Referring next to
FIGS. 6-6D , a variety of specific descriptor structures suitable for use in defining various wraps, cards and/or components will be described. Although specific descriptor structures are illustrated, it should be appreciated that the structure of the various descriptors can be widely varied. In general, the descriptors are arranged to define the structure, layout, content and behaviors of the wrap without details of its presentation on a particular device. That is, the descriptors capture the functional and behavioral intent of the author, in a platform independent way, such that the runtime may implement the described structures and behaviors in a way optimal for the platform in question. - A wrap generally will include multiple cards and the corresponding wrap descriptor will typically have discrete descriptors for each of the cards. The card descriptors each include a unique card identifier and define the structure, behavior, layout and content of the corresponding card. Behaviors associated with any particular card can be applied at the card level (i.e., associated with the card as a whole), at a component level (i.e., associated to a particular component alone—which may or may not include subcomponents) or at any subcomponent level. Since the card descriptors are discrete, self-contained, units with a unique identifier, it is very easy to mix wraps (i.e., use cards created for one wrap in a second wrap). When cards are mixed, their components and associated behaviors remain the same—although it is possible to define behaviors that are context or state aware and therefore exhibit different states/properties/responses/etc. in different circumstances.
- The components are encapsulated units that may have defined content (although such content may be dynamic) and, when desired, specific defined behaviors, styles and/or other attributes. In some preferred embodiments, each component has a unique identifier and could optionally also have an associated type and/or name. The use of encapsulated components with unique component identifiers makes the components highly modular such that an authoring tool can readily use and reuse the same components in different cards and/or wraps. Behaviors can be associated with the component and any component can be composed of one or more subcomponents which themselves are fully defined components.
- Regardless of the level to which they are applied (i.e., wrap level, card level, component level, subcomponent level, etc.), the behaviors are preferably declared in the descriptor rather than being explicitly defined within the descriptor. In that way, the behavior declaration acts as a hook which can be used to associate virtually any programmable logic with a card/component/etc. The behaviors are preferably defined (or at least obtainable) by the runtime viewer.
-
FIG. 6 , diagrammatically illustrates the structure of a firstrepresentative wrap descriptor 40. In the illustrated embodiment, thewrap descriptor 40 includes thewrap ID 42, thewrap title 44, and acard descriptor 46 for each of thecards 14. Eachcard descriptor 46 describes of the structure, layout and content of the associated card. Thewrap descriptor 40 may also optionally include cover identifier(s) 43 and/or any other desired information ormetadata 45 relevant to the wrap. The cover identifier(s) 43 identify any cover(s) 15 associated with the wrap. Other information andmetadata 45 may include any other information that is deemed relevant to the wrap, as for example, an indication of the creation date and/or version number of the wrap, attributions to the author(s) or publisher(s) of the wrap, etc. - The card descriptors 46 may be arranged in an array, deck, or in any other suitable format. In the diagrammatically illustrated embodiment, each
card descriptor 46 includes: a unique card identifier (card ID 71); acard layout 75; and optionally, an associatedcard type 73. Thecard layout 75 preferably includes at least one of a layout identifier (layout ID 76) and alayout definition 78 and optionally, alayout name 77. When the layout definition is not explicitly provided in thecard descriptor 46, it may be obtained by reference through thelayout ID 76. Thelayout definition 78 may be provided in a variety of different format. By way of example, Cascading Style Sheets (CSS) works well. As will be appreciated by those familiar with the art, CSS is a style sheet language used for describing the look and formatting of a document. Of course, in alternative embodiments, other style sheets and/or other now existing or future developed constructs may be used to define the layout of the cards. - The
card ID 71 is preferably a unique identifier that uniquely identifies the associatedcard 14. An advantage of using unique identifiers ascard IDs 71 is that thecards 14 are not wed to aparticular wrap package 10, but rather, can to be used in or shared among a plurality of wrap packages. That is, once a card is created it can be used in any number of different wraps by simply placing that card'sdescriptor 46 at the appropriate locations in the card decks of the desired wrap package. Thus, theunique card IDs 71 can be used to help streamline the process of using one ormore cards 14 from onewrap package 10 in a second wrap (sometimes referred to as the “mixing” ofcards 14 and/or wrap packages 10), which can help simplify the process of creating the second wrap package. In some implementations, thecard IDs 71 may also take the form of URLs, although this is not a requirement. A potential advantage of using URLs as thecard IDs 71 is that the URLs can potentially be used to allow a card in the middle of the wrap to be more directly accessed from outside of the wrap. - The
card layout 75 defines the layout of thecomponents 16 of the associatedcard 14. Preferably thecard layout 75 includes acard layout ID 76 which uniquely identifies the associated layout. In some embodiments, the descriptor itself defines the layout using a conventional web presentation definition mechanism such as Cascading Style Sheets (CSS). In other embodiments, the layout definition may be accessed from a server using thelayout ID 76. As will be familiar to those skilled in the art, CSS is a style sheet language used for describing the look and formatting of a document written in a markup language. CSS enables separation of document content from the document presentation, including elements such as the layout, colors and fonts. Thus, CSS is very well adapted for inclusion within thewrap descriptor 40. - It should be noted that the
layout ID 76 is also useful in the context of the aforementioned authoring tool used to create and author wrap packages 10. Specifically, in some embodiments, the authoring tool is provided with a number of pre-defined templates (card layouts) from which an author of a new card can choose. Each template has one or more containers/components 16, which are arranged on the card in a predetermined manner for holdingcard content 17. The template itself can have any particular layout, or can be used to create a particular layout. In either case, the particular layout can be assigned aunique layout ID 76, and thereafter, be used and reused in conjunction with different cards thereby simplifying the card creation process. - The card type 73 (which is optional in the descriptor) relates primarily to such an authoring tool. For convenience, the templates may be categorized into different groups or classes. By way of example, the classes/groups may relate to their intended uses, the entity for which the templates are to be used, to the creator of the templates or any other logical grouping of templates. For example,
card type 73, can be assigned to one or more predefined card templates, depending on their intended function. For instance, an authoring tool may include one or more card templates, each centric for the display of text, visual media such as photos or images, the playing of video, live or streaming media, application functionality (e.g., scheduling appointments, GPS, etc.), or supporting e-commerce (e.g., displaying products and/or services for purchases, chatting with online sales representative, etc.) respectively. Thus for each template type and class/grouping,card type ID 73 may be assigned. - With the template-based approach, the author(s) of a
wrap package 10 can easily select a desired template/card layout that meets their need from a set of available templates and create a new card by readily inserting the desired content, functionality and/or services into the predefined containers. Such a template based approach can greatly simplify the authoring ofcards 14 and wrappackages 10, since the author(s) need not be an expert in HTML, scripting or other typical web page language constructs required in order to create the card(s) 14 as typically required with creating conventional web pages. Rather, those details are embodied in the selected template itself, which translates to aspecific layout 75, which in turn is identified by thelayout ID 76. When a run-time instance of thewrap package 10 is created,layout 75 is used to format the associatedcard 14. - The associations between
components 16 and their contained content objects 17, whether explicit in the card descriptors, or implicit and anonymous, are sometimes referred to herein as “pins” 80. When explicit, pins 80 are identified in thecard descriptors 46 by a universallyunique Pin ID 81, and by asymbolic pin name 82. When implicit, pins are anonymous at runtime, but may at design time be instantiated in order to provide operable constructs to the authoring tools, in which case they will share the name and ID of the component they bind and associate. - Whether implicit or explicit, these conditions are equivalent, and one representation may be trivially transformed into the other and vice versa, with no loss of meaning. The runtime, authoring environment and other tools are free to transform the object graph as they see fit, and whether the association is treated as intrinsic or extrinsic is irrelevant for the purposes of the determination of the structure of the wrap and its contents, this transformation being a matter of convenience.
- The symbolic name of a pin (pin name 82) or component is both Human and Machine-Readable, for example, “Headline”, “Glyph”, “Body”, “Image”, “Video”, “Cul-de-sac”, or any other heading that the template designer deems appropriate. The symbolic name is used to identify its function; can be used and bound to by constraints and layouts to further constrain their display, behavior and function; and is used by the authoring tools to identify the role of the thus-associated component and map fields from one layout to another when changing the layout associated with a card. Multiple pins or components can share the same symbolic name. When they do, it implies that they serve the same role in the system, and that the same rules will apply to them.
-
Components 16 contain there associatedcontent 17 and may also contain or reference zero or more attributes or constraint objects, specifying metadata to manage or modify the display of, or behavior of, that component. Constraint objects may specify abstract symbolic data used by the runtime to determine how to display or manage the object containing it, (the Constrained Object,) or the behavior of that object. Examples of such abstract symbolic data are CSS class names, behavior names, or other symbolic names acted on by other objects in the system. Constraints may also contain concrete specifications to modify the display or behavior of the object, or its container or any contained objects. An example of the former is containing CSS rules applied to the content. An example of the latter is inclusion inline or by reference of JavaScript code that acts on the constrained object. - The various constraint objects may be thought of as attributes that define the style, format, behaviors, source/feed, and/or constraints associated the corresponding
content 17. In the illustrated embodiment, these attributes include style attributes 86, source attributes 87 and other constraint objects such asbehaviors - The style attributes associate various styles with the
content 17 and may take the form of style sheets (e.g. CSS) or other conventional style definition mechanisms. By way of example, if thecontent 17 is a text string, the style attributes 86 may include features such as the font, size, case, color, justification, etc. of the text. If the content is a glyph, the style attributes may include the color of the glyph, the size, etc. - The source attributes 87 indicate the source of the associated
content 17. In some circumstances, the source attribute may simply be a reference or pointer (e.g. a URL) that identifies the location of a static content object (e.g., an image, a photo, a video, etc.). However, it should be appreciated that the content can also be dynamic. For example, the content object associated with a component of a wrap could be the current price of a particular stock. In such a case, the source attribute identifies the feed from which the current price will be retrieved when the card is rendered. - The ability to incorporate feeds into a wrap is a powerful construct that facilitates a wide variety of different functionalities including the dynamic updating of information presented in a wrap after the wrap has been rendered. In general, a feed is a structured source having content that can be dynamically updated after the wrap has been rendered. As will be appreciated by those familiar with the art, there are a wide variety of different types of feeds and different feed structures. For example, a live streaming feed may present a live stream that is progressively rendered as the stream is received. Examples of live streams include live video streams, audio streams, biometric streams, stock ticker streams, etc. Other feeds are server side event driven as is commonly used to facilitate live updates—as for example, sports score updates, stock price updates, etc. Still other feeds are polling feeds in which the wrap periodically polls a source.
- The source attribute 87 may take the form a feed descriptor that defines the nature and structure of the feed as well as its feed characteristics including source location, data format(s), update semantics, etc. For example, some feeds (e.g. live feeds and live update feeds) require that a socket be opened and kept open as long as the feed is active. Polling feeds require the identification of the desired polling frequency. In other embodiments, the source attribute may include a reference to a feed object (note shown) that defines the feed.
- It should be appreciated that there are a very wide variety of different types of information/content that a wrap author may desire have updated dynamically while a wrap is being displayed. These might include items that may be expected to update frequently and others that may update very slowly. By way of example, a few examples of items that may be desirable to update dynamically include sports scores, stock prices, the number of tickets still available for purchase for an event, number of units of a product that are available or simply an indication of whether a product is in our out of stock, breaking news headlines, etc. A number of services can also benefit from the ability to dynamically update content based on information that can change while a wrap is displayed such as, the user's geographic location, social networking group information (e.g. friends or peers that are nearby, online, etc.), featured information, etc. For example, a card in a wrap for a sports stadium could show the nearest concession stands, restrooms, etc. which can vary as the user roams around the stadium. Another card could show the stats of a baseball player currently at bat. A social networking card may inform a user when their friends or others sharing similar interests are nearby. A retailer may wish to run special offers that update periodically. Of course, these are just a few examples. The types of content that an author may wish dynamically update is limited only by the creativity of the author. Other constraint objects may include declarations of specific behaviors that are intended to be associated with the
component 16 and/orcontent 17. Such behaviors may includebehaviors runtime viewer 50 as discussed above. -
FIG. 6A diagrammatically illustrates an alternative pin basedcard descriptor structure 46A. Appendix II of U.S. Provisional Application No. 62/133,574 illustrates a representative wrap descriptor 40A that takes the form of a JSON object that utilizes the pin basedcard descriptor structure 46A illustrated inFIG. 6A .FIGS. 14A-14E illustrate the wrap defined by the wrap descriptor of Appendix II of the referenced provisional. To facilitate correlation between the Appendix andFIG. 6A , various descriptor elements are labeled with corresponding reference numbers in Appendix II of the referenced provisional. - In the embodiment of
FIG. 6A , thecard descriptor 46 includes a unique card ID, 71, a card name 72,card type 73 and acard layout 75. Thelayout 75 includes alayout ID 76, optionally alayout name 77 and anexplicit layout definition 78. In the illustrated embodiment, the layout definition takes the form of style sheets (e.g., cascading style sheets (CSS)). Although the illustrated embodiment includes both thelayout ID 76 and anexplicit layout definition 78, it should be appreciated that either could be eliminated from the descriptor if desired. For example, if the explicit layout definition is not part of the descriptor structure, it could be accessed through the use of the layout ID. Alternatively, when thelayout definition 78 is explicitly provided, the explicit use of thelayout ID 76 may be eliminated. However, it is generally preferable to explicitly provide the layout ID. - The
descriptor 46A also includes an array of zero ormore pins 80, with eachpin 80 corresponding to afirst level component 16. Eachpin 80 includes apin ID 81, apin name 82 and an associatedcomponent 16. Thecomponent 16 includes acomponent ID 88, acomponent type 89, and thecomponent content 17. As indicated above, the content may be provided in-line or by reference. Any desired attributes and behaviors may then be associated with the component through a set of zero or more component attributes 86 which potentially include any desired componentstyle class declarations 91, component style sheets (CSS) 93 andcomponent behavior declarations 95. In the illustrated embodiment, thestyle class declarations 91 refer and bind to CSS classes defined in thelayout definition 78 that are used to define the format of the associatedcomponent 16. Numerous examples of this binding can be seen in the Appendix II of the referenced provisional. By way of example, the first pin 80(1) in Appendix II has an associated component style class declaration 91(1) that refers to and binds the font size style “font size-x1” 96 defined inlayout 78 to the associated text content 17(1). -
Component style sheets 93 provide an alternative component level mechanism for associating specific styles and formatting with acomponent 16. In general, it is expected that thecard layout definition 78 will define the styles and formats associated with each component in a robust manner that is satisfactory to the card author. In such implementations, there is no need to include any componentlevel style sheets 93, and it is expected that in many (indeed most) such card implementations, no component style sheets would be provided. Rather, the associated styles may be bound through the use ofclass declarations 91. However, thecomponent style sheets 93 provide a mechanism by which the style assigned to the component by thelayout definition 78 may be overwritten, which gives card authors great flexibility in defining the stylistic presentation of their content without altering the card layout definition. In other implantations, it may be desirable to define some of the style attributes at the component level rather than the card level. In such implementations more aggressive use of componentlevel style sheet 93 would be expected. In still other embodiments, the availability of component level style sheets can be eliminated altogether. In the illustrated embodiment, style sheet are used to assign styles to the components since they are currently a popular format for associating different styles with HTML content. However, it should be appreciated that other now existing or later developed constructs can readily be used to associate styles with the content as appropriate. -
Behaviors behavior declarations 95 which declarespecific behaviors - The
card descriptor 46A also associates any desired card level attributes and/or behaviors with the card through a set of zero ormore attributes 86C that are associated with the card at the card level. Like the component attributes 86, the card attributes 86C potentially include any desired card levelstyle class declarations 91C, cardlevel style sheets 93C and/or cardlevel behavior declarations 95C which work in substantially the same way as the component attributes, except that they operate at the card level. When desired, thewrap descriptor 40 can also have similar wrap level attributes 86W. Similarly, when the content of a component includes one or more subcomponent(s), the various subcomponent(s) may have their own associated component attributes 86 regardless of the tier of the component/subcomponent. Still further, when desired, attributes can be associated with groups of components. -
FIG. 6B diagrammatically illustrates an alternativecard descriptor structure 46B that does not utilize pins 80. The structure ofcard descriptor 46B is generally similar to the structure ofcard descriptor 46A described above with respect toFIG. 6A except for the use of pins. Therefore, the attributes (e.g., styles and behaviors) are associated with theircorresponding components 16 rather than withpins 80. Like in the embodiment ofFIG. 6A , thecard descriptor 46B includes acard ID 71, a card name 72 and alayout 75. Thelayout 75 includes alayout ID 76,layout name 77 andlayout definition 78. The descriptor then includes an array of zero tomany components 16. - Each
component 16 includes acomponent ID 88, acomponent name 84, acomponent type 89, the associatedcontent 17 and the associated attributes 86. Like in the previously described embodiment, the associated attributes may include associatedclasses 91, component style sheets ordefinitions 93,behavior declarations 95 and/or their associatedbehaviors card descriptors 46B are functionally substantially equivalent to thecard descriptors 46A described above. - Appendix III of U.S. Provisional Application No. 62/133,574 illustrates a representative wrap descriptor 40B that takes the form of a JSON object that utilizes the component based
card descriptor structure 46B illustrated inFIG. 6B . To facilitate correlation between Appendix III andFIG. 6B , various descriptor elements are labeled with corresponding reference numbers in the Appendix. It is noted that theattributes container 86 is labeled “Styles” in the JSON code of Appendix III. - Although only a few particular card descriptor structures have been described, it should be appreciated that equivalent functionality can be obtained using a wide variety of different descriptor arrangements.
-
FIG. 6C illustrates a representativegallery card descriptor 46G. The illustrated embodiment uses the component based descriptor approach ofFIG. 6B although it should be appreciated that other card descriptor hierarchies (such as those illustrated inFIGS. 6 and 6A can be used as well.Gallery card descriptor 46G includescard ID 71G,card name 72G (in this case “Gallery Card”), andcard layout 75G withlayout ID 76G,layout name 77G andCSS layout definitions 78G, which together define a layout suitable for a gallery card. The initial component isgallery component 16G, which has acomponent ID 88G, acomponent name 84G, acomponent type 89G,gallery component content 17G, and any associatedattributes 86G (includingclass declarations 91G,style sheets 93G andbehavior declarations 95G). - In the illustrated embodiment, both the
component name 84G and thecomponent type 89G are “Gallery.” The “content” of thegallery component 16G is a set of one or moregallery item components 116. Each of thegallery item components 116 typically, although not necessarily, has the same component structure previously described and can be thought of as subcomponents. This introduces a powerful feature of the described architecture. That is, the “content” of any particular component may be one or more “subcomponents”. Similarly, the content of any of these “subcomponents” may also include one or more next tier components and so on, with the components at each tier having the same generic structure. Thus, eachgallery item component 116 includes: acomponent ID 88, which may be thought of as a gallery item ID; acomponent name 84, acomponent type 89, content and any associate attributes 86 (potentially includingclass declarations 91,style sheets 93 and behavior declarations 95). - In the illustrated embodiment, the
component name 84 andcomponent type 89 for thegallery item 116 is “Gallery Item”. The content of thegallery item 116 is a set of components (subcomponents) that make up the gallery item (that is,gallery items 116, which are subcomponents of thegallery component 16G, themselves have subcomponents which might be thought of as third tier components). Each of these gallery item components has the same structure as any other component. By way of example, the gallery item components may include aheadline component 16H, and an image component 16I (shown in Appendix III of U.S. Provisional Application No. 62/133,574). Only theheadline component 16H is shown illustrated inFIG. 6C , but the corresponding JSON descriptor is shown and labeled in Appendix III. - With the described structure, specific behaviors or styles can be associated with components at any level. Thus, for example, a behavior can be associated at the card level, the gallery item level, the component of a gallery item level or at any other level at which components are used. An example of a card level behavior might be the aforementioned gallery card “snap to item” behavior 60C, which can be seen in the aforementioned Appendices I, II and III. An example of a gallery item subcomponent level behavior might be a trigger as described below.
- Although a particular gallery card descriptor structure has been described, it should be appreciated that equivalent functionality can be obtained using a wide variety of different descriptor arrangements.
- Referring next to
FIG. 6D , a descriptor structure for a representative trigger component will be described. Like other components, thetrigger component 16T includes an optionaltrigger component ID 88T, acomponent type 89T, acomponent name 84T,content 17T and any associatedattributes 86T (including any class declarations 91T, style sheets 93T and behavior declarations 95T). In the illustrated embodiment, thecomponent type 89T is labeled “trigger” and thecomponent name 84T is labeled “transact” indicating that the trigger is a transaction trigger. - The
content 17T of thetrigger component 16T in this illustrative example includes three subcomponents. The subcomponents include a text box 16TT, an image 16TI that takes the form of a “buy button” and alink 16L. Thelink 16L has an associated behavior “open-in-new-tab”, which causes the browser to open the target URL in a new tab when the trigger is activated by tapping on a touch sensitive display anywhere within the region defined by the trigger or by otherwise activating the trigger. The described link trigger behavior is a good example of a component level behavior. - In the illustrated embodiment, the
link component 16L is a first level component of the trigger and therefore the link is activated by tapping on (or otherwise selecting) any component within the trigger—as for example either the text box 321 or the buy button 327. If the card creator preferred to have the link activated only by selection of the buy button 327, that can readily be accomplished by making the link 327 a component of the buy button rather than a first level component of the trigger—or, by moving the text box component definition out of the trigger—as for example to the same component level as the trigger itself. Any tap or click in the bounding rectangle of the trigger, as defined by the components contained by the trigger, results in the trigger being activated. - It should be apparent that the trigger component may be included as a first tier component in the card descriptor or as a subcomponent at any level within the card descriptor hierarchy. Although a particular trigger descriptor structure is illustrated, it should be appreciated that equivalent functionality can be obtained using a variety of different descriptor arrangements. It should further that
FIG. 6D is illustrative for providing an example for the purchase of an item for sale. It should be understood, however, the cards can be authored with triggers for a wide variety of actions besides purchasing an item, such as the reservation or booking of goods and/or services, online chats, GPS related services and functionality, etc. - As indicated above, there are a wide variety of different types of feeds and feed structures that may be desirable to incorporate into any particular wrap. To facilitate the use of feeds, any
wrap descriptor 40 orindividual card descriptor 46 may include one or more feed descriptors. As described below, each feed descriptor has a number of descriptive elements that together define an associated feed in a manner that can be used by the runtime to integrate information from the feed into a rendered wrap instance in the manner desired by the wrap author. - Referring next to
FIG. 6E , arepresentative feed descriptor 187 in accordance with a nonexclusive embodiment will be described. In the illustrated embodiment, the descriptive elements offeed descriptor 187 include a feed type 105, a feed source 107, a desired lifecycle 109, a feed target 111, an update frequency indicator 113 and any required feed parameters 115. Of course, not all of these descriptive elements are required in every feed descriptors and any particular feed descriptor may include one or more additional descriptive elements as appropriate. Thefeed descriptor 187 may also optionally include a feed ID 103 and/or a feed name 104. - The feed type 105 indicates the type of the associated feed. In general, most feeds can be categorized into categories or “types” that share similar traits and/or requirements. As previously discussed, some of the feed types might include “live” (server side event driven) feeds, polling feeds, streaming video feeds, streaming audio feeds, etc. When the feed descriptor is processed by the runtime, the feed type can be used to help identify the resources that may be required to support the feed. For example live streaming feeds and server side event driven feeds may require the opening of a socket for the feed and keeping the socket open for the duration of the defined feed lifecycle 109.
- The feed source 107 indicates the location from which the feed can be obtained. Often, the feed source 107 takes the form of a URL, although other endpoints or source identifiers may be used in alternative embodiments.
- The lifecycle 109 indicates the feed's lifecycle semantics. That is, when and how the feed in activated, the conditions under which it remains active and potentially, when it is closed. For example, a few potential lifecycles might include: (a) “while-card-visible” which opens the feed when that associated card is displayed and keeps the feed active as long as the associated card is the visible card within the wrap; (b) “always” which opens the feed when the associate wrap is rendered and keeps the feed active as long as the wrap is displayed; (c) “on-card-open”—which activates a feed any time the wrap transitions to the associated card; (d) “on-wrap-load” which opens the feed when the wrap is loaded; (e) “on-user-selection” which opens and/or updates the feed in response to a user input (e.g., the selection of a displayed button or other user activated trigger). Some of the lifecycles, such as “while-card-visible” and “always” may be more appropriate for live and streaming feeds, or feeds that affect globally-visible wrap state (e.g. in a globally visible sports score ticker or stock ticker) whereas others, such as “on-card-open” or “on-wrap-load” may be more appropriate for polling feeds. Which type of feed is most appropriate is highly context-dependent, and will be determined by wrap authors.
- In addition, the lifecycle 109 may optionally include functionality to terminate the feed. In accordance with various embodiments, the termination may occur in any number of ways. For example, the feed may “time-out” after a predetermined period of time or manually in response to an input from the viewer of the wrap. For example, if the viewer closes and is no longer consuming the wrap, then the feed may be terminated. Alternatively, the feed may automatically terminate 10 minutes after a baseball game that is being streamed has ended. Again, these are just a few examples. The terms and/or conditions for termination of a feed may widely vary.
- The target 111 indicates the callback endpoint for the feed—which may be the method to call when an event happens. In many implementations, the target will be a container within the wrap that the feed is to be associated with. In many circumstances, the intended container will be the component or other structure (e.g., card/wrap) within which the
feed descriptor 187 is defined within thewrap descriptor 40. That is, when thefeed descriptor 187 is included as part of a particular component definition, it might be assumed that the feed is intended to be bound to that particular component. Alternatively, if thefeed descriptor 187 is included as part of acard descriptor 46 outside of any of the associated component descriptions, it might be assumed that the feed is intended to be bound to the associated card. Still further, if the feed descriptor is included as a part of awrap descriptor 40 outside of any of the associatedcard descriptors 46, it might be assumed that the feed in intended to be bound to the wrap as opposed to any particular card or component. - The frequency 113 is particularly relevant to polling feeds and indicates how often the feed should be polled. In some circumstances it will only be desirable to poll the feed once—e.g., when the associated card is opened, which can be uniquely defined by the combination of Lifecycle: on-card-open and Frequency: once. In other circumstances it may be desirable to periodically poll the feed, as for example, every minute, every 15 seconds, every 5 minutes, etc. In still other circumstances it may be desirable to poll when the card or wrap is first opened and thereafter only poll in response to user inputs or other events, as for example in response to the user selection of an “update” button (not shown). Of course, a very wide variety of other update rules can be defined through the use of different frequency and lifecycle constraints, and the feed may itself update the polling frequency for subsequent reads, over the life of the interaction.
- Some feeds may require the passing of specific parameters to the server that may be used by the server for various control, tracking or authentication or other purposes. Feed parameters 115 can be used to pass such parameters to the feed server. In the illustrated embodiment, the feed parameters take the form of name/value pairs although other data structures can be used in other embodiments. In some circumstances, the feed parameters 115 may be static and explicitly included in the wrap descriptor. For example, if a card employing a feed is associated with a particular ad campaign, it may be desirable to identify the ad campaign through the use of campaign identifier passed a feed parameter. In other circumstances the feed parameters may be variables. For example, a card arranged to provide current MLB scores sports may use team identifier parameters to identify the teams of interest to the user, with the user being given the ability to select the teams of interest—as for example, through a menu of teams provided on the card. Of course the specific parameters that are appropriate for any given feed and the manner in which the parameters are obtained may vary widely and will often depend in large part on the APIs associated with the feed.
- In many circumstances it may be desirable to transitorily or persistently maintain state information associated with a user of a
wrap 10 and/or state information associated with awrap 10. Some information, such as general information about the user, may be shared state information that is relevant to a number of different wraps. Other state information may be specific to a particular wrap (e.g., a particular user selection or input within a wrap, etc.). Still other relevant state information can be more global state information that is relevant to all instances of a particular wrap independent of the specific user. - State information can be stored in a number of ways and the appropriate storage techniques will vary in part based on the nature of the state information. By way of example, general information about a user and other user specific shared state data can be maintained in a cookie, or when the user has a persistent viewer application, the user state information can be persistently stored locally in association with the viewer application. If desired, any or all of the shared state information can also be stored on the server side. The shared state information may be useful to support a wide variety of different services including: user login and/or authentication; e-commerce applications where the identity, contact info, mailing address, credit card information etc. of the user may be necessary; integration with other applications (e.g. a calendar application, a chat application, etc.); and many other services. User specific shared state information can also be used to affect the navigation within a wrap. For example, user demographic information can be used to determine which card to display next in a set of cards.
- There are also a variety of circumstances where it will be desirable to persistently maintain state information about the state of a particular wrap. For example, if a card includes a dialog box that receives a user selection or a textual input, it may be desirable to persistently store such selections/inputs in association with the wrap itself so that such information is available the next time the wrap is opened by the same user (or same device).
- In a nonexclusive embodiment, a
state descriptor 68 is created and used to maintain state information associated with a particular wrap as illustrated inFIG. 5B . Thestate descriptor 68 is associated with both a specific wrap and a specific user and thus can be used to store state information relevant to that specific user's interaction with the wrap. When persistent state descriptors are used, thestate descriptor 68 may be stored with the wrap on thepublication server 22. When the user has a persistent viewer application, the state information can additionally or alternatively be stored locally in association with the viewer application either in the state descriptor form or in other suitable forms. Generally, astate descriptor 68 will include awrap ID 42 and a user ID that identify the wrap and user that the descriptor is associated with respectively. Thestate descriptor 68 also stores the relevant state information in association with the card and component IDs for which the state information applies. - In certain embodiments, it may also be desirable to synchronize different instantiations of state information, depending on the where the state information is stored. For example if a user updates their credit card or shipping address information at a
publication server 22, then the corresponding state information residing within any particular wraps associated with the user, or within a persistently stored wrap viewer residing on a communication device belonging to the user, would preferably automatically be updated. Conversely, any state information locally updated within a wrap and/or a persistently stored viewer would also selectively be updated in any other instantiations of the state information, such as but not limited to, other wraps,publication servers 22, on a network, or any other remote data processing location for example. - Wrap packages 10 are composed by
authors 34 using anauthoring tool 100. In various embodiments, the authoring tool may operate in a desktop computing environment or a mobile communication environment, such as on a mobile or cellular phone, a tablet, or other mobile device, such as a laptop computer. - Referring to
FIG. 7 , an exemplary “home screen” 102 of a computing device running theauthoring tool 100 is illustrated. In this example, the home page includes a number of existingwrap packages 104A through 104N. For each wrap package 104, options are provided to “Copy”, “Preview”, “Edit” and “Share”. By selecting any of these options, the corresponding wrap package 104 may be copied, previewed, edited or shared respectively. - For the purpose of explaining the operation of the
authoring tool 100, the authoring of a new wrap package is described below. By selecting a “New Wrap”icon 106 appearing within thehome screen 102, an author can begin the process of authoring a new wrap package. - Referring to
FIG. 8 , awindow 108 for assigning a title for the new wrap appears on the screen of the computing device running theauthoring tool 100 after theicon 106 is selected. Within this screen, atext field 110 is provided for entering an appropriate name or title for the new wrap package. Once the title has been entered, theauthor 34 selects the “Create”icon 112 to begin the authoring process for the new wrap package. - Referring to
FIG. 9 , anexemplary authoring workspace 114 is shown, which appears on the display screen of the computing device executing thetool 100 after the title for the new wrap has been defined. Within theworkspace 114, theauthor 34 is provided a work area and a set of tools for the composing of wrap packages. - The
workspace 114 includes aheader field 116, a cardtype selector field 117 for specifying the type of card to be authored, anauthoring space 118 for defining the components and content of cards the of the wrap package as they are authored, anadd component field 119 for adding component(s) to the cards appearing in thespace 118, a preview and configurespace 120 for previewing and configuring the card defined in theauthoring space 118, and alayout selector space 122 for defining various card templates used for creating and configuring the various card types of the wrap package. - Referring to
FIGS. 10A through 10C , features of theheader field 116 of theworkspace 114 are illustrated. - As shown in
FIG. 10A , the header field includes the previously defined title of thewrap package 10, atitle editing tool 124 for revising or changing the title of the wrap package, asave tool 126, a publishtool 128, and a discardtool 130. Thetools cards 14 of thewrap package 10 as they are authored. - The
header field 116 also includes acard sequencing space 132. Within thisspace 132, the author can arrange the cards and define the one or more linear sequences in which the cards are to be rendered when the wrap package is consumed. - As the individual cards of the wrap package are authored, they are added to the
sequencing space 132 in the numerical order (e.g., 1, 2, 3, 4, etc.) in which they are created. In the event theauthor 34 wishes to re-order the sequence, one of several operations may be used. - As shown in
FIG. 10B , an exemplary re-sequencing operation is illustrated. In this particular example,Card 2 is moved afterCard 3 using a drag and drop operation. When the operation is complete, the cards are renumbered to reflect their new sequence order. In another embodiment (not illustrated), cards can be copied and pasted. In yet other embodiments, cards can be moved or re-sequenced using any technique. - By moving the various cards to different positions within the
space 132, the horizontal sequence of the cards can be arranged in any order as determined by theauthor 34. In addition, one or more of the cards can also be configured as a gallery card(s), which are navigable in the vertical direction. Thus, by defining (a) any gallery cards in the horizontal sequence inspace 132 and (b) the horizontal order of the cards, including any gallery cards, inspace 132, the horizontal and/or vertical sequence for rendering the cards when the wrap package is consumed is defined by theauthor 34. - The
header 116 also includes left and right scrollingicons 131. When either the left orright scrolling icon 131 is selected, the cards appearing in thecard sequencing space 132 scroll in either the left or right direction respectively. By providing the scrollingicons 131, all of the cards of the wrap package can be viewed, even in situations where the number of cards in the wrap package are too numerous to conveniently all fit into thesequence space 132 at the same time. The scrollingicons 131 thus allow theauthor 34 to navigate, view and edit all of the cards of the wrap package. - As illustrated in
FIG. 10C , theheader 116 also includes a “New Card”tool 134. When the author selects this tool, two actions occur. First, anew card 140 is created inspace 132. Implicitly, thenew card 140 appears next in the horizontal sequence order inspace 132. However, as noted above, the sequence order of the card can be changed by theauthor 34 if desired. Second, a new cardtype selector tool 136, which lists a number of different possible card types, appears. In a non-exhaustive list, the types of cards that are provided within the cardtype selector tool 136, include, but not limited to, a textual card, an image/photo card, a video card, a gallery card, a document card, a chat card, a transact card, an appointment card, a feed card and an end of wrap card. By selecting any one of these card types, and then the createicon 138, thenew card 140 is defined as the selected type. - In this particular example, the
new card 140 appears ascard 4 in the sequence order. A number of examples are provided below illustrating the authoring of thenew card 140 for each of the card types listed above. - Referring to
FIG. 11A through 11D , the authoring of an exemplarytextual card 140 is illustrated. - As shown in
FIG. 11A , a number of textual card templates are provided in thelayout selector space 122. Each of the templates is labeledTemplate 1,Template 2, through Template N. Each of the various templates include a different structure and layout. For example, each may include different arrangement of predefined headlines, sub-headlines, and/or components. In this particular example,Template 2 is selected, resulting in a card having the same structure and layout as the selected template appearing in theauthoring space 118 and preview and configurespace 120. In this particular example, the selected template includes aheadline 142 and asub-headline 144. - As illustrated in
FIG. 11B , theauthor 34 types text into theheadline 142 and thesub-headline 144 within theauthoring space 118. As the text is typed, it appears in thecorresponding headline 142 andsub-headline 144 of the card appearing in thespace 120. In this particular example, the author has typed “Wrap” into theheadline component 142 and “The narrative web . . . ” into the sub-component 144. Since this card includes text components, a set ofstyle tools 146 are provided to enable the author to configure the font, size, justification and color of the text contained in thecomponents style tools 146 may optionally not be provided for cards that do not contain text. Thestyle tools 146 are, therefore, not necessarily constrained to all the different card types. - Additional tools, provided in the
authoring space 118, enable the author to further modify the selected card template if desired. For example, aheadline tool 148 enables the author to modify the card template with another header andsub-headline tool 158 enables the author to create another sub-heading. When either is selected, a text box appears in the image of the cards appearing inspace 118 andspace 120. The author can then type into the text box(es), similar to that described above. In addition, the text box(es) can be positioned or moved in the image of the card appearing inspace 120 to any location desired by the author and thestyle tools 146 can be used to define the style of the entered text. - Referring to
FIG. 11C , a number of exemplary textual cards are illustrated. In each instance, a different card, each derived from a template with different layouts, structures, headers and/or sub-components, is illustrated. Also in each case, thestyle tools 146 are available to the author to define the different fonts, sizes, justification and potentially color (not visible) of the text in each of the cards. It should be noted that these examples are not exhaustive. Various templates of different structures, layouts and/or arrangements of components can be used to create an almost infinite number of textual card styles. - Referring to
FIGS. 12A through 12C , a series of diagrams showing how thenew card 140 is configured as an image card is illustrated. - As illustrated in
FIG. 12A , in this particular example, the author selects a particular image template fromspace 122. In response, a card corresponding to the selected template with animage box 154 appears inspaces image box 154, the author selects theselect image icon 156. - As illustrated in
FIG. 12B , an “Add Image”box 158 appears in response to the selection of theselect image icon 156. Within thebox 158, the author may selectively either (i) drag and drop or otherwise select and image or photo from an existing library (i.e.,image 1,image 2,image 3, etc.), upload and image, or provide a URL or other identifier for accessing the image from a remote location when the card is rendered when the wrap is consumed. The defined image is then inserted into thecomponent box 152 when theAdd icon 160 is selected. - As illustrated in
FIG. 12C , the added image appears in both the card template provided inspace 118 andspace 120. Furthermore, withinspace 120, theauthor 34 may further stylize the image by adjusting its size and/or location within the card, as represented by author manipulating the image box containing the image. - Referring to
FIGS. 13A and 13B , diagrams showing how thenew card 140 is configured as a video card is illustrated. - As illustrated in
FIG. 13A , the author selects a particular video template fromspace 122. In response, a card corresponding to the selected template, including avideo component box 162, appears in the preview and configurespace 120. Next, theauthor 34 selects theicon 164 for defining the video for insertion into thecomponent box 162. - As illustrated in
FIG. 13B , abox 166 for inserting a URL or other identifier for a chosen video appears. In addition, apreview icon 168, and addicon 170 and aclear icon 172 also appear. By selecting thepreview icon 168, the selected video defined inbox 166 can be previewed in thecomponent box 162 of thevideo card 160 appearing in thespace 120. Theadd icon 170 results in the video being inserted into thecard 160, whereas theclear icon 172 will remove the URL. Again, the author may resize and position the video within the card in thespace 120 as illustrated. - It should noted that with each of the examples provided above, an
add component tool 119 appears in thespace 118. Theadd component tool 119 allows the author to add a new component to a card that was not previously defined by whatever template was used to create the card in the first place. Thus, by using theadd component tool 119, theauthor 34 has the option to add additional text, an image, video or other action component beyond what was originally defined in the starting template, as described in more detail below. - Referring to
FIGS. 14A through 14C , a series of diagrams showing how thenew card 140 can be configured as a document card is illustrated. - As illustrated in
FIG. 14A , the author selects a particular document template fromspace 122. In response, acard 170 corresponding to the selected template, including adocument component box 172, appears in the preview and configurespace 120. By selecting thedocument icon 174, and either dragging and dropping or uploading the document, the author can define the document for insertion into thecomponent box 172. In the particular example shown, the author has selected a PDF document, which appears within thecomponent box 172 of thedocument card 170. - The author may also elect to add an additional component to the
document card 170, for example, a descriptor or title for the uploaded PDF file. To do so, the author selects theAdd tool 119, as also illustrated inFIG. 14A . - As illustrated in
FIG. 14B , anadd component window 182 appears in response to the selection of theAdd component tool 119. Within thecomponent box 182, the author may select text, image or some other action component. In this particular example, the author selects the text component. - As illustrated in
FIG. 14C , atext box 184 in theauthoring space 118 and atext box 184 appearing within thecard 170 in thespace 120 appear in response to the selection of the text option inbox 182. By typing into text box 184 (e.g., “User Manual”, the corresponding text appears in thetext box 184 of thecard 170. Again, the author may adjust the style of thecard 170 by resizing and positioning both the PDF document and/or the text box inspace 120. Also, the author may change the font, size, justification and color of the text usingstyle tools 146. - In various embodiments, behaviors or tools may also be inherently provided within document templates that enable or facilitate navigation of any inserted document within a card. For example, for PDF, Word or PowerPoint documents, scrolling bars, pointers, or a page flipping behavior may be embedded in the card templates so that a view of the wrap package can flip from page to page within the document when the card is consumed.
- Referring to
FIGS. 15A through 15C , a series of diagrams illustrating hownew card 140 is configured as a chat card is illustrated. - As illustrated in
FIG. 15A , the author selects a particular chat template fromspace 122. In response, achat card 190, corresponding to the chat template, appears in the preview and configurespace 120. Thecard 190 includes a chat function that enables a chat session to take place between a consumer of the wrap package and a remote person when thecard 190 is rendered. The chat functionality ofcard 190 can be implemented in a number of different ways. For example, the chat function can be embedded as a widget that appears in an i-frame within thecard 190. When the viewer interacts with the widget, a chat server is accessed, and the viewer may engage in a chat session with another party via the chat server. In another embodiment, the chat may be implemented using a cul-de-sac method. In other words when the viewer is consumingcard 190 and would like to engage in a chat, the viewer is taken to another web page or location to engage in the chat. When done, the viewer is returned topage 190. In yet another embodiment, the chat functionality can be built into as a component of thecard 190. For example, thechat card 190 may include feed functionality as described herein. Thus, when the viewer would like to engage in a chat, a session is established between thecard 190 and a chat server, enabling the chat to take place as described above. - As illustrated in
FIG. 15B , the author may also elect to add an addition component to thechat card 190 by selecting theAdd tool 119, which causes theadd component box 194 to appear. Within thecomponent box 194, the author may select text, image or some other action component. - As illustrated in
FIG. 15C , the author in this example selects the add image component, which results in animage box 196 appearing in theauthoring space 118 and acorresponding image box 198 appearing within thecard 190 in thespace 120. By adding an image into box 196 (e.g., a Nieman Marcus store), the corresponding image appears in theimage box 198 of thecard 190. Again, the author may resize andposition image box 198 within thecard 190. In addition, other components may be added in a similar manner. For example, theauthor 34 may also elect to ad a text component, such as “Chat with an online sales representative” (not illustrated), by selecting the Text option within theadd component window 194, similar to that described above. - Referring to
FIGS. 16A through 16F , a number of diagrams showing thenew card 140 authored as an appointment card for making an appointment is illustrated. - As illustrated in
FIG. 16A , the author selects a particular appointment template with a built-in calendaring function fromspace 122. In response, anappointment card 220, corresponding to the selected appointment template, appears in the preview and configurespace 120. Thecard 200 as shown has already been authored to include text (i.e., “Rancho Relaxo Spa”), and image, and a “Book and Appointment” button using theAdd tool 119, as described above. - The
card 200 may implement the appointment booking/reservation function in a number of ways. For example, the function can be implemented via a widget embedded in the card and that allows interaction with a remote reservation/booking server. - In accordance with one embodiment as illustrated in
FIG. 16B , a number of calendar related icons appear in theauthoring area 118 when theappointment function 202 is selected. In this example, the author can specify the year, month and time increments for receiving appointment requests from a consumer of the wrap package. In response, the selected parameters are set into the appointment function of thecard 200. In this latter embodiment, a session is established between the wrap package and the remote reservation or booking database when thecard 200 is being consumed. During the session, state information is exchanged, meaning the remote database provides the wrap package with appropriate feed information, such as booked and/or available time-slots for reservations. In response, the feed information is presented within thecard 200, allowing the viewer of the wrap to book an available time-slot. In this embodiment, thecard 200 captures the required information, such as the date and time specified by the viewer, along with optionally user information (name, contact information, credit card, etc.), and provides it to the remote database for reserving the requested time slot. - Referring to
FIGS. 16C through 16F , an alternative embodiment of authoring the “cul-de-sacing” to a remote reservation-booking location is illustrated. In this example as illustrated inFIG. 16C , theauthor 34 selects theadd component tool 119, which results in the appearance of theadd component window 194, as illustrated inFIG. 16D . Next, theauthor 34 selects the “Action” icon, which results in the appearance of a set of tools inspace 118, including abutton tool 202 and alink tool 204, as illustrated inFIG. 16E . By selecting thebutton tool 202, the user can create a “Book Now” trigger within thecard 200. By selecting thelink tool 204, as illustrated inFIG. 16F , the author can define a URL of the remote reservation booking database. Thus when a viewer selects the Book Now trigger, a web page associated with the remote reservation booking system appears. Once a reservation is made, or the viewer opts to not make a reservation, the viewer is returned back to card 16F of the wrap package. - Referring to
FIGS. 17A through 17C , diagrams showingnew card 140 configured as a location/GPS card is illustrated. - As illustrated in
FIG. 17A , the author selects a particular GPS/location template with GPS/location functionality fromspace 122. In response, GPS/location card 220, corresponding to the selected template, appears in the preview and configurespace 120. - As illustrated in
FIG. 17B , theauthor 34 can add additional components to the GPS/location card 210 by selecting theadd component tool 119. As previously described, the author can add text and/or image component(s) as described above. In addition, the author can add a location component, as is provided in this example. - As illustrated in
FIG. 17C , acomponent box 212 appears in theauthoring space 118 and in thecard 210 in thespace 120. In this example, thecomponent box 212 enables theauthor 34 to define GPS functionality in thecard 210. For example, the wrap package may be authored on behalf of a merchant located at 923 Elm Street in San Francisco. By including an action component into the card allowing a consumer of the wrap package to enter their current address, thecard 210 is configured to interact with the GPS functionality of the consuming device, such as the Google Maps application running on the device, to provide GPS related services. For example, the viewer of the wrap may enter their current location into thecard 210, which would result in the card providing directions to the location of the merchant, located at 923 Elm Street in San Francisco. - In an alternative embodiment,
FIGS. 17D through 17F illustrate a sequence of diagrams for authoring a cul-de-sacing” action to a remote web site providing GPS/location functionality, such as Mapquest or the like. In this example as illustrated inFIG. 17D , theauthor 34 selects theadd component tool 119, which results in the appearance ofwindow 194, as illustrated inFIG. 17E . In response, the author selects the Action item, which enables the insertion of a URL to a remote web page providing GPS/location functionality. Again, as a cul-de-sac, the viewer is returned to the wrap package after they are done accessing the remote GPS/location web page. In yet other embodiments, the GPS/location functionality can also be implemented using a widget or by building the functionality into the card itself. - Referring to
FIG. 18A through 18F , a sequence of diagrams illustratingnew card 140 authored as a transactcard 220 is shown. - As illustrated in
FIG. 18A , the author selects a particular transact template fromspace 122. In response, a transactcard 220, corresponding to the selected template, appears in the preview and configurespace 120. In addition, a number of options for adding component(s) specific to transactions are provided in theauthoring space 118. In this particular example, animage component 222, aheadline component 224, abutton component 226 and alink component 228 are provided. - As illustrated in
FIG. 18B , theimage component 222 is selected. As a result, the author may add an image to thecard 220, similar to that described above. - As illustrated in
FIG. 18C , theheadline component 224 is selected. As a result, the author may add headline to thecard 220, similar to that described above. - As illustrated in
FIG. 18E , thebutton component 226 is selected. As a result, the author may add a “Buy Now” button similar to that described above. - As illustrated in
FIG. 18F , thelink component 228 is selected. In this non-exclusive example, the author can then enter a URL intobox 230, which will result in the cul-de-sacing to a remote web site location when the Buy Now icon is selected. For instance, a web page that allows the consumer of the wrap to purchase goods and/or services appears. When the transaction is complete, the viewer is returned to the wrap package. - It should be noted that transact cards are not necessarily limited to cul-de-sacing for the processing of transactions. On the contrary, transactions can also be conducted within the context of a transact card while it is being consumed. For example, the transact card can be configured with a bi-directional feed of data and the ability to synchronize data during a session with a remote data processing center used for handling online transactions. For example within the context of the wrap, the viewer may peruse a number of items for purchase. While viewing the wrap, current data pertinent to the items, such as number in stock, size information, color choices, etc., are synchronized and presented to the viewer while consuming the wrap. The viewer may then elect to place one or more items into a shopping cart for purchase. When ready to complete the transaction, the viewer prompted to enter the appropriate user information, such as mailing address, billing address and credit card information, to complete the transaction. Alternatively, all this information may be previously stored, in which case, the purchase can be completed with a “one-click” operation or the like.
- In yet another embodiment, the processing of a transaction within a card can be implemented using a widget as a component in the card. With such an embodiment, the widget appears inline an i-frame of the card. When accessed by the viewer, the content from a remote location, referenced using for example a URL, is presented in the i-frame, enabling the viewer to complete the transaction.
- Referring to
FIGS. 19A through 19D , diagrams illustrating the authoring ofnew card 140 as a gallery card is shown. - Unlike the above-described cards, the
layout selector space 122 is modified to include a verticalframe sequencing area 123, anew frame icon 125 and abehavior declaration 250 that enables the author to define if the individual frames of the gallery card will have a “snap” action or “rolling” scroll action when swipe navigated. - When a new frame “N” is to be added to the vertical sequence of the gallery card, the
icon 123 is selected. Thereafter, the author selects a template for the new frame, which could be any of the above-listed card types. In addition, the vertical sequence of the individual frames of the gallery card can be changes using a drag and drop or analogous operation, similar to that described above with regard to the horizontal sequence. Consequently, theauthor 34 may compose a gallery card by creating, authoring and sequencing new frames one after the other. - As illustrated in
FIG. 19A , afirst frame 230 (1) of the gallery card is illustrated. In this example, thefirst frame 230 (1) is selected from a text-based frame template that has been authored to include the text component “See the New 2015 Mustang”. - As illustrated in
FIG. 19B , the samefirst frame 230 (1) of the gallery card is illustrated. In this example, thesecond frame 230 (1) is selected from an image-based frame template that has been authored to include an image of the 2015 Mustang. - As illustrated in
FIG. 19C , asecond frame 230 (2) of the gallery card is illustrated. In this example, thesecond frame 230 (2) is selected from a document-based template that has been authored to include an PDF article about the 2015 Mustang published by the magazine Car & Driver. - As illustrated in
FIG. 19D , athird frame 230 (3) of the gallery card is illustrated. In this example, thethird frame 230 (3) was selected from a video based frame template that has been authored to include a video of the 2015 Mustang. - As illustrated in
FIG. 19D , an “N” andfinal frame 230 (N) of the gallery card is illustrated. In this example, thefourth frame 230 (N) was selected from an end-of-gallery template and has been authored to include a link to the Ford Motor Company web site as well as icons for sharing the wrap package. - The frame templates used for authoring the individual frames of gallery cards are similar to card templates. As such, frame templates having the same features and functionality as described herein with respect to cards.
- Referring to
FIGS. 20A and 20B , diagrams showing the authoring ofnew card 140 as an end of wrap card is shown. When the end of wrap card is selected within thecard type selector 136, a number of appropriate templates appear in thespace 122. The author can then select one of the templates and begin the process of defining thelast card 240 in the wrap package. For example, the author may select a template with “Share”, “Like” and “Tweet” functionality built-in to the card, as illustrated inFIG. 20A . By selecting any of these options, the wrap package may be shared like a message, and included for example in a Facebook feed or a Twitter feed. - In addition, the author may, by selecting the
add component tool 119, add image, text, video or other media, actions and/or behaviors to the card, as described above. For example as illustrated inFIG. 20B , the author has added an image of a woman in a dress and text in a sub-header that reads “Fall Fashion at the Gap”. This is just one example of an almost infinite number of different card arrangements that can be authored as the last card in a wrap. - In each of the examples provided above, the
new card 140 can be either saved using 126, discarded usingicon 130, or published usingicon 128. When saved, thecard 140 is stored in its current state and can be later accessed for additional authoring. When discarded, thecard 140 is removed from thesequence space 132. When published, thecard 160 is included in the wrap package. At any point in time, the wrap package, or any particular card in the package, can be edited, removed, re-ordered, etc., using the above-described tools. - It should be understood that the card authoring examples provided above are merely exemplary and should in no way be construed as limiting. In various alternative embodiments, the
authoring tool 100 may use an almost limitless number of different card templates, components, styles and attributes, functionality and card types, resulting in an almost infinite number of different cards that may be used in wrap packages. - Referring to
FIG. 21 , aflow chart 300 illustrating the steps of authoring a wrap package from the perspective of the author is illustrated. - In the
initial step 302, the author elects to create a new wrap package by selecting thenew wrap tool 106 as provided inFIG. 7 . - Thereafter, in
step 304, the author titles the wrap in thetext field 110 appearing inwindow 108 as illustrated inFIG. 8 . - In the
next step 306, the author creates a new card using thenew card tool 134 and then defines the card type using the cardtype selector tool 136 as illustrated inFIG. 10C . - In
subsequent step 308, a card template is selected. - Thereafter, the resulting card (or frame in the case of a gallery card) is authored in
step 310 to selectively include, as described above, one or more text, image/photo, or action components (GPS/location, appointments, transactions, and/or triggers to cul-de-sac to a remote location, etc.). - In
optional step 312, a behavior may be associated with the card. For example, a gallery card may be assigned a “snap” or “scroll” behavior to the next frame in response to an up or down swipe when the card is being consumed. - In
step 314, the author may keep the current card (or frame) in its implicit order when it was created, or re-arrange the card (or frame) or other cards within the horizontal sequence of cards. - In
decision 316, the author determines if a new card should be added to the wrap package or not. If yes, the process ofsteps 306 through 314 described above are repeated. - If not, then the author has the option to save the wrap using tool 126 (or alternatively discard the wrap using tool 130), preview the wrap in
step 320, assign any covers to the wrap instep 322 and optionally set any permission(s) that define who may or may not access and view the wrap instep 324. - Finally, in
step 326, the author may publish or share the wrap thepublishing using tool 128, which enables the wrap to be distributed in or through any of the above-mentioned distribution channels. - Referring to
FIG. 22 , aflow chart 400 illustrating the steps of a background process run by theauthoring tool 100 during the authoring of a wrap package is shown. - In the
initial step 402, awrap identifier 42 andtitle 44 are defined when the author elects to create a new wrap. - In
decision 404, thetool 100 waits until a new card is created usingtool 134. When a new card is created and its type defined usingtool 136, acard identifier 71 andcard type 73 are assigned instep 406. - Next in
step 408, the components and attributes from a selected card template are copied and assigned to the newly created card. - Thereafter, during the editing process, components of the card may be optionally added in
step 410. - In
optional step 412, the style(s) and/or attribute(s) of the components and/or card may be modified. - In
optional step 414, any triggers associated with a component or the card can be added or modified. - In addition with certain cards, behaviors may optionally be assigned during the authoring process in
step 416, such as with gallery cards as described above. For example, either the “snap” or “scroll” behavior will be assigned to the card, depending on the selection by the author. - In
step 418, the sequence order of the card within the wrap is defined, either implicitly in the order in which the card was created, or explicitly by the author re-arranging the card order in thespace 132. - In
decision 420, theauthoring tool 100 then determines if the wrap has been saved usingtool 126, for example when an editing session is complete. - If not, then the
tool 100 waits until the author defines another card instep 404, in which case, thesteps 406 through 418 are repeated. - Alternatively, if saved, then the
authoring tool 100 generates the card descriptor(s) for each of the defined cards in the wrap package instep 422. - Finally, in
step 424, thetool 100 generates the wrap descriptor from all of the card descriptor(s). - It should be understood that with gallery cards, the
authoring tool 100 essentially performs the background steps outlined above with respect toFIG. 22 , except on a frame-by-frame basis (as opposed to a card-by-card basis). Accordingly, any component(s), attribute(s), style(s), trigger(s) and/or behaviors assigned to the frames of a gallery card, as well as the sequence order of the frames, are all defined during the authoring process of the gallery card. - It should be noted that the steps defined in the flow diagrams 300 and 400 as described above are merely exemplary. Do to the inherent nature of authoring a wrap, one author or multiple authors may create a wrap during one or multiple sessions. During each session, new cards can be created and existing cards can be either revised or deleted. As such, the sequence of steps illustrated in each flow chart are not intended to be rigidly construed, but rather, for illustrating the step or steps that an author or set of authors may optionally elect to use in any particular order during the authoring of a wrap.
- Referring to
FIG. 23 , aflow chart 450 illustrating the steps of generating a card descriptor (i.e., step 422 ofFIG. 22 ) for a card of a wrap in accordance with a non-exclusive embodiment is shown. As previously noted, a card descriptor is a data object (e.g., JSON or BSON). Thus, generating the card descriptor generally involves generating and assembling individual data objects for every feature and content contained in the card. - For example in
initial step 452, a first component of the card is selected. Thereafter, data object(s) are generated for the component itself (step 454) along with content (step 456), attribute(s) (step 458), style(s) (step 460), trigger(s) (step 462) and/or defined and/or declared behavior(s) (step 464) associated with the component. Indecision step 466, it is determined if there are any additional components associated with the card. IF yes, then steps 454 through 466 are repeated for each component. If not, then any meta data is associated with the card instep 470. Finally, the card descriptor is generated from all the data object(s) and meta data (step 472). The card descriptor thus contains everything needed to render the card at runtime. - Referring to
FIG. 24 , a flow diagram 480 illustrating the steps of generating a wrap descriptor (step 424 ofFIG. 22 ) is illustrated. In the initial step (482), the first card of the wrap is selected and its card descriptor is generated (step 484) using, for example, the process described above with respect toFIG. 23 . Thereafter, indecision 486, it is determined if there are any additional cards in the wrap package. If yes, then next card in the wrap is incremented (step 488) and the card descriptor for that card is generated instep 486. This process is repeated until a card descriptor is generated for all the cards in the wrap, as determined indecision 486. Finally, instep 492, the wrap descriptor is generated from the wrap descriptor and any media data associated with the wrap as provided instep 490. The wrap descriptor thus contains everything needed to render the wrap at runtime. - Thus, generating the wrap descriptor generally involves combining the collection of data objects for each card, along with any meta data, to generate the wrap descriptor. Again, since the since the individual card components are defined in terms of data objects, the wrap descriptor will also be defined in terms of data objects (e.g., JSON, BSON, or any other suitable data object format). Consequently, the wrap descriptor includes everything needed to render the
wrap package 10 at runtime by the runtime viewer. - Again, it should be noted that the
flow chart 450 described above similarly applies to gallery cards. For each frame of a gallery card, the above process is repeated for each component in the frame, resulting in essentially a “frame” descriptor, which is similar to a card descriptor. When all the components have been exhausted for a given frame, the process is repeated for the next frame, until frame descriptors have been generated for all the windows. A card descriptor is then generated for the gallery card from each of the frame descriptors and any meta data. - The wrap descriptor is thus a collection of card descriptors, each specified in terms of a collection of data objects (e.g., JSON or BSON) defining each of the cards of the wrap package respectively. As such, the wrap descriptor includes everything necessary to render the wrap upon runtime.
- The described
wrap packages 10 are essentially cloud based portable data objects that can readily be distributed using a wide variety of electronic techniques including messaging, posting and inclusion as links in documents, articles or other electronic communications. Thewrap package 10 thus allows authors to take applet and website functionality and make them consumable as a message, delivered in a narrative storytelling format. This allows the transformation of an app or website functionality into a portable, sharable, andsavable wrap package 10, that can be distributed like electronic messages (e.g. email, SMS, text) are disseminated today. For example as illustrated inFIG. 7M , the media triggers 381 and 383 can be used to share thewrap package 310 with others via Facebook Twitter. Although in this embodiment actual triggers for sharing are provided within or embedded in the wrap itself, this is not always necessary for sharing the wrap. Alternatively for example, thecover 15 that includes a URL associated with the wrap (e.g., the wrap ID 42) can be posted on a social media site or feed, email to others, or otherwise distributed using an electronic communication protocol or platform. - Not only are the wrap packages 10 easy for publishers and others to distribute, but viewers and other recipients of a wrap may also readily share a wrap with their friends, family, coworkers, colleagues, etc. This is a powerful construct that can greatly extend or enhance the market (or other target segment) reach and penetration of a well designed wrap since a “message” from a friend or acquaintance is often more favorably received than a message from an unknown party. Neither applets nor websites are well suited for such viral distribution.
- Since the set of
cards 14 that make up awrap package 10 are encapsulated as a data object and can be sent as a unit, thewrap package 10 can also readily be stored on a viewer's device if the viewer so desires. Contrast this with a conventional multi-page website which is not designed to be persistently stored on a viewer's device as a unit, even if individual pages may sometimes be cached. It also eliminates third party aggregator (e.g., the Apple App Store; Google Play, etc.) control over the delivery of a company's services/messages to its customers as occurs in the distribution of conventional apps. - Wrap packages 10 offer a number of benefits and attributes currently not available with conventional methods of distributing content, such as with ME's, web sites, or stand-alone apps. Since
cards 14 can be sequenced and authored to include media content, application functionality, and e-commerce related services, wrappackages 10 have the unique ability to narrate a story, in a book-like format, that captures and holds the attention of the viewer, while also offering an “app” like user experience. As such, wrappackages 10 offer a new web-based platform for storytelling, communicating ideas, and delivering highly visual and functional user experiences. Wrap packages 10 thus enable a new business paradigm for selling, advertising, publishing, increasing brand loyalty, offering services, and contacting and engaging new and old customers alike, all ideally delivered to consumers on their mobile devices, where they spend their time and consciousness. Where businesses used to have to build destinations (e.g., websites) or monolithic systems (e.g., “apps”), they can now, instead, provide consumers withwrap packages 10, that are delivered like messages, and that provide the user experiences and functionality they really want and need. As a result, wraps 10 create opportunities for business to innovate and improve products and services, leveraging the mobile web in ways not before possible, because a convenient, enabling interface and platform did not previously exist. - Wrap packages 10 are also like interactive messages that can be easily shared, delivered over the mobile web, and locally stored. With the ability to share, distribute over the mobile web and locally store, popular wrap packages can readily go viral.
- Wrap packages 10 are also preferably delivered using a SaaS (Software as a Service) model, meaning wrap packages are delivered only on an as-needed basis.
- Wrap packages can be authored by anyone, from an individual with little technical or design skills, to large and sophisticated enterprises.
- Wrap packages 10 can be distributed narrowly to a specific or targeted person or persons or widely distributed to many, many persons.
- Wrap packages 10 can be written once and can run on just about any browser enabled device. As a result, wraps are not platform, operating system, or device dependent.
- Since wrap packages 10 can be easily generated and optionally dynamically updated with new content, wrap packages can be used as a digital “corollary” or “companion”, accompanying the sale or rental of goods and/or services. For example, wrap packages can be created and distributed as an “Active Receipt” accompanying the sale or rental of a good or service. The merchant can thus provide through the
wrap package 10 ongoing contact and support to on-board, up-sell and/or cross-sell the customer with ancillary goods and/or services, potentially for the entire life cycle of the product or service, all delivered in a digital format that never gets lost or misplaced. Accordingly, wrap packages can be used as an essential component of any product or service, delivering better customer service and creating new selling opportunities. - In summary, wrap
packages 10 introduce the “narrative web”, which is a storytelling mobile user interface, delivered over a cloud-based platform, ushering in a digital evolution of mobile marketing and customer relationship management. As a marketing tool, wrappackages 10 have the unique ability to increase mobile engagement, lead generation, and conversion, enabling businesses to increase sales, improve loyalty, and enhance customer relationships and loyalty. Wrap packages 10 thus offer a compelling business proposition by solving one of the biggest problems in the mobile space of today; namely the lack of connectivity between apps. With wrap packages 10, however, consumers and other users can enjoy a multi-function app-like experience, without having to be in an app, download an app, or open any apps. - Finally, while many of the benefits and attributes of wrap packages 10 are realized on mobile devices operating on the mobile web, it should be made clear that there is nothing inherent with
wrap packages 10 that limit their usefulness or functionality in non-mobile environments. On the contrary, wrappackages 10 can also be used, and all the same benefits and attributes realized, on non-mobile devices, such as desktop computers and/or smart TVs for example. - The present invention is thus intended to be broadly construed to cover any system and method, such as carousel ads for example, that enables publishers and marketers to tell sequenced stories with (i) a combination of images, photos, text, video and other types of media, (ii) a swipe-able format that enables viewers to navigate the media displayed in one screen shot or frame to the next, and (iii) includes embedded app-like functionality and/or links to other locations that provide additional information or such functionality and/or services. Consequently, the present application should not be construed to just those specific embodiments as described herein.
- In the primary described embodiments, all of the behaviors are declared rather than being stored in-line within the descriptor. Thus, the descriptor itself does not have any programmable logic. In many embodiments, the declared behavior are all defined within the runtime viewer such that the runtime view can readily associate the desired behavior with the wrap, card or component as appropriate in a runtime instance of the wrap. It should be appreciated that this is a particularly powerful framework for enhancing portability of the wraps. With the descriptor/runtime viewer approach, a single item (the descriptor) can be used to define all of the content and functionality of a set of cards that can be rendered on virtually any platform. The declared functionality is provided (or obtained) by the runtime viewers when the wrap is to be rendered so that the author of the wrap is not required to know or understand any of the idiosyncrasies of any particular platform. The runtime viewer may be a generic runtime viewer (e.g., a viewer executable by a conventional browser) or may be native viewer customized for a particular platform. Regardless of the underlying platform, the runtime viewer handles the tasks of associating the declared behaviors with the wrap/cards/components which frees the wrap author and/or authoring tool from having to ensure that desired behaviors are programmed correctly for all of the different platforms that the wrap may be rendered on.
- In most implementations, all of the sizeable assets that serve as content of the wrap are referenced in the wrap by appropriate identifiers rather than being stored directly in the wrap. This again significantly enhances portability by keeping the size of the descriptor small while facilitating the use of rich media content.
- From the foregoing it should be apparent that the described wrap packages provide businesses with a powerful tool for engaging their customers, suppliers, employees or other constituents in a format that is particularly well tailored for display on mobile devices.
- Although only a few embodiments of the invention have been described in detail, it should be appreciated that the invention may be implemented in many other forms without departing from the spirit or scope of the invention. For example several specific wrap descriptor structures have been described. Although such descriptor structures work well, it should be appreciated that the actual descriptor structure may vary widely. For example, in some embodiments some special behaviors can be defined within a wrap descriptor if desired. Such in-line behavior definition might be particularly useful in association with certain behavior extensions that are not otherwise readily available. For example, JavaScript can be included within a JSON object and various other descriptor structures. Thus, when JSON descriptors are used, selected behaviors or behavior overrides can be defined in-line using JavaScript if desired. Although programmed functionality can be included in some circumstances, it should be appreciated that liberal definition of behaviors within a wrap tends to defeat some of the primary advantages of the described descriptor/runtime viewer framework.
- In many implementations much of the actual content of the wrap will be referenced by the descriptor rather than being stored in-line within the descriptor. However, the balance between in-line storage and references to external assets in any particular wrap descriptor may be widely varied anywhere from 100% referenced content to (at least theoretically) 100% in-line content—although the later is less desirable for media rich content and again, begins to defeat some of the advantages of using the descriptor approach. The choice between in-line and referenced content will typically be dictated in large part by the relative size of the content. For example, text, which tends to be very compact, is generally more suitable for inclusion in-line, whereas more graphic media, images, videos and/or audio files are typically more efficiently referenced.
- A few different methods of and architectures for serving wrap packages and constructing runtime instances have been described herein. Although only a few approaches have been described in detail, it should be apparent from the foregoing that a wide variety other methods and architectures can be used as well. Therefore, the present embodiments should be considered illustrative and not restrictive and the invention is not to be limited to the details given herein, but may be modified within the scope and equivalents of the appended claims.
Claims (30)
1. An authoring tool, embedded in a tangible computer readable medium, the authoring tool configured to enable the authoring of a wrap package by defining:
(i) a wrap descriptor that specifies a set of cards associated with the wrap package;
(ii) a structure, layout and content of the set of cards suitable for display on a computer display separately from their presentation; and
(ii) a plurality of card descriptors, each card descriptor arranged to define the content, structure and layout of an associated one of the cards.
2. An authoring tool as recited in claim 1 , further comprising:
one or more card templates used for authoring the set of cards of the wrap package; and
an authoring tool set that enables customized authoring of the one or more card templates to create the set of cards of the wrap package.
3. The authoring tool as recited in claim 1 , further enabling the authoring of the cards of the wrap package from card templates to selectively include one or more of the following:
(i) a component for containing or referencing an object;
(ii) a headline for the insertion of text; or
(iii) a trigger that triggers an action when activated.
4. The authoring tool as recited in claim 1 , further enabling the authoring of the set of cards from one or more card templates, each of the cards of the wrap package selectively authored to include the structure, layout, content and style as defined by the author using the authoring tool.
5. An authoring tool of claim 1 , further configured to selectively enable authoring of a card in the set to include one or more component(s), the one or more components containing inline or externally referencing one or more object(s) to be rendered when the card is rendered.
6. An authoring tool of claim 1 , further configured to selectively enable authoring of a card in the set to include one or more defined or declared or behavior(s) that is/are bound to the card when rendered.
7. An authoring tool of claim 1 , further configured to selectively enable authoring of a card in the set to include one or more trigger(s), each of the one or more trigger(s) causing a predefined action to be performed when activated when the card is rendered.
8. An authoring tool as recited in claim 1 , further comprising one or more card templates used for authoring the set of cards of the wrap package, the one or more card templates defining one or more card layouts for the set of cards which are derived from the one or more card templates respectively.
9. An authoring tool as recited in claim 1 , further configured to assign, for each of the cards of the wrap package, a layout that defines the presentation of the associated card and that includes a unique layout identifier and an internal layout definition in-line with the card descriptor.
10. An authoring tool as recited in claim 1 , further configured to enable authoring of a wrap title for the wrap package distinct from the wrap identifier.
11. An authoring tool as recited in claim 1 , further configured to assign, for each of the card descriptors, an associated card identifier that uniquely identifies the associated card.
12. An authoring tool as recited in claim 1 , further comprising a sequencing tool for authoring one or more linear sequences for rendering the set of cards, the one or more sequences including:
(i) a horizontal sequence;
(ii) a vertical sequence; or
(iii) both the horizontal and the vertical sequences.
13. An authoring tool as recited in claim 1 , further comprising a new card tool for creating and adding a new card to the set of cards of the wrap package.
14. An authoring tool as recited in claim 1 , further comprising a card type selector tool for defining a card type among a plurality of card types for a new card added to the wrap package, the plurality of card types including:
(a) a textual card;
(b) an image or photo card;
(c) a video card;
(d) a document card;
(e) a gallery card;
(f) a chat card;
(g) a location or GPS functionality card;
(h) a transact card;
(i) an appointment making card; and
(j) an end of the wrap package card.
15. An authoring tool as recited in claim 1 , further including an authoring workspace for authoring the set of cards of the wrap package, the authoring workspace including one or more of the following:
(a) a new card selector tool;
(a) a card type selector tool;
(b) an authoring space for authoring a select card among the set of cards of the wrap package;
(c) a preview space to display the select card as it is authored; and
(d) a sequencing space for defining one or more linear sequences for rendering the set of cards when the wrap package is consumed.
16. An authoring tool of claim 1 , further comprising a component tool for selectively authoring a component into a select card of the wrap package.
17. The authoring tool of claim 16 , wherein the component authored into the select card is a dynamic component that is capable of dynamically changing when the select card is rendered.
18. An authoring tool of claim 16 , wherein the components is selected from the group consisting of:
(a) text;
(b) an image or photo
(c) video;
(d) a document;
(e) a chat function;
(f) a location or GPS function;
(g) a transact function; or
(h) an appointment making function.
19. An authoring tool as recited in claim 1 , further comprising a text tool for selectively authoring text into one or more text headlines of a selected card of the wrap package.
20. An authoring tool as recited in claim 1 , further comprising an image/photo tool for selectively authoring one or more image(s)/photo(s) into a selected card of the wrap package.
21. An authoring tool as recited in claim 1 , further comprising a video tool for selectively authoring a video into a select card of the wrap package by identifying an identifier that identifies the video and associating the identifier with the select card, the identifier used to retrieve and play the video when the select card is rendered.
22. An authoring tool as recited in claim 1 , further comprising a positioning and sizing tool configured to position and size one or more component(s) authored into a select card of the wrap package.
23. An authoring tool as recited in claim 1 , further comprising a document tool for selectively authoring a document into a select card of the wrap package by either:
(i) inserting the document into the select card; or
(ii) inserting an identifier associated with a document into the select card, the identifier used to retrieve and display the document when the select card is rendered.
24. An authoring tool as recited in claim 1 , further comprising an appointment tool for authoring a calendar function into a select card of the wrap package, the calendar function enabling a consumer of the wrap package to schedule an appointment while consuming the wrap package.
25. An authoring tool as recited in claim 1 , further comprising a location/GPS tool for authoring location/GPS functionality into a select card of the wrap package.
26. An authoring tool as recited in claim 1 , further comprising a gallery card tool for authoring a gallery card into the wrap package, the gallery card including a gallery of related content items for display in a gallery format when the gallery card is rendered.
27. An authoring tool as recited in claim 1 , further comprising a transact tool for authoring a transaction function into a card of the wrap package.
28. An authoring tool as recited in claim 27 , wherein the transaction function is configured to facilitate e-commerce by:
(i) enabling one-click buying of a displayed good or service using previously stored customer account information;
(ii) enabling cul-de-sacing to a remote location for process of a transaction and then returning to the cards; and/or
(iii) prompting the entering of requisite information needed for the processing of the transaction within the wrap package.
29. An authoring tool as recited in claim 1 , further configured to assign a unique wrap identifier for accessing the wrap package, wherein the unique wrap identifier is contained within a URL.
30. An authoring tool as recited in claim 1 , further comprising a cover tool for associating a cover with the wrap package, the cover defining a wrap identifier for identifying and accessing the wrap descriptor.
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US14/740,539 US20160103820A1 (en) | 2014-10-09 | 2015-06-16 | Authoring tool for the authoring of wrap packages of cards |
Applications Claiming Priority (10)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US201462062056P | 2014-10-09 | 2014-10-09 | |
US201462062061P | 2014-10-09 | 2014-10-09 | |
US201462084171P | 2014-11-25 | 2014-11-25 | |
US201462091866P | 2014-12-15 | 2014-12-15 | |
US201562114675P | 2015-02-11 | 2015-02-11 | |
US201562133574P | 2015-03-16 | 2015-03-16 | |
US201562144139P | 2015-04-07 | 2015-04-07 | |
US201562170569P | 2015-06-03 | 2015-06-03 | |
US201562170438P | 2015-06-03 | 2015-06-03 | |
US14/740,539 US20160103820A1 (en) | 2014-10-09 | 2015-06-16 | Authoring tool for the authoring of wrap packages of cards |
Publications (1)
Publication Number | Publication Date |
---|---|
US20160103820A1 true US20160103820A1 (en) | 2016-04-14 |
Family
ID=55655549
Family Applications (11)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US14/740,539 Abandoned US20160103820A1 (en) | 2014-10-09 | 2015-06-16 | Authoring tool for the authoring of wrap packages of cards |
US14/740,839 Abandoned US20160103821A1 (en) | 2014-10-09 | 2015-06-16 | Authoring tool for the authoring of wrap packages of cards |
US14/740,617 Abandoned US20160104210A1 (en) | 2014-10-09 | 2015-06-16 | Authoring tool for the authoring of wrap packages of cards |
US14/740,533 Abandoned US20160103791A1 (en) | 2014-10-09 | 2015-06-16 | Authoring tool for the authoring of wrap packages of cards |
US14/816,935 Abandoned US20160103904A1 (en) | 2014-10-09 | 2015-08-03 | Defining and delivering wrap packages of cards with insight content derived from the use of analytics |
US14/816,662 Abandoned US20160104211A1 (en) | 2014-10-09 | 2015-08-03 | Authoring and delivering wrap packages of cards with custom content to target individuals |
US14/816,678 Abandoned US20160105771A1 (en) | 2014-10-09 | 2015-08-03 | Using beacons to author and deliver wrap packages of cards with custom content to target individuals |
US14/851,362 Active US9600449B2 (en) | 2014-10-09 | 2015-09-11 | Authoring tool for the authoring of wrap packages of cards |
US15/239,060 Abandoned US20160357727A1 (en) | 2014-10-09 | 2016-08-17 | Using beacons to author and deliver wrap packages of cards with custom content to target individuals |
US15/239,052 Active US9582485B2 (en) | 2014-10-09 | 2016-08-17 | Authoring and delivering wrap packages of cards with custom content to target individuals |
US15/240,556 Abandoned US20160357849A1 (en) | 2014-10-09 | 2016-08-18 | Defining and delivering wrap packages of cards with insight content derived from the use of analytics |
Family Applications After (10)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US14/740,839 Abandoned US20160103821A1 (en) | 2014-10-09 | 2015-06-16 | Authoring tool for the authoring of wrap packages of cards |
US14/740,617 Abandoned US20160104210A1 (en) | 2014-10-09 | 2015-06-16 | Authoring tool for the authoring of wrap packages of cards |
US14/740,533 Abandoned US20160103791A1 (en) | 2014-10-09 | 2015-06-16 | Authoring tool for the authoring of wrap packages of cards |
US14/816,935 Abandoned US20160103904A1 (en) | 2014-10-09 | 2015-08-03 | Defining and delivering wrap packages of cards with insight content derived from the use of analytics |
US14/816,662 Abandoned US20160104211A1 (en) | 2014-10-09 | 2015-08-03 | Authoring and delivering wrap packages of cards with custom content to target individuals |
US14/816,678 Abandoned US20160105771A1 (en) | 2014-10-09 | 2015-08-03 | Using beacons to author and deliver wrap packages of cards with custom content to target individuals |
US14/851,362 Active US9600449B2 (en) | 2014-10-09 | 2015-09-11 | Authoring tool for the authoring of wrap packages of cards |
US15/239,060 Abandoned US20160357727A1 (en) | 2014-10-09 | 2016-08-17 | Using beacons to author and deliver wrap packages of cards with custom content to target individuals |
US15/239,052 Active US9582485B2 (en) | 2014-10-09 | 2016-08-17 | Authoring and delivering wrap packages of cards with custom content to target individuals |
US15/240,556 Abandoned US20160357849A1 (en) | 2014-10-09 | 2016-08-18 | Defining and delivering wrap packages of cards with insight content derived from the use of analytics |
Country Status (1)
Country | Link |
---|---|
US (11) | US20160103820A1 (en) |
Cited By (5)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US9600449B2 (en) | 2014-10-09 | 2017-03-21 | Wrap Media, LLC | Authoring tool for the authoring of wrap packages of cards |
US9600464B2 (en) | 2014-10-09 | 2017-03-21 | Wrap Media, LLC | Authoring tool for the authoring of wrap packages of cards |
US9600803B2 (en) | 2015-03-26 | 2017-03-21 | Wrap Media, LLC | Mobile-first authoring tool for the authoring of wrap packages |
US20180032235A1 (en) * | 2016-08-01 | 2018-02-01 | Facebook, Inc. | Systems and methods for content interaction |
US20180373800A1 (en) * | 2017-06-27 | 2018-12-27 | Alan Pizer | Method of storing and ordering interactive content data in localized and connected content data structures |
Families Citing this family (23)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
USD771079S1 (en) * | 2013-01-04 | 2016-11-08 | Level 3 Communications, Llc | Display screen or portion thereof with graphical user interface |
USD845979S1 (en) | 2013-01-23 | 2019-04-16 | Yandex Europe Ag | Display screen with graphical user interface |
JP5976033B2 (en) * | 2014-04-24 | 2016-08-23 | 株式会社オプティム | Mobile terminal, access point related content acquisition method, mobile terminal program |
US11294549B1 (en) * | 2014-06-06 | 2022-04-05 | Massachusetts Mutual Life Insurance Company | Systems and methods for customizing sub-applications and dashboards in a digital huddle environment |
US9852398B1 (en) | 2014-06-06 | 2017-12-26 | Massachusetts Mutual Life Insurance Company | Systems and methods for managing data in remote huddle sessions |
US11270264B1 (en) | 2014-06-06 | 2022-03-08 | Massachusetts Mutual Life Insurance Company | Systems and methods for remote huddle collaboration |
US11023940B1 (en) * | 2015-10-28 | 2021-06-01 | State Farm Mutual Automobile Insurance Company | Systems and methods for using hardware transmitters to improve customer service |
US10547576B1 (en) * | 2016-04-04 | 2020-01-28 | Google Llc | Modifying presentation of message based on content identified by uniform resource locator (URL) in message |
US20180034764A1 (en) * | 2016-07-29 | 2018-02-01 | Linkedin Corporation | Selecting applications for message handling |
WO2018160770A2 (en) * | 2017-02-28 | 2018-09-07 | Woods Michael E | Communicator |
US11283738B2 (en) * | 2017-06-23 | 2022-03-22 | Realpage, Inc. | Interaction driven artificial intelligence system and uses for same, including travel or real estate related contexts |
US11436521B2 (en) * | 2017-08-01 | 2022-09-06 | Meta Platforms, Inc. | Systems and methods for providing contextual recommendations for pages based on user intent |
US10635857B2 (en) * | 2017-09-29 | 2020-04-28 | Hewlett Packard Enterprise Development Lp | Card system framework |
US10949842B1 (en) * | 2018-01-30 | 2021-03-16 | Mastercard International Incorporated | Preventing data analysis interruptions by identifying card continuity without using personally identifiable information |
US11157694B2 (en) * | 2018-08-14 | 2021-10-26 | Snap Inc. | Content suggestion system |
US11645047B2 (en) | 2019-09-13 | 2023-05-09 | Axure Software Solutions, Inc. | Focused specification generation for interactive designs |
USD956814S1 (en) * | 2020-05-15 | 2022-07-05 | Barel Ip, Inc. | Computing device display screen or portion thereof with icon |
US11829452B2 (en) | 2020-08-24 | 2023-11-28 | Leonard L. Drey | System and method of governing content presentation of multi-page electronic documents |
US11762531B2 (en) * | 2020-10-28 | 2023-09-19 | Axure Software Solutions, Inc. | Stateful widget container management for interactive designs |
JP2022097134A (en) * | 2020-12-18 | 2022-06-30 | 富士フイルムビジネスイノベーション株式会社 | Information processing apparatus and information processing program |
US20230106337A1 (en) * | 2021-10-06 | 2023-04-06 | Ella Interactive | Marketing management system, business management system, processes, and method for managing digital marketing profiles |
CN114818633A (en) * | 2022-06-23 | 2022-07-29 | 远江盛邦(北京)网络安全科技股份有限公司 | PDF report generation system, method, electronic equipment and storage medium |
US11907508B1 (en) * | 2023-04-12 | 2024-02-20 | Adobe Inc. | Content analytics as part of content creation |
Citations (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20130305145A1 (en) * | 2012-05-09 | 2013-11-14 | Ni Group Limited | A Method of Publishing Digital Content |
Family Cites Families (197)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US5228123A (en) | 1990-01-04 | 1993-07-13 | Heckel Paul C | Interface and application development management system based on a gene metaphor |
US5659793A (en) | 1994-12-22 | 1997-08-19 | Bell Atlantic Video Services, Inc. | Authoring tools for multimedia application development and network delivery |
US5880740A (en) | 1996-07-12 | 1999-03-09 | Network Sound & Light, Inc. | System for manipulating graphical composite image composed of elements selected by user from sequentially displayed members of stored image sets |
US6157935A (en) | 1996-12-17 | 2000-12-05 | Tran; Bao Q. | Remote data access and management system |
US6021417A (en) | 1997-10-31 | 2000-02-01 | Foto Fantasy, Inc. | Method of stimulating the creation of an artist's drawing or painting, and device for accomplishing same |
US6321244B1 (en) | 1997-12-04 | 2001-11-20 | Siemens Corporate Research, Inc. | Style specifications for systematically creating card-based hypermedia manuals |
US6216112B1 (en) | 1998-05-27 | 2001-04-10 | William H. Fuller | Method for software distribution and compensation with replenishable advertisements |
US20030101092A1 (en) | 1998-05-27 | 2003-05-29 | William Fuller | Method for software distribution and compensation with replenishable advertisements |
US6553403B1 (en) | 1998-06-03 | 2003-04-22 | International Business Machines Corporation | System, method and computer program product for monitoring in a distributed computing environment |
US6507865B1 (en) | 1999-08-30 | 2003-01-14 | Zaplet, Inc. | Method and system for group content collaboration |
US20030191816A1 (en) | 2000-01-11 | 2003-10-09 | Spoovy, Llc | System and method for creating and delivering customized multimedia communications |
AU2001231259A1 (en) | 2000-02-04 | 2001-08-14 | America Online Incorporated | System and process for delivering and rendering scalable web pages |
US20020047856A1 (en) | 2000-02-07 | 2002-04-25 | Baker Ronald K. | Web based stacked images |
US6731316B2 (en) | 2000-02-25 | 2004-05-04 | Kargo, Inc. | Graphical layout and keypad response to visually depict and implement device functionality for interactivity with a numbered keypad |
US20010034746A1 (en) | 2000-02-26 | 2001-10-25 | Alex Tsakiris | Methods and systems for creating user-defined personal web cards |
US6738079B1 (en) | 2000-06-02 | 2004-05-18 | Sun Microsystems, Inc. | Graphical user interface layout customizer |
US7017189B1 (en) * | 2000-06-27 | 2006-03-21 | Microsoft Corporation | System and method for activating a rendering device in a multi-level rights-management architecture |
US6981262B1 (en) * | 2000-06-27 | 2005-12-27 | Microsoft Corporation | System and method for client interaction in a multi-level rights-management architecture |
US20030009694A1 (en) | 2001-02-25 | 2003-01-09 | Storymail, Inc. | Hardware architecture, operating system and network transport neutral system, method and computer program product for secure communications and messaging |
US20030041110A1 (en) | 2000-07-28 | 2003-02-27 | Storymail, Inc. | System, Method and Structure for generating and using a compressed digital certificate |
GB0027414D0 (en) | 2000-11-09 | 2000-12-27 | Enmark Systems Ltd | Automated electronic communication system |
US20020063152A1 (en) * | 2000-11-29 | 2002-05-30 | Ncr Corporation | Card data processing method for a network kiosk |
US20070028166A1 (en) | 2002-04-10 | 2007-02-01 | Allen Hundhausen | System and processes for dynamic document construction |
GB2374748A (en) | 2001-04-20 | 2002-10-23 | Discreet Logic Inc | Image data editing for transitions between sequences |
US8990214B2 (en) | 2001-06-27 | 2015-03-24 | Verizon Patent And Licensing Inc. | Method and system for providing distributed editing and storage of digital media over a network |
EP1304616B1 (en) | 2001-10-18 | 2010-03-17 | Sun Microsystems, Inc. | Method for processing a data file using a plug-in |
CA2414378A1 (en) | 2002-12-09 | 2004-06-09 | Corel Corporation | System and method for controlling user interface features of a web application |
CA2414053A1 (en) | 2002-12-09 | 2004-06-09 | Corel Corporation | System and method for manipulating a document object model |
US8468126B2 (en) | 2005-08-01 | 2013-06-18 | Seven Networks, Inc. | Publishing data in an information community |
US7853563B2 (en) | 2005-08-01 | 2010-12-14 | Seven Networks, Inc. | Universal data aggregation |
US20040226048A1 (en) | 2003-02-05 | 2004-11-11 | Israel Alpert | System and method for assembling and distributing multi-media output |
US9213365B2 (en) | 2010-10-01 | 2015-12-15 | Z124 | Method and system for viewing stacked screen displays using gestures |
US7322007B2 (en) | 2003-05-30 | 2008-01-22 | Vistaprint Technologies Limited | Electronic document modification |
US20050027820A1 (en) | 2003-06-02 | 2005-02-03 | O'laughlen Eric | Page views proxy servers |
US20050066279A1 (en) | 2003-07-23 | 2005-03-24 | Lebarton Jeffrey | Stop motion capture tool |
US7743322B2 (en) | 2003-09-30 | 2010-06-22 | Hewlett-Packard Development Company, L.P. | Automatic photo album page layout |
US7941739B1 (en) | 2004-02-19 | 2011-05-10 | Microsoft Corporation | Timeline source |
US20050210416A1 (en) | 2004-03-16 | 2005-09-22 | Maclaurin Matthew B | Interactive preview of group contents via axial controller |
US20050228824A1 (en) | 2004-04-01 | 2005-10-13 | Gattuso Joseph A | Intelligent consequence management system |
US7873708B2 (en) | 2004-04-28 | 2011-01-18 | At&T Mobility Ii Llc | Systems and methods for providing mobile advertising and directory assistance services |
US8028250B2 (en) | 2004-08-31 | 2011-09-27 | Microsoft Corporation | User interface having a carousel view for representing structured data |
US8223785B2 (en) | 2004-09-13 | 2012-07-17 | International Business Machines Corporation | Message processing and content based searching for message locations in an asynchronous network |
US20060123089A1 (en) | 2004-12-03 | 2006-06-08 | Cahn Janet E | Formulating and sending a message by a personal messaging device |
US7652594B2 (en) | 2005-04-08 | 2010-01-26 | Trigger California, Inc. | Architecture for creating, organizing, editing, management and delivery of locationally-specific information to a user in the field |
US8836580B2 (en) | 2005-05-09 | 2014-09-16 | Ehud Mendelson | RF proximity tags providing indoor and outdoor navigation and method of use |
US20060259462A1 (en) | 2005-05-12 | 2006-11-16 | Sybase, Inc. | System and Methodology for Real-time Content Aggregation and Syndication |
CA2662485A1 (en) * | 2005-08-30 | 2007-03-08 | Jasminder Singh Banga | Apparatus, systems and methods for targeted content delivery |
US20070118801A1 (en) | 2005-11-23 | 2007-05-24 | Vizzme, Inc. | Generation and playback of multimedia presentations |
US7669123B2 (en) | 2006-08-11 | 2010-02-23 | Facebook, Inc. | Dynamically providing a news feed about a user of a social network |
US20070208704A1 (en) * | 2006-03-06 | 2007-09-06 | Stephen Ives | Packaged mobile search results |
US9071367B2 (en) | 2006-03-17 | 2015-06-30 | Fatdoor, Inc. | Emergency including crime broadcast in a neighborhood social network |
US20070232399A1 (en) | 2006-04-03 | 2007-10-04 | Kathman Brian F | Mobile trading card generation and distribution |
US20080040322A1 (en) | 2006-08-03 | 2008-02-14 | Hal Rucker | Web presence using cards |
US8635521B2 (en) | 2006-09-22 | 2014-01-21 | Microsoft Corporation | Customizing applications in a discovery interface |
US9110903B2 (en) | 2006-11-22 | 2015-08-18 | Yahoo! Inc. | Method, system and apparatus for using user profile electronic device data in media delivery |
US8402356B2 (en) | 2006-11-22 | 2013-03-19 | Yahoo! Inc. | Methods, systems and apparatus for delivery of media |
US20140114866A1 (en) | 2006-11-22 | 2014-04-24 | Raj V. Abhyanker | Automobile sharing by users of a neighborhood social network using a radial algorithm |
US20140165091A1 (en) | 2006-11-22 | 2014-06-12 | Raj Abhyanker | Television and radio stations broadcasted by users of a neighborhood social network using a radial algorithm |
US7882442B2 (en) | 2007-01-05 | 2011-02-01 | Eastman Kodak Company | Multi-frame display system with perspective based image arrangement |
US20080215964A1 (en) * | 2007-02-23 | 2008-09-04 | Tabblo, Inc. | Method and system for online creation and publication of user-generated stories |
US20090158182A1 (en) | 2007-09-26 | 2009-06-18 | Picaboo Corporation | Greeting Card System and Method |
TW200921478A (en) | 2007-11-06 | 2009-05-16 | Giga Byte Comm Inc | A picture-page scrolling control method of touch panel for hand-held electronic device and device thereof |
US7953654B2 (en) | 2008-01-29 | 2011-05-31 | Transaction Wireless, Inc. | Integration of gift card services for mobile devices and social networking services |
US20120150728A1 (en) | 2010-12-14 | 2012-06-14 | Isaacson Thomas M | System and method for splitting a transaction |
US20140250001A1 (en) | 2010-12-14 | 2014-09-04 | Giftya Llc | System and method for processing gifts between different payment account types |
US20120150743A1 (en) | 2010-12-14 | 2012-06-14 | Moneyhoney Llc | System and method for transferring redemption rights to gift cards |
US20120150729A1 (en) | 2010-12-14 | 2012-06-14 | Moneyhoney Llc | System and method for processing group gift cards using a temporary, limited scope social networking entity |
US20130166445A1 (en) | 2010-12-14 | 2013-06-27 | Giftya Llc | System and method for processing gift cards which hide some gift card data |
US20120150730A1 (en) | 2010-12-14 | 2012-06-14 | Moneyhoney Llc | System and method for processing group gift cards |
US20120150732A1 (en) | 2010-12-14 | 2012-06-14 | Moneyhoney Llc | System and method for processing gift cards according to a communication context |
US20120150731A1 (en) | 2010-12-14 | 2012-06-14 | Moneyhoney Llc | System and method for processing group gift cards |
US20130144707A1 (en) | 2010-12-14 | 2013-06-06 | Giftya Llc | System and method for processing gifts between different exchange mediums |
US8577957B2 (en) | 2008-04-01 | 2013-11-05 | Litl Llc | System and method for streamlining user interaction with electronic content |
US8732581B2 (en) | 2008-05-20 | 2014-05-20 | Adobe Systems Incorporated | Package file presentation |
US20140250002A1 (en) | 2008-05-29 | 2014-09-04 | Giftya Llc | System and method for processing a gift card via the cloud |
US7934129B2 (en) | 2008-09-05 | 2011-04-26 | Microsoft Corporation | Network hang recovery |
US20100070876A1 (en) | 2008-09-18 | 2010-03-18 | Pictela, Inc. | Self-Replicating Rich Media Interface |
US8442866B2 (en) | 2008-10-27 | 2013-05-14 | Cashstar, Inc. | Systems and methods for implementing and managing virtual gift cards |
US8762885B2 (en) | 2008-12-15 | 2014-06-24 | Verizon Patent And Licensing Inc. | Three dimensional icon stacks |
US8412729B2 (en) | 2009-04-22 | 2013-04-02 | Genarts, Inc. | Sharing of presets for visual effects or other computer-implemented effects |
US8291314B2 (en) * | 2009-04-23 | 2012-10-16 | Hewlett-Packard Development Company, L.P. | Arranging graphic objects on a page |
US20110060993A1 (en) * | 2009-09-08 | 2011-03-10 | Classified Ventures, Llc | Interactive Detailed Video Navigation System |
FR2954536A1 (en) | 2009-12-21 | 2011-06-24 | France Telecom | METHOD FOR INTEGRATING THE WEB BROWSER WITH A GRAPHICAL APPLICATION |
US20110283172A1 (en) | 2010-05-13 | 2011-11-17 | Tiny Prints, Inc. | System and method for an online memories and greeting service |
US9754043B2 (en) | 2010-07-09 | 2017-09-05 | Facebook, Inc. | Rendering structured documents with place-markers |
US8904277B2 (en) | 2010-08-31 | 2014-12-02 | Cbs Interactive Inc. | Platform for serving online content |
US9129641B2 (en) | 2010-10-15 | 2015-09-08 | Afterlive.tv Inc | Method and system for media selection and sharing |
US9104647B2 (en) | 2010-10-26 | 2015-08-11 | Nook Digital, Llc | System and method for reading multifunctional electronic books on portable readers |
US8996463B2 (en) | 2012-07-26 | 2015-03-31 | Mongodb, Inc. | Aggregation framework system architecture and method |
US20120236201A1 (en) | 2011-01-27 | 2012-09-20 | In The Telling, Inc. | Digital asset management, authoring, and presentation techniques |
US9122374B2 (en) | 2011-02-01 | 2015-09-01 | 9224-5489 Quebec Inc. | Expandable and collapsible arrays of documents |
US20120210200A1 (en) | 2011-02-10 | 2012-08-16 | Kelly Berger | System, method, and touch screen graphical user interface for managing photos and creating photo books |
US9336512B2 (en) | 2011-02-11 | 2016-05-10 | Glenn Outerbridge | Digital media and social networking system and method |
US8898630B2 (en) | 2011-04-06 | 2014-11-25 | Media Direct, Inc. | Systems and methods for a voice- and gesture-controlled mobile application development and deployment platform |
US9134964B2 (en) | 2011-04-06 | 2015-09-15 | Media Direct, Inc. | Systems and methods for a specialized application development and deployment platform |
US9152616B2 (en) | 2011-04-28 | 2015-10-06 | Flipboard, Inc. | Template-based page layout for web content |
WO2012150602A1 (en) | 2011-05-03 | 2012-11-08 | Yogesh Chunilal Rathod | A system and method for dynamically monitoring, recording, processing, attaching dynamic, contextual & accessible active links & presenting of physical or digital activities, actions, locations, logs, life stream, behavior & status |
US8341525B1 (en) | 2011-06-03 | 2012-12-25 | Starsvu Corporation | System and methods for collaborative online multimedia production |
US9335921B2 (en) | 2011-06-10 | 2016-05-10 | Amx Llc | Providing subpages in a touch panel user interface |
US8935279B2 (en) | 2011-06-13 | 2015-01-13 | Opus Deli, Inc. | Venue-related multi-media management, streaming, online ticketing, and electronic commerce techniques implemented via computer networks and mobile devices |
US9218413B2 (en) * | 2011-06-13 | 2015-12-22 | Opus Deli, Inc. | Venue-related multi-media management, streaming, online ticketing, and electronic commerce techniques implemented via computer networks and mobile devices |
US9355393B2 (en) | 2011-08-18 | 2016-05-31 | Visa International Service Association | Multi-directional wallet connector apparatuses, methods and systems |
US20130159154A1 (en) | 2011-08-18 | 2013-06-20 | Thomas Purves | Wallet service enrollment platform apparatuses, methods and systems |
US10534842B2 (en) * | 2011-07-12 | 2020-01-14 | Inkling Systems, Inc. | Systems and methods for creating, editing and publishing cross-platform interactive electronic works |
US8788925B1 (en) | 2011-07-21 | 2014-07-22 | Flipboard, Inc. | Authorized syndicated descriptions of linked web content displayed with links in user-generated content |
US8872855B2 (en) | 2011-07-21 | 2014-10-28 | Flipboard, Inc. | Adjusting orientation of content regions in a page layout |
US9396167B2 (en) | 2011-07-21 | 2016-07-19 | Flipboard, Inc. | Template-based page layout for hosted social magazines |
US20130282605A1 (en) | 2011-08-12 | 2013-10-24 | Philippe Noelting | System and Method for User Profile Creation and Access Control |
US20130046781A1 (en) | 2011-08-19 | 2013-02-21 | Stargreetz, Inc. | Design, creation, and delivery of personalized message/audio-video content |
CN102955803B (en) | 2011-08-26 | 2016-04-20 | 腾讯科技(深圳)有限公司 | A kind of website display method and browser |
US9213775B2 (en) | 2011-09-01 | 2015-12-15 | Facebook. Inc. | Domain-specific browser tab creation and management |
US10127564B2 (en) | 2011-09-15 | 2018-11-13 | Stephan HEATH | System and method for using impressions tracking and analysis, location information, 2D and 3D mapping, mobile mapping, social media, and user behavior and information for generating mobile and internet posted promotions or offers for, and/or sales of, products and/or services |
US10217117B2 (en) | 2011-09-15 | 2019-02-26 | Stephan HEATH | System and method for social networking interactions using online consumer browsing behavior, buying patterns, advertisements and affiliate advertising, for promotions, online coupons, mobile services, products, goods and services, entertainment and auctions, with geospatial mapping technology |
US10096033B2 (en) | 2011-09-15 | 2018-10-09 | Stephan HEATH | System and method for providing educational related social/geo/promo link promotional data sets for end user display of interactive ad links, promotions and sale of products, goods, and/or services integrated with 3D spatial geomapping, company and local information for selected worldwide locations and social networking |
US10127563B2 (en) | 2011-09-15 | 2018-11-13 | Stephan HEATH | System and method for providing sports and sporting events related social/geo/promo link promotional data sets for end user display of interactive ad links, promotions and sale of products, goods, gambling and/or services integrated with 3D spatial geomapping, company and local information for selected worldwide locations and social networking |
US10120877B2 (en) | 2011-09-15 | 2018-11-06 | Stephan HEATH | Broad and alternative category clustering of the same, similar or different categories in social/geo/promo link promotional data sets for end user display of interactive ad links, coupons, mobile coupons, promotions and sale of products, goods and services integrated with 3D spatial geomapping and mobile mapping and social networking |
US9473904B2 (en) | 2011-09-23 | 2016-10-18 | Verizon Telematics Inc. | Method and system for determining and triggering targeted marketing content |
US8255293B1 (en) | 2011-10-10 | 2012-08-28 | Google Inc. | Product catalog dynamically tailored to user-selected media content |
US8463795B2 (en) | 2011-10-18 | 2013-06-11 | Filpboard, Inc. | Relevance-based aggregated social feeds |
US20130099447A1 (en) | 2011-10-19 | 2013-04-25 | Stephen Patton | Card having a flexible, dynamically changeable display, a set of such cards and related system and method |
US8935629B2 (en) | 2011-10-28 | 2015-01-13 | Flipboard Inc. | Systems and methods for flipping through content |
US8799778B2 (en) | 2011-12-13 | 2014-08-05 | Facebook, Inc. | Scrolling velocity modulation in a tactile interface for a social networking system |
US20150058709A1 (en) | 2012-01-26 | 2015-02-26 | Michael Edward Zaletel | Method of creating a media composition and apparatus therefore |
US10430866B2 (en) | 2012-01-30 | 2019-10-01 | Gift Card Impressions, LLC | Personalized webpage gifting system and method |
US10430865B2 (en) | 2012-01-30 | 2019-10-01 | Gift Card Impressions, LLC | Personalized webpage gifting system |
US10417677B2 (en) | 2012-01-30 | 2019-09-17 | Gift Card Impressions, LLC | Group video generating system |
US8825083B1 (en) | 2012-01-31 | 2014-09-02 | Google Inc. | Experience sharing system and method |
US8832062B1 (en) | 2012-01-31 | 2014-09-09 | Google Inc. | Experience sharing system and method |
US8832127B1 (en) | 2012-01-31 | 2014-09-09 | Google Inc. | Experience sharing system and method |
US8812528B1 (en) | 2012-01-31 | 2014-08-19 | Google Inc. | Experience sharing system and method |
US9275403B2 (en) * | 2012-01-31 | 2016-03-01 | Google Inc. | Experience sharing system and method |
US8832191B1 (en) | 2012-01-31 | 2014-09-09 | Google Inc. | Experience sharing system and method |
US8903852B1 (en) | 2012-01-31 | 2014-12-02 | Google Inc. | Experience sharing system and method |
US9197911B2 (en) | 2012-02-16 | 2015-11-24 | Gopop.tv | Method and apparatus for providing interaction packages to users based on metadata associated with content |
US8291312B1 (en) | 2012-03-06 | 2012-10-16 | Google Inc. | Displaying web pages without downloading static files |
US20130254705A1 (en) | 2012-03-20 | 2013-09-26 | Wimm Labs, Inc. | Multi-axis user interface for a touch-screen enabled wearable device |
US20130268372A1 (en) | 2012-04-04 | 2013-10-10 | Stor Networks, Inc. | System, method, and computer-readable storage medium for consolidating and personalizing the delivery of marketing communications |
US20130283194A1 (en) | 2012-04-19 | 2013-10-24 | Yudek, Inc. | Systems and methods for managing content using virtual cards |
AU2013202944B2 (en) | 2012-04-26 | 2015-11-12 | Samsung Electronics Co., Ltd. | Method and terminal for displaying a plurality of pages, method and terminal for displaying a plurality of applications being executed on terminal, and method of executing a plurality of applications |
US9069744B2 (en) | 2012-05-15 | 2015-06-30 | Google Inc. | Extensible framework for ereader tools, including named entity information |
US20130318424A1 (en) | 2012-05-28 | 2013-11-28 | Ian A. R. Boyd | System and method for the creation of an e-enhanced multi-dimensional pictostory using pictooverlay technology |
US8933312B2 (en) | 2012-06-01 | 2015-01-13 | Makemusic, Inc. | Distribution of audio sheet music as an electronic book |
US20130339830A1 (en) | 2012-06-15 | 2013-12-19 | Microsoft Corporation | Optimized document views for mobile device interfaces |
AU2013206449A1 (en) | 2012-06-20 | 2014-01-16 | Visa International Service Association | Multi-channel remote payment apparatuses, methods and systems |
US20140047413A1 (en) | 2012-08-09 | 2014-02-13 | Modit, Inc. | Developing, Modifying, and Using Applications |
CN104583901B (en) | 2012-08-20 | 2019-10-01 | 爱维士软件私人有限公司 | The packing of multi-medium data based on set and display methods and system |
US9165314B2 (en) | 2012-09-12 | 2015-10-20 | Flipboard, Inc. | Interactions for sharing content items in a digital magazine |
US9037592B2 (en) | 2012-09-12 | 2015-05-19 | Flipboard, Inc. | Generating an implied object graph based on user behavior |
US10289661B2 (en) | 2012-09-12 | 2019-05-14 | Flipboard, Inc. | Generating a cover for a section of a digital magazine |
US10061760B2 (en) | 2012-09-12 | 2018-08-28 | Flipboard, Inc. | Adaptive layout of content in a digital magazine |
US20140089804A1 (en) | 2012-09-24 | 2014-03-27 | Burkiberk Ltd. | Interactive creation of a movie |
US20140096014A1 (en) | 2012-09-29 | 2014-04-03 | Oracle International Corporation | Method for enabling dynamic client user interfaces on multiple platforms from a common server application via metadata |
US20140108289A1 (en) | 2012-10-11 | 2014-04-17 | CardSpark, Inc. | System and method for using a hybrid business card |
US20140152591A1 (en) | 2012-11-30 | 2014-06-05 | Kabushiki Kaisha Toshiba | Electronic device and computer program product |
US20140164507A1 (en) | 2012-12-10 | 2014-06-12 | Rawllin International Inc. | Media content portions recommended |
US20140173417A1 (en) | 2012-12-18 | 2014-06-19 | Xiaopeng He | Method and Apparatus for Archiving and Displaying historical Web Contents |
US9594732B2 (en) * | 2012-12-20 | 2017-03-14 | Google Inc. | Selectively replacing displayed content items based on user interaction |
US9483855B2 (en) | 2013-01-15 | 2016-11-01 | Flipboard, Inc. | Overlaying text in images for display to a user of a digital magazine |
WO2014115147A1 (en) | 2013-01-24 | 2014-07-31 | Telesofia Medical Ltd. | System and method for flexible video construction |
US9324166B2 (en) | 2013-01-31 | 2016-04-26 | American Greetings Corporation | Systems, methods, and apparatuses for creating digital glitter |
US9357243B2 (en) | 2013-02-26 | 2016-05-31 | Splenvid, Inc. | Movie compilation system with integrated advertising |
US20160034437A1 (en) | 2013-03-15 | 2016-02-04 | KIM Yong | Mobile social content-creation application and integrated website |
US20140287779A1 (en) | 2013-03-22 | 2014-09-25 | aDesignedPath for UsabilitySolutions, LLC | System, method and device for providing personalized mobile experiences at multiple locations |
US9836875B2 (en) | 2013-04-26 | 2017-12-05 | Flipboard, Inc. | Viewing angle image manipulation based on device rotation |
US20140344765A1 (en) | 2013-05-17 | 2014-11-20 | Barnesandnoble.Com Llc | Touch Sensitive UI Pinch and Flick Techniques for Managing Active Applications |
WO2014190297A1 (en) | 2013-05-23 | 2014-11-27 | Flipboard, Inc. | Dynamic arrangement of content presented while a client device is in a locked state |
US9304666B2 (en) | 2013-06-24 | 2016-04-05 | Oracle International Corporation | Supporting navigation on touch screens displaying elements organized in a fixed number of dimensions |
US9742753B2 (en) | 2013-07-12 | 2017-08-22 | Hj Holdings Llc | Multimedia personal historical information system and method |
WO2015012977A1 (en) | 2013-07-26 | 2015-01-29 | Evernote Corporation | Direct presentations from content collections |
US9818101B2 (en) | 2013-09-05 | 2017-11-14 | Mastercard International Incorporated | System and method for socially connecting payment card holders |
US20150072330A1 (en) * | 2013-09-06 | 2015-03-12 | Knowledge Initiatives LLC | Electronic textbook |
US20150088655A1 (en) | 2013-09-24 | 2015-03-26 | Nike, Inc. | Social media product reservation |
US10437901B2 (en) | 2013-10-08 | 2019-10-08 | Flipboard, Inc. | Identifying similar content on a digital magazine server |
KR102139664B1 (en) | 2013-10-11 | 2020-07-30 | 삼성전자주식회사 | System and method for sharing profile image card |
US9324374B2 (en) | 2013-11-11 | 2016-04-26 | Magisto Ltd. | Method and system for automatic generation of clips from a plurality of images based on an inter-objects relationship score |
KR20150055689A (en) | 2013-11-13 | 2015-05-22 | 삼성전자주식회사 | System and method for sharing profile image card for communication |
US20150149353A1 (en) | 2013-11-27 | 2015-05-28 | Facebook, Inc. | Methods and systems for obtaining merchant identification within payment authorization networks |
US9544655B2 (en) | 2013-12-13 | 2017-01-10 | Nant Holdings Ip, Llc | Visual hash tags via trending recognition activities, systems and methods |
US8949250B1 (en) | 2013-12-19 | 2015-02-03 | Facebook, Inc. | Generating recommended search queries on online social networks |
CN104753911B (en) | 2013-12-31 | 2019-03-15 | 腾讯科技(深圳)有限公司 | A kind of information processing method based on social application, relevant apparatus and system |
US20150193857A1 (en) | 2014-01-08 | 2015-07-09 | Modest, Inc. | System and method for quick transactions |
US9922270B2 (en) | 2014-02-13 | 2018-03-20 | Nant Holdings Ip, Llc | Global visual vocabulary, systems and methods |
US20150296033A1 (en) | 2014-04-15 | 2015-10-15 | Edward K. Y. Jung | Life Experience Enhancement Via Temporally Appropriate Communique |
US9910640B2 (en) | 2014-05-15 | 2018-03-06 | International Business Machines Corporation | Modeling representational state transfer application programming interfaces |
US8990672B1 (en) | 2014-08-25 | 2015-03-24 | Interactive Memories, Inc. | Flexible design architecture for designing media-based projects in a network-based platform |
US20160063580A1 (en) * | 2014-08-26 | 2016-03-03 | Gersse LLC | System, apparatus, and method for template-based adaptive review |
US9460058B2 (en) | 2014-09-02 | 2016-10-04 | Microsoft Technology Licensing, Llc | Operating system support for location cards |
US20160094536A1 (en) * | 2014-09-30 | 2016-03-31 | Frederick R. Krueger | System and method for portable social data in a webpublishing application |
US20160103805A1 (en) | 2014-10-09 | 2016-04-14 | Wrap Media, LLC | Card based package for distributing electronic media and services |
US20160124924A1 (en) | 2014-10-09 | 2016-05-05 | Wrap Media, LLC | Displaying a wrap package of cards within an overlay window embedded in an application or web page |
US9465788B2 (en) | 2014-10-09 | 2016-10-11 | Wrap Media, LLC | Authoring tool for the authoring of wrap packages of cards |
WO2016057188A1 (en) | 2014-10-09 | 2016-04-14 | Wrap Media, LLC | Active receipt wrapped packages accompanying the sale of products and/or services |
US12032897B2 (en) | 2014-10-09 | 2024-07-09 | Wrap Communications, Inc. | Methods of using a wrap descriptor to display a sequence of cards on a display device |
US9442906B2 (en) * | 2014-10-09 | 2016-09-13 | Wrap Media, LLC | Wrap descriptor for defining a wrap package of cards including a global component |
US20160103820A1 (en) | 2014-10-09 | 2016-04-14 | Wrap Media, LLC | Authoring tool for the authoring of wrap packages of cards |
US9600594B2 (en) | 2014-10-09 | 2017-03-21 | Wrap Media, LLC | Card based package for distributing electronic media and services |
US9438691B1 (en) * | 2015-10-26 | 2016-09-06 | Supirb Technologies, LLC | Online social referral network |
-
2015
- 2015-06-16 US US14/740,539 patent/US20160103820A1/en not_active Abandoned
- 2015-06-16 US US14/740,839 patent/US20160103821A1/en not_active Abandoned
- 2015-06-16 US US14/740,617 patent/US20160104210A1/en not_active Abandoned
- 2015-06-16 US US14/740,533 patent/US20160103791A1/en not_active Abandoned
- 2015-08-03 US US14/816,935 patent/US20160103904A1/en not_active Abandoned
- 2015-08-03 US US14/816,662 patent/US20160104211A1/en not_active Abandoned
- 2015-08-03 US US14/816,678 patent/US20160105771A1/en not_active Abandoned
- 2015-09-11 US US14/851,362 patent/US9600449B2/en active Active
-
2016
- 2016-08-17 US US15/239,060 patent/US20160357727A1/en not_active Abandoned
- 2016-08-17 US US15/239,052 patent/US9582485B2/en active Active
- 2016-08-18 US US15/240,556 patent/US20160357849A1/en not_active Abandoned
Patent Citations (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20130305145A1 (en) * | 2012-05-09 | 2013-11-14 | Ni Group Limited | A Method of Publishing Digital Content |
Cited By (7)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US9600449B2 (en) | 2014-10-09 | 2017-03-21 | Wrap Media, LLC | Authoring tool for the authoring of wrap packages of cards |
US9600464B2 (en) | 2014-10-09 | 2017-03-21 | Wrap Media, LLC | Authoring tool for the authoring of wrap packages of cards |
US9600803B2 (en) | 2015-03-26 | 2017-03-21 | Wrap Media, LLC | Mobile-first authoring tool for the authoring of wrap packages |
US20180032235A1 (en) * | 2016-08-01 | 2018-02-01 | Facebook, Inc. | Systems and methods for content interaction |
US10593084B2 (en) * | 2016-08-01 | 2020-03-17 | Facebook, Inc. | Systems and methods for content interaction |
US10600220B2 (en) * | 2016-08-01 | 2020-03-24 | Facebook, Inc. | Systems and methods for content interaction |
US20180373800A1 (en) * | 2017-06-27 | 2018-12-27 | Alan Pizer | Method of storing and ordering interactive content data in localized and connected content data structures |
Also Published As
Publication number | Publication date |
---|---|
US9600449B2 (en) | 2017-03-21 |
US20160103821A1 (en) | 2016-04-14 |
US20160104210A1 (en) | 2016-04-14 |
US20160105771A1 (en) | 2016-04-14 |
US20160357727A1 (en) | 2016-12-08 |
US20160357849A1 (en) | 2016-12-08 |
US20160104211A1 (en) | 2016-04-14 |
US20160103904A1 (en) | 2016-04-14 |
US20160103797A1 (en) | 2016-04-14 |
US20160103791A1 (en) | 2016-04-14 |
US20160357726A1 (en) | 2016-12-08 |
US9582485B2 (en) | 2017-02-28 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US20240362402A1 (en) | Methods of using a wrap descriptor to display a sequence of cards on a display device | |
US9600464B2 (en) | Authoring tool for the authoring of wrap packages of cards | |
US9600449B2 (en) | Authoring tool for the authoring of wrap packages of cards | |
US9582154B2 (en) | Integration of social media with card packages | |
US9285977B1 (en) | Card based package for distributing electronic media and services | |
US9449335B2 (en) | Delivering wrapped packages in response to the selection of advertisements | |
US20170017634A1 (en) | System and method for authoring and delivering wrap packages of cards | |
US20160321222A1 (en) | Card based package for distributing electronic media and services | |
US20160357373A1 (en) | Authoring tool for the authoring of wrap packages of cards | |
US20160103563A1 (en) | System and method for authoring, distributing, viewing and saving wrap packages | |
US20160132894A1 (en) | Digital companion wrap packages accompanying the sale or lease of a product and/or service | |
US20160117068A1 (en) | Wrapped packages of cards for conveying a story-book user experience with media content, providing application and/or web functionality and engaging users in e-commerce | |
US20160140647A1 (en) | Active receipt wrapped packages accompanying the sale of products and/or services | |
WO2016057135A1 (en) | Authoring and delivering wrap packages of cards with custom content to target individuals | |
WO2017014966A1 (en) | System and method for authoring and delivering wrap packages of cards | |
WO2016057190A1 (en) | Digital companion wrap packages accompanying the sale or lease of a product and/or service | |
WO2016057176A1 (en) | Authoring tool for the authoring of wrap packages of cards | |
US20160103654A1 (en) | Wrap package of cards including an audio component |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
AS | Assignment |
Owner name: WRAP MEDIA, LLC, CALIFORNIA Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNORS:GREENBERG, ERIC H.;GARRIS, JOHN M.;MCFARLAND, IAN;AND OTHERS;SIGNING DATES FROM 20150609 TO 20150615;REEL/FRAME:035921/0736 |
|
AS | Assignment |
Owner name: SILICON VALLEY BANK, CALIFORNIA Free format text: SECURITY INTEREST;ASSIGNOR:BRUNOCO, INC.;REEL/FRAME:044324/0282 Effective date: 20170912 |
|
STCB | Information on status: application discontinuation |
Free format text: ABANDONED -- FAILURE TO RESPOND TO AN OFFICE ACTION |