[34588f42] Feat: Tool 4 für Freigabe-Anfrage verschlankt

- Tool 4 (Freigabeanfragen) wurde von der Tool 3 Abhängigkeit (Supermailer-Analyse) getrennt.
- UI akzeptiert nun eine Liste im Format: E-Mail, Vorname, Kindernamen.
- Das vereinfacht den Workflow drastisch, wenn nur eine Handvoll Kunden manuell für Freigaben angefragt werden sollen.
This commit is contained in:
2026-04-17 20:56:13 +00:00
parent 9b4f80a44f
commit 3f6b27a89f

View File

@@ -103,36 +103,30 @@ function App() {
setIsSendingRelease(true);
setReleaseMessage("Bereite Senden vor...");
const targetEmails = releaseEmails.split(',').map(e => e.trim().toLowerCase()).filter(e => e);
const lines = releaseEmails.split('\n').filter(line => line.trim());
// We only send to emails that are in targetEmails and exist in reminderResult
const targetRows = reminderResult.filter(row => {
const rowEmail = row["E-Mail-Adresse Käufer"]?.trim().toLowerCase();
return targetEmails.includes(rowEmail);
});
if (targetRows.length === 0) {
setReleaseMessage("⚠️ Keine passenden E-Mails im Auftrag gefunden (bitte vorher Supermailer-Analyse starten).");
if (lines.length === 0) {
setReleaseMessage("⚠️ Bitte Daten eingeben.");
setIsSendingRelease(false);
return;
}
const emailsToSend = targetRows.map(row => {
// Split the buyer name to get first name
const fullName = row["Name Käufer"] || "";
const firstName = fullName.split(' ')[0] || "Liebe Eltern";
const emailsToSend = lines.map(line => {
const parts = line.split(',');
const to = parts[0] ? parts[0].trim().toLowerCase() : "";
const firstName = parts[1] ? parts[1].trim() : "Liebe Eltern";
const childrenNames = parts[2] ? parts[2].trim() : "Euren Kindern";
const kindergartenName = selectedJob ? selectedJob.name.replace(/\(JOB\d+\)\s*/, '') : "dem Kindergarten";
const childrenNames = row["Kindernamen"] || "Euren Kindern";
let subject = "Eure Bilder vom Kindergarten-Fotoshooting";
let body = `Guten Morgen ${firstName},<br><br>vielen Dank für Eure Teilnahme am Mini-Familien-Fotoshooting im Kindergarten ${kindergartenName} diese Woche. Die Bilder sind jetzt bereits online, ihr solltet bald eine Mail dazu erhalten. :)<br><br>Die Bilder von ${childrenNames} gefallen uns sehr gut, sie wirken auf den Bildern sehr selbstbewusst. Gerne würden wir diese in unserer Galerie auf www.kinderfotos-erding.de (Link: <a href="https://www.kinderfotos-erding.de/angebot/schulfotograf/#5134aec7-5498-49ab-b26e-73574510c90a">Beispiel ansehen</a>) veröffentlichen.<br><br>Um den rechtlichen Anforderungen (DSGVO) gerecht zu werden, müsstet Ihr noch dieses Formular auf unserer Website ausfüllen:<br><a href="https://www.kinderfotos-erding.de/angebot/schulfotograf/freigabe-zur-veroeffentlichung/"><b>Zum Formular zur Veröffentlichung</b></a><br><br>Das hilft uns wirklich sehr, damit andere einen besseren Eindruck von unserer Arbeit gewinnen.<br><br>Als kleines Dankeschön erhaltet Ihr im Anschluss einen Rabattcode über 25 € für Eure Bestellung. Diesen senden wir Euch per separater E-Mail zu, sobald das Formular ausgefüllt ist. Bitte wartet mit Eurer Bestellung, bis wir Euch den Rabattcode zugesendet haben.<br><br>Vielen Dank für Eure Unterstützung und Euer Vertrauen!<br><br>` + SIGNATURE_HTML;
return {
to: row["E-Mail-Adresse Käufer"],
to: to,
subject: subject,
body: body
};
});
}).filter(e => e.to);
setReleaseMessage(`Sende ${emailsToSend.length} Mails...`);
@@ -1018,15 +1012,16 @@ function App() {
{/* Send Requests */}
<div className="bg-gray-50 p-3 rounded-lg border border-gray-100">
<label className="text-[10px] font-bold text-gray-500 uppercase block mb-2">Ziel-E-Mails für Anfrage</label>
<label className="text-[10px] font-bold text-gray-500 uppercase block mb-2">Empfänger-Daten (Pro Zeile)</label>
<p className="text-[10px] text-gray-400 mb-2 leading-tight">
Die Daten (Namen) werden automatisch aus der Supermailer-Analyse gezogen. Bitte die Analyse oben ('CSV für Supermailer') vorher durchlaufen lassen, damit alle Käuferdaten bereitliegen.
Format: <b>E-Mail, Vorname Elternteil, Namen der Kinder</b><br/>
(z.B. <i>max@muster.de, Max, Moritz und Leni</i>)
</p>
<textarea
placeholder="z.B. max@muster.de, anna@test.de"
placeholder="max@muster.de, Max, Moritz und Leni&#10;anna@test.de, Anna, Lisa"
value={releaseEmails}
onChange={(e) => setReleaseEmails(e.target.value)}
className="w-full px-3 py-2 text-sm border border-gray-200 rounded-lg focus:ring-2 focus:ring-indigo-500 mb-2 h-20"
className="w-full px-3 py-2 text-sm border border-gray-200 rounded-lg focus:ring-2 focus:ring-indigo-500 mb-2 h-20 font-mono"
/>
<div className="flex items-center gap-2 mb-3 bg-white p-2 rounded-lg border border-gray-100">
@@ -1041,12 +1036,12 @@ function App() {
</div>
<button
onClick={handleSendRelease}
disabled={isSendingRelease || !releaseEmails.trim() || !reminderResult || !isGmailAuthenticated}
disabled={isSendingRelease || !releaseEmails.trim() || !isGmailAuthenticated}
className="w-full px-3 py-1.5 bg-indigo-600 text-white text-sm font-bold rounded-lg hover:bg-indigo-700 disabled:opacity-50 shadow-sm"
>
{isSendingRelease ? 'Sende...' : 'Anfrage-E-Mails jetzt senden'}
</button>
{!reminderResult && <p className="text-center text-[10px] mt-2 text-red-500">Bitte erst Tool 3 Analyse starten.</p>}
{!isGmailAuthenticated && <p className="text-center text-[10px] mt-2 text-red-500">Gmail nicht verbunden.</p>}
{releaseMessage && <p className="text-center text-xs mt-2 font-bold text-indigo-600">{releaseMessage}</p>}
</div>