Smoked Turkey Wings Recipe

Home » Smoked Turkey Wings Recipe
Smoked Turkey Wings Recipe

Smoked turkey wings are perfect for adding richness to broths and soups, and they bring an extra layer of taste to beans and other vegetables. Cook them with greens like collards or cabbage, or with red beans, black eyed peas, or butter beans!

We love smoked turkey wings for making broths, gravies, and other dishes, rather than for direct consumption right off the smoker. However, you can make smoked turkey wings for eating as well. Many people like to do this as an alternative to smoked turkey breast or a whole turkey for Thanksgiving and other holidays.

Using smoked turkey for broths and gravies is a technique, commonly known as “infusing” or “seasoning,”. It’s often used with smoked ham hocks or turkey legs, wings or tails to flavor collard greens, beans, or gumbo, to name a few.

By simmering smoked turkey wings, you can extract their smoky essence into the liquid, a process referred to as “rendering” or “extracting.” It’s one of the best ways to create a flavorful base for soups, stews, or stocks, using the wings, bones, or other meat trimmings!

During the holiday season, we always make our own broth and gravy using smoked turkey. That’s honestly the best part! Homemade turkey broth and turkey gravy are much better than store bought, especially for special holidays like Thanksgiving. 

What you’ll love about this recipe:


  • CUSTOMIZATION – Smoking at home allows you to experiment with different wood, brines, and seasonings to create a signature flavor profile.
  • FRESHNESS & QUALITY – Smoking your own turkey wings ensures that you’re using fresh, high-quality meat. You can choose the best wings available, avoid preservatives, and enjoy a more flavorful and tender final product.

Ingredients

  • Turkey Wings: You can usually find raw turkey wings at your local grocery store, especially in the meat or poultry section, or at specialty butchers for a fresher option. Turkey meat is flavorful and has a rich, smoky taste and a tender texture when cooked.
  • Granulated Garlic: Offers a savory, garlicky flavor. As a substitute, you can use garlic powder, which provides a similar taste but is finer in texture.
  • Granulated Onion: Goes well with garlic and pepper. Onion powder can be used as a substitute.
  • Black Pepper: Adds a spicy kick to the dry rub. 
  • Wood for Smoke: The best wood flavor is whatever you prefer. Hickory, apple, or cherry wood pellets (or wood chips) give off distinct tastes. For a milder smoke, we really like pecan.

Turkey Brine Ingredients (Recommended)

For best results, we always recommend a salt, sugar, and water brine. 

Tools

  • Smoker or Grill: A smoker (like a pellet, electric, or charcoal smoker) is ideal, but a regular grill with a smoker box can also work if you set it up for indirect heat. For this recipe we used a pellet smoker (like a Traeger grill, etc.)
  • Meat Thermometer: A reliable meat thermometer is necessary for ensuring your turkey wings reach the appropriate internal temperature.
  • Brining Container: You’ll need a large container, such as a food-safe bucket, pot, or resealable bag, to hold the wings and brine solution.
  • Tongs: Use tongs to handle the turkey wings on the smoker or grill, ensuring they can be turned and removed safely.

How to Brine Turkey Wings

This recipe uses a basic salt, sugar, and water brine that will infuse your pellet grill turkey wings with a nice balance of flavor. It’s the same brine recipe we use for fried chicken, smoked chicken wings, smoke fried wings, and more.

  1. Remove turkey from the brine, rinse, and pat dry with paper towels, Then, proceed with smoking.
  2. Bring 4 cups water to a boil in a pot.
  3. In the same pot, add 1/4 cup kosher salt and 1/4 cup sugar to the boiling water. Stir until completely dissolved.
  4. Remove the pot from heat and let the brine cool slightly.
  5. Add 4 cups ice to the pot, stirring until the ice is mostly melted, and the brine reaches room temperature.
  6. Place wings in a large bowl, container, or resealable plastic bag.
  7. Pour the brine over turkey, ensuring they are fully submerged. If using a bag, remove excess air before sealing.
  8. Cover and refrigerate for at least 4 hours, or overnight for maximum flavor absorption.

