diff --git a/entity/PermissionCalendar_entity/PermissionCalendar_entity.aod b/entity/PermissionCalendar_entity/PermissionCalendar_entity.aod
index ffffa204d1e4a592e2547bb58813e4962091c19a..6fabd72427657a993d50120b1cf8a2eeed217d8b 100644
--- a/entity/PermissionCalendar_entity/PermissionCalendar_entity.aod
+++ b/entity/PermissionCalendar_entity/PermissionCalendar_entity.aod
@@ -173,6 +173,7 @@
     <entityField>
       <name>permissionDealer_rowId</name>
       <title>Permission Dealer</title>
+      <valueProcess>%aditoprj%/entity/PermissionCalendar_entity/entityfields/permissiondealer_rowid/valueProcess.js</valueProcess>
       <displayValueProcess>%aditoprj%/entity/PermissionCalendar_entity/entityfields/permissiondealer_rowid/displayValueProcess.js</displayValueProcess>
     </entityField>
     <entityField>
@@ -202,6 +203,8 @@
       <name>permissionProcurer_User_RowId</name>
       <title>Permission Procurer User</title>
       <consumer>User</consumer>
+      <mandatoryProcess>%aditoprj%/entity/PermissionCalendar_entity/entityfields/permissionprocurer_user_rowid/mandatoryProcess.js</mandatoryProcess>
+      <stateProcess>%aditoprj%/entity/PermissionCalendar_entity/entityfields/permissionprocurer_user_rowid/stateProcess.js</stateProcess>
       <displayValueProcess>%aditoprj%/entity/PermissionCalendar_entity/entityfields/permissionprocurer_user_rowid/displayValueProcess.js</displayValueProcess>
       <onValueChange>%aditoprj%/entity/PermissionCalendar_entity/entityfields/permissionprocurer_user_rowid/onValueChange.js</onValueChange>
     </entityField>
@@ -214,8 +217,27 @@
           <onActionProcess>%aditoprj%/entity/PermissionCalendar_entity/entityfields/addactionsreverse/children/addnewuserpermissionprocureraction/onActionProcess.js</onActionProcess>
           <iconId>VAADIN:USER</iconId>
         </entityActionField>
+        <entityActionField>
+          <name>addNewDepartmentPermissionProcurerAction</name>
+          <title>Grant new Department Permission</title>
+          <onActionProcess>%aditoprj%/entity/PermissionCalendar_entity/entityfields/addactionsreverse/children/addnewdepartmentpermissionprocureraction/onActionProcess.js</onActionProcess>
+          <iconId>VAADIN:GROUP</iconId>
+        </entityActionField>
       </children>
     </entityActionGroup>
+    <entityField>
+      <name>permissionProcurer_Department_RowId</name>
+      <title>Permission Procurer Department</title>
+      <consumer>Departments</consumer>
+      <mandatoryProcess>%aditoprj%/entity/PermissionCalendar_entity/entityfields/permissionprocurer_department_rowid/mandatoryProcess.js</mandatoryProcess>
+      <stateProcess>%aditoprj%/entity/PermissionCalendar_entity/entityfields/permissionprocurer_department_rowid/stateProcess.js</stateProcess>
+      <displayValueProcess>%aditoprj%/entity/PermissionCalendar_entity/entityfields/permissionprocurer_department_rowid/displayValueProcess.js</displayValueProcess>
+      <onValueChange>%aditoprj%/entity/PermissionCalendar_entity/entityfields/permissionprocurer_department_rowid/onValueChange.js</onValueChange>
+    </entityField>
+    <entityParameter>
+      <name>PermissionProcurerType_param</name>
+      <expose v="true" />
+    </entityParameter>
   </entityFields>
   <recordContainers>
     <dbRecordContainer>
