PRINT+PLUS
  • Einleitung
  • Einrichtung
    • Installation
  • Aktualisierung
    • Aktualisierungseinführung
  • Lizenzierung
    • Lizenzierungseinführung
  • Funktionsweise von PRINT+PLUS
    • Einführung Funktionsweise
  • Gestalten von Vorlagen
    • Intro Vorlagen
    • Beispiel mit Rechnung
    • Formatierung
    • Spezielle Platzhalter für Datum, Ja/Nein-Felder, Bilder und HTML
    • Platzhalter für die Benutzerattribute von cobra CRM
    • Eigene Platzhalter
  • Einrichtung von Ausgabeformaten
    • Intro
    • Alle Einstellungen eines Ausgabeformats im Detail
    • Register "Allgemeine Konfiguration"
    • Register "Ausgangstabelle (Current)"
    • Register "Ausgangs-Vorlage"
    • Register "Übergeordnete Tabellen (Parent)"
    • Register "Untergeordnete Tabellen (Children)"
    • Register "Dokumente speichern"
    • Register "Filter-Dialog"
    • Register "Ergebnis-Verhalten"
    • Register "Skripte"
  • Ausgabe ausführen
    • Intro Ausgabe ausführen
  • AUSGABEN PER TASK AUSFÜHREN
    • Aufgaben dem Task zuweisen
    • Windows Aufgabenplanung für den Task einrichten
    • Besonderheiten in Skripten
  • Eingabemasken Steuerelement
  • Intro Eingabemasken Steuerelement
    • Steuerelement hinzufügen
  • Einbindung von Print+Plus in cobra Kampagnen
  • Intro Einbindung von Print+Plus in cobra Kampagnen
  • Grundlagen Skripting
    • C#
    • Skript-Events
    • Kontexte
    • Geladene Daten verwenden
    • Geladene Daten verändern
    • Datensätze anlegen
    • Eingabemaske öffnen
    • Eigene Werte ergänzen (Custom Values)
  • Beispielskripte
    • Nummer vergeben
    • PDF-Formulare füllen
    • PDF-Dokumente zusammenfügen
    • Generiertes Dokument via SMTP versenden
    • Weitere Ausgabe starten
    • Vorlage aus DMS-Feld holen
    • Felder für CRYPTO+PLUS verschlüsseln
    • Benutzerabhängige Drucker verwenden
    • Bilder in E-Mails einbinden
    • Zahlen in Worten ausschreiben
    • Datensatz-Bilder aus cobra einbetten
    • Ergebnisdokumente kopieren
    • Regionsspezifische Ausgabeformate
    • Andere Datenquelle-Objekte nutzen
    • DocuSign Integration
  • FAQs
    • Fehlermeldung Template konnte nicht geöffnet werden
    • DevExpress-Word-Exporter
      • Bilder in Vorlage
      • Bekannte Einschränkungen
      • Hinweise für Entwickler
  • Zusätzliches Tool im Zusammenhang mit PRINT+PLUS
    • Intro Zusätzliches Tool
Powered by GitBook
On this page
  • Konfiguration
  • Ideen
  • Tipps
  • Skript
  1. Beispielskripte

Benutzerabhängige Drucker verwenden

Dieses Skript zeigt, wie pro Benutzer ein anderer Drucker verwendet werden kann. In der GUI kann immer nur ein Drucker eingestellt werden.

Konfiguration

  • Dieses Skript funktioniert bei allen Exportern, die ein Dokument generieren (NICHT Skript-Exporter)

  • Das Skript wird als AfterLoadData ausgeführt

Ideen

  • Es wird zur Laufzeit die Konfiguration der eigenen Ausgabe verändert, ohne dass diese in der JSON-Datei gespeichert wird

  • Es lohnt sich evtl. das Skript direkt im Wurzelverzeichnis von PRINT+PLUS abzulegen, sodass es von mehreren Ausgabeformaten gemeinsam genutzt werden kann

Tipps

  • Um sicherzugehen, kann man den Drucker einmal über die PRINT+PLUS Oberfläche statisch auswählen. Dann die Schreibweise in der JSON-Datei der Ausgabe nachschauen.

Skript

// Version 5
namespace Ruthardt.PrintPlus.Skripting
{
	using System.Collections.Generic;
	using Ruthardt.CobraBase.Functions.Access.Ado;
	using Ruthardt.PrintPlus.Model.Interfaces;
	using Ruthardt.PrintPlus.Model.Container;

	public class Verschluesseln : IScriptAction
	{
		public void Execute(IPrintContext printContext, ICurrentContext currentContext, IChildContext childContext)
		{
			switch (printContext.CobraContext.UserShortname)
			{
				case "Benutzer1":
					printContext.Config.Printer1 = new PrinterContainer() { Name = "HP Drucker 123" };
					break;
				case "Benutzer2":
					printContext.Config.Printer1 = new PrinterContainer() { Name = "HP Drucker 321" };
					break;
				case "Benutzer3":
					// bei Netzwerkdruckern die ein \ im Namen haben 
					// muss in C# dies durch das vorgestellt @ gekennzeichnet werden
					// Alternativ sind die \ zu verdoppeln
					// Variante 1:
					printContext.Config.Printer1 = new PrinterContainer() { Name = @"\\server\drucker" };
					// Variante 2:
					printContext.Config.Printer1 = new PrinterContainer() { Name = "\\\\server\\drucker" };					break;					
			}
		}
	}
}
PreviousFelder für CRYPTO+PLUS verschlüsselnNextBilder in E-Mails einbinden

Last updated 1 year ago