Decorator Pattern

15 minutes
Share the link to this page
Copied
  Completed
You need to have access to the item to view this lesson.
One-time Fee
$69.99
List Price:  $99.99
You save:  $30
€67.87
List Price:  €96.96
You save:  €29.09
£56.33
List Price:  £80.48
You save:  £24.14
CA$101.11
List Price:  CA$144.46
You save:  CA$43.34
A$112.90
List Price:  A$161.30
You save:  A$48.39
S$95.89
List Price:  S$136.99
You save:  S$41.10
HK$544.41
List Price:  HK$777.77
You save:  HK$233.35
CHF 63.59
List Price:  CHF 90.85
You save:  CHF 27.25
NOK kr795.45
List Price:  NOK kr1,136.41
You save:  NOK kr340.95
DKK kr506.37
List Price:  DKK kr723.41
You save:  DKK kr217.04
NZ$125.48
List Price:  NZ$179.27
You save:  NZ$53.78
د.إ257.07
List Price:  د.إ367.26
You save:  د.إ110.19
৳8,489.45
List Price:  ৳12,128.31
You save:  ৳3,638.85
₹6,003.32
List Price:  ₹8,576.54
You save:  ₹2,573.22
RM314.95
List Price:  RM449.95
You save:  RM135
₦108,169.08
List Price:  ₦154,533.88
You save:  ₦46,364.80
₨19,460.08
List Price:  ₨27,801.31
You save:  ₨8,341.22
฿2,414.58
List Price:  ฿3,449.55
You save:  ฿1,034.97
₺2,476.26
List Price:  ₺3,537.66
You save:  ₺1,061.40
B$432.69
List Price:  B$618.15
You save:  B$185.46
R1,309.65
List Price:  R1,871.01
You save:  R561.36
Лв132.94
List Price:  Лв189.93
You save:  Лв56.98
₩102,666.23
List Price:  ₩146,672.33
You save:  ₩44,006.10
₪255.59
List Price:  ₪365.15
You save:  ₪109.55
₱4,073.94
List Price:  ₱5,820.16
You save:  ₱1,746.22
¥11,002.07
List Price:  ¥15,717.92
You save:  ¥4,715.85
MX$1,443.99
List Price:  MX$2,062.93
You save:  MX$618.94
QR254.73
List Price:  QR363.91
You save:  QR109.18
P971.15
List Price:  P1,387.42
You save:  P416.26
KSh9,031.62
List Price:  KSh12,902.87
You save:  KSh3,871.24
E£3,551.78
List Price:  E£5,074.19
You save:  E£1,522.41
ብር8,922.62
List Price:  ብር12,747.15
You save:  ብር3,824.52
Kz63,830.88
List Price:  Kz91,190.88
You save:  Kz27,360
CLP$70,211.88
List Price:  CLP$100,306.99
You save:  CLP$30,095.10
CN¥512.36
List Price:  CN¥731.98
You save:  CN¥219.61
RD$4,268.13
List Price:  RD$6,097.60
You save:  RD$1,829.46
DA9,503.22
List Price:  DA13,576.62
You save:  DA4,073.39
FJ$162.81
List Price:  FJ$232.59
You save:  FJ$69.78
Q539.11
List Price:  Q770.19
You save:  Q231.08
GY$14,612.09
List Price:  GY$20,875.31
You save:  GY$6,263.22
ISK kr9,750.89
List Price:  ISK kr13,930.45
You save:  ISK kr4,179.55
DH704.78
List Price:  DH1,006.87
You save:  DH302.09
L1,300.73
List Price:  L1,858.26
You save:  L557.53
ден4,174.94
List Price:  ден5,964.46
You save:  ден1,789.51
MOP$559.86
List Price:  MOP$799.84
You save:  MOP$239.97
N$1,311.40
List Price:  N$1,873.51
You save:  N$562.11
C$2,571.06
List Price:  C$3,673.10
You save:  C$1,102.04
रु9,593.53
List Price:  रु13,705.64
You save:  रु4,112.10
S/262.27
List Price:  S/374.69
You save:  S/112.42
K279.90
List Price:  K399.88
You save:  K119.97
SAR262.85
List Price:  SAR375.52
You save:  SAR112.66
ZK1,946.04
List Price:  ZK2,780.17
You save:  ZK834.13
L337.70
List Price:  L482.45
You save:  L144.75
Kč1,708.24
List Price:  Kč2,440.45
You save:  Kč732.21
Ft28,222.76
List Price:  Ft40,319.96
You save:  Ft12,097.20
SEK kr777.78
List Price:  SEK kr1,111.16
You save:  SEK kr333.38
ARS$72,264.67
List Price:  ARS$103,239.67
You save:  ARS$30,975
Bs482.86
List Price:  Bs689.83
You save:  Bs206.97
COP$305,718.10
List Price:  COP$436,758.87
You save:  COP$131,040.76
₡35,617.57
List Price:  ₡50,884.43
You save:  ₡15,266.85
L1,775.85
List Price:  L2,537.04
You save:  L761.19
₲546,995.01
List Price:  ₲781,454.93
You save:  ₲234,459.92
$U3,074.18
List Price:  $U4,391.87
You save:  $U1,317.69
zł289.95
List Price:  zł414.23
You save:  zł124.28
Already have an account? Log In