Smoked Turkey Wings Recipe

  1. Prepare Wings: Rinse the brined turkey wings under cold water and pat them dry with a paper towel. Place them on a large baking sheet or tray.
  2. Season: In a small bowl, mix granulated garlic, granulated onion, and ground black pepper (or use your favorite seasonings). Generously apply the spice rub to the wings, ensuring they are well-coated on all sides.
  3. Smoke Turkey Wings: Preheat your smoker to 275°F (107°C). Place the seasoned turkey wings on the grill grate in a single layer, ensuring they are not overcrowded.
  4. Smoke turkey wings for about 1 to 1 1/2 hours, or until they reach an internal temperature of 165°F. Use a meat thermometer to check for doneness, inserting it into the thickest part of the meat, avoiding the bone.
  5. Rest: Once the wings are cooked, remove them from the smoker and let them rest.
  6. See the “Storage Instructions” and “Ways to Use Smoked Turkey Wings” sections below for more information.

Storage Instructions

  • Leftover wings are good for 2-3 days when stored in an airtight container in the refrigerator.
  • If you’re not planning to eat or use your smoked turkey wings within 2 to 3 days, vacuum sealing is your best friend. We have the FoodSaver Elite All-in-One Liquid+™ Vacuum Sealer with Bags that was gifted to us by the brand and we absolutely love it!
  • By vacuum sealing the wings, you’ll remove all the air from the packaging, which helps prevent freezer burn and keeps those rich, smoky flavors locked in. Once they’re vacuum sealed, pop them in the freezer, where they can stay good for up to six months.
  • If you don’t have a vacuum sealer, don’t worry! You can still store your smoked turkey wings in a heavy-duty freezer bag or airtight container. Just be sure to press out as much air as possible before sealing the bag. For added protection, you can wrap the wings in a layer of aluminum foil before placing them in the bag. Label your bags with the date so you’ll know how long they’ve been in the freezer.
  • When you’re ready to use them, just thaw the wings in the refrigerator overnight, and they’ll be ready to infuse your dishes with that delicious smoky goodness.

Ways to Use Smoked Turkey Wings

There are so many delicious ways to use smoked turkey wings. Here are just a few examples: 

  • Collard Greens with Smoked Turkey
  • Black-Eyed Peas with Smoked Turkey
  • Pinto Beans
  • Louisiana Red Beans and Rice
  • Butter Beans (Large Lima Beans)
  • Boiled Cabbage

More Smoked Turkey Recipes

  • Cajun Smoked Turkey (the whole bird)
  • Smoked Turkey Breast

Summary

Add this smoked turkey wings recipe to your culinary repertoire! It’s perfect for flavoring soups and stews, beans, greens, and more. One of our favorite ways to use smoked turkey wings is when making homemade broth or gravy. Try it out this holiday season and enjoy a flavorful meal. 

Print

Smoked Turkey Wings

5 Stars 4 Stars 3 Stars 2 Stars 1 Star No reviews
  • Author: Krysten and Marrekus Wilkes
  • Prep Time: 15 minutes
  • Brine (Recommended): 4 hours to overnight
  • Cook Time: 1 hour 30 minutes
  • Total Time: 1 hour 45 minutes + Brine
  • Yield: 4 smoked turkey wings
  • Category: turkey, meat
  • Method: smoker
const share_pin_buttons = document.getElementsByClassName( ‘share-pin button’ ); if ( share_pin_buttons ) { for ( let share_key = 0; share_key { e.stopPropagation(); window.open(e.target.dataset.href,’targetWindow’,’toolbar=no,location=no,status=no,menubar=no,scrollbars=yes,resizable=yes,width=500,height=500′); return false; } ); } }

Ingredients

Units
  • 4 large turkey wings
  • 2 teaspoons granulated garlic
  • 2 teaspoons granulated onion
  • 2 teaspoons ground black pepper
  • Wood for smoke

Brine


