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(); };