Transcript

The next design pattern, which we're going to learn right now is a decorator pattern. And this is also a structural design pattern in our category. Now decorator pattern is one of the frequently used patterns, whatever business applications have seen in my career, I'm sure that if I see 10 business application, this is one of the pattern, which is going to be there in out of 10 is going to be there in five. So this is one of the useful pattern for each and every developer because the basic purpose of the design pattern is actually it's going to add some functionality of a code to our existing code dynamically. Now, in our scenario, we are going to take an example of a burger joint with the name Mac Mickey. In Mac Mickey we actually provide a different kind of burgers to our customer.

And this different burgers are going to have varieties of customization options inside that These options are going to be customizable and my customers are going to choose Add or Remove any of the options which are available inside the burger customization. So, this is what the scenario we are going to work in our code sample and we are going to develop some tasty burgers for Mac Micki client, the goal is we are going to create a base burger first and after that we are going to add multiple decorators on that. So we are going to create one basic burger element and then we are going to add different different decorators like cheese, ham, and some other ingredients which are requiring the burger. If you want to understand decorator pattern, then you have to understand the flow of the object creation. Actually, in our case, when we are going to follow this decorator pattern, the flow of this pattern is going to go like this.

That first we are going to create one abstract component. This abstract component is going to be my base component using this app component, we are going to create one concrete component, which is going to be our basic bug. Now we can create multiple concrete component, but in this sample we are going to create only one. After this, once you have your concrete component, you can create one abstract decorator, which is going to be a small part which can associate with your base component. And then you can create multiple concrete decorators. From that, we are going to create multiple concrete decorators from one abstract decorator.

So this is a flow which we are going to follow in the sample. And when we do the core, I want you to remember this flow structure so that we can develop a code base on that. In my Visual Studio, I'm first going to create a new project and I'm giving a name of the project. Mac Mickey. This is a basic class library project. And inside this MAC Mickey when we click OK, we know that we are going to have one C sharp class with the name class one.

Now first, I'm just going to delete this class. And then I'm going to add one more project in the same solution. So I'm doing add new project. And this one is going to be my unit test project with the name Mac Mickey dot paste, I will click OK. And you can see this test project is now I'm coming back to my class library. And in this class library, the first thing is I need to create my abstract base component. So for that, we are going to right click on this project and we're going to add a new C sharp class.

Remember, in this full design patterns, we are not going to have any interface we are all going to have abstract classes. So I'm going to click on OK and this burger component is going to be my public as well as abstract class. And you can see I have a simple logic like this, how abstract class burger component and this worker component is having two abstract properties, name and price. We do not have any values inside this because this is abstract. Let's add a concrete class. So add a new item, this is going to be a class.