diff --git a/entity/PermissionCalendar_entity/entityfields/addactionsreverse/children/addnewdepartmentpermissionprocureraction/onActionProcess.js b/entity/PermissionCalendar_entity/entityfields/addactionsreverse/children/addnewdepartmentpermissionprocureraction/onActionProcess.js
new file mode 100644
index 0000000000000000000000000000000000000000..1d2df49b6706814050016064d6cdcc63a551f945
--- /dev/null
+++ b/entity/PermissionCalendar_entity/entityfields/addactionsreverse/children/addnewdepartmentpermissionprocureraction/onActionProcess.js
@@ -0,0 +1,9 @@
+import("KeywordRegistry_basic");
+import("PermissionCalendar_lib");
+import("system.vars");
+import("system.neon");
+
+var params = {};
+params["PermissionProcurerType_param"] = $KeywordRegistry.permissionCalendarType$department();
+params["PermissionDealer_param"] = vars.get("$param.PermissionDealer_param");
+neon.openContext("PermissionCalendar", null, null, neon.OPERATINGSTATE_NEW, params);
\ No newline at end of file
diff --git a/entity/PermissionCalendar_entity/entityfields/addactionsreverse/children/addnewuserpermissionprocureraction/onActionProcess.js b/entity/PermissionCalendar_entity/entityfields/addactionsreverse/children/addnewuserpermissionprocureraction/onActionProcess.js
index b19d4ef7af1b5282c804a7aa5187e03282710bb7..f2036f9dd03482fbcad1be27e33aa8ea0b39c2ae 100644
--- a/entity/PermissionCalendar_entity/entityfields/addactionsreverse/children/addnewuserpermissionprocureraction/onActionProcess.js
+++ b/entity/PermissionCalendar_entity/entityfields/addactionsreverse/children/addnewuserpermissionprocureraction/onActionProcess.js
@@ -4,6 +4,6 @@ import("system.vars");
 import("system.neon");
 
 var params = {};
-params["PermissionDealerType_param"] = $KeywordRegistry.permissionCalendarType$user();
+params["PermissionProcurerType_param"] = $KeywordRegistry.permissionCalendarType$user();
 params["PermissionDealer_param"] = vars.get("$param.PermissionDealer_param");
-neon.openContext("PermissionCalendar", "PermissionCalendarEditReverse_view", null, neon.OPERATINGSTATE_NEW, params);
\ No newline at end of file
+neon.openContext("PermissionCalendar", null, null, neon.OPERATINGSTATE_NEW, params);
\ No newline at end of file
diff --git a/entity/PermissionCalendar_entity/entityfields/permissiondealer_department_rowid/mandatoryProcess.js b/entity/PermissionCalendar_entity/entityfields/permissiondealer_department_rowid/mandatoryProcess.js
index b0dd49473c7bcc91b7780c8cbf92b2c7543e27a9..ce5b287666060686b801c0c9f3f1784f16a2e9ec 100644
--- a/entity/PermissionCalendar_entity/entityfields/permissiondealer_department_rowid/mandatoryProcess.js
+++ b/entity/PermissionCalendar_entity/entityfields/permissiondealer_department_rowid/mandatoryProcess.js
@@ -3,7 +3,7 @@ import("system.vars");
 import("system.result");
 import("PermissionCalendar_lib");
 
-if(vars.getString("$field.PERMISSIONDEALER_TYPE") == $KeywordRegistry.permissionCalendarType$department())
+if(vars.getString("$field.PERMISSIONDEALER_TYPE") == $KeywordRegistry.permissionCalendarType$department()&& vars.getString("$param.PermissionProcurer_param"))
     result.string(true);
 else
     result.string(false);
\ No newline at end of file
diff --git a/entity/PermissionCalendar_entity/entityfields/permissiondealer_department_rowid/stateProcess.js b/entity/PermissionCalendar_entity/entityfields/permissiondealer_department_rowid/stateProcess.js
index 9d47dab7c47ceadfac3e9b602cd8156ef6232290..3d2ee67a3de6457a6e676e324fc9241f20059b12 100644
--- a/entity/PermissionCalendar_entity/entityfields/permissiondealer_department_rowid/stateProcess.js
+++ b/entity/PermissionCalendar_entity/entityfields/permissiondealer_department_rowid/stateProcess.js
@@ -4,10 +4,10 @@ import("system.result");
 import("PermissionCalendar_lib");
 import("system.neon");
 
