If you’re looking for a quick and delicious way to enjoy bagels without the fuss, you’ve come to the right place! These High-Protein Greek Yogurt Bagels (Easy and Healthy) have become a favorite in my kitchen. They are so simple to make that you might want to whip them up for breakfast on busy mornings or even serve them at family gatherings. The best part? You don’t need any yeast or long rising times, making this recipe perfect for anyone who loves fresh bagels but doesn’t have hours to spare.

What I adore most about these bagels is their chewy texture and golden crust, all while being packed with protein from Greek yogurt. Whether you enjoy them plain, toasted, or topped with your favorite spreads, they are sure to please everyone in the family!


Why You’ll Love This Recipe
- Quick and easy preparation: These bagels come together in just 10 minutes of prep time, perfect for busy mornings.
- High in protein: With Greek yogurt as a key ingredient, these bagels help keep you full longer and are great for muscle recovery.
- Customizable toppings: Get creative! Add everything bagel seasoning or cinnamon sugar for a sweet twist.
- Meal prep friendly: Make a batch ahead of time, store them in the fridge or freezer, and enjoy throughout the week.
- Kid-friendly: These bagels are not only fun to eat but also simple enough for kids to help make!
Ingredients You’ll Need
Making these high-protein Greek yogurt bagels is as easy as gathering a few wholesome ingredients from your pantry. Here’s what you’ll need:
For the Bagels
- 1 ½ cups self-rising flour (or 1 ½ cups all-purpose flour + 1 ½ teaspoons baking powder + ½ teaspoon salt)
- 1 cup Greek yogurt (full-fat or non-fat)
- 1 egg (for egg wash)
- Optional: 1 scoop protein powder (for extra protein)
For Toppings (Optional)
- Everything bagel seasoning (sesame seeds, poppy seeds, cinnamon sugar)
Variations
One of the best things about this recipe is its flexibility! Feel free to customize your bagels based on what you have at home or your taste preferences.
- Add herbs: Mix in dried herbs like rosemary or garlic powder into the dough for an aromatic touch.
- Try different flavors: Use flavored Greek yogurt instead of plain for added taste—think vanilla or honey!
- Make mini-bagels: Shape smaller rounds for bite-sized snacks that are perfect for kids’ lunches.
- Switch up the toppings: Experiment with savory toppings like cheese or sweet options like chocolate chips!
How to Make High-Protein Greek Yogurt Bagels (Easy and Healthy)
Step 1: Preheat Your Oven
Preheat your oven to 375°F (190°C). This step is crucial because it ensures your bagels bake evenly and develop that lovely golden crust we all love.
Step 2: Prepare the Dough
In a mixing bowl, combine your self-rising flour with Greek yogurt. If you’re using all-purpose flour, make sure to add the baking powder and salt too. Mix until a dough forms. It should be slightly sticky but manageable. Kneading it briefly will help bring everything together nicely!
Step 3: Shape Your Bagels
Once your dough is ready, divide it into four equal pieces. Roll each piece into a ball and then poke a hole through the center with your finger. Gently stretch the hole to form a bagel shape. Don’t worry if they aren’t perfectly round; homemade charm is part of their appeal!
Step 4: Apply Egg Wash
Beat one egg in a small bowl and brush it over each bagel using a pastry brush. This step gives them a beautiful shine and helps any toppings stick.
Step 5: Bake
Place your shaped bagels on a lined baking sheet and bake in your preheated oven for about 20 minutes or until they turn golden brown. The aroma wafting through your kitchen will be absolutely irresistible!
Step 6: Enjoy!
Let your bagels cool slightly before digging in. They are delightful fresh out of the oven but can also be toasted later for an extra crispy bite! Enjoy with cream cheese, avocado, or whatever toppings you love best.
These High-Protein Greek Yogurt Bagels (Easy and Healthy) are not just food; they’re an experience waiting to happen! I can’t wait for you to try them!
Pro Tips for Making High-Protein Greek Yogurt Bagels (Easy and Healthy)
Making these delightful bagels is a breeze, but a few pro tips can help you achieve the perfect texture and flavor!
-
Use self-rising flour: This is key for achieving that classic bagel texture without the need for yeast. If you don’t have self-rising flour, combining all-purpose flour with baking powder and salt works just as well!
-
Don’t overmix the dough: Gently mix until combined to keep your bagels light and airy. Overmixing can lead to tough bagels, which is not what we want!
-
Experiment with protein powder: Adding a scoop of protein powder not only boosts nutrition but also enhances the chewy texture. Just be mindful of the flavor—vanilla or unflavored works best.
-
Shape them properly: Don’t skip the shaping step! Rolling the dough into a ball and creating a hole in the center will give your bagels their signature look and ensure even cooking.
-
Brush with egg wash: For a beautiful golden crust, brush each bagel with an egg wash before baking. It adds a nice sheen and helps toppings stick better.
How to Serve High-Protein Greek Yogurt Bagels (Easy and Healthy)
These high-protein Greek yogurt bagels are incredibly versatile, making them perfect for various occasions. Whether you’re enjoying them for breakfast, brunch, or as a snack, there are endless ways to present this delicious dish!
Garnishes
- Fresh herbs: Sprinkle some chopped chives or parsley on top after baking for a fresh burst of flavor.
- Cream cheese alternatives: Spread your favorite dairy-free cream cheese or hummus on top to add creaminess and enhance flavors.
- Avocado slices: Top with ripe avocado slices for added creaminess and healthy fats—plus, they make for a beautiful presentation!
Side Dishes
- Fresh fruit salad: A colorful bowl of mixed fruits adds sweetness and freshness, balancing out the savory flavors of the bagels.
- Scrambled eggs: Lightly seasoned scrambled eggs make for a protein-packed side that complements the bagels perfectly.
- Greek yogurt parfait: Layer Greek yogurt with granola and berries for a nutritious side that echoes the ingredients in your bagels while adding some crunch.
- Vegetable sticks: Crisp carrot or cucumber sticks offer a refreshing crunch and enhance your meal’s nutritional value—perfect for dipping into spreads!
Enjoy your homemade high-protein Greek yogurt bagels any way you like! With these serving suggestions, you’ll impress family and friends while nourishing your body with wholesome ingredients. Happy munching!
Make Ahead and Storage
These High-Protein Greek Yogurt Bagels are perfect for meal prep! You can whip up a batch in no time, making them an ideal choice for busy mornings or quick snacks.
Storing Leftovers
- Place the cooled bagels in an airtight container at room temperature for up to 2 days.
- For longer storage, refrigerate them, where they will last about a week.
Freezing
- Allow the bagels to cool completely before freezing.
- Wrap each bagel tightly in plastic wrap or aluminum foil, then place them in a freezer-safe bag.
- They can be frozen for up to 3 months. Just label the bag with the date!
Reheating
- To reheat from frozen, preheat your oven to 350°F (175°C).
- Remove the plastic wrap and place the bagels on a baking sheet. Bake for about 10-15 minutes until warmed through.
- Alternatively, you can microwave them for about 30 seconds to 1 minute, checking frequently to avoid overheating.
FAQs
Here are some common questions you might have about these delicious bagels!
Can I make High-Protein Greek Yogurt Bagels without protein powder?
Absolutely! The protein powder is optional. You can still enjoy a tasty and nutritious bagel using just Greek yogurt and self-rising flour.
How do I customize my High-Protein Greek Yogurt Bagels?
Feel free to add your favorite seasonings or toppings! Everything bagel seasoning, sesame seeds, or even cinnamon sugar work beautifully to enhance flavor.
How long do High-Protein Greek Yogurt Bagels last?
When stored correctly, these bagels will last up to 2 days at room temperature or up to a week in the refrigerator.
Can I use regular yogurt instead of Greek yogurt?
While Greek yogurt provides more protein and a thicker texture, you can substitute regular yogurt if that’s what you have on hand. Just keep in mind that it may alter the texture slightly.
Are High-Protein Greek Yogurt Bagels suitable for meal prep?
Yes! These bagels are fantastic for meal prep. You can make a batch ahead of time and store or freeze them for quick breakfasts or snacks throughout the week.
Final Thoughts
I hope you enjoy making these delightful High-Protein Greek Yogurt Bagels as much as I do! They’re not only simple to prepare but also packed with nutrition. Whether you top them with cream cheese, avocado, or any spread of your choice, they’re sure to become a favorite in your kitchen. Happy baking!
High-Protein Greek Yogurt Bagels (Easy and Healthy)
-
Prep Time:
10 minutes -
Cook Time:
20 minutes -
Total Time:
30 minutes -
Yield:
Makes 4 servings 1x -
Category:
Breakfast -
Method:
Baking -
Cuisine:
American
Description
Elevate your breakfast game with these High-Protein Greek Yogurt Bagels! Perfect for busy mornings or family gatherings, these bagels are quick to prepare and require no yeast or long rising times. Made with just a few wholesome ingredients, they boast a delightful chewy texture and a golden crust. With Greek yogurt as the star ingredient, they provide a protein-packed start to your day that keeps you satisfied longer. Customize them with your favorite toppings for a delicious twist. Whether enjoyed plain, toasted, or dressed up with spreads, these bagels are sure to become a staple in your kitchen!
Ingredients
Scale
- 1 ½ cups self-rising flour
- 1 cup Greek yogurt (full-fat or non-fat)
- 1 egg (for egg wash)
- Optional: 1 scoop protein powder (for extra protein)
Instructions
- 1. Preheat your oven to 375°F (190°C).
- 2. In a mixing bowl, combine self-rising flour and Greek yogurt (and baking powder/salt if using all-purpose flour). Mix until a slightly sticky dough forms.
- 3. Divide the dough into four pieces, roll into balls, and poke holes in the center to shape into bagels.
- 4. Brush each bagel with beaten egg for shine and toppings adherence.
- 5. Place on a lined baking sheet and bake for about 20 minutes until golden brown.
- 6. Let cool slightly before enjoying fresh out of the oven or toasted.
Nutrition
- Serving Size: 1 bagel (70g)
- Calories: 150
- Sugar: 2g
- Sodium: 200mg
- Fat: 2g
- Saturated Fat: 0.5g
- Unsaturated Fat: 1.5g
- Trans Fat: 0g
- Carbohydrates: 27g
- Fiber: 1g
- Protein: 10g
- Cholesterol: 35mg
window.trCommon={“minRating”:6,”ajaxurl”:”https:\/\/www.easycookinspo.com\/wp-admin\/admin-ajax.php”,”ratingNonce”:”d6999d9e8c”,”postId”:1072};
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-scale-button’,
buttonActiveClass = ‘tasty-recipes-scale-button-active’,
buttons = document.querySelectorAll(‘.tasty-recipes-scale-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 scalables = recipe.querySelectorAll(‘span[data-amount]’);
var buttonAmount = parseFloat( button.dataset.amount );
scalables.forEach(function(scalable){
if (typeof scalable.dataset.amountOriginalType === ‘undefined’
&& typeof scalable.dataset.nfOriginal === ‘undefined’) {
if (-1 !== scalable.innerText.indexOf(‘/’)) {
scalable.dataset.amountOriginalType = ‘frac’;
}
if (-1 !== scalable.innerText.indexOf(‘.’)) {
scalable.dataset.amountOriginalType = ‘number’;
}
Object.keys(window.tastyRecipesVulgarFractions).forEach(function(vulgar) {
if (-1 !== scalable.innerText.indexOf(vulgar)) {
scalable.dataset.amountOriginalType = ‘vulgar’;
}
});
if (typeof scalable.dataset.amountOriginalType !== ‘undefined’) {
scalable.dataset.amountShouldRound = scalable.dataset.amountOriginalType;
}
}
var amount = parseFloat( scalable.dataset.amount ) * buttonAmount;
amount = window.tastyRecipesFormatAmount(amount, scalable);
if ( typeof scalable.dataset.unit !== ‘undefined’ ) {
if ( ! scalable.classList.contains(‘nutrifox-quantity’) ) {
if ( ! scalable.classList.contains(‘nutrifox-second-quantity’) ) {
amount += ‘ ‘ + scalable.dataset.unit;
}
}
}
scalable.innerText = amount;
});
var nonNumerics = recipe.querySelectorAll(‘[data-has-non-numeric-amount]’);
nonNumerics.forEach(function(nonNumeric){
var indicator = nonNumeric.querySelector(‘span[data-non-numeric-label]’);
if ( indicator ) {
nonNumeric.removeChild(indicator);
}
if ( 1 !== buttonAmount ) {
indicator = document.createElement(‘span’);
indicator.setAttribute(‘data-non-numeric-label’, true);
var text = document.createTextNode(‘ (x’ + buttonAmount + ‘)’);
indicator.appendChild(text);
nonNumeric.appendChild(indicator);
}
});
window.tastyRecipesUpdatePrintLink();
});
});
}());
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 );
});



Leave a Comment