And this is going to be my concrete base component. So it's going to be a concrete component, I'm giving a name of the class basic burger. And inside this basic burger, I'm going to make sure this class is going to be public, as well as I'm going to put my abstract class. So we are going to put our burger component in this. I'm going to implement my abstract class into this. And if I do that, you can see I'm getting those two properties overridden inside this.

The core of this class is going to have the values which we are going to get from that. But let's change the code from this one to this. You can see I have two private variables on the top with the name underscore name and underscore price with some default values assigning to that. Then I'm using this private variables into my properties and these properties are actually getting the values from these variables. I will click on Save all. And now I'm going to deal with my burger component, which is abstract class.

And then we have a basic worker, which is our concrete basic burger component, it's time to move on to our decorators. As we know, the flow for the first thing, which we're going to create is going to be an abstract decorator. So we are adding a new C sharp class, and I'm giving a name of this decorator. This one is going to be my abstract decorator. So I'm making sure that this could be public as well as abstract. And inside this we are going to have some base functionality.

But before that, we know that this is a decorator. And in decorator pattern, decorators are going to be applicable on our abstract component. In our case there is this burger component. So we are just putting Collin and I'm adding burger component as a parent class here. The connection between these two abstract class is actually going to show me that this burger component parent class is the base class on this We can apply this abstract decorator. Let's quickly implement this abstract class into this.

Now inside this abstract class, we are going to override our name property. And we're going to have some logic using that like this, you can see that we have a one protected underscore component reference variable. And then we have a name and price. These two properties inside that my abstract decorator is actually going to have a base price zero. And then we have a constructor of that class, which is actually taking one parameter of type component. We are simply injecting the connection of the burger component into this.

And then the name and price property, which we have overridden are actually going to have the name which is going to be my component name plus that name, which is going to come from the protected variable. Same way, the price is going to be the base component price, plus the price Which I'm going to add into this. This code is so simple. Let's up to this point we are done with this abstract decorator, which is based on the burger component. Now it's a time to create more than one. Concrete decorators based on this particular class.

I'm going to right click on my project, I'm going to add a new item. And this new item is going to be class. And let's say that the first concrete component is going to be a wheat bread. So I'm giving a name of this wheat bread, and we will click on Add. This wheat bread class is going to be a public class and you can see this is actually based on that abstract decorator. Inside the constructor, we are going to inject that burger component dependency so that we can associate this with the burger.

And then we are just having the values for the name and price. The name of this particular decorator is read braid and we are giving a price of this which is going to be 20 So if something like this that based on the logic of our abstract decorator, the total price is going to be based on the base price plus this particular decorator price. We'll see that when we are going to use this right now is the time to create some more like this. So we're going to click on Save all and then I'm going to right click on my project and I'm going to add a new item which is going to be a second decorator with the name ham. Now if my customer wants a hamburger, we're going to add a ham in that and the core of the ham is exactly same like that.

We still have a decorator and then the name is ham as well as we have a price of that which is 10. Let's quickly create one more decorator. Maybe the third decorator is going to be cheese. So we are going to add a name cheese and you can see the only thing which we are changing his name as well as the price. So quickly, we have created actually three different decorators from that abstract decorator class. We have We breed and ham and cheese and all three are our decorator parts, we can create some more also for right now we are happy with the three decorator parts.

And we have one base component which is basic logo, and which is based on the abstract class burger component. Let's check this particular structure in our taste project. So we are just going to have a unit test project in which the first we need to add a reference of our class library. So we are adding a reference of Mac Mickey. I'm going to click on OK. And now we are going to add a namespace of that using Mac Mickey. I hope you're familiar with this now because we are doing this thing in all the samples up to this point.

Now inside this taste method, I'm gonna write my basic logic First, we have basic pro side by side, so we can check the test case there. And now the first thing which I'm doing is you can see I have a variant with the name burgo, which is actually an instance of placebo. So I'm actually creating a basic burger first. And when I have this variable, obviously Find that the this one the burger price is should be equal to 20 because this is not having any other decorator into that. So we are just checking an assert that this should be a 20. If this is true this basic cases would pass.

