No edit summary |
(Automatically adding template at the end of the page.) |
||
(3 intermediate revisions by 2 users not shown) | |||
Line 1: | Line 1: | ||
When you create a model, the deletion of objects is seldom at the top of your mind. Sooner or later, though, users are going to want to remove objects from the system executing your model. | When you create a model, the deletion of objects is seldom at the top of your mind. Sooner or later, though, users are going to want to remove objects from the system executing your model. | ||
The main problem with deletion is the question of what ''business rules'' the deletion should adhere to. The technical rules the deletion adheres to are covered by aggregation and the | The main problem with deletion is the question of what ''business rules'' the deletion should adhere to. The technical rules the deletion adheres to are covered by aggregation and the delete action described [[Training:Composite and Aggregate and what they imply|earlier here.]] | ||
We have also added the IBusinessDeleteService that works like this | We have also added the IBusinessDeleteService that works like this. On every association end, you can set one of four values: NotDecided, MustBeEmpty, NeedNotBeEmptyButWarn, and NeedNotBeEmptyNoWarning. The default value is NotDecided. | ||
Now, what you should do with this meta information is up to you. You are free to implement your own flavor of the IBusinessDeleteService or you can just implement the IBusinessDeleteService.OnInformTheUser event on the standard implementation. | Now, what you should do with this meta information is up to you. You are free to implement your own flavor of the IBusinessDeleteService, or you can just implement the IBusinessDeleteService.OnInformTheUser event on the standard implementation. | ||
WECPOF implements this event and shows a dialog to the user. | WECPOF implements this event and shows a dialog to the user. | ||
Line 24: | Line 24: | ||
== Delete Constraints == | == Delete Constraints == | ||
Furthermore, you may have explicit business rules that control if it is ok to delete an object or not – you can now handle these as normal class constraints. Constraints have been extended with an attribute IsDeleteConstraint. If this is set, the default implementation of the IBusinessDeleteService will call the OnInformUser event with the message constraint as a parameter. WECPOF uses this to show a dialog to the user and stop the delete until the constraint | Furthermore, you may have explicit business rules that control if it is ok to delete an object or not – you can now handle these as normal class constraints. Constraints have been extended with an attribute IsDeleteConstraint. If this is set, the default implementation of the IBusinessDeleteService will call the OnInformUser event with the message constraint as a parameter. WECPOF uses this to show a dialog to the user and stop the delete until the constraint break is fixed. | ||
This new service helps you feel in control and good about the deletion. It will not automatically solve all your delete issues – but we believe that it will enable you to | This new service helps you feel in control and good about the deletion. It will not automatically solve all your delete issues – but we believe that it will enable you to solve them all easily as needed - Agile, so to speak. | ||
[[Category:UML]] | [[Category:UML]] | ||
{{Edited|July|12|2024}} |
Latest revision as of 15:27, 10 February 2024
When you create a model, the deletion of objects is seldom at the top of your mind. Sooner or later, though, users are going to want to remove objects from the system executing your model.
The main problem with deletion is the question of what business rules the deletion should adhere to. The technical rules the deletion adheres to are covered by aggregation and the delete action described earlier here.
We have also added the IBusinessDeleteService that works like this. On every association end, you can set one of four values: NotDecided, MustBeEmpty, NeedNotBeEmptyButWarn, and NeedNotBeEmptyNoWarning. The default value is NotDecided.
Now, what you should do with this meta information is up to you. You are free to implement your own flavor of the IBusinessDeleteService, or you can just implement the IBusinessDeleteService.OnInformTheUser event on the standard implementation.
WECPOF implements this event and shows a dialog to the user.
When you have the BusinessDeleteRule set to NeedNotBeEmptyButWarn, you will get messages like these:
If you have BusinessDeleteRule set to NotDecided, you get a message like this:
If you have the BusinessDeleteRule set to MustBeEmpty, you get this:
Delete Constraints
Furthermore, you may have explicit business rules that control if it is ok to delete an object or not – you can now handle these as normal class constraints. Constraints have been extended with an attribute IsDeleteConstraint. If this is set, the default implementation of the IBusinessDeleteService will call the OnInformUser event with the message constraint as a parameter. WECPOF uses this to show a dialog to the user and stop the delete until the constraint break is fixed.
This new service helps you feel in control and good about the deletion. It will not automatically solve all your delete issues – but we believe that it will enable you to solve them all easily as needed - Agile, so to speak.