-if(vars.getString("$field.PERMISSIONDEALER_TYPE") == $KeywordRegistry.permissionCalendarType$department())
+if(vars.getString("$field.PERMISSIONDEALER_TYPE") == $KeywordRegistry.permissionCalendarType$department()&& vars.getString("$param.PermissionProcurer_param"))
     if(vars.getString("$sys.recordstate") == neon.OPERATINGSTATE_EDIT)
-        result.string("READONLY")
+        result.string(neon.COMPONENTSTATE_READONLY)
     else
-        result.string("EDITABLE");
+        result.string(neon.COMPONENTSTATE_EDITABLE);
 else
-    result.string("INVISIBLE");
\ No newline at end of file
+    result.string(neon.COMPONENTSTATE_INVISIBLE);
\ No newline at end of file
diff --git a/entity/PermissionCalendar_entity/entityfields/permissiondealer_user_rowid/valueProcess.js b/entity/PermissionCalendar_entity/entityfields/permissiondealer_rowid/valueProcess.js
similarity index 100%
rename from entity/PermissionCalendar_entity/entityfields/permissiondealer_user_rowid/valueProcess.js
rename to entity/PermissionCalendar_entity/entityfields/permissiondealer_rowid/valueProcess.js
diff --git a/entity/PermissionCalendar_entity/entityfields/permissiondealer_type/valueProcess.js b/entity/PermissionCalendar_entity/entityfields/permissiondealer_type/valueProcess.js
index c02d458db6ede7ee066f364a67745996fee3166d..de18eafdc483197e7e50910ce5cc6d01fdaba400 100644
--- a/entity/PermissionCalendar_entity/entityfields/permissiondealer_type/valueProcess.js
+++ b/entity/PermissionCalendar_entity/entityfields/permissiondealer_type/valueProcess.js
@@ -1,8 +1,15 @@
+import("system.neon");
+import("PermissionCalendar_lib");
 import("system.result");
 import("system.vars");
 
 
-let permissionDealerType = vars.get("$param.PermissionDealerType_param");
+let permissionProcurerType = vars.get("$param.PermissionDealerType_param");
 
-if (vars.get("$this.value") == null && permissionDealerType)
-    result.string(permissionDealerType);
\ No newline at end of file
+if(vars.get("$this.value") == null && vars.get("$sys.recordstate") == neon.OPERATINGSTATE_NEW) 
+{
+    if (permissionProcurerType)
+        result.string(permissionProcurerType);
+    else
+        result.string(PermissionCalendar.getObjectType(vars.get("$param.PermissionDealer_param")));
+}
\ No newline at end of file
diff --git a/entity/PermissionCalendar_entity/entityfields/permissiondealer_user_rowid/mandatoryProcess.js b/entity/PermissionCalendar_entity/entityfields/permissiondealer_user_rowid/mandatoryProcess.js
index 20c989da57b7e91f711995280a680e661d35c514..e21c5a274d5116118bf7c8eac19ba628b466d3e3 100644
--- a/entity/PermissionCalendar_entity/entityfields/permissiondealer_user_rowid/mandatoryProcess.js
+++ b/entity/PermissionCalendar_entity/entityfields/permissiondealer_user_rowid/mandatoryProcess.js
@@ -3,7 +3,7 @@ import("system.vars");
 import("system.result");
 import("PermissionCalendar_lib");
 
-if(vars.getString("$field.PERMISSIONDEALER_TYPE") == $KeywordRegistry.permissionCalendarType$user())
+if(vars.getString("$field.PERMISSIONDEALER_TYPE") == $KeywordRegistry.permissionCalendarType$user() && vars.getString("$param.PermissionProcurer_param"))
     result.string(true);
 else
     result.string(false);
\ No newline at end of file
diff --git a/entity/PermissionCalendar_entity/entityfields/permissiondealer_user_rowid/stateProcess.js b/entity/PermissionCalendar_entity/entityfields/permissiondealer_user_rowid/stateProcess.js
index d1da690a3e6cf9421ad0846601bc23a73912d719..e17b225d175d6dcd6978e2b416fae4b519f94f7f 100644
--- a/entity/PermissionCalendar_entity/entityfields/permissiondealer_user_rowid/stateProcess.js
+++ b/entity/PermissionCalendar_entity/entityfields/permissiondealer_user_rowid/stateProcess.js
@@ -4,13 +4,10 @@ import("system.result");
 import("PermissionCalendar_lib");
 import("system.neon");
 
