/* global marketplace_suggestions ajaxurl */ ( function( $, marketplace_suggestions ) { $( function() { if ( 'undefined' === typeof marketplace_suggestions ) { return; } function dismissSuggestion( suggestionSlug ) { // hide the suggestion in the UI var selector = '.marketplace-suggestions-container[data-suggestion-slug=' + suggestionSlug + ']'; $( selector ).fadeOut(); // save dismissal in user settings jQuery.post( ajaxurl, { 'action': 'add_dismissed_marketplace_suggestion', '_wpnonce': marketplace_suggestions.dismiss_suggestion_nonce, 'slug': suggestionSlug, } ); } function renderDismissButton( suggestionSlug ) { var dismissButton = document.createElement( 'a' ); dismissButton.classList.add( 'suggestion-dismiss' ); dismissButton.setAttribute( 'href', '#' ); dismissButton.onclick = function() { dismissSuggestion( suggestionSlug ); } return dismissButton; } function renderLinkoutButton( url, buttonText ) { var linkoutButton = document.createElement( 'a' ); linkoutButton.classList.add( 'button' ); linkoutButton.setAttribute( 'href', url ); linkoutButton.textContent = buttonText; return linkoutButton; } function renderTableBanner( slug, title, url, buttonText ) { if ( ! title || ! url ) { return; } if ( ! buttonText ) { buttonText = 'Go'; } var row = document.createElement( 'tr' ); row.classList.add( 'marketplace-suggestions-container' ); row.classList.add( 'marketplace-table-banner' ); row.dataset.suggestionSlug = slug; var titleColumn = document.createElement( 'td' ); titleColumn.setAttribute( 'colspan', 5 ); titleColumn.classList.add( 'marketplace-table-title' ); var titleHeading = document.createElement( 'h2' ); titleColumn.appendChild( titleHeading ); titleHeading.textContent = title; row.appendChild( titleColumn ); var linkoutColumn = document.createElement( 'td' ); linkoutColumn.setAttribute( 'colspan', 5 ); linkoutColumn.classList.add( 'marketplace-table-linkout' ); var linkoutButton = renderLinkoutButton( url, buttonText ); linkoutColumn.appendChild( linkoutButton ); linkoutColumn.appendChild( renderDismissButton( slug ) ) row.appendChild( linkoutColumn ); return row; } function renderListItem( slug, title, url, buttonText, copy ) { if ( ! title ) { return; } if ( ! buttonText ) { buttonText = 'Go'; } var container = document.createElement( 'div' ); container.classList.add( 'marketplace-listitem-container' ); container.dataset.suggestionSlug = slug; var titleHeading = document.createElement( 'h4' ); titleHeading.textContent = title; container.appendChild( titleHeading ); if ( copy ) { var body = document.createElement( 'p' ); body.textContent = copy; container.appendChild( body ); } if ( url ) { var linkoutButton = renderLinkoutButton( url, buttonText ); container.appendChild( linkoutButton ); } container.appendChild( renderDismissButton( slug ) ) return container; } var visibleSuggestions = []; function getRelevantPromotions( marketplaceSuggestionsApiData, displayContext ) { // select based on display context var promos = _.filter( marketplaceSuggestionsApiData, function( promo ) { return ( displayContext === promo.context ); } ); // hide promos the user has dismissed promos = _.filter( promos, function( promo ) { return ! _.contains( marketplace_suggestions.dismissed_suggestions, promo.slug ); } ); // hide promos for things the user already has installed promos = _.filter( promos, function( promo ) { return ! _.contains( marketplace_suggestions.installed_woo_plugins, promo['hide-if-installed'] ); } ); // hide promos that are not applicable based on user's installed extensions promos = _.filter( promos, function( promo ) { if ( ! promo['show-if-installed'] ) { // this promotion is relevant to all return true; } // if the user has any of the prerequisites, show the promo return ( _.intersection( marketplace_suggestions.installed_woo_plugins, promo['show-if-installed'] ).length > 0 ); } ); return promos; } function hidePageElementsForOnboardingStyle() { if ( _.contains( visibleSuggestions, 'products-list-empty-body' ) ) { $('h1.wp-heading-inline').hide(); $('#screen-meta-links').hide(); $('#wpfooter').hide(); } } function displaySuggestions( marketplaceSuggestionsApiData ) { // iterate over all suggestions containers, rendering promos $( '.marketplace-suggestions-container' ).each( function() { // determine the context / placement we're populating var context = this.dataset.marketplaceSuggestionsContext; // find promotions that target this context var promos = getRelevantPromotions( marketplaceSuggestionsApiData, context ); // render the promo content for ( var i in promos ) { var content = renderListItem( promos[ i ].slug, promos[ i ].title, promos[ i ].url, promos[ i ]['button-text'], promos[ i ].copy ); $( this ).append( content ); visibleSuggestions.push( promos[i].context ); } } ); // render inline promos in products list $( '.wp-admin.admin-bar.edit-php.post-type-product table.wp-list-table.posts tbody').first().each( function() { var context = 'products-list-inline'; // find promotions that target this context var promos = getRelevantPromotions( marketplaceSuggestionsApiData, context ); if ( ! promos || ! promos.length ) { return; } // render first promo var content = renderTableBanner( promos[ 0 ].slug, promos[ 0 ].title, promos[ 0 ].url, promos[ 0 ]['button-text'] ); if ( content ) { // where should we put it in the list? var rows = $( this ).children(); var minRow = 3; if ( rows.length <= minRow ) { // if small number of rows, append at end $( this ).append( content ); } else { // for more rows, append $( rows[ minRow - 1 ] ).after( content ); } visibleSuggestions.push( context ); } } ); hidePageElementsForOnboardingStyle(); } var data = jQuery.getJSON( ajaxurl, { 'action': 'marketplace_suggestions', }, displaySuggestions ); }); })( jQuery, marketplace_suggestions, ajaxurl );