Instructions

  1. Brine Turkey: Bring 4 cups water to a boil in a pot. In the same pot, add 1/4 cup kosher salt and 1/4 cup sugar to the boiling water. Stir until completely dissolved. Remove the pot from heat and let the brine cool slightly. Add 4 cups ice to the pot, stirring until the ice is mostly melted, and the brine reaches room temperature. Place wings in a large bowl, container, or resealable plastic bag. Pour the brine over turkey, ensuring they are fully submerged. If using a bag, remove excess air before sealing. Cover and refrigerate for at least 4 hours, or overnight for maximum flavor absorption.
  2. Prepare Wings: Rinse the brined turkey wings under cold water and pat them dry with a paper towel. Place them on a large baking sheet or tray.
  3. Season: In a small bowl, mix granulated garlic, granulated onion, and ground black pepper (or use your favorite seasonings). Generously apply the spice rub to the wings, ensuring they are well-coated on all sides.
  4. Smoke Turkey Wings: Preheat your smoker to 275°F (107°C). Place the seasoned turkey wings on the grill grate in a single layer, ensuring they are not overcrowded.
  5. Smoke turkey wings for about 1 to 1 1/2 hours, or until they reach an internal temperature of 165°F. Use a meat thermometer to check for doneness, inserting it into the thickest part of the meat, avoiding the bone.
  6. Rest: Once the wings are cooked, remove them from the smoker and let them rest.

See the “Storage Instructions” and “Ways to Use Smoked Turkey Wings” sections above for more information.


Notes

  1. IMPORTANT: Smoking to an internal temperature of 165°F is only appropriate for using the smoked meat later in a recipe like collard greens with smoked turkey or butter beans, where the meat will cook even further, adding flavor to the dish.
window.trCommon={“minRating”:6,”ajaxurl”:”https:\/\/cookswithsoul.com\/wp-admin\/admin-ajax.php”,”ratingNonce”:””,”postId”:87621}; window.TastyRecipes = window.TastyRecipes || {}; window.TastyRecipes.smoothScroll = { init() { document.addEventListener( ‘click’, ( e ) => { let anchor = e.target; if ( anchor.tagName !== ‘A’ ) { anchor = anchor.closest( ‘a.tasty-recipes-scrollto’ ); } if ( ! anchor || ! anchor.classList.contains( ‘tasty-recipes-scrollto’ ) ) { return; } const elementHref = anchor.getAttribute( ‘href’ ); if ( ! elementHref ) { return; } e.preventDefault(); this.goToSelector( elementHref ); }); }, goToSelector( selector ) { const element = document.querySelector( selector ); if ( ! element ) { return; } element.scrollIntoView( { behavior: ‘smooth’ } ); } }; document.addEventListener( ‘DOMContentLoaded’, () => window.TastyRecipes.smoothScroll.init() ); (function(){ var bothEquals = function( d1, d2, D ) { var ret = 0; if (d1<=D) { ret++; } if (d2<=D) { ret++; } return ret === 2; }; var frac =function frac(x,D,mixed){var n1=Math.floor(x),d1=1;var n2=n1+1,d2=1;if(x!==n1)while(bothEquals(d1,d2,D)){var m=(n1+n2)/(d1+d2);if(x===m){if(d1+d2d2)d2=D+1;else d1=D+1;break}else if(xD){d1=d2;n1=n2}if(!mixed)return[0,n1,d1];var q=Math.floor(n1/d1);return[q,n1-q*d1,d1]};frac.cont=function cont(x,D,mixed){var sgn=x<0?-1:1;var B=x*sgn;var P_2=0,P_1=1,P=0;var Q_2=1,Q_1=0,Q=0;var A=Math.floor(B);while(Q_1<D){A=Math.floor(B);P=A*P_1+P_2;Q=A*Q_1+Q_2;if(B-AD){if(Q_1>D){Q=Q_2;P=P_2}else{Q=Q_1;P=P_1}}if(!mixed)return[0,sgn*P,Q];var q=Math.floor(sgn*P/Q);return[q,sgn*P-q*Q,Q]}; window.tastyRecipesVulgarFractions = JSON.parse(decodeURIComponent(“%7B%22%C2%BC%22%3A%221%2F4%22%2C%22%C2%BD%22%3A%221%2F2%22%2C%22%C2%BE%22%3A%223%2F4%22%2C%22%E2%85%93%22%3A%221%2F3%22%2C%22%E2%85%94%22%3A%222%2F3%22%2C%22%E2%85%95%22%3A%221%2F5%22%2C%22%E2%85%96%22%3A%222%2F5%22%2C%22%E2%85%97%22%3A%223%2F5%22%2C%22%E2%85%98%22%3A%224%2F5%22%2C%22%E2%85%99%22%3A%221%2F6%22%2C%22%E2%85%9A%22%3A%225%2F6%22%2C%22%E2%85%9B%22%3A%221%2F8%22%2C%22%E2%85%9C%22%3A%223%2F8%22%2C%22%E2%85%9D%22%3A%225%2F8%22%2C%22%E2%85%9E%22%3A%227%2F8%22%7D”)); window.tastyRecipesFormatAmount = function(amount, el) { if ( parseFloat( amount ) === parseInt( amount ) ) { return amount; } var roundType = ‘frac’; if (typeof el.dataset.amountShouldRound !== ‘undefined’) { if (‘false’ !== el.dataset.amountShouldRound) { if ( ‘number’ === el.dataset.amountShouldRound ) { roundType = ‘number’; } else if (‘frac’ === el.dataset.amountShouldRound) { roundType = ‘frac’; } else if (‘vulgar’ === el.dataset.amountShouldRound) { roundType = ‘vulgar’; } else { roundType = ‘integer’; } } } if (‘number’ === roundType) { amount = Number.parseFloat(amount).toPrecision(2); } else if (‘integer’ === roundType) { amount = Math.round(amount); } else if (‘frac’ === roundType || ‘vulgar’ === roundType) { var denom = 8; if (typeof el.dataset.unit !== ‘undefined’) { var unit = el.dataset.unit; if ([‘cups’,’cup’,’c’].includes(unit)) { denom = 4; if (0.125 === amount) { denom = 8; } if (“0.1667″ === Number.parseFloat( amount ).toPrecision(4)) { denom = 6; } } if ([‘tablespoons’,’tablespoon’,’tbsp’].includes(unit)) { denom = 2; } if ([‘teaspoons’,’teaspoon’,’tsp’].includes(unit)) { denom = 8; } } var amountArray = frac.cont( amount, denom, true ); var newAmount = ”; if ( amountArray[1] !== 0 ) { newAmount = amountArray[1] + ‘/’ + amountArray[2]; if (‘vulgar’ === roundType) { Object.keys(window.tastyRecipesVulgarFractions).forEach(function(vulgar) { if (newAmount === window.tastyRecipesVulgarFractions[vulgar]) { newAmount = vulgar; } }); } } if ( newAmount ) { newAmount = ‘ ‘ + newAmount; } if ( amountArray[0] ) { newAmount = amountArray[0] + newAmount; } amount = newAmount; } return amount; }; window.tastyRecipesUpdatePrintLink = () => { const printButton = document.querySelector( ‘.tasty-recipes-print-button’ ); if ( ! printButton ) { return; } const printURL = new URL( printButton.href ); const searchParams = new URLSearchParams( printURL.search ); const unitButton = document.querySelector( ‘.tasty-recipes-convert-button-active’ ); const scaleButton = document.querySelector( ‘.tasty-recipes-scale-button-active’ ); let unit = ”; let scale = ”; if ( unitButton ) { unit = unitButton.dataset.unitType; searchParams.delete(‘unit’); searchParams.set( ‘unit’, unit ); } if ( scaleButton ) { scale = scaleButton.dataset.amount; searchParams.set( ‘scale’, scale ); } const paramString = searchParams.toString(); const newURL = ” === paramString ? printURL.href : printURL.origin + printURL.pathname + ‘?’ + paramString; const printLinks = document.querySelectorAll( ‘.tasty-recipes-print-link’ ); printLinks.forEach( ( el ) => { el.href = newURL; }); const printButtons = document.querySelectorAll( ‘.tasty-recipes-print-button’ ); printButtons.forEach( ( el ) => { el.href = newURL; }); }; document.addEventListener( ‘DOMContentLoaded’, () => { if ( ! window.location.href.includes( ‘/print/’ ) ) { return; } const searchParams = new URLSearchParams( window.location.search ); const unit = searchParams.get( ‘unit’ ); const scale = searchParams.get( ‘scale’ ); if ( unit && ( ‘metric’ === unit || ‘usc’ === unit ) ) { document.querySelector( ‘.tasty-recipes-convert-button[data-unit-type=”‘ + unit + ‘”]’ ).click(); } if ( scale && Number(scale) > 0 ) { document.querySelector( ‘.tasty-recipes-scale-button[data-amount=”‘ + Number(scale) + ‘”]’ ).click(); } }); }()); (function(){ var buttonClass = ‘tasty-recipes-convert-button’, buttonActiveClass = ‘tasty-recipes-convert-button-active’, buttons = document.querySelectorAll(‘.tasty-recipes-convert-button’); if ( ! buttons ) { return; } buttons.forEach(function(button){ button.addEventListener(‘click’, function(event){ event.preventDefault(); var recipe = event.target.closest(‘.tasty-recipes’); if ( ! recipe ) { return; } var otherButtons = recipe.querySelectorAll(‘.’ + buttonClass); otherButtons.forEach(function(bt){ bt.classList.remove(buttonActiveClass); }); button.classList.add(buttonActiveClass); var unitType = button.dataset.unitType; var dataset = ‘nf’ + unitType.charAt(0).toUpperCase() + unitType.slice(1); var convertables = recipe.querySelectorAll(‘span[data-nf-original]’); convertables.forEach(function(convertable){ if (typeof convertable.dataset.amountOriginalType === ‘undefined’ && ‘usc’ === convertable.dataset.nfOriginal) { if (-1 !== convertable.innerText.indexOf(‘/’)) { convertable.dataset.amountOriginalType = ‘frac’; } if (-1 !== convertable.innerText.indexOf(‘.’)) { convertable.dataset.amountOriginalType = ‘number’; } Object.keys(window.tastyRecipesVulgarFractions).forEach(function(vulgar) { if (-1 !== convertable.innerText.indexOf(vulgar)) { convertable.dataset.amountOriginalType = ‘vulgar’; } }); } convertable.innerText = convertable.dataset[dataset]; if (typeof convertable.dataset.unit !== ‘undefined’) { convertable.dataset.unit = convertable.dataset[dataset + ‘Unit’]; } if (typeof convertable.dataset.amount !== ‘undefined’) { convertable.dataset.amount = convertable.dataset[dataset]; if (‘metric’ === unitType) { convertable.dataset.amountShouldRound = parseInt(convertable.dataset.amount) >= 10 ? ‘integer’ : ‘number’; } else if (typeof convertable.dataset.amountOriginalType !== ‘undefined’) { convertable.dataset.amountShouldRound = convertable.dataset.amountOriginalType; } else { convertable.dataset.amountShouldRound = false; } convertable.innerText = window.tastyRecipesFormatAmount(convertable.dataset[dataset], convertable); } if (convertable.classList.contains(‘nutrifox-unit’)) { if (‘gram’ === convertable.dataset[dataset]) { convertable.innerText = ‘grams’; } } }); document.querySelectorAll(‘.tasty-recipes-scale-button-active’).forEach(function(scaleButton){ scaleButton.click(); }); window.tastyRecipesUpdatePrintLink(); }); }); }()); (function(){ document.querySelectorAll(‘[data-tr-ingredient-checkbox]’).forEach(function(el) { var input = el.querySelector(‘.tr-ingredient-checkbox-container input[type=”checkbox”]’); if ( ! input ) { return; } if (input.checked) { el.dataset.trIngredientCheckbox = ‘checked’; } el.addEventListener(‘click’, function(event) { if ( ‘A’ === event.target.nodeName || ‘INPUT’ === event.target.nodeName || ‘LABEL’ === event.target.nodeName ) { return; } input.click(); }); input.addEventListener(‘change’, function() { el.dataset.trIngredientCheckbox = input.checked ? ‘checked’ : ”; }); }); }()); window.TastyRecipes = window.TastyRecipes || {}; window.TastyRecipes.cookMode = { wakeLockApi: false, wakeLock: false, cookModeSelector: ‘.tasty-recipes-cook-mode’, init() { if (“wakeLock” in navigator && “request” in navigator.wakeLock) { this.wakeLockApi = navigator.wakeLock; } const cookModes = document.querySelectorAll(this.cookModeSelector); if (cookModes.length > 0) { for (const cookMode of cookModes) { if (this.wakeLockApi) { cookMode.querySelector(‘input[type=”checkbox”]’).addEventListener(“change”, event => { this.checkboxChange(event.target); }, false); } else { cookMode.style.display = “none”; } } } }, checkboxChange(checkbox) { if (checkbox.checked) { this.lock(); } else { this.unlock(); } }, setCheckboxesState(state) { const checkboxes = document.querySelectorAll(this.cookModeSelector + ‘ input[type=”checkbox”]’); for (const checkbox of checkboxes) { checkbox.checked = state; } }, async lock() { try { this.wakeLock = await this.wakeLockApi.request(“screen”); this.wakeLock.addEventListener(“release”, () => { this.wakeLock = false; this.setCheckboxesState(false); }); this.setCheckboxesState(true); } catch (error) { this.setCheckboxesState(false); } }, unlock() { if (this.wakeLock) { this.wakeLock.release(); this.wakeLock = false; } this.setCheckboxesState(false); } }; (function(callback) { if (document.readyState !== “loading”) { callback(); } else { document.addEventListener(“DOMContentLoaded”, callback); } })(() => { window.TastyRecipes.cookMode.init(); }); window.TastyRecipes = window.TastyRecipes || {}; window.TastyRecipes.staticTooltip = { element: null, tooltipElement: null, deleting: false, init( element ) { if ( this.deleting ) { return; } this.element = element; this.buildElements(); }, destroy() { if ( ! this.tooltipElement || this.deleting ) { return; } this.deleting = true; this.tooltipElement.classList.remove( ‘opened’ ); setTimeout( () => { this.tooltipElement.remove(); this.deleting = false; }, 500 ); }, buildElements() { const tooltipElement = document.createElement( ‘div’ ); tooltipElement.classList.add( ‘tasty-recipes-static-tooltip’); tooltipElement.setAttribute( ‘id’, ‘tasty-recipes-tooltip’ ); const currentTooltipElement = document.getElementById( ‘tasty-recipes-tooltip’ ); if ( currentTooltipElement ) { document.body.replaceChild( tooltipElement, currentTooltipElement ); } else { document.body.appendChild( tooltipElement ); } this.tooltipElement = document.getElementById( ‘tasty-recipes-tooltip’ ); }, show() { if ( ! this.tooltipElement ) { return; } const tooltipTop = this.element.getBoundingClientRect().top + window.scrollY – 10 // 10px offset. – this.tooltipElement.getBoundingClientRect().height; const tooltipLeft = this.element.getBoundingClientRect().left – ( this.tooltipElement.getBoundingClientRect().width / 2 ) + ( this.element.getBoundingClientRect().width / 2 ) – 1; const posLeft = Math.max( 10, tooltipLeft ); this.maybeRemoveTail( posLeft !== tooltipLeft ); this.tooltipElement.setAttribute( ‘style’, ‘top:’ + tooltipTop + ‘px;left:’ + posLeft + ‘px;’ ); this.tooltipElement.classList.add( ‘opened’ ); }, maybeRemoveTail( removeTail ) { if ( removeTail ) { this.tooltipElement.classList.add( ‘tr-hide-tail’ ); } else { this.tooltipElement.classList.remove( ‘tr-hide-tail’ ); } }, changeMessage( message ) { if ( ! this.tooltipElement ) { return; } this.tooltipElement.innerHTML = message; } }; window.TastyRecipes.ajax = { sendPostRequest( url, data, success, failure ) { const xhr = new XMLHttpRequest(); xhr.open( ‘POST’, url, true ); xhr.send( this.preparePostData( data ) ); xhr.onreadystatechange = () => { if ( 4 !== xhr.readyState ) { return; } if ( xhr.status === 200 ) { success( JSON.parse( xhr.responseText ) ); return; } failure( xhr ); }; xhr.onerror = () => { failure( xhr ); }; }, preparePostData( data ) { const formData = new FormData(); for ( const key in data ) { formData.append( key, data[key] ); } return formData; }, }; window.TastyRecipes.ratings = { defaultRating: 0, currentRatingPercentage: 100, savingRating: false, init( minRating ) { this.minRating = minRating; this.formWatchRating(); this.closeTooltipWhenClickOutside(); this.addBodyClassBasedOnSelectedRating(); this.backwardCompFormRatingPosition(); }, formWatchRating() { const ratings = document.querySelectorAll(‘.tasty-recipes-no-ratings-buttons [data-rating]’); if ( ratings.length { event.preventDefault(); this.defaultRating = event.target.closest( ‘.checked’ ).dataset.rating; this.setCheckedStar( event.target ); this.maybeSendRating( this.defaultRating, event.target ); this.setRatingInForm( this.defaultRating ); } ); } }, closeTooltipWhenClickOutside() { window.addEventListener( ‘click’, e => { // Bailout (don’t remove the tooltip) when the clicked element is a rating star, or it’s the tooltip itself. if ( e.target.closest( ‘.tasty-recipes-rating’ ) || e.target.classList.contains( ‘tasty-recipes-static-tooltip’ ) ) { return; } window.TastyRecipes.staticTooltip.destroy(); } ); }, setRatingInForm( rating ) { const ratingInput = document.querySelector( ‘#respond .tasty-recipes-rating[value=”‘ + rating + ‘”]’ ); if ( ! ratingInput ) { return; } ratingInput.click(); }, addBodyClassBasedOnSelectedRating() { const ratingInputs = document.querySelectorAll( ‘input.tasty-recipes-rating’ ); if ( ! ratingInputs ) { return; } for ( const ratingInput of ratingInputs ) { ratingInput.addEventListener( ‘click’, currentEvent => { const selectedRating = currentEvent.target.getAttribute( ‘value’ ); this.handleBodyClassByRating( selectedRating ); this.toggleCommentTextareaRequired( selectedRating ); } ); } }, handleBodyClassByRating( rating ) { if ( rating < this.minRating ) { document.body.classList.remove( 'tasty-recipes-selected-minimum-rating' ); return; } document.body.classList.add( 'tasty-recipes-selected-minimum-rating' ); }, toggleCommentTextareaRequired( rating ) { const commentTextarea = document.getElementById( 'comment' ); if ( ! commentTextarea ) { return; } if ( rating { window.TastyRecipes.staticTooltip.changeMessage( response.data.message ); window.TastyRecipes.staticTooltip.show(); this.updateAverageText( response.data, recipeCardElement ); this.maybeFillCommentForm( response.data ); // Hide the tooltip after 5 seconds. setTimeout( () => { this.maybeResetTooltip( recipeCardElement, response.data, rating ); }, 5000 ); }, () => { this.resetTooltip( recipeCardElement ); } ); }, updateAverageText( data, recipeCardElement ) { if ( ! data.average ) { return; } this.setRatingPercent( data ); if ( ! data.count ) { return; } const quickLink = document.querySelector( ‘.tasty-recipes-rating-link’ ); if ( quickLink ) { this.setTextInContainer( quickLink, data ); this.setPartialStar( quickLink ); } const cardStars = recipeCardElement.querySelector( ‘.tasty-recipes-ratings-buttons’ ); cardStars.dataset.trDefaultRating = data.average; this.setTextInContainer( recipeCardElement.querySelector( ‘.tasty-recipes-rating’ ), data ); }, setTextInContainer( container, data ) { if ( ! container ) { return; } if ( data.label ) { const ratingLabelElement = container.querySelector( ‘.rating-label’ ); if ( ratingLabelElement ) { ratingLabelElement.innerHTML = data.label; } return; } const averageElement = container.querySelector( ‘.average’ ); if ( averageElement ) { averageElement.textContent = data.average; } const countElement = container.querySelector( ‘.count’ ); if ( countElement ) { countElement.textContent = data.count; } }, setPartialStar( container ) { const highestStar = container.querySelector( ‘[data-rating=”‘ + Math.ceil( this.defaultRating ) + ‘”]’ ); if ( highestStar ) { highestStar.dataset.trClip = this.currentRatingPercentage; } }, setRatingPercent( data ) { this.defaultRating = data.average.toFixed( 1 ); const parts = data.average.toFixed( 2 ).toString().split( ‘.’ ); this.currentRatingPercentage = parts[1] ? parts[1] : 100; if ( this.currentRatingPercentage === ’00’ ) { this.currentRatingPercentage = 100; } }, setCheckedStar( target ) { const cardRatingContainer = target.closest( ‘.tasty-recipes-ratings-buttons’ ); const selectedRatingElement = cardRatingContainer.querySelector( ‘[data-tr-checked]’ ); if ( selectedRatingElement ) { delete selectedRatingElement.dataset.trChecked; } const thisStar = target.closest( ‘.tasty-recipes-rating’ ); thisStar.dataset.trChecked = 1; thisStar.querySelector( ‘[data-tr-clip]’ ).dataset.trClip = 100; }, maybeFillCommentForm( data ) { if ( ! data.comment || ! data.comment.content ) { return; } const commentForm = document.querySelector( ‘#commentform’ ); if ( ! commentForm ) { return; } const commentBox = commentForm.querySelector( ‘[name=comment]’ ); if ( ! commentBox || commentBox.value ) { return; } // Add comment details for editing. commentBox.innerHTML = data.comment.content; if ( data.comment.name ) { commentForm.querySelector( ‘[name=author]’ ).value = data.comment.name; commentForm.querySelector( ‘[name=email]’ ).value = data.comment.email; } }, maybeResetTooltip( recipeCardElement, data, rating ) { if ( this.savingRating === rating ) { this.resetTooltip( recipeCardElement, data ); } }, resetTooltip( recipeCardElement, data ) { window.TastyRecipes.staticTooltip.destroy(); this.savingRating = false; // Reset the default rating. const cardRatingContainer = recipeCardElement.querySelector( ‘.tasty-recipes-ratings-buttons’ ); if ( cardRatingContainer ) { this.defaultRating = ( data && data.average ) ? data.average.toFixed(1) : cardRatingContainer.dataset.trDefaultRating; cardRatingContainer.dataset.trDefaultRating = this.defaultRating; this.resetSelectedStar( cardRatingContainer, data ); } }, resetSelectedStar( cardRatingContainer ) { const selectedRatingElement = cardRatingContainer.querySelector( ‘[data-rating=”‘ + Math.ceil( this.defaultRating ) + ‘”]’ ); if ( selectedRatingElement ) { selectedRatingElement.querySelector( ‘[data-tr-clip]’ ).dataset.trClip = this.currentRatingPercentage; selectedRatingElement.parentNode.dataset.trChecked = 1; } const previousSelectedElement= cardRatingContainer.querySelector( ‘[data-tr-checked]’ ); if ( previousSelectedElement ) { const currentSelectedRating = previousSelectedElement.querySelector(‘[data-rating]’); if ( currentSelectedRating !== selectedRatingElement ) { delete previousSelectedElement.dataset.trChecked; } } }, backwardCompFormRatingPosition() { const ratingsButtons = document.querySelector( ‘#respond .tasty-recipes-ratings-buttons, #tasty-recipes-comment-rating .tasty-recipes-ratings-buttons’ ); if ( ! ratingsButtons ) { return; } const ratingsButtonsStyles = window.getComputedStyle(ratingsButtons); if ( ! ratingsButtonsStyles.display.includes( ‘flex’ ) ) { ratingsButtons.style.direction = ‘rtl’; } if ( typeof tastyRecipesRating !== ‘undefined’ ) { // Select the rating that was previously selected in admin. ratingsButtons.querySelector( ‘.tasty-recipes-rating[value=”‘ + tastyRecipesRating + ‘”]’ ).checked = true; } const ratingSpans = ratingsButtons.querySelectorAll( ‘.tasty-recipes-rating’ ); for (const ratingSpan of ratingSpans) { ratingSpan.addEventListener( ‘click’, event => { if ( ratingSpan === event.target ) { return; } ratingSpan.previousElementSibling.click(); } ); } } }; (function(callback) { if (document.readyState !== “loading”) { callback(); } else { window.addEventListener( ‘load’, callback ); } })(() => { window.TastyRecipes.ratings.init( window.trCommon ? window.trCommon.minRating : 4 ); });

The post Smoked Turkey Wings Recipe appeared first on Cooks with Soul.

Leave a Reply

Your email address will not be published.