-if(vars.getString("$field.PERMISSIONDEALER_TYPE") == $KeywordRegistry.permissionCalendarType$user())
+if(vars.getString("$field.PERMISSIONDEALER_TYPE") == $KeywordRegistry.permissionCalendarType$user() && vars.getString("$param.PermissionProcurer_param"))
     if(vars.getString("$sys.recordstate") == neon.OPERATINGSTATE_EDIT)
-        result.string("READONLY");
+        result.string(neon.COMPONENTSTATE_READONLY)
     else
-        if (vars.getString("$param.PermissionDealer_param"))
-            result.string("READONLY");
-        else
-            result.string("EDITABLE");
+        result.string(neon.COMPONENTSTATE_EDITABLE);
 else
-    result.string("INVISIBLE");
\ No newline at end of file
+    result.string(neon.COMPONENTSTATE_INVISIBLE);
\ No newline at end of file
diff --git a/entity/PermissionCalendar_entity/entityfields/permissionprocurer_department_rowid/displayValueProcess.js b/entity/PermissionCalendar_entity/entityfields/permissionprocurer_department_rowid/displayValueProcess.js
new file mode 100644
index 0000000000000000000000000000000000000000..d5a26f0a31fbf7854ef8c2fd22f90655b93bfa4b
--- /dev/null
+++ b/entity/PermissionCalendar_entity/entityfields/permissionprocurer_department_rowid/displayValueProcess.js
@@ -0,0 +1,6 @@
+import("system.vars");
+import("system.result");
+
+let display = vars.get("$field.PERMISSIONPROCURER_ROWID.displayValue");
+if(display != "undefined")
+    result.string(vars.get("$field.PERMISSIONPROCURER_ROWID.displayValue"));
\ No newline at end of file
diff --git a/entity/PermissionCalendar_entity/entityfields/permissionprocurer_department_rowid/mandatoryProcess.js b/entity/PermissionCalendar_entity/entityfields/permissionprocurer_department_rowid/mandatoryProcess.js
new file mode 100644
index 0000000000000000000000000000000000000000..6736c4a5eca0adf47347adb7db0951392aff3f6c
--- /dev/null
+++ b/entity/PermissionCalendar_entity/entityfields/permissionprocurer_department_rowid/mandatoryProcess.js
@@ -0,0 +1,9 @@
+import("KeywordRegistry_basic");
+import("system.vars");
+import("system.result");
+import("PermissionCalendar_lib");
+
+if(vars.getString("$field.PERMISSIONPROCURER_TYPE") == $KeywordRegistry.permissionCalendarType$department() && vars.getString("$param.PermissionDealer_param"))
+    result.string(true);
+else
+    result.string(false);
\ No newline at end of file
diff --git a/entity/PermissionCalendar_entity/entityfields/permissionprocurer_department_rowid/onValueChange.js b/entity/PermissionCalendar_entity/entityfields/permissionprocurer_department_rowid/onValueChange.js
new file mode 100644
index 0000000000000000000000000000000000000000..a10a281ce5afe63ce87eef4c182927d89f050e80
--- /dev/null
+++ b/entity/PermissionCalendar_entity/entityfields/permissionprocurer_department_rowid/onValueChange.js
@@ -0,0 +1,9 @@
+import("KeywordRegistry_basic");
+import("system.neon");
+import("system.vars");
+
+if (vars.get("$this.value") != null && vars.get("$sys.recordstate") == neon.OPERATINGSTATE_NEW)
+{
+    vars.set("$field.PERMISSIONPROCURER_ROWID", vars.get("$this.value"));
+    vars.set("$field.PERMISSIONPROCURER_TYPE", $KeywordRegistry.permissionCalendarType$department());
+}
\ No newline at end of file
diff --git a/entity/PermissionCalendar_entity/entityfields/permissionprocurer_department_rowid/stateProcess.js b/entity/PermissionCalendar_entity/entityfields/permissionprocurer_department_rowid/stateProcess.js
new file mode 100644
index 0000000000000000000000000000000000000000..69ad9d69c792575595fb64fed74b3b0ce1bd9c2b
--- /dev/null
+++ b/entity/PermissionCalendar_entity/entityfields/permissionprocurer_department_rowid/stateProcess.js
@@ -0,0 +1,13 @@
+import("KeywordRegistry_basic");
+import("system.vars");
+import("system.result");
+import("PermissionCalendar_lib");
+import("system.neon");
+
+if(vars.getString("$field.PERMISSIONPROCURER_TYPE") == $KeywordRegistry.permissionCalendarType$department() && vars.getString("$param.PermissionDealer_param"))
+    if(vars.getString("$sys.recordstate") == neon.OPERATINGSTATE_EDIT)
+        result.string(neon.COMPONENTSTATE_READONLY)
+    else
+        result.string(neon.COMPONENTSTATE_EDITABLE);
+else
+    result.string(neon.COMPONENTSTATE_INVISIBLE);
\ No newline at end of file
diff --git a/entity/PermissionCalendar_entity/entityfields/permissionprocurer_type/valueProcess.js b/entity/PermissionCalendar_entity/entityfields/permissionprocurer_type/valueProcess.js
index 2cb573dc5124212cdf42bae591557f96684eb0ab..7d609bbc471ec12848fde99610e0f112f180d3f0 100644
--- a/entity/PermissionCalendar_entity/entityfields/permissionprocurer_type/valueProcess.js
+++ b/entity/PermissionCalendar_entity/entityfields/permissionprocurer_type/valueProcess.js
@@ -1,8 +1,15 @@
+import("system.neon");
 import("PermissionCalendar_lib");
