“Wörter nicht übersetzen” in die Datenbank einlesen
Leider geht das nicht direkt über das Datenmodell.
Aber mein grandioser Kollege Daniel hatte die Idee es über den XML Import des Wörterbuchs mal zu probieren. Siehe da, dies funktioniert.
Somit brauchen wir eine DTO-Klasse für das Import-Format:
<?xml version="1.0" encoding="utf-8"?> <EplanLanguageDbRoot> <NonTranslateSection> <NTW>Foo</NTW> <NTW>Bar</NTW> </NonTranslateSection> </EplanLanguageDbRoot>
[XmlRoot("EplanLanguageDbRoot")] public class EplanTranslationsDto { [XmlArray("NonTranslateSection")] [XmlArrayItem("NTW")] public List<string> NonTranslatedWords { get; set; } = new(); }
Das ganze speichern wir als XML und importieren es über die Standard-Action, welche auch im Scripting verfügbar ist:
private static void ImportXmlToTranslations(string filename) { ActionCallingContext acc = new ActionCallingContext(); acc.AddParameter("TYPE", "IMPORTTOTRANSDB"); acc.AddParameter("IMPORTFILE", filename); acc.AddParameter("CONVERTER", "XTrLanguageDbXmlConverterImpl"); new CommandLineInterpreter().Execute("translate", acc); }
EPLAN 2025: Scripting Neuerungen
Folgende Änderungen gab es im Scripting:
XCCreateGravingtextAction
Erzeugt einen Graviertext aus den BMK von Quelle und Ziel des Kabels. Die Bezeichnung wird entsprechend dem VASS-Standard (Volkswagen Audi Seat Skoda) gekürzt.XCabCalculateEnclosureTotalWeightAction
Berechnet das Gesamtgewicht eines Schrankes und schreibt es in die Eigenschaft „Gesamtgewicht“ (#36108 – FUNCTION3D_CABINET_TOTALWEIGHT)
AutoSyncNavis
Mit diesem Script werden Navigatoren automatisch mit der aktuellen Selektion synchronisiert.
Vielen Dank an FrankS für das Erstellen 💖
Achtung: Je nachdem wie viele Navigatoren geöffnet sind und wie groß das Projekt ist, kann sich das Script negativ auf die Perfomance auswirken.
// AutoSyncNavis.cs // // Nachdem das Script geladen wurde kann das Synchronisieren aller Navigatoren mit dem // ausgewählten Element im GED aktiviert werden. // // Es wird ein neuer Menüpunkt "AutoSync Navigatoren" in der Gruppe "Erweiterung" im Tab "Ansicht" angelegt, // außerdem wird die aktuelle Einstellung gespeichert. // // Copyright by Frank Schöneck, 2024 // // letzte Änderung: // V1.0.0, 23.07.2024, Frank Schöneck, Projektbeginn using Eplan.EplApi.ApplicationFramework; using Eplan.EplApi.Base; using Eplan.EplApi.Gui; using Eplan.EplApi.Scripting; using System.Linq; public class AutoSyncNavis { private string sSettingName = "USER.SCRIPTS.AutoSyncNavis.AutoSyncState"; //RibbonBar Einträge definieren string m_TabName = "Ansicht"; string m_commandGroupName = "Erweiterungen"; string m_commandName = "AutoSync"; string m_SVGstringIconNavigator = @"<svg fill='#464646' height='800px' width='800px' version='1.1' id='XMLID_85_' xmlns='http://www.w3.org/2000/svg' xmlns:xlink='http://www.w3.org/1999/xlink' viewBox='0 0 24 24' enable-background='new 0 0 24 24' xml:space='preserve'> <path d='M21,24h-6v-6h6V24z M17,22h2v-2h-2V22z M15,22H6V8H3V0h8v8H8v4h7v2H8v6h7V22z M5,6h4V2H5V6z M21,16h-6v-6h6V16z M17,14h2 v-2h-2V14z'/> </svg>"; [DeclareRegister] public void registerRibbonItems() { RibbonBar ribbonBar = new RibbonBar(); var newTab = new Eplan.EplApi.Gui.RibbonBar().Tabs.FirstOrDefault(item => item.Name == m_TabName); if (newTab == null) //Tab noch nicht vorhanden, dann neu erzeugen { newTab = new Eplan.EplApi.Gui.RibbonBar().AddTab(m_TabName); } var commandGroup = newTab.CommandGroups.FirstOrDefault(item => item.Name == m_commandGroupName); if (commandGroup == null) //CommandGroup noch nicht vorhanden, dann neu erzeugen { commandGroup = newTab.AddCommandGroup(m_commandGroupName); } RibbonIcon ribbonIconNavigator = ribbonBar.AddIcon(m_SVGstringIconNavigator); //Icon festlegen commandGroup.AddCommand(m_commandName, "AutoSyncNavis", m_commandName, "AutoSync der Navigatoren ein- / ausschalten", ribbonIconNavigator); } [DeclareUnregister] public void unRegisterRibbonItems() { //Command entfernen var vTab = new Eplan.EplApi.Gui.RibbonBar().Tabs.FirstOrDefault(item => item.Name == m_TabName); if (vTab != null) { var commandGroup = vTab.CommandGroups.FirstOrDefault(item => item.Name == m_commandGroupName); if (commandGroup != null) { var command = commandGroup.Commands.Values.FirstOrDefault(item => item.Text == m_commandName); if (command != null) { command.Remove(); } //Wenn CommandGroup leer ist diese auch entfernen if (commandGroup.Commands.Count == 0) { commandGroup.Remove(); } } //Wenn Tab leer ist dieses auch entfernen if (vTab.Commands.Count == 0) { vTab.Remove(); } } //Einstellungen löschen DeleteSettings(); } [DeclareAction("AutoSyncNavis")] public void AutoSyncNavisAction() { Settings oSettings = new Settings(); string sAutoSyncState = string.Empty; if (oSettings.ExistSetting(sSettingName)) { sAutoSyncState = oSettings.GetStringSetting(sSettingName, 0); } //Prüfen ob AutoSync aktiviert ist if (sAutoSyncState == string.Empty | sAutoSyncState.ToUpper() != "ON") { //nicht aktiviert Decider eDecision = new Decider(); EnumDecisionReturn eAnswer = eDecision.Decide( EnumDecisionType.eYesNoDecision, "Soll das Auto-Synchronisieren der Navigatoren eingeschaltet werden?", "AutoSyncNavis", EnumDecisionReturn.eYES, EnumDecisionReturn.eNO, string.Empty, false, EnumDecisionIcon.eQUESTION); if (eAnswer == EnumDecisionReturn.eYES) { //Einstellung speichern SetSettings("ON"); } } else { Decider eDecision = new Decider(); EnumDecisionReturn eAnswer = eDecision.Decide( EnumDecisionType.eYesNoDecision, "Soll das Auto-Synchronisieren der Navigatoren ausgeschaltet werden?", "AutoSyncNavis", EnumDecisionReturn.eYES, EnumDecisionReturn.eNO, string.Empty, false, EnumDecisionIcon.eQUESTION); if (eAnswer == EnumDecisionReturn.eYES) { //Einstellung speichern SetSettings("OFF"); } } return; } //Einstellungen speichern private void SetSettings(string AutoSyncActive) { Settings oSettings = new Settings(); if (!oSettings.ExistSetting(sSettingName)) { oSettings.AddStringSetting(sSettingName, new string[] { }, new string[] { }, ISettings.CreationFlag.Insert); } oSettings.SetStringSetting(sSettingName, AutoSyncActive, 0); } //Einstellungen löschen public void DeleteSettings() { Settings oSettings = new Settings(); if (oSettings.ExistSetting(sSettingName)) { oSettings.DeleteSetting(sSettingName); new Decider().Decide(EnumDecisionType.eOkDecision, "Die Einstellung [" + sSettingName + "] wurde gelöscht.", "AutoSyncNavis", EnumDecisionReturn.eOK, EnumDecisionReturn.eOK, string.Empty, false, EnumDecisionIcon.eINFORMATION); } else { new Decider().Decide(EnumDecisionType.eOkDecision, "Die Einstellungen wurden nicht gefunden!", "AutoSyncNavis", EnumDecisionReturn.eOK, EnumDecisionReturn.eOK, string.Empty, false, EnumDecisionIcon.eFATALERROR); } } //Eine Element wurde markiert [DeclareEventHandler("onSelChanged")] public void MyEventOnSelChanged() { Settings oSettings = new Settings(); string sAutoSyncState = string.Empty; if (oSettings.ExistSetting(sSettingName)) { sAutoSyncState = oSettings.GetStringSetting(sSettingName, 0); } //Prüfen ob AutoSync aktiviert ist if (sAutoSyncState == string.Empty | sAutoSyncState.ToUpper() != "ON") { //Keine Aktion ausführen return; } else { //Setting existiert und AutoSync soll aktiviert werden new CommandLineInterpreter().Execute("XEsSyncPDDsAction"); } return; } //Prüft ob Eplan gestartet wurde [DeclareEventHandler("Eplan.EplApi.OnMainStart")] public void MyEventEplanStart() { Settings oSettings = new Settings(); string sAutoSyncState = string.Empty; //War AutoSync beim letzten mal aktiv? if (oSettings.ExistSetting(sSettingName)) { sAutoSyncState = oSettings.GetStringSetting(sSettingName, 0); //wenn ja ("ON") dann AutoSync aktivieren if (sAutoSyncState.ToUpper() == "ON") { new CommandLineInterpreter().Execute("XEsSyncPDDsAction"); } } return; } }
XPartsSetDataSourceAction: Artikelverwaltung Datenquelle wählen
Auch still und heimlich kam eine neue Action hinzu: XPartsSetDataSourceAction
.
Mit dieser Action kann schnell und einfach die aktive Artikeldatenbank eingestellt werden.
Ihr findet alle Parameter mit Beschreibung hier in der EPLAN Hilfe.
Lokale Datenbank
XPartsSetDataSourceAction /DataSourceType:0 /DataBaseFileName:C:\Users\Public\EPLAN\Data\Article\COMPANY_NAME\Database.alk
SQL Datenbank: Windows Authentifizierung
XPartsSetDataSourceAction /DataSourceType:1 /SqlLogin:0 /SqlServer:SQL_SERVER_NAME /SqlCatalog:SQL_DATABASE
SQL Datenbank: SQL Authentifizierung
XPartsSetDataSourceAction /DataSourceType:1 /SqlLogin:1 /SqlServer:SQL_SERVER_NAME /SqlCatalog:SQL_DATABASE /SqlUserName:SQL_USERNAME /SqlPassword:SQL_PASSWORD
eStock
XPartsSetDataSourceAction /DataSourceType:3 /CollectionName:ESTOCK_COLLECTION_NAME /CollectionId:ESTOCK_COLLECTION_ID