From 7c92acd7acb6782401cfe1a298c1861d6b6adf9e Mon Sep 17 00:00:00 2001 From: "m.groppe" <m.groppe@adito.de> Date: Mon, 12 Jul 2021 17:01:10 +0200 Subject: [PATCH] =?UTF-8?q?[Projekt:=20xRM-Marketing][TicketNr.:=201044537?= =?UTF-8?q?][Kampagne=20-=20Kontakt=20oder=20Firma=20zu=20Kampagne=20hinzu?= =?UTF-8?q?f=C3=BCgen=20-=20alle=20Kampagnen=20angezeigt]?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit [Projekt: xRM-Marketing][TicketNr.: 1081911][Firma zu Kampagne hinzufügen] [Projekt: xRM-Marketing][TicketNr.: 1082689][CampaignStep sollte in Preview nicht editable sein] [Projekt: xRM-Marketing][TicketNr.: 1083583][Kampagne, Teilnehmer, Aktualisieren des Kampagnenschrittes] [Projekt: xRM-Marketing][TicketNr.: 1083212][Kampagnenzähler zählt bei Bearbeitung hoch] --- .../CampaignAddParticipants_entity.aod | 6 ++++++ .../addparticipants/onActionProcess.js | 8 +++++++- .../children/onlyactive_param}/valueProcess.js | 2 +- .../CampaignParticipant_entity.aod | 10 ++++++---- .../ignorecontactstates_param/valueProcess.js | 7 +++++++ entity/Campaign_entity/Campaign_entity.aod | 4 ++++ .../entityfields/campaigncode/valueProcess.js | 5 ++++- .../recordcontainers/db/conditionProcess.js | 17 ++++++++++++++--- language/_____LANGUAGE_de/_____LANGUAGE_de.aod | 8 ++++---- .../CampaignStepParticipnatsPerStep_view.aod | 1 + process/KeywordRegistry_basic/process.js | 1 + 11 files changed, 55 insertions(+), 14 deletions(-) rename entity/{CampaignParticipant_entity/entityfields/anycontacts/children/onlypers_param => CampaignAddParticipants_entity/entityfields/campaignconsumer/children/onlyactive_param}/valueProcess.js (53%) create mode 100644 entity/CampaignParticipant_entity/entityfields/anycontacts/children/ignorecontactstates_param/valueProcess.js diff --git a/entity/CampaignAddParticipants_entity/CampaignAddParticipants_entity.aod b/entity/CampaignAddParticipants_entity/CampaignAddParticipants_entity.aod index f867fcdc40..c0178e47a9 100644 --- a/entity/CampaignAddParticipants_entity/CampaignAddParticipants_entity.aod +++ b/entity/CampaignAddParticipants_entity/CampaignAddParticipants_entity.aod @@ -60,6 +60,12 @@ <entityName>Campaign_entity</entityName> <fieldName>Campaigns</fieldName> </dependency> + <children> + <entityParameter> + <name>OnlyActive_param</name> + <valueProcess>%aditoprj%/entity/CampaignAddParticipants_entity/entityfields/campaignconsumer/children/onlyactive_param/valueProcess.js</valueProcess> + </entityParameter> + </children> </entityConsumer> <entityConsumer> <name>CampaignStepConsumer</name> diff --git a/entity/CampaignAddParticipants_entity/entityfields/addparticipants/onActionProcess.js b/entity/CampaignAddParticipants_entity/entityfields/addparticipants/onActionProcess.js index ceeb7e8662..53f88a49de 100644 --- a/entity/CampaignAddParticipants_entity/entityfields/addparticipants/onActionProcess.js +++ b/entity/CampaignAddParticipants_entity/entityfields/addparticipants/onActionProcess.js @@ -26,7 +26,13 @@ if(contactIds != null && contactIds.length > 0) neon.refreshAll(); if (!vars.exists("$param.currentCampaignId_param") || !vars.get("$param.currentCampaignId_param")) - neon.openContext("Campaign", "CampaignMain_view", [campaignId], neon.OPERATINGSTATE_VIEW, null); +{ + neon.openContext("Campaign", "CampaignMain_view", [campaignId], neon.OPERATINGSTATE_VIEW, null); +} +else +{ + neon.closeImage(vars.get("$sys.currentimage"), true); +} diff --git a/entity/CampaignParticipant_entity/entityfields/anycontacts/children/onlypers_param/valueProcess.js b/entity/CampaignAddParticipants_entity/entityfields/campaignconsumer/children/onlyactive_param/valueProcess.js similarity index 53% rename from entity/CampaignParticipant_entity/entityfields/anycontacts/children/onlypers_param/valueProcess.js rename to entity/CampaignAddParticipants_entity/entityfields/campaignconsumer/children/onlyactive_param/valueProcess.js index 70aefbf842..d3ed7d447b 100644 --- a/entity/CampaignParticipant_entity/entityfields/anycontacts/children/onlypers_param/valueProcess.js +++ b/entity/CampaignAddParticipants_entity/entityfields/campaignconsumer/children/onlyactive_param/valueProcess.js @@ -1,2 +1,2 @@ import("system.result"); -result.string(true) \ No newline at end of file +result.string("true"); \ No newline at end of file diff --git a/entity/CampaignParticipant_entity/CampaignParticipant_entity.aod b/entity/CampaignParticipant_entity/CampaignParticipant_entity.aod index 7f9346cc2d..f85dbe2011 100644 --- a/entity/CampaignParticipant_entity/CampaignParticipant_entity.aod +++ b/entity/CampaignParticipant_entity/CampaignParticipant_entity.aod @@ -19,6 +19,8 @@ </entityProvider> <entityProvider> <name>CampaignParticipantsProvider</name> + <targetContextField>CONTACTCONTEXT</targetContextField> + <targetIdField>CONTACT_ID</targetIdField> <documentation>%aditoprj%/entity/CampaignParticipant_entity/entityfields/campaignparticipantsprovider/documentation.adoc</documentation> <recordContainer>db</recordContainer> <children> @@ -127,14 +129,14 @@ <fieldName>ContactsByIds</fieldName> </dependency> <children> - <entityParameter> - <name>OnlyPers_param</name> - <valueProcess>%aditoprj%/entity/CampaignParticipant_entity/entityfields/anycontacts/children/onlypers_param/valueProcess.js</valueProcess> - </entityParameter> <entityParameter> <name>WithPrivatePersons_param</name> <valueProcess>%aditoprj%/entity/CampaignParticipant_entity/entityfields/anycontacts/children/withprivatepersons_param/valueProcess.js</valueProcess> </entityParameter> + <entityParameter> + <name>IgnoreContactStates_param</name> + <valueProcess>%aditoprj%/entity/CampaignParticipant_entity/entityfields/anycontacts/children/ignorecontactstates_param/valueProcess.js</valueProcess> + </entityParameter> </children> </entityConsumer> <entityConsumer> diff --git a/entity/CampaignParticipant_entity/entityfields/anycontacts/children/ignorecontactstates_param/valueProcess.js b/entity/CampaignParticipant_entity/entityfields/anycontacts/children/ignorecontactstates_param/valueProcess.js new file mode 100644 index 0000000000..6d246bbd4d --- /dev/null +++ b/entity/CampaignParticipant_entity/entityfields/anycontacts/children/ignorecontactstates_param/valueProcess.js @@ -0,0 +1,7 @@ +import("system.result"); +import("KeywordRegistry_basic"); + +result.string(JSON.stringify([ + $KeywordRegistry.contactStatus$inactive(), + $KeywordRegistry.contactStatus$markToDelete() +])); \ No newline at end of file diff --git a/entity/Campaign_entity/Campaign_entity.aod b/entity/Campaign_entity/Campaign_entity.aod index 7e0c6abd26..9ca492da02 100644 --- a/entity/Campaign_entity/Campaign_entity.aod +++ b/entity/Campaign_entity/Campaign_entity.aod @@ -606,6 +606,10 @@ </entityParameter> </children> </entityConsumer> + <entityParameter> + <name>OnlyActive_param</name> + <expose v="true" /> + </entityParameter> </entityFields> <recordContainers> <dbRecordContainer> diff --git a/entity/Campaign_entity/entityfields/campaigncode/valueProcess.js b/entity/Campaign_entity/entityfields/campaigncode/valueProcess.js index 28366e4157..f501fca35f 100644 --- a/entity/Campaign_entity/entityfields/campaigncode/valueProcess.js +++ b/entity/Campaign_entity/entityfields/campaigncode/valueProcess.js @@ -1,4 +1,7 @@ +import("system.vars"); import("system.result"); import("Campaign_lib"); +import("system.neon"); -result.string(CampaignUtils.getNextProjectNumber()); \ No newline at end of file +if (vars.get("$sys.operatingstate") == neon.OPERATINGSTATE_NEW && !vars.get("$this.value")) + result.string(CampaignUtils.getNextProjectNumber()); \ No newline at end of file diff --git a/entity/Campaign_entity/recordcontainers/db/conditionProcess.js b/entity/Campaign_entity/recordcontainers/db/conditionProcess.js index e5c5faf2b6..2e845464f0 100644 --- a/entity/Campaign_entity/recordcontainers/db/conditionProcess.js +++ b/entity/Campaign_entity/recordcontainers/db/conditionProcess.js @@ -1,17 +1,28 @@ +import("KeywordRegistry_basic"); import("system.db"); import("system.neon"); import("system.result"); import("system.vars"); import("Employee_lib"); import("Sql_lib"); - +import("Util_lib"); +import("system.SQLTYPES") var recordState = vars.get("$sys.recordstate"); var cond = newWhere(); +var sqlHelper = new SqlMaskingUtils(); - -if(vars.get("$param.ShowOnlyCurrentUsersCampaigns_param") == 'true') +if(Utils.toBoolean(vars.get("$param.ShowOnlyCurrentUsersCampaigns_param"))) { cond.and("CAMPAIGN.EMPLOYEE_CONTACT_ID", EmployeeUtils.getCurrentContactId()); } +if(Utils.toBoolean(vars.get("$param.OnlyActive_param"))) +{ + cond.and("CAMPAIGN.STATUS",$KeywordRegistry.campaignState$completed(),SqlBuilder.NOT_EQUAL()); + cond.and(newSelect(sqlHelper.max("CAMPAIGNSTEP.DATE_END")) + .from("CAMPAIGNSTEP") + .where("CAMPAIGNSTEP.CAMPAIGN_ID = CAMPAIGN.CAMPAIGNID") + ,vars.get("$sys.date"),SqlBuilder.GREATER_OR_EQUAL(),SQLTYPES.DATE) +} + result.string(cond.toString()); \ No newline at end of file diff --git a/language/_____LANGUAGE_de/_____LANGUAGE_de.aod b/language/_____LANGUAGE_de/_____LANGUAGE_de.aod index f333233b07..6f23da5142 100644 --- a/language/_____LANGUAGE_de/_____LANGUAGE_de.aod +++ b/language/_____LANGUAGE_de/_____LANGUAGE_de.aod @@ -1016,7 +1016,7 @@ </entry> <entry> <key>Update campaign step</key> - <value>Aktualisieren des Kampagnenschrittes</value> + <value>Kampagnenstufe ändern</value> </entry> <entry> <key>Serial letters</key> @@ -1521,7 +1521,7 @@ </entry> <entry> <key>Participants</key> - <value>Teilnehmer/innen</value> + <value>Teilnehmer</value> </entry> <entry> <key>Contact Management</key> @@ -1577,7 +1577,7 @@ </entry> <entry> <key>Add participants to Campaign</key> - <value>Kampagnenteilnehmer/innen hinzufügen</value> + <value>Kampagnenteilnehmer hinzufügen</value> </entry> <entry> <key>Firstname</key> @@ -4402,7 +4402,7 @@ </entry> <entry> <key>Add participant to Campaign</key> - <value>Kampagnenteilnehmer/in hinzufügen</value> + <value>Kampagnenteilnehmer hinzufügen</value> </entry> <entry> <key>Relationtype</key> diff --git a/neonView/CampaignStepParticipnatsPerStep_view/CampaignStepParticipnatsPerStep_view.aod b/neonView/CampaignStepParticipnatsPerStep_view/CampaignStepParticipnatsPerStep_view.aod index 9ff58eaf03..f5b7670ca5 100644 --- a/neonView/CampaignStepParticipnatsPerStep_view/CampaignStepParticipnatsPerStep_view.aod +++ b/neonView/CampaignStepParticipnatsPerStep_view/CampaignStepParticipnatsPerStep_view.aod @@ -13,6 +13,7 @@ <titleField>NAME</titleField> <highlightingField>CurrentMaxParticipantsInfo</highlightingField> <entityField>#ENTITY</entityField> + <isEditable v="false" /> <columns> <neonTitledListTableColumn> <name>4ea71a13-4108-47a5-9a28-2256618fdc2c</name> diff --git a/process/KeywordRegistry_basic/process.js b/process/KeywordRegistry_basic/process.js index b71e5b84d7..c2757f2c08 100644 --- a/process/KeywordRegistry_basic/process.js +++ b/process/KeywordRegistry_basic/process.js @@ -176,6 +176,7 @@ $KeywordRegistry.contactContactrole = function(){return "ContactContactrole";}; $KeywordRegistry.campaignState = function(){return "CampaignManagementStates";}; $KeywordRegistry.campaignState$planning = function(){return "PLANNING";}; $KeywordRegistry.campaignState$approved = function(){return "APPROVED";}; +$KeywordRegistry.campaignState$completed = function(){return "COMPLETED";}; $KeywordRegistry.campaignStepState = function(){return "CampaignManagementStepStates";}; $KeywordRegistry.campaignStepState$open = function(){return "OPEN";}; -- GitLab