-import("Employee_lib");
 import("system.result");
-import("system.neon");
 import("system.vars");
 
-if(vars.get("$this.value") == null && vars.get("$sys.recordstate") == neon.OPERATINGSTATE_NEW && vars.get("$param.PermissionProcurer_param"))
-    result.string(PermissionCalendar.getObjectType(vars.get("$param.PermissionProcurer_param")));
\ No newline at end of file
+
+let permissionProcurerType = vars.get("$param.PermissionProcurerType_param");
+
+if(vars.get("$this.value") == null && vars.get("$sys.recordstate") == neon.OPERATINGSTATE_NEW) 
+{
+    if (permissionProcurerType)
+        result.string(permissionProcurerType);
+    else
+        result.string(PermissionCalendar.getObjectType(vars.get("$param.PermissionProcurer_param")));
+}
\ No newline at end of file
diff --git a/entity/PermissionCalendar_entity/entityfields/permissionprocurer_user_rowid/displayValueProcess.js b/entity/PermissionCalendar_entity/entityfields/permissionprocurer_user_rowid/displayValueProcess.js
index 4aed1075952ea7d36cb32696eb893f4df04d1bf3..d5a26f0a31fbf7854ef8c2fd22f90655b93bfa4b 100644
--- a/entity/PermissionCalendar_entity/entityfields/permissionprocurer_user_rowid/displayValueProcess.js
+++ b/entity/PermissionCalendar_entity/entityfields/permissionprocurer_user_rowid/displayValueProcess.js
@@ -1,9 +1,6 @@
-import("KeywordRegistry_basic");
-import("system.result");
 import("system.vars");
-import("PermissionCalendar_lib");
-
-let permissionProcurerUserDisplay = PermissionCalendar.getNameDisplay(vars.getString("$this.value"), $KeywordRegistry.permissionCalendarType$user());
+import("system.result");
 
