Joomladay francophone 2018 à Paris 18 et 19 mai

Chèque boutique de 3ème type

Réduire
X
  • Filtrer
  • Heure
  • Afficher
Tout effacer
nouveaux messages

  • Chèque boutique de 3ème type

    Salut à tous,

    J'ai un problème avec les chèques boutiques. Je cherche à marquer sur la page d'accueil d'une boutique le code d'un chèque boutique de bienvenue que tout le monde peut utiliser mais qu'une seule fois. Or les chèques boutiques classiques disparaissent après la 1ere utilisation (donc ça ne convient pas) et les chèques permanents tout le monde peut s'en servir autant de fois qu'ils veulent

    Une idée pour palier à ce manque ?

    Merci à tous.
    Dernière édition par Kehel à 04/09/2008, 23h05

  • #2
    Bonjour,

    Par défaut , ce type de chèque boutique n'existe pas.
    alatak.net, Spécialiste VirtueMart et Développeur http://alatak.net

    Aucun MP. Je n'y réponds pas. Merci de votre compréhension.

    Commentaire


    • #3
      C'est bien ce que je pensais

      Est-ce que quelqu'un connaît un hack pour réaliser cela ? Si ça n'existe pas, je veux bien essayer de faire un hack mais je pense que j'aurais besoin de votre aide pour avancer.

      D'après ce que j'imagine il faudrait rajouter une table dans la base de données stockant pour chaque membre les numéros de chèque boutique déjà utilisés. Qu'en pensez-vous ?

      Commentaire


      • #4
        Bon ça y est j'ai fini le hack. ATTENTION : Il modifie la façon dont les chèques boutique permanents fonctionnent. Si vous êtes satisfait de la façon dont ils marchent n'appliquez pas ce hack.

        Bon on commence par la base de données. Ajoutez la table suivante à votre base de données :

        Code:
        CREATE TABLE `jos_vm_users_coupons` ( `user_id` int(11) NOT NULL, `coupon_id` int(16) NOT NULL) TYPE=MyISAM ;
        Ensuite, rajoutez dans le fichier /administrator/components/com_virtuemart/html/basket.php après la ligne 44 :

        Code:
        $vars["user_id"] = $_SESSION['auth']['user_id']; // Permet de faire passer l'id utilisateur à la fonction process_coupon_code
        Editez ensuite le fichier /administrator/components/com_virtuemart/classes/ps_coupon.php. Nous allons modifier la fonction process_coupon_code qui se trouve à la fin du fichier.

        Code:
        /* function to process a coupon_code entered by a user */ 
        function process_coupon_code( $d ) {
        	global $VM_LANG, $vmLogger;
        	/* init the database */
        	$coupon_db =& new ps_DB;
        
        	/* we need some functions from the checkout module */
        	require_once( CLASSPATH . "ps_checkout.php" );
        	$checkout =& new ps_checkout();
        	$d['coupon_code'] = trim(mosGetParam( $_REQUEST, 'coupon_code' ));
        	$coupon_id = mosGetParam( $_SESSION, 'coupon_id', null );
        
        	if( $coupon_id ) {
        	    /* the query to select the coupon coupon_code */
        	    $q = "SELECT coupon_id, percent_or_total, coupon_value, coupon_montantmini, coupon_type FROM #__{vm}_coupons WHERE coupon_id = '".$coupon_id."' ";
        	}
        	else {
        	    /* the query to select the coupon coupon_code */
        	    $q = "SELECT coupon_id, percent_or_total, coupon_value, coupon_montantmini, coupon_type FROM #__{vm}_coupons WHERE coupon_code = '".$d['coupon_code']."' ";
        	}
        	/* make the query */
        	$coupon_db->query($q);
        
        	/* see if we have any fields returned */
        	if ($coupon_db->num_rows() > 0)
        	{
        		/* we have a record */
        		/****************************** Début Hack ******************************/
        		/** Si le coupon a déjà été utilisé par l'utilisateur courant c'est noté dans la table jos_vm_users_coupons **/
        		$q = "SELECT * FROM #__{vm}_users_coupons WHERE coupon_id = ".$coupon_db->f("coupon_id")." AND user_id = ".$d['user_id'];
        		/** Création d'une nouvelle instance de base de données pour ne pas perdre le résultat de la requête précedente **/
        		$users_coupons_db =& new ps_DB;
        		$users_coupons_db->query($q);
        		if ($users_coupons_db->num_rows() == 0)
        		{
        			/** Aucun enregistrement n'est retourné -> cet utilisateur n'a pas encore utilisé ce coupon. **/
        			/** On le note maintenant dans la table jos_vm_users_coupons pour éviter une réutilisation **/
        			$q = "INSERT INTO #__{vm}_users_coupons (user_id, coupon_id) VALUES (".$d['user_id'].", ".$coupon_db->f("coupon_id").")";
        			$users_coupons_db->query($q);
        			/****************************** Fin Hack ******************************/
        			...
        			...
        		}
        		else   /****************************** Début Hack ******************************/
        		{
        			/** Ce coupon a déjà été utilisé par ce client **/
        			$_REQUEST['coupon_error'] = $VM_LANG->_PHPSHOP_COUPON_ALREADY_USED;
        			return false;
        		}      /****************************** Fin Hack ******************************/
        Pour finir ajoutez un message d'erreur dans le fichier /administrator/components/com_virtuemart/languages/french.php au niveau des messages concernant les coupons :

        var $_PHPSHOP_COUPON_ALREADY_USED = 'Vous avez déjà utilisé ce chèque boutique !';

        Je ne sais pas si c'est codé super propre, ou si ça respecte parfaitement les standards joomla, mais bon ça fonctionne.

        J'espère que cela pourra aider quelques uns d'entre vous.
        Dernière édition par Kehel à 22/09/2008, 16h56

        Commentaire


        • #5
          Envoyé par Kehel Voir le message
          Je ne sais pas si c'est codé super propre, ou si ça respecte parfaitement les standards joomla, mais bon ça fonctionne.

          J'espère que cela pourra aider quelques uns d'entre vous.
          Ca m'a l'air bien ce code !!!! Bravo !

          Commentaire


          • #6
            Bonjour,
            Ce hack m'intéresse fortement mais je voudrais savoir si ce hack fonctionne sur virtuemart 1.0.14 ?
            Merci d'avance.
            Joomla! 2.5.19 - Template ja_elastica - Virtuemart 2.6

            Commentaire


            • #7
              Bonjour,
              Pour mon site www.balkal.fr ce hack m'intéresse mais je voudrais savoir s'il fonctionne sous Joomla 1.0.15 et VM 1.0.14 ?
              Comment faire pour ajouter la table :
              Code:
              CREATE TABLE `jos_vm_users_coupons` ( `user_id` int(11) NOT NULL, `coupon_id` int(16) NOT NULL) TYPE=MyISAM ;
              à ma base de donnée ?
              Merci d'avance pour votre aide.
              Joomla! 2.5.19 - Template ja_elastica - Virtuemart 2.6

              Commentaire

              Annonce

              Réduire
              1 sur 2 < >

              C'est [Réglé] et on n'en parle plus ?

              A quoi ça sert ?
              La mention [Réglé] permet aux visiteurs d'identifier rapidement les messages qui ont trouvé une solution.

              Merci donc d'utiliser cette fonctionnalité afin de faciliter la navigation et la recherche d'informations de tous sur le forum.

              Si vous deviez oublier de porter cette mention, nous nous permettrons de le faire à votre place... mais seulement une fois
              Comment ajouter la mention [Réglé] à votre discussion ?
              1 - Aller sur votre discussion et éditer votre premier message :


              2 - Cliquer sur la liste déroulante Préfixe.

              3 - Choisir le préfixe [Réglé].


              4 - Et voilà… votre discussion est désormais identifiée comme réglée.

              2 sur 2 < >

              Assistance au forum - Outil de publication d'infos de votre site

              Compatibilité: PHP 4.1,PHP4, 5, 6DEV MySQL 3.2 - 5.5 MySQLi from 4.1 ( @ >=PHP 4.4.9)

              Support Version de Joomla! : | J!3.0 | J!2.5.xx | J!1.7.xx | J!1.6.xx | J1.5.xx | J!1.0.xx |

              Version française (FR) D'autres versions sont disponibles depuis la version originale de FPA

              UTILISER À VOS PROPRES RISQUES :
              L'exactitude et l'exhaustivité de ce script ainsi que la documentation ne sont pas garanties et aucune responsabilité ne sera acceptée pour tout dommage, questions ou confusion provoquée par l'utilisation de ce script.

              Problèmes connus :
              FPA n'est actuellement pas compatible avec des sites Joomla qui ont eu leur fichier configuration.php déplacé en dehors du répertoire public_html.

              Installation :

              1. Téléchargez l'archive souhaitée : http://afuj.github.io/FPA/

              Archive zip : https://github.com/AFUJ/FPA/zipball/master

              2. Décompressez le fichier de package téléchargé sur votre propre ordinateur (à l'aide de WinZip ou d'un outil de décompression natif).

              3. Lisez le fichier LISEZMOI inclus pour toutes les notes de versions spécifiques.

              4. LIRE le fichier de documentation inclus pour obtenir des instructions d'utilisation détaillées.

              5. Téléchargez le script fpa-fr.php à la racine de votre site Joomla!. C'est l'endroit que vous avez installé Joomla et ce n'est pas la racine principale de votre serveur. Voir les exemples ci-dessous.

              6. Exécutez le script via votre navigateur en tapant: http:// www. votresite .com/ fpa-fr.php
              et remplacer www. votresite .com par votre nom de domaine


              Exemples:
              Joomla! est installé dans votre répertoire web et vous avez installé la version française du fichier FPA:
              Télécharger le script fpa-fr.php dans: /public_html/
              Pour executer le script: http://www..com/fpa-fr.php

              Joomla! est installé dans un sous-répertoire nommé "cms" et vous avez installé la version française du fichier FPA:
              Télécharger le script fpa-fr.php dans: /public_html/cms/
              Pour executer le script: http://www..com/cms/fpa-fr.php

              En raison de la nature très sensible de l'information affichée par le script FPA, il doit être retiré immédiatement du serveur après son utilisation.

              Pour supprimer le script de votre site, utilisez le lien de script de suppression fourni en haut de la page du script. Si le lien de suppression échoue pour supprimer le script, utilisez votre programme FTP pour le supprimer manuellement ou changer le nom une fois que le script a généré les données du site et le message publié sur le forum. Si le script est toujours présent sur le site, il peut être utilisé pour recueillir suffisamment d'informations pour pirater votre site. Le retrait du script empêche des étrangers de l'utiliser pour jeter un oeil à la façon dont votre site est structuré et de détecter les défauts qui peuvent être utilisé à vos dépends.
              Voir plus
              Voir moins
              Travaille ...
              X