Second, we have a wheat bread burger, which is actually adding a new wheat bread and in that we are passing that particular burger object which we treated on the top. So, when we do this thing, this burger which is having a price 20 is going to have a we read into that, and that's why the total price is going to be 40. If this assert is passing, it means that the combination of the base component with the decorator is done successfully. You can see if I right click on this, and if I do run selected test, this test case is going to pass because it's matching with the price 40. If I change the price to 50, if I build and now if I try to pass this as case this should fail, and you can see this is actually failing And if I check, the reason of that is showing that the expected is 40, but the actual value is 50.

And that's where our combination of the decorator with the base component is done successfully. Now let's check this thing with some more decorators into that. So I'm making sure this is 40 right now and then I'm going to write some more lines of code like this. Now I'm creating first one hamburger, which is having your ham on that we'd read burger. So base price of the burger was 40 Plus we're adding a ham into that so that should be 40 plus 10 is going to be 50 into that because ham price is 10. So we know that so this should be 50 and then we are adding one cheese hamburger exactly below that.

And you can see in this cheese hamburger, I'm adding cheese twice. So it's not that I'm just want one slice of cheese, I want double cheeseburger actually. So we are having two cheese clauses inserted into that and inside that we have passing over hamburger insurance. If we see the cheese price is also 10. But because we're adding this thing twice, the total cost is going to be 50 plus this double cheese 10 plus 10. So it's going to be 70.

If we save all and if I try to run the test once again, this test is going to be passed because we have assigned us right prices. Now right now, we have the 75. And we have a connection of multiple decorators onto our one base component, which is basic logo. So it's 20 plus 40 plus 50, which is ham. And then finally we are at two cheeseburgers into that so that's why it is 70 I hope you understood the total calculation which we have done right now in this and this shows the connections of all the decorators with our base component. Now let's do one thing that you know we are going to add some more code into this and we are going to have some more decorators which Give me some cheese discounts also.

So exactly below the score, I'm going to add some more code, which is actually going to help me to give some discounts on this particular cheeseburger price. So if my customer is going to choose cheeseburger, then we are going to give them a discounted burger in which maybe we are going to add some cheese discount. You can see right now in this code, I am getting some errors because I do not have any cheese discount decorator for me. So let's do one thing. Let's create one decorator. So I'm going to add a new C sharp class once again, and I'm giving a name of the C sharp class cheese discount.

The code is going to be similar but the customer name is going to be cheese discount and I'm just changing the name of this also. With that I'm going to give a price which is going to be not 10 this time because it's a discounted burger we're going to give minus 10 So assume that today is actually a world Cheese Day and today in all the burgers we are going to give cheese free of cost. So we are going to have a unit Test once again. And if I build, it should show me that okay, it's showing the error because it's not public right now let's make this class public. And once it is public, we'll save all will go to this project. And now this did not show me that error.

So this is working, you can see that because we have added cheese twice, now we are adding a cheese discount also twice. And if I add a cheese discount, the actual cost is going to be 70 minus 20. So there should be 50. If I save and if I run the test case, this should pass. So let me run the test case. And you can see it's popping.

Now let's assume that we are giving the discount also and we got a new price. Now I do not want to give a double discount. Because my user is having double cheese. Let's say that the discount is available only for the one cheese. So we are just adding cheese count once while we have added cheese twice. So let's say that in this case when the Chiefs twice and we are given one day Count, the cost should be 70 minus 10.

That should be 60. But let me check whether the fish case is showing the same thing or not. If you see it's failing this time, and it's showing me that X Factor should be 60, not 50. So if I make it 60, and then if I run the test case, this should pass. I hope you guys are getting what we are doing in this particular sample. And the dynamic addition of this decorators into this particular base component.

That's what the magic of the decorator pattern. The key factor is the connection between these two abstract classes, and all the concrete components which we can create. Thank you.

Sign Up

Share

Share with friends, get 20% off
Invite your friends to LearnDesk learning marketplace. For each purchase they make, you get 20% off (upto $10) on your next purchase.