-if (permissionProcurerUserDisplay != "undefined")
-    result.string(permissionProcurerUserDisplay);
+let display = vars.get("$field.PERMISSIONPROCURER_ROWID.displayValue");
+if(display != "undefined")
+    result.string(vars.get("$field.PERMISSIONPROCURER_ROWID.displayValue"));
\ No newline at end of file
diff --git a/entity/PermissionCalendar_entity/entityfields/permissionprocurer_user_rowid/mandatoryProcess.js b/entity/PermissionCalendar_entity/entityfields/permissionprocurer_user_rowid/mandatoryProcess.js
new file mode 100644
index 0000000000000000000000000000000000000000..c958afbcaa9dafcd96f380798f8bddd02729bef4
--- /dev/null
+++ b/entity/PermissionCalendar_entity/entityfields/permissionprocurer_user_rowid/mandatoryProcess.js
@@ -0,0 +1,9 @@
+import("KeywordRegistry_basic");
+import("system.vars");
+import("system.result");
+import("PermissionCalendar_lib");
+
+if(vars.getString("$field.PERMISSIONPROCURER_TYPE") == $KeywordRegistry.permissionCalendarType$user() && vars.getString("$param.PermissionDealer_param"))
+    result.string(true);
+else
+    result.string(false);
\ No newline at end of file
diff --git a/entity/PermissionCalendar_entity/entityfields/permissionprocurer_user_rowid/stateProcess.js b/entity/PermissionCalendar_entity/entityfields/permissionprocurer_user_rowid/stateProcess.js
new file mode 100644
index 0000000000000000000000000000000000000000..1af2036a8c6ed62380e7674dd32a71bc9c5bc4f7
--- /dev/null
+++ b/entity/PermissionCalendar_entity/entityfields/permissionprocurer_user_rowid/stateProcess.js
@@ -0,0 +1,13 @@
+import("KeywordRegistry_basic");
+import("system.vars");
+import("system.result");
+import("PermissionCalendar_lib");
+import("system.neon");
+
+if(vars.getString("$field.PERMISSIONPROCURER_TYPE") == $KeywordRegistry.permissionCalendarType$user() && vars.getString("$param.PermissionDealer_param"))
+    if(vars.getString("$sys.recordstate") == neon.OPERATINGSTATE_EDIT)
+        result.string(neon.COMPONENTSTATE_READONLY)
+    else
+        result.string(neon.COMPONENTSTATE_EDITABLE);
+else
+    result.string(neon.COMPONENTSTATE_INVISIBLE);
\ No newline at end of file
diff --git a/entity/PermissionCalendar_entity/recordcontainers/permissioncalendardb/conditionProcess.js b/entity/PermissionCalendar_entity/recordcontainers/permissioncalendardb/conditionProcess.js
index 80d6ae15b8e5c9b21a8d215cdce17445cb48b090..82af1af206386982e03c55e531947e9da0ff227b 100644
--- a/entity/PermissionCalendar_entity/recordcontainers/permissioncalendardb/conditionProcess.js
+++ b/entity/PermissionCalendar_entity/recordcontainers/permissioncalendardb/conditionProcess.js
@@ -9,7 +9,8 @@ let permissionDealer = vars.getString("$param.PermissionDealer_param");
 var cond = new SqlBuilder();
 if (permissionProcurer) 
 {
-    cond.whereIfSet("AB_PERMISSIONCALENDAR.PERMISSIONPROCURER_ROWID", EmployeeUtils.sliceUserId(permissionProcurer));
+    cond.whereIfSet("AB_PERMISSIONCALENDAR.PERMISSIONPROCURER_ROWID", EmployeeUtils.sliceUserId(permissionProcurer))
+    .orIfSet("AB_PERMISSIONCALENDAR.PERMISSIONPROCURER_ROWID", PermissionCalendar.getAllParents(permissionProcurer) , SqlBuilder.IN());
 } 
 else if (permissionDealer)  
 {
diff --git a/language/_____LANGUAGE_EXTRA/_____LANGUAGE_EXTRA.aod b/language/_____LANGUAGE_EXTRA/_____LANGUAGE_EXTRA.aod
index 63ba21d8cea8fa19a20a99a87c9309db1a97aa19..754ed5d7008765076f1ad44f6dab44111ea06fc2 100644
--- a/language/_____LANGUAGE_EXTRA/_____LANGUAGE_EXTRA.aod
+++ b/language/_____LANGUAGE_EXTRA/_____LANGUAGE_EXTRA.aod
@@ -6851,6 +6851,12 @@
     <entry>
       <key>Workflow Model</key>
     </entry>
+    <entry>
+      <key>Permission Procurer Department</key>
+    </entry>
+    <entry>
+      <key>Grant new Department Permission</key>
+    </entry>
   </keyValueMap>
   <font name="Dialog" style="0" size="11" />
   <sqlModels>
diff --git a/language/_____LANGUAGE_de/_____LANGUAGE_de.aod b/language/_____LANGUAGE_de/_____LANGUAGE_de.aod
index 23532c5d74ab3c632128fe806ced5e4c75b84cb5..093846f329d5c213d522e253585952464f2f51d4 100644
--- a/language/_____LANGUAGE_de/_____LANGUAGE_de.aod
+++ b/language/_____LANGUAGE_de/_____LANGUAGE_de.aod
@@ -8771,6 +8771,7 @@ Bitte Datumseingabe prüfen</value>
     </entry>
     <entry>
       <key>Permission Procurer User</key>
+      <value>Rechteempfänger Benutzer</value>
     </entry>
     <entry>
       <key>Grant new User Permission</key>
@@ -8779,6 +8780,14 @@ Bitte Datumseingabe prüfen</value>
     <entry>
       <key>Workflow Model</key>
     </entry>
+    <entry>
+      <key>Permission Procurer Department</key>
+      <value>Rechteempfänger Abteilung</value>
+    </entry>
+    <entry>
+      <key>Grant new Department Permission</key>
+      <value>Neue Abteilungs-Berechtigung vergeben</value>
+    </entry>
   </keyValueMap>
   <font name="Dialog" style="0" size="11" />
 </language>
diff --git a/language/_____LANGUAGE_en/_____LANGUAGE_en.aod b/language/_____LANGUAGE_en/_____LANGUAGE_en.aod
index 48dca7bfd8201120b99fcddebd8b8966dbd36b8b..a2eaa32042e11b039942082cf696bad353bdc067 100644
--- a/language/_____LANGUAGE_en/_____LANGUAGE_en.aod
+++ b/language/_____LANGUAGE_en/_____LANGUAGE_en.aod
@@ -6917,6 +6917,12 @@
     <entry>
       <key>Workflow Model</key>
     </entry>
+    <entry>
+      <key>Permission Procurer Department</key>
+    </entry>
+    <entry>
+      <key>Grant new Department Permission</key>
+    </entry>
   </keyValueMap>
   <font name="Dialog" style="0" size="11" />
 </language>
diff --git a/neonContext/PermissionCalendar/PermissionCalendar.aod b/neonContext/PermissionCalendar/PermissionCalendar.aod
index 2a143ec693d60041608bf024fd0a70f3dee9ad84..01c68cf39a1a4a71c81c6eb1abea36f4d15b1441 100644
--- a/neonContext/PermissionCalendar/PermissionCalendar.aod
+++ b/neonContext/PermissionCalendar/PermissionCalendar.aod
@@ -27,9 +27,5 @@
       <name>e0b5c183-3f5c-48ad-ba6c-60ae1a0c3b85</name>
       <view>PermissionCalendarFilterDrawer_view</view>
     </neonViewReference>
-    <neonViewReference>
-      <name>dd1363e0-d7ba-44d3-b587-e243b760d9e4</name>
-      <view>PermissionCalendarEditReverse_view</view>
-    </neonViewReference>
   </references>
 </neonContext>
diff --git a/neonView/PermissionCalendarEditReverse_view/PermissionCalendarEditReverse_view.aod b/neonView/PermissionCalendarEditReverse_view/PermissionCalendarEditReverse_view.aod
deleted file mode 100644
index 3fca170746d71dac2cc3470b2800d0f939545654..0000000000000000000000000000000000000000
--- a/neonView/PermissionCalendarEditReverse_view/PermissionCalendarEditReverse_view.aod
+++ /dev/null
@@ -1,31 +0,0 @@
-<?xml version="1.0" encoding="UTF-8"?>
-<neonView xmlns="http://www.adito.de/2018/ao/Model" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" VERSION="1.1.6" xsi:schemaLocation="http://www.adito.de/2018/ao/Model adito://models/xsd/neonView/1.1.6">
-  <name>PermissionCalendarEditReverse_view</name>
-  <majorModelMode>DISTRIBUTED</majorModelMode>
-  <layout>
-    <noneLayout>
-      <name>layout</name>
-    </noneLayout>
-  </layout>
-  <children>
-    <genericViewTemplate>
-      <name>PermissionCalendarEditReverseGeneric</name>
-      <editMode v="true" />
-      <entityField>#ENTITY</entityField>
-      <fields>
-        <entityFieldLink>
-          <name>c40a7708-1983-4848-a93c-92b873104095</name>
-          <entityField>PERMISSION</entityField>
-        </entityFieldLink>
-        <entityFieldLink>
-          <name>8da9a2ae-f338-4342-b762-125e972d4980</name>
-          <entityField>permissionProcurer_User_RowId</entityField>
-        </entityFieldLink>
-        <entityFieldLink>
-          <name>7ce1d83a-9d5c-4c36-81a8-2e832448eaaf</name>
-          <entityField>PERMISSIONDEALER_USER_ROWID</entityField>
-        </entityFieldLink>
-      </fields>
-    </genericViewTemplate>
-  </children>
-</neonView>
diff --git a/neonView/PermissionCalendarEdit_view/PermissionCalendarEdit_view.aod b/neonView/PermissionCalendarEdit_view/PermissionCalendarEdit_view.aod
index 9e557d4f2eed1a851d46cd2b4d2525f38304ecb2..60c76072d2afc883a3e23ecccea591e5f236dfab 100644
--- a/neonView/PermissionCalendarEdit_view/PermissionCalendarEdit_view.aod
+++ b/neonView/PermissionCalendarEdit_view/PermissionCalendarEdit_view.aod
@@ -27,6 +27,14 @@
           <name>bf110421-8305-47c4-8bab-d859b14c7bd4</name>
           <entityField>PERMISSIONDEALER_USER_ROWID</entityField>
         </entityFieldLink>
+        <entityFieldLink>
+          <name>687b28e4-ea71-40d9-92b4-c771c5c04132</name>
+          <entityField>permissionProcurer_Department_RowId</entityField>
+        </entityFieldLink>
+        <entityFieldLink>
+          <name>413799e6-1f74-43c9-a947-6b5423b75aa2</name>
+          <entityField>permissionProcurer_User_RowId</entityField>
+        </entityFieldLink>
       </fields>
     </genericViewTemplate>
   </children>
diff --git a/neonView/PermissionCalendarFilterReverse_view/PermissionCalendarFilterReverse_view.aod b/neonView/PermissionCalendarFilterReverse_view/PermissionCalendarFilterReverse_view.aod
index 41f27fe542e3d479e92c89009576f8a809296ad2..e3ac3b974a8469be05d8311be356a9f0c7e8be52 100644
--- a/neonView/PermissionCalendarFilterReverse_view/PermissionCalendarFilterReverse_view.aod
+++ b/neonView/PermissionCalendarFilterReverse_view/PermissionCalendarFilterReverse_view.aod
@@ -16,8 +16,7 @@
       <favoriteActionGroup1>AddActionsReverse</favoriteActionGroup1>
       <entityField>#ENTITY</entityField>
       <isCreatable v="false" />
-      <isDeletable v="false" />
-      <isEditable v="false" />
+      <isEditable v="true" />
       <title></title>
       <columns>
         <neonTableColumn>
diff --git a/process/PermissionCalendar_lib/process.js b/process/PermissionCalendar_lib/process.js
index 453eced12825a0e4bd825fec36a58c1e98080896..25a29b8bd5e3b7ce9698d6ef0f56ebc150003ee2 100644
--- a/process/PermissionCalendar_lib/process.js
+++ b/process/PermissionCalendar_lib/process.js
@@ -415,6 +415,7 @@ PermissionCalendar.getPermissions = function(pCurrentUser)
     .select("AB_PERMISSIONCALENDARID, PERMISSIONDEALER_ROWID, PERMISSIONDEALER_TYPE, PERMISSIONPROCURER_ROWID, PERMISSION")
     .from("AB_PERMISSIONCALENDAR")
     .where("AB_PERMISSIONCALENDAR.PERMISSIONPROCURER_ROWID", pCurrentUser)
+    .orIfSet("AB_PERMISSIONCALENDAR.PERMISSIONPROCURER_ROWID", PermissionCalendar.getAllParents(EmployeeUtils.prefixUserId(pCurrentUser)) , SqlBuilder.IN())
     .orderBy("PERMISSIONDEALER_ROWID ASC")
     .table();
 };