Shopsystem ShopPilot Shoploesung Diskussionen und Infos zum Shopsystem ShopPilot
Willkommen Gast. Bitte einloggen oder registrieren.
Februar 08, 2012, 00:36:44

Einloggen mit Benutzername, Passwort und Sitzungslänge
Suche:     Erweiterte Suche
5208 Beiträge in 1408 Themen von 330 Mitglieder
Neuestes Mitglied: spraytool
* Übersicht Hilfe Login Registrieren
+  Diskussionen und Infos zum Shopsystem ShopPilot
|-+  ShopPilot
| |-+  Shopbetrieb
| | |-+  Gutschein auf Guthabenkonto buchen
0 Mitglieder und 1 Gast betrachten dieses Thema. « vorheriges nächstes »
Seiten: [1] Drucken
Autor Thema: Gutschein auf Guthabenkonto buchen  (Gelesen 750 mal)
dobra
Global Moderator
Hero Member
*****

Lob: 18
Offline Offline

Beiträge: 1167


WWW
« am: Dezember 13, 2009, 08:33:11 »

Aufgabe:
Der Kunde soll (Wert)Gutscheine auf sein Konto buchen können
(wie es z.B. bei Amazon gemacht werden kann)

Lösung:

1) ein *echtes* Guthabenkonto für eingelogte Kunden anlegen
(s. http://www.shoppilot.net/pf/index.php?topic=1159.msg4308#msg4308)

2) ein Infoseite anlegen, auf der der Kunde die Gutscheinnr. eingeben und auf sein Konto buchen kann und diese Seite - sinnvollerweise nur für eingelogte Kunden sichtbar - verlinken.

Code auf dieser Seite
Code:
<!--spmacro:module(gutschein)
sub buchen {
if (length($main::userid)) {
my $pre = ssp::db_get_prefix();
my $USR = $pre . "USR";
my $ITEM = $pre . "ITEM";
my $kdnr = ssp::get_var_user("kundennr");
my $gscode = ssp::qform(ssp::get_var_form('gscode')) ;
my $jetzt = time();
my $showgsum;
my $showsum2;
my $gsum;

ssp::readSQLData(qq|SELECT GUTSCHBETR  FROM $USR WHERE KUNDENNR = '$kdnr'|, "GUTSCHBETR ");
my $wert =  ssp::get_var_db('GUTSCHBETR ',0);

    ssp::readSQLData("SELECT PRICE FROM $ITEM WHERE ITEMID='$gscode' AND (STAFP2 >='1' OR STAFP2 = '') AND (STAFP4 > $jetzt OR STAFP3 = '0')","PRICE");

            $gsum = ssp::get_var_db("PRICE",0);
$gsum =~ s/-//g;
$showgsum = main::fp($gsum);
if (length($gsum) && $gsum ne "undefined") {
if ($gsum > 0) {
$showgsum = qq|Der Betrag von $showgsum wurde Ihrem Konto gutgeschrieben|;
}
}
else {
if (length($gscode) && $gscode ne "undefined") {$showgsum = qq|ungültiger Code, Gutschein bereits eingelöst oder abgelaufen|; }
}

$gsum2 = $gsum + $wert;
$showsum2 = main::fp($gsum2);

if (length($gsum) && $gsum ne "undefined") {
my $sql = qq|UPDATE $USR SET GUTSCHBETR  = "$gsum2" WHERE KUNDENNR = '$kdnr'|;
ssp::exec_sql($sql, 1);
my $sql2 = qq|UPDATE $ITEM SET STAFP2 = "0" WHERE ITEMID = '$gscode'|;
ssp::exec_sql($sql2, 1);
ssp::db_update_usr($kdnr,"GUTSCHBETR ",$gsum2)
}

main::mprint ("$showgsum <br><br> <b>Ihr aktuelles Guthaben: $showsum2</b>");
}
else { main::mprint ("Sie müssen eingelogt sein, um Gutscheine auf Ihr Konto buchen zu können!"); }
}
-->

Im HTML-Bereich dann das Formular
Code:
       <form Method="Post" name="gsgebucht" action="__xxpath__?showbynamegsbuchen" autocomplete="off">
<b>Gutschein-Nr:</b>
   <input type="text" name="gscode" size="18">
            <input type="submit" value="auf Guthabenkonto buchen">
</form>
<br> __gutschein::buchen__

Wenn die Infoseite nicht "gsbuchen" heißt, muß das showbynamegsbuchen entsprechend angepasst werden.

Wie funktioniert es?
Kunde gibt hier seine GS-Nr. ein wie im Warenkorb.
Ist der GS OK (also in der DB vorhanden, noch nicht eingelöst oder abgelaufen) wird der Wert auf sein Guthabenkonto gebucht und der GS in der DB als "eingelöst" eingetragen.
(er soll ihn ja schließlich nicht nochmal im WK einlösen können  Wink)
Auf der "Gutschein buchen" Seite wird das aktuelle Guthaben und im Erfolgsfall der gebuchte GS-Wert ausgegeben.
Ist der GS-Code falsch (oder schon eingelöst oder abgelaufen) wird die entsprechende Fehlermeldung angezeigt

Im WK wird das Guthaben automatisch vom Rechnungsbetrag abgezogen bzw. wenn Rechnungsbetrag kleiner als Guthaben dieses aktualisiert wie schon bei "echtes Guthabenkonto bauen" beschrieben.
Neu ist jetzt nur, dass der Kunde eben Gutscheine selber auf sein Konto buchen kann.

Möchte man dass NUR Wertgutscheine aber keine Promotion-GS gebucht werden können, muss man diese mit einer bestimmten Zeichenfolge kennzeichnen und als Bedingung abfragen.

Beispiel:
Promotion-GS beginnen mit _GS_pr....
Code:
my $gscode = ssp::qform(ssp::get_var_form('gscode')) ;

if ($gscode !~ /^_GS_pr/)  {
...
...
}
else {main::mprint ("<br>Promotion-GS können nur im Warenkorb eingelöst werden!"); }
« Letzte Änderung: Dezember 13, 2009, 09:08:01 von dobra » Gespeichert

Seiten: [1] Drucken 
« vorheriges nächstes »
Gehe zu:  

mysitelist Impressum Powered by SMF 1.1.16 | SMF © 2006, Simple Machines Prüfe XHTML 1.0 Prüfe CSS