Pellet Grill Turkey Breast (Smoked Turkey Breasts)

Home » Pellet Grill Turkey Breast (Smoked Turkey Breasts)
Pellet Grill Turkey Breast (Smoked Turkey Breasts)

Instead of smoking the whole bird, this pellet grill turkey breast recipe offers a delicious meal for a small family or party of one. It’s a perfect alternative to a traditional Thanksgiving turkey and a delicious dish when you’re craving smoked white meat.

Hey family! If you’re looking for a pellet grill turkey recipe that’s both simple and impressive, you’re in the right place. These smoked turkey breasts are just that—easy to make but full of flavor, making it perfect for sharing with family and friends. Plus, it pairs effortlessly with just about any side dish you can think of, making it a versatile choice for any meal or occasion.

What’s great about this recipe is that it’s ideal for those of us who might not need or want a massive Thanksgiving turkey for the holidays. Whether you’re cooking for a small family, just a couple of people, or if you’re not a huge fan of the traditional big turkey, this recipe has you covered.

As a prior military family, we’ve spent our fair share of holidays on our own, so I understand the need to keep things manageable and avoid piles of leftovers. This smoked turkey breast offers all the deliciousness of Thanksgiving without the stress of dealing with a gigantic bird.

The best part? This turkey is juicy and flavorful, thanks to the brining and smoking process—it’s never dry. You can enjoy this any time of year, and it’s a fantastic alternative to the usual roast turkey. Give it a try, and I bet you’ll love it as much as we do! Feel free to share your own take on this recipe or any tips you might have.

What you’ll love about this recipe:


  • DELICIOUS SMOKY FLAVOR – The pellet grill turkey breast gets amazing yet subtle smokiness from the wood that you can taste in every bite.
  • JUICY TURKEY BREASTS – The brining and smoking process ensures the turkey stays moist and tender.

Ingredients

  • Turkey Breast (Bone-In, Skin On): A bone-in turkey breast ensures maximum flavor and moisture during smoking. For a quicker cooking time or easier carving, you can use a boneless turkey breast, though it may be slightly less juicy.
  • Granulated Garlic: Offers an earthy, garlicky flavor. As a substitute, you can use garlic powder, which provides a similar taste but is finer in texture.
  • Granulated Onion: Complements the garlic and pepper. Onion powder can be used as a substitute, but it has a finer consistency.
  • Ground Black Pepper: Ground black pepper adds a spicy kick to the dry rub. Freshly cracked black pepper can be used as an alternative for a more intense, slightly coarser flavor.
  • Wood for Smoke: The best wood is whatever you prefer. Hickory, apple, or cherry wood pellets impart distinct tastes. For a milder smoke, go with pecan. 

Turkey Brine Ingredients (Recommended)

Recipe Variations and Substitutions

  • Seasonings: Try a poultry seasoning or other smoked turkey rub. Fresh or dried herbs like thyme, rosemary, or sage can also added to the seasoning mix.
  • Boneless Turkey Breast: You can use a boneless breast instead of a bone-in breast. Just keep a close eye on the temp to avoid overcooking.
  • Brine: During the holiday season, add aromatics like bay leaves, peppercorns, and fresh herbs (e.g., rosemary, thyme, or sage) to your brine mixture. Lemon and/or orange zest and juice can give it a citrusy twist.
  • Injection: Prepare our Creole butter injection that we use when smoking an entire bird. Using an injection will give it extra moisture and flavor.

Special Equipment and Tools

  • Smoker: We used a pellet smoker (i.e. a Traeger pellet grill, electric smoker), but any type of smoker or even a charcoal grill can be used. 
  • Large Pot: We use a stock pot to make the brine.
  • Large Bowl, Container, or Resealable Plastic Bag: For brining the turkey.
  • Meat Thermometer: To check the internal temperature during smoking.
  • Sharp Knife: For carving the smoked turkey breasts.

How to Brine Turkey Breast

This recipe uses a basic salt, sugar, and water brine that will infuse your pellet grill turkey breast with a nice balance of flavor while helping to retain moisture during cooking. 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 breast 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 Breasts Recipe

  • First, give your turkey breast a good rinse and pat it dry. Put it on a baking sheet. Mix up some granulated garlic, granulated onion, and black pepper, then rub it all over, making sure to get under the skin if you’ve got skin-on.
  • Preheat your smoker to 275°F and use some apple, cherry, or hickory wood for a nice, sweet smoke flavor. Place the turkey breast on the grill grates, skin side up, and smoke it for about 3 to 4 hours until it hits 160°F internally.
  • Once it’s done, cover it loosely with foil and let it rest for 10-15 minutes—this lets the temperature rise a bit more to 165°F and keeps it juicy. After resting, slice it against the grain and serve with your favorite sides.

A Note About Internal Temp

Carryover cooking refers to the phenomenon where food continues to cook after being removed from the heat source. This happens because the outer layers of the meat are hotter than the center, and as the heat redistributes, the temperature of the meat rises.

  • Turkey breast is typically considered safe to eat when it reaches an internal temperature of 165°F (74°C). However, cooking it to exactly 165°F can sometimes result in dry meat, especially with lean cuts like the breast.
  • To prevent dryness, turkey breast can be cooked to an internal temp of around 160°F (71°C) before removing it from the heat. At this point, the breast is still slightly under the recommended safe temperature, but carryover cooking will bring it up to the proper level.
  • Use a meat thermometer to check the temperature, inserting it into the thickest part of the turkey breast without touching the bone.
  • After removing the breast from the oven or smoker, cover it loosely with aluminum foil and let it rest for about 10-15 minutes. During this rest period, the internal temperature will rise by 5-10°F, reaching the safe temperature of 165°F without overcooking the meat.
  • Resting is crucial not only for reaching the desired internal temperature but also for allowing the juices to redistribute within the meat. This results in a moister, more flavorful turkey breast.

Recipe Tips & Tricks

  • Season Under the Skin: When seasoning a skin-on turkey breast, lift the skin and rub the seasoning mixture directly onto the meat. This allows the flavors to penetrate more deeply and enhances the overall taste.
  • Maintain Steady Temperature: Keep a close eye on your smoker’s temperature. Fluctuations can affect cooking time and the flavor of the turkey. Use a reliable thermometer to monitor the smoker’s temperature.
  • Rest Longer for Larger Breasts: For larger turkey breasts or if you’re smoking multiple pieces, allow a longer resting time of 20-30 minutes to ensure the juices redistribute properly.

Using a Charcoal Grill

If you don’t have a smoker, you can use a charcoal grill set up for indirect cooking. Arrange the coals on one side of the grill. Add wood chunks to the coals for smoke. Place turkey breast on the grill grate over the cool side (indirect heat), cover, and maintain a temperature of around 275°F. Smoke until the breast reaches an internal temperature of 165°F. Cover loosely with aluminum foil and let it rest for about 10-15 minutes. 

What to Serve with Pellet Grill Turkey Breast

For a holiday dinner, we recommend serving smoked turkey breasts with: 

Other side dishes that pair well with smoked turkey include: 

What to Do with Leftover Turkey Breast Meat

Got leftover turkey breast? There are plenty of tasty ways to use it up! Make a turkey club sandwich or a fresh turkey wrap. You can also add it to salads for something light. Use leftover turkey in soups, stews, or chili. Another favorite is turkey pot pie.

Summary

If you’re in the mood for something that’s perfect for both special occasions and casual dinners, give these smoked turkey breasts a try! It’s simple to make, packed with flavor, and just right for small families. Let us know how it turns out and feel free to pass along the recipe!

Print

Pellet Grill Turkey Breast (Smoked Turkey Breasts)

5 Stars 4 Stars 3 Stars 2 Stars 1 Star No reviews

  • Author: Krysten and Marrekus Wilkes
  • Prep Time: 30 minutes
  • Brine (Recommended): 4 hours
  • Cook Time: 3 to 4 hours
  • Total Time: 4 hours
  • Yield: 2-3 servings
  • Category: dinner
  • Method: smoking
  • Cuisine: american, southern

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

  • 1 whole turkey breast (bone-in, skin on)
  • 2 teaspoons granulated garlic
  • 2 teaspoons granulated onion
  • 2 teaspoons ground black pepper
  • Wood for smoke

Turkey Brine


Instructions

Turkey Brine

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

Pellet Grill Turkey Breast

  1. Prepare Turkey Breast: Rinse the turkey breast under cold water and pat them dry with paper towels. Place breast on a large baking sheet or tray.
  2. Season with Dry Rub: In a small bowl, combine granulated garlic, granulated onion, and ground black pepper. Generously apply the seasoning mix to the breast, ensuring it is evenly covered on all sides. Since this recipe calls for a skin-on turkey breast, be sure to season under the skin. 
  3. Smoke: Preheat your smoker to 275°F (107°C). Use wood such as apple, cherry, or hickory for a subtle, sweet smoke flavor.
  4. Place turkey breast on the grill grates, skin side up. If your smoker has multiple racks, place on the middle rack for even cooking.
  5. Smoke the turkey breast for about 3 to 4 hours, or until it reaches an internal temperature of 160°F (74°C). Use a meat thermometer to check the temperature, inserting it into the thickest part of the breast without touching the bone.
  6. Cover the turkey breast loosely with aluminum foil and let it rest for about 10-15 minutes. During this rest period, the temperature will rise by 5-10°F, reaching the safe temperature of 165°F without overcooking the meat.
  7. Rest and Serve: Once the turkey breast has reached the desired temperature, remove from the smoker and let it rest for 15-20 minutes. This allows the juices to redistribute, ensuring moist and flavorful meat.
  8. Slice turkey breast against the grain and serve with your favorite sides.


window.trCommon={“minRating”:6,”ajaxurl”:”https:\/\/cookswithsoul.com\/wp-admin\/admin-ajax.php”,”ratingNonce”:””,”postId”:87619};
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 Pellet Grill Turkey Breast (Smoked Turkey Breasts) appeared first on Cooks with Soul.

Leave a Reply

Your email address will not be published.