aveeva Posted January 7, 2020 Share Posted January 7, 2020 I am using magento for sending mail with condition, My code: <?php class Gta_MerchantNotification_Model_Observer { public function merchantremainder($Observer) { $order = $Observer->getEvent()->getOrder(); $order_details = $order->getAllVisibleItems(); $itemData = array(); foreach ($order_details as $list) { $incrementid = $order->getIncrementId(); $sku = $list->getsku(); $name = $list->getName(); $price = $list->getPrice(); $Qty = $list->getQtyOrdered(); $extra = $order->getIncrementId(); $message = " <tr> <!-- <td>$incrementid</td> --> <td>$sku</td> <td>$name</td> <td>$price</td> <td>$Qty</td> </tr>"; $itemData[$list->getId()] = $message; } $finalMessage = " <p>Order Id : $incrementid</p> <table border='1'> <tr> <!-- <th>Id</th> --> <th>Sku</th> <th>Product name</th> <th>Price</th> <th>Qty Ordered</th> </tr>"; if (!empty($itemData)) { foreach ($itemData as $data) { $finalMessage .= $data; } $finalMessage .= "</table>"; $this->sendMail($finalMessage); } } public function sendMail($message) { $body ="$message"; $emailTemplate = Mage::getModel('core/email'); $emailTemplate->setFromName('abc'); $emailTemplate->setBody($body); $emailTemplate->setSubject("Custom Email from observer"); $emailTemplate->setType('html'); $emailTemplate->setToEmail('[email protected]'); $emailTemplate->send(); } } ?> Output : If order placed mail send to [email protected]. How to set email sender based on SKU $sku from order. I want : 1) If SKU starts with 2, email should go to the mail id [email protected], screenshot : 2) If SKU starts with 3, email should go to the mail id [email protected], screenshot : 3) If SKU starts with 4, email should go to the mail id [email protected], screenshot : FYI - If an order contains 10 items email should go separately based on SKU. But an order id the same must include all the emails. Quote Link to comment https://forums.phpfreaks.com/topic/309806-php-mail-function-how-to-set-sender-mail-id-based-on-if-condition/ Share on other sites More sharing options...
gw1500se Posted January 7, 2020 Share Posted January 7, 2020 I'm not sure what you are asking. If I understand, simply convert the integer to a string (strval) then test the first character of that strnig and take the appropriate action. Quote Link to comment https://forums.phpfreaks.com/topic/309806-php-mail-function-how-to-set-sender-mail-id-based-on-if-condition/#findComment-1573162 Share on other sites More sharing options...
aveeva Posted January 8, 2020 Author Share Posted January 8, 2020 PHP mail function how to set recipient mail id based on if condition? Quote Link to comment https://forums.phpfreaks.com/topic/309806-php-mail-function-how-to-set-sender-mail-id-based-on-if-condition/#findComment-1573181 Share on other sites More sharing options...
requinix Posted January 8, 2020 Share Posted January 8, 2020 1 hour ago, aveeva said: PHP mail function how to set recipient mail id based on if condition? Oh, I saw a thread about that a second ago... Here. That looks like it talks about your question exactly. Quote Link to comment https://forums.phpfreaks.com/topic/309806-php-mail-function-how-to-set-sender-mail-id-based-on-if-condition/#findComment-1573183 Share on other sites More sharing options...
Barand Posted January 8, 2020 Share Posted January 8, 2020 Seems like you need a couple of things 1 ) An array of email addresses (index = first digit of sku) $addys = [ 2 => '[email protected]', 3 => '[email protected]', 4 => '[email protected]' ]; 2 ) Alter the structure of your $itemData array to add the first digit of sku as a sub-index to separate each order into 3 groups $itemData[$orderNo][$skuFirst] = $message; Quote Link to comment https://forums.phpfreaks.com/topic/309806-php-mail-function-how-to-set-sender-mail-id-based-on-if-condition/#findComment-1573184 Share on other sites More sharing options...
aveeva Posted January 9, 2020 Author Share Posted January 9, 2020 Any help with my error, Code : <?php class Gta_MerchantNotification_Model_Observer { public function merchantremainder($Observer) { $order = $Observer->getEvent()->getOrder(); $order_details = $order->getAllVisibleItems(); $itemData = array(); foreach ($order_details as $list) { $incrementid = $order->getIncrementId(); $sku = $list->getsku(); $name = $list->getName(); $price = $list->getPrice(); $Qty = $list->getQtyOrdered(); $this->sendMailbasedOnSku($sku); $message = "<tr> <!-- <td>$incrementid</td> --> <td>$sku</td> <td>$name</td> <td>$price</td> <td>$Qty</td> </tr>"; $itemData[$list->getId()] = $message; } $finalMessage = " <p>Order Id : $incrementid</p> <table border='1'> <tr> <!-- <th>Id</th> --> <th>Sku</th> <th>Product name</th> <th>Price</th> <th>Qty Ordered</th> </tr>"; if (!empty($itemData)) { foreach ($itemData as $data) { $finalMessage .= $data; } $finalMessage .= "</table>"; $this->sendMail($finalMessage); } } public function sendMail($message) { $body = "$message"; $emailTemplate = Mage::getModel('core/email'); $emailTemplate->setFromName('Test mail'); $emailTemplate->setBody($body); $emailTemplate->setSubject("Custom Email from observer"); $emailTemplate->setType('html'); // $emailTemplate->setToEmail('[email protected]'); if($sku == '2') { $emailTemplate->setToEmail('[email protected]'); } elseif($sku == '3') { $emailTemplate->setToEmail('[email protected]'); } elseif($sku == '4') { $emailTemplate->setToEmail('[email protected]'); } else { $emailTemplate->setToEmail('[email protected]'); } $emailTemplate->send(); } public function sendMailbasedOnSku($sku) { // sku is 22302 $chk_sku=(int)substr($sku, 0, 1); if($chk_sku == '2') { $emailTemplate->setToEmail('[email protected]'); } elseif($chk_sku == '3') { $emailTemplate->setToEmail('[email protected]'); } elseif($chk_sku == '4') { $emailTemplate->setToEmail('[email protected]'); } else{ $emailTemplate->setToEmail('[email protected]'); } try{ return $emailTemplate->send(); Mage::getSingleton('core/session')->addSuccess('Your request has been sent'); } catch (Exception $e) { Mage::getSingleton('core/session')->addError($e->getMessage()); } } } ?> error : [09-Jan-2020 04:53:42 UTC] PHP Fatal error: Uncaught Error: Call to a member function setToEmail() on null in C:\wamp64\www\magento\app\code\local\Gta\MerchantNotification\Model\Observer.php:99 Stack trace: #0 C:\wamp64\www\magento\app\code\local\Gta\MerchantNotification\Model\Observer.php(15): Gta_MerchantNotification_Model_Observer->sendMailbasedOnSku('22') #1 C:\wamp64\www\magento\app\code\core\Mage\Core\Model\App.php(1358): Gta_MerchantNotification_Model_Observer->merchantremainder(Object(Varien_Event_Observer)) #2 C:\wamp64\www\magento\app\code\core\Mage\Core\Model\App.php(1337): Mage_Core_Model_App->_callObserverMethod(Object(Gta_MerchantNotification_Model_Observer), 'merchantremaind...', Object(Varien_Event_Observer)) #3 C:\wamp64\www\magento\app\Mage.php(448): Mage_Core_Model_App->dispatchEvent('checkout_submit...', Array) #4 C:\wamp64\www\magento\app\code\core\Mage\Checkout\Model\Type\Onepage.php(872): Mage::dispatchEvent('checkout_submit...', Array) #5 C:\wamp64\www\magento\app\code\core\Mage\Checkout\controllers\OnepageController.php(579): M in C:\wamp64\www\magento\app\code\local\Gta\MerchantNotification\Model\Observer.php on line 99 Quote Link to comment https://forums.phpfreaks.com/topic/309806-php-mail-function-how-to-set-sender-mail-id-based-on-if-condition/#findComment-1573196 Share on other sites More sharing options...
Barand Posted January 9, 2020 Share Posted January 9, 2020 2 hours ago, aveeva said: public function sendMailbasedOnSku($sku) $emailTemplate has not been defined inside that function and is, therefore, null. Quote Link to comment https://forums.phpfreaks.com/topic/309806-php-mail-function-how-to-set-sender-mail-id-based-on-if-condition/#findComment-1573198 Share on other sites More sharing options...
aveeva Posted January 9, 2020 Author Share Posted January 9, 2020 @Barand After added $emailTemplate = Mage::getModel('core/email'); mail working, but if condition not working. As per my condition if sku start with 2 mail should go to [email protected] but here mail received [email protected] (Final email id in my if condition). How to correct my script? Quote Link to comment https://forums.phpfreaks.com/topic/309806-php-mail-function-how-to-set-sender-mail-id-based-on-if-condition/#findComment-1573199 Share on other sites More sharing options...
aveeva Posted January 9, 2020 Author Share Posted January 9, 2020 Final code : <?php class Gta_MerchantNotification_Model_Observer { public function merchantremainder($Observer) { $order = $Observer->getEvent()->getOrder(); $order_details = $order->getAllVisibleItems(); $itemData = array(); foreach ($order_details as $list) { $incrementid = $order->getIncrementId(); $sku = $list->getsku(); $name = $list->getName(); $price = $list->getPrice(); $Qty = $list->getQtyOrdered(); $this->sendMailbasedOnSku($sku); $message = "<tr> <!-- <td>$incrementid</td> --> <td>$sku</td> <td>$name</td> <td>$price</td> <td>$Qty</td> </tr>"; $itemData[$list->getId()] = $message; } $finalMessage = " <p>Order Id : $incrementid</p> <table border='1'> <tr> <!-- <th>Id</th> --> <th>Sku</th> <th>Product name</th> <th>Price</th> <th>Qty Ordered</th> </tr>"; if (!empty($itemData)) { foreach ($itemData as $data) { $finalMessage .= $data; } $finalMessage .= "</table>"; $this->sendMail($finalMessage); } } public function sendMail($message) { $body = "$message"; $emailTemplate = Mage::getModel('core/email'); $emailTemplate->setFromName('Test mail'); $emailTemplate->setBody($body); $emailTemplate->setSubject("Custom Email from observer"); $emailTemplate->setType('html'); // $emailTemplate->setToEmail('[email protected]'); if($sku == '2') { $emailTemplate->setToEmail('[email protected]'); } elseif($sku == '3') { $emailTemplate->setToEmail('[email protected]'); } elseif($sku == '4') { $emailTemplate->setToEmail('[email protected]'); } else { $emailTemplate->setToEmail('[email protected]'); } $emailTemplate->send(); } public function sendMailbasedOnSku($sku) { $chk_sku=(int)substr($sku, 0, 1); $emailTemplate = Mage::getModel('core/email'); if($chk_sku == '2') { $emailTemplate->setToEmail('[email protected]'); } elseif($chk_sku == '3') { $emailTemplate->setToEmail('[email protected]'); } elseif($chk_sku == '4') { $emailTemplate->setToEmail('[email protected]'); } else{ $emailTemplate->setToEmail('[email protected]'); } try{ return $emailTemplate->send(); Mage::getSingleton('core/session')->addSuccess('Success message'); }catch (Exception $e) { Mage::getSingleton('core/session')->addError($e->getMessage()); } } } ?> Quote Link to comment https://forums.phpfreaks.com/topic/309806-php-mail-function-how-to-set-sender-mail-id-based-on-if-condition/#findComment-1573200 Share on other sites More sharing options...
Barand Posted January 9, 2020 Share Posted January 9, 2020 I suggested the $addys array to save you a lot of repetitive ifelse coding. Getting the email address to use becomes $chk_sku=substr($sku, 0, 1); $sendTo = $addys[$chk_sku] ?? '[email protected]'; Quote Link to comment https://forums.phpfreaks.com/topic/309806-php-mail-function-how-to-set-sender-mail-id-based-on-if-condition/#findComment-1573201 Share on other sites More sharing options...
aveeva Posted January 9, 2020 Author Share Posted January 9, 2020 How to declare more than one mail id, $chk_sku=substr($sku, 0, 1); $sendTo = $addys[$chk_sku] ?? '[email protected]'; Quote Link to comment https://forums.phpfreaks.com/topic/309806-php-mail-function-how-to-set-sender-mail-id-based-on-if-condition/#findComment-1573202 Share on other sites More sharing options...
aveeva Posted January 9, 2020 Author Share Posted January 9, 2020 (edited) @Barand Updated Code : <?php class Gta_MerchantNotification_Model_Observer { public function merchantremainder($Observer) { $order = $Observer->getEvent()->getOrder(); $order_details = $order->getAllVisibleItems(); $itemData = array(); foreach ($order_details as $list) { $incrementid = $order->getIncrementId(); $sku = $list->getsku(); $name = $list->getName(); $price = $list->getPrice(); $Qty = $list->getQtyOrdered(); $this->sendMailbasedOnSku($sku); $message = "<tr> <!-- <td>$incrementid</td> --> <td>$sku</td> <td>$name</td> <td>$price</td> <td>$Qty</td> </tr>"; $itemData[$list->getId()] = $message; } $finalMessage = " <p>Order Id : $incrementid</p> <table border='1'> <tr> <!-- <th>Id</th> --> <th>Sku</th> <th>Product name</th> <th>Price</th> <th>Qty Ordered</th> </tr>"; if (!empty($itemData)) { foreach ($itemData as $data) { $finalMessage .= $data; } $finalMessage .= "</table>"; $this->sendMailbasedOnSku($finalMessage); } } public function sendMailbasedOnSku($message) { $body = "$message"; $emailTemplate = Mage::getModel('core/email'); $emailTemplate->setFromName('Test mail'); $emailTemplate->setBody($body); $emailTemplate->setSubject("Custom Email from observer"); $emailTemplate->setType('html'); $chk_sku=(int)substr($sku, 0, 1); $emailTemplate = Mage::getModel('core/email'); if($chk_sku == '2') { $emailTemplate->setToEmail('[email protected]'); } elseif($chk_sku == '3') { $emailTemplate->setToEmail('[email protected]'); } elseif($chk_sku == '4') { $emailTemplate->setToEmail('[email protected]'); } else{ $emailTemplate->setToEmail('[email protected]'); } try{ $emailTemplate->send(); Mage::getSingleton('core/session')->addSuccess('Success message'); }catch (Exception $e) { Mage::getSingleton('core/session')->addError($e->getMessage()); } } } ?> Anything wrong? Edited January 9, 2020 by aveeva Quote Link to comment https://forums.phpfreaks.com/topic/309806-php-mail-function-how-to-set-sender-mail-id-based-on-if-condition/#findComment-1573203 Share on other sites More sharing options...
Barand Posted January 9, 2020 Share Posted January 9, 2020 +---------------------+ | | Yes | DOES IT WORK? +-----------------------+ | | | +----------+----------+ | | | | | | No | | | | | | | +---------------------+ +----------------+ | | | | | SOMETHING'S WRONG | | PROBABLY OK | | | | | +---------------------+ +----------------+ Quote Link to comment https://forums.phpfreaks.com/topic/309806-php-mail-function-how-to-set-sender-mail-id-based-on-if-condition/#findComment-1573205 Share on other sites More sharing options...
aveeva Posted January 10, 2020 Author Share Posted January 10, 2020 @Barand here i can see only one mail id, $chk_sku=substr($sku, 0, 1); $sendTo = $addys[$chk_sku] ?? '[email protected]'; How to add more than one mail id? Quote Link to comment https://forums.phpfreaks.com/topic/309806-php-mail-function-how-to-set-sender-mail-id-based-on-if-condition/#findComment-1573241 Share on other sites More sharing options...
aveeva Posted January 10, 2020 Author Share Posted January 10, 2020 getting error, <?php class Gta_MerchantNotification_Model_Observer { public function merchantremainder($Observer) { $order = $Observer->getEvent()->getOrder(); $order_details = $order->getAllVisibleItems(); $itemData = array(); foreach ($order_details as $list) { $incrementid = $order->getIncrementId(); $sku = $list->getsku(); $name = $list->getName(); $price = $list->getPrice(); $Qty = $list->getQtyOrdered(); $this->sendMailbasedOnSku($sku); $message = "<tr> <!-- <td>$incrementid</td> --> <td>$sku</td> <td>$name</td> <td>$price</td> <td>$Qty</td> </tr>"; // $itemData[$list->getId()] = $message; $itemData[$orderNo][$skuFirst] = $message; } $finalMessage = "<p>Order Id : $incrementid</p> <table border='1'> <tr> <!-- <th>Id</th> --> <th>Sku</th> <th>Product name</th> <th>Price</th> <th>Qty Ordered</th> </tr>"; if (!empty($itemData)) { foreach ($itemData as $data) { $finalMessage .= $data; } $finalMessage .= "</table>"; $this->sendMailbasedOnSku($finalMessage); } } public function sendMailbasedOnSku($message) { $body = "$message"; $emailTemplate = Mage::getModel('core/email'); $emailTemplate->setFromName('GIRI Test mail'); $emailTemplate->setBody($body); $emailTemplate->setSubject("Custom Email from observer"); $emailTemplate->setType('html'); $addys = [ 2 => '[email protected]', 3 => '[email protected]', 4 => '[email protected]' ]; // CHECK SKU FIRST DIGIT $chk_sku=(int)substr($sku, 0, 1); if($chk_sku == '2') { $sendTo = $addys[$chk_sku] ?? '[email protected]'; } elseif($chk_sku == '3') { $sendTo = $addys[$chk_sku] ?? '[email protected]'; } elseif($chk_sku == '4') { $sendTo = $addys[$chk_sku] ?? '[email protected]'; } else{ $emailTemplate->setToEmail('[email protected]'); } return $emailTemplate->send(); } } ?> Could you help me with above script. Quote Link to comment https://forums.phpfreaks.com/topic/309806-php-mail-function-how-to-set-sender-mail-id-based-on-if-condition/#findComment-1573243 Share on other sites More sharing options...
Barand Posted January 10, 2020 Share Posted January 10, 2020 $addys = [ 2 => '[email protected]', 3 => '[email protected]', 4 => '[email protected]' ]; // CHECK SKU FIRST DIGIT $chk_sku=(int)substr($sku, 0, 1); // GET THE APPROPRIATE EMAIL ADDRESS $sendTo = $addys[$chk_sku] ?? '[email protected]'; // USE IT $emailTemplate->setToEmail($sendTo); return $emailTemplate->send(); Quote Link to comment https://forums.phpfreaks.com/topic/309806-php-mail-function-how-to-set-sender-mail-id-based-on-if-condition/#findComment-1573244 Share on other sites More sharing options...
aveeva Posted January 10, 2020 Author Share Posted January 10, 2020 @Barand code : <?php class Gta_MerchantNotification_Model_Observer { public function merchantremainder($Observer) { $order = $Observer->getEvent()->getOrder(); $order_details = $order->getAllVisibleItems(); $itemData = array(); foreach ($order_details as $list) { $incrementid = $order->getIncrementId(); $sku = $list->getsku(); $name = $list->getName(); $price = $list->getPrice(); $Qty = $list->getQtyOrdered(); $this->sendMailbasedOnSku($sku); $message = "<tr> <!-- <td>$incrementid</td> --> <td>$sku</td> <td>$name</td> <td>$price</td> <td>$Qty</td> </tr>"; // $itemData[$list->getId()] = $message; $itemData[$orderNo][$skuFirst] = $message; } $finalMessage = "<p>Order Id : $incrementid</p> <table border='1'> <tr> <!-- <th>Id</th> --> <th>Sku</th> <th>Product name</th> <th>Price</th> <th>Qty Ordered</th> </tr>"; if (!empty($itemData)) { foreach ($itemData as $data) { $finalMessage .= $data; } $finalMessage .= "</table>"; $this->sendMailbasedOnSku($finalMessage); } } public function sendMailbasedOnSku($message) { $body = "$message"; $emailTemplate = Mage::getModel('core/email'); $emailTemplate->setFromName(' Test mail'); $emailTemplate->setBody($body); $emailTemplate->setSubject("Custom Email from observer"); $emailTemplate->setType('html'); $addys = [ 2 => '[email protected]', 3 => '[email protected]', 4 => '[email protected]' ]; // CHECK SKU FIRST DIGIT $chk_sku=(int)substr($sku, 0, 1); if($chk_sku == '2') { $sendTo = $addys[$chk_sku] ?? '[email protected]'; } elseif($chk_sku == '3') { $sendTo = $addys[$chk_sku] ?? '[email protected]'; } elseif($chk_sku == '4') { $sendTo = $addys[$chk_sku] ?? '[email protected]'; } else{ $emailTemplate->setToEmail('[email protected]'); } $emailTemplate->setToEmail($sendTo); return $emailTemplate->send(); } } ?> order not placed. Quote Link to comment https://forums.phpfreaks.com/topic/309806-php-mail-function-how-to-set-sender-mail-id-based-on-if-condition/#findComment-1573253 Share on other sites More sharing options...
aveeva Posted January 11, 2020 Author Share Posted January 11, 2020 Finally done with below script : <?php class Gta_MerchantNotification_Model_Observer { public function merchantremainder($Observer) { $order = $Observer->getEvent()->getOrder(); $order_details = $order->getAllVisibleItems(); $itemData = array(); foreach ($order_details as $list) { $incrementid = $order->getIncrementId(); $sku = $list->getsku(); $name = $list->getName(); $price = $list->getPrice(); $Qty = $list->getQtyOrdered(); // $this->sendMailbasedOnSku($sku); $message = "<tr> <!-- <td>$incrementid</td> --> <td>$sku</td> <td>$name</td> <td>$price</td> <td>$Qty</td> </tr>"; $itemData[$list->getId()] = $message; } $finalMessage = "<p>Order Id : $incrementid</p> <table border='1'> <tr> <!-- <th>Id</th> --> <th>Sku</th> <th>Product name</th> <th>Price</th> <th>Qty Ordered</th> </tr>"; if (!empty($itemData)) { foreach ($itemData as $data) { $finalMessage .= $data; } $finalMessage .= "</table>"; // $this->sendMail($finalMessage); $this->sendMailbasedOnSku($finalMessage,$sku); } } public function sendMail($message) { $body = "$message"; $emailTemplate = Mage::getModel('core/email'); $emailTemplate->setFromName('Test mail'); $emailTemplate->setBody($body); $emailTemplate->setSubject("Custom Email from observer"); $emailTemplate->setType('html'); // $emailTemplate->setToEmail('[email protected]'); if($sku == '2') { $emailTemplate->setToEmail('[email protected]'); } elseif($sku == '3') { $emailTemplate->setToEmail('[email protected]'); } elseif($sku == '4') { $emailTemplate->setToEmail('[email protected]'); } else { $emailTemplate->setToEmail('[email protected]'); } $emailTemplate->send(); } public function sendMailbasedOnSku($message, $sku) { $body = "$message"; $emailTemplate = Mage::getModel('core/email'); $emailTemplate->setFromName('Giri Test mail'); $emailTemplate->setBody($body); $emailTemplate->setSubject("Custom Email from observer"); $emailTemplate->setType('html'); $chk_sku=(int)substr($sku, 0, 1); if($chk_sku == '2') { $emailTemplate->setToEmail('[email protected]'); } elseif($chk_sku == '3') { $emailTemplate->setToEmail('[email protected]'); } elseif($chk_sku == '4') { $emailTemplate->setToEmail('[email protected]'); } else{ $emailTemplate->setToEmail('[email protected]'); } return $emailTemplate->send(); // try{ // return $emailTemplate->send(); // Mage::getSingleton('core/session')->addSuccess('Success message'); // }catch (Exception $e) // { // Mage::getSingleton('core/session')->addError($e->getMessage()); // } } } ?> But few correction are there, how to solve below logic, eg: If an order contains, 2 series of sku and 3 series of sku order mail received only by 3 series of sku mail not received 2 series of sku mail. another eg. If order placed with 3 products, sku- 22 ([email protected]), sku - 33 ([email protected]), sku -44 ([email protected]) order received only [email protected] My condition, if the order contains 2 products means to send a separate mail. like 2 series of sku : 3 series of sku : 4 Series of sku : now order received highest value of sku, Quote Link to comment https://forums.phpfreaks.com/topic/309806-php-mail-function-how-to-set-sender-mail-id-based-on-if-condition/#findComment-1573323 Share on other sites More sharing options...
Barand Posted January 11, 2020 Share Posted January 11, 2020 Your problems are mainly because you are trying to write code before you have learnt to read. In my first post I said you needed 2 things. The first you have totally disregarded despite my spoonfeeding you the required code. The second addresses the problem you are now having and has also been ignored. Good luck and goodbye. 1 Quote Link to comment https://forums.phpfreaks.com/topic/309806-php-mail-function-how-to-set-sender-mail-id-based-on-if-condition/#findComment-1573324 Share on other sites More sharing options...
aveeva Posted January 11, 2020 Author Share Posted January 11, 2020 Thank you for your support. Thanks ☺️ Quote Link to comment https://forums.phpfreaks.com/topic/309806-php-mail-function-how-to-set-sender-mail-id-based-on-if-condition/#findComment-1573325 Share on other sites More sharing options...
Barand Posted January 11, 2020 Share Posted January 11, 2020 One more attempt. Here's a script which puts the hints I gave you into practice. As you can see, it splits the ordered items into separate order depending on the SKU group SAMPLE: Code (read, understand what's going on and learn. Refer to php.net manual if you don't know what something does.) (Not an elseif()..elseif() to be found!) <?php const HOST = 'localhost'; # const USERNAME = '????'; # const PASSWORD = '????'; # const DATABASE = '????'; # These lines would # function pdoConnect($dbname=DATABASE) # normally be in { # $db = new PDO("mysql:host=".HOST.";dbname=$dbname;charset=utf8",USERNAME,PASSWORD); # an included file $db->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION); # $db->setAttribute(PDO::ATTR_DEFAULT_FETCH_MODE, PDO::FETCH_ASSOC); # $db->setAttribute(PDO::ATTR_EMULATE_PREPARES, false); # return $db; # } # $pdo = pdoConnect(); // // CREATE TEST DATA USED BY THIS EXAMPLE // $pdo->exec("CREATE TABLE IF NOT EXISTS aveeva ( id int not null auto_increment primary key, order_no int, sku int, product varchar(50), qty int ) "); $pdo->exec("REPLACE INTO aveeva (id, order_no, sku, product, qty) VALUES (1,1020345, 12345, 'Pair of left-footed socks', 2), (2,1020345, 35547, 'Square Hula hoop', 1), (3,1020345, 12346, 'Pair of right-footed socks', 2), (4,1020345, 62347, 'Pair of three-legged tights', 5), (5,1020345, 45501, 'String vest', 1), (6,1020345, 45501, 'Thermal long johns (red)', 2), (7,1020345, 22105, 'Staffordshire pot dog', 2), (8,1020345, 38962, '250 Kg dumbell set', 1), (9,1020345, 23176, 'Ming vase', 1), (10,1020345, 23194, 'Porcelain elephant', 1), (11,1020345, 38547, '0.5 metre yoga mat', 1) "); // DUMMY CLASS TO PROVIDE THE METHODS YOU USED class Magee { private $fromName; private $body; private $subject; private $type; private $sendTo; public function __construct() { } public function setFromName($str) { $this->fromName = $str; } public function setBody($str) { $this->body = $str; } public function setSubject($str) { $this->subject = $str; } public function setType($str) { $this->type = $str; } public function setToEmail($str) { $this->sendTo = $str; } public function send() { // // Instead of sending emails // we just build content // for demonstration output // $out = "<fieldset><legend>TO: {$this->sendTo}</legend> <label>From</label>{$this->fromName}<br> <label>Subject</label>{$this->subject}<br> {$this->body}<br> "; $out .= "</fieldset>"; return $out; } } #Magee // define email addresses for the sku groups const DEFAULT_ADDY = '[email protected]'; $addys = [ 2 => '[email protected]', 3 => '[email protected]', 4 => '[email protected]' ]; $res = $pdo->query("SELECT sku , product , qty , order_no FROM aveeva ORDER BY order_no, sku "); $orders = []; // // Split the items for each order // into groups depending the first // digit of their SKU // foreach ($res as $r) { $ono = array_pop($r); $sku1 = substr($r['sku'], 0, 1); if (!isset($addys[$sku1])) { $sku1 = 0; } $orders[$ono][$sku1][] = $r; } // // Build the email bodies from the array data // $emailsSent = ''; foreach ($orders as $ono => $odata) { foreach ($odata as $sku1 => $sdata) { $message = "<table border='1'> <caption>Order No: $ono</caption> <tr><th>SKU</th><th>Product</th><th>Quantity</th></tr>\n"; foreach ($sdata as $item) { $message .= "<tr><td>" . join("</td><td>", $item) . "</td></tr>\n"; } $message .= "</table>\n"; $emailsSent .= sendMailbasedOnSku($message, $addys, $sku1); } } function sendMailbasedOnSku($message, $addys, $sku1) { $emailTemplate = new Magee; $emailTemplate->setFromName('GIRI Test mail'); $emailTemplate->setBody($message); $emailTemplate->setSubject("Custom Email from observer"); $emailTemplate->setType('html'); // GET THE APPROPRIATE EMAIL ADDRESS $sendTo = $addys[$sku1] ?? DEFAULT_ADDY; // USE IT $emailTemplate->setToEmail($sendTo); return $emailTemplate->send(); } ?> <html> <head> <title>Example</title> <style type='text/css'> body { font-family: clibri, sans-serif; font-size: 11pt;} fieldset { width: 70%; margin: 16px auto; padding: 16px;} legend { background-color: black; color: white; padding: 4px;} label { display: inline-block; width: 120px; font-weight: 600;} table { width: 50%; margin: 16px auto; border-collapse: collapse;} th { background-color: black; color: white; padding: 8px;} td { padding: 4px 8px;} </style> </head> <body> <?=$emailsSent?> </body> </html> 1 Quote Link to comment https://forums.phpfreaks.com/topic/309806-php-mail-function-how-to-set-sender-mail-id-based-on-if-condition/#findComment-1573326 Share on other sites More sharing options...
Recommended Posts
Join the conversation
You can post now and register later. If you have an account, sign in now to post with your account.