magento add tax on custom attribute based price - magento

we sell bunch of product and we need to display each price product and entire box price.For that reason i have created attribute with each price and calling it on product page.So main price of product will be box price and each price will be display from attribute.but now i when i add tax i can see the main price with excluding and including tax but how to apply that tax on attribute based price?
this would be each product price
<?php echo $_product->getResource()->getAttribute('each_price')->getFrontend()- >getValue($_product)?>
this would be whole box price
<?php echo $this->getPriceHtml($_product, true);?>

some thing like this can be done to achive this.please look the code below
<?php $txrate= $_product->getData('tax_percent');
if($txrate!=""):
echo '<div class="each-inc-tax">';
$ech_price= $_product->getResource()->getAttribute('each_price')->getFrontend()->getValue($_product);
$tx=($txrate*$ech_price)/100;
$each_tax=$ech_price+$tx;
echo ' <b>Each Price Including Tax:</b> <b>'. $each_tax.'</b>';
echo '</div>';
endif;

I was using the MSRP attribute in my magento and storing the value excluding Tax, but wishing to display on the frontend including Tax.
I used the following code...
<?php
$_finalPriceExclTax = $this->helper('tax')->getPrice($_product, $_product->getPrice(), false);
$_finalPriceInclTax = $this->helper('tax')->getPrice($_product, $_product->getFinalPrice(), true);
$_taxpercent = $_finalPriceInclTax / $_finalPriceExclTax;
$_msrpPrice = $_product->getMsrp() * $_taxpercent;
?>

Related

Magento Applying tax (VAT) twice

I finally got VAT (tax) working on my site with prices being entered in the catalog INCLUSIVE of tax. Then the decision was made to input value EXCLUSIVE of tax. A little SQL allowed me to change all the stored prices, however, when the catalog pages are displayed, the wrong values are being shown... tax is being applied twice!
The tax rate is 20% and if a product has a tax exclusive price of £10, it's showing as tax exclusive, £12.00 and tax inclusive £14.40.
If I click on the product then the product page shows the correct values of £10 and £12.
The template displaying the catalog prices is catalog/product/price.phtml and in there I see code which I'm not understanding (i.e. I assume it's correct because this is a well used product but it doesn't make sense to me!)
I see (in template/catalog/product/price.phtml), first of all, variables being set...
$_price = $_taxHelper->getPrice($_product, $_product->getPrice())
$_finalPrice = $_taxHelper->getPrice($_product, $_product->getFinalPrice())
$_finalPriceInclTax = $_taxHelper->getPrice($_product, $_product->getFinalPrice(), true)
and debug statements show these to be returning £10.00 and £12.00 as expected - and then £14.40 (not as expected!).
Further on, where the value is output I see...
<span class="price-excluding-tax <?=$groupclass?>">
<span class="label"><?php echo $this->helper('tax')->__('Excl. Tax:') ?></span>
<span class="price" id="price-excluding-tax-<?php echo $_id ?><?php echo $this->getIdSuffix() ?>">
<?php if ($_finalPrice == $_price): ?>
<?php echo $_coreHelper->currency($_price, true, false) ?>
<?php else: ?>
<?php echo $_coreHelper->currency($_finalPrice, true, false) ?>
<?php endif; ?>
</span>
</span>
So it seems to me that the final price should actually be the exclusive price but is actually including the tax, which then gets added in again!
That appears to be the mechanism but I assume I've got a setting wrong somewhere or others would have been yelling long before now!
In the configuration I've got it set saying catalog prices exclude tax and country of origin and default destination both as UK.
So what am I missing?
This is Magento 1.7.0.2
I also spent a couple of days in this problem and I realized that sometimes totals are collected in the wrong order.
In particular in my case I was using catalog prices intended as including tax and I figured out Mage_Sales_Model_Quote_Address_Total_Subtotal::collect() ran before Mage_Tax_Model_Sales_Total_Quote_Subtotal::collect(), you can understand is the same issue looking at the table sales_flat_quote_item, when the base_price field is correctly set with the price value excluding tax and the price field is set with the price gross value (including tax).
You can check the execution order of collect method for each total in app/code/core/Mage/Sales/Model/Quote/Address.php around line #1004
/**
* Collect address totals
*
* #return Mage_Sales_Model_Quote_Address
*/
public function collectTotals()
{
Mage::dispatchEvent($this->_eventPrefix . '_collect_totals_before', array($this->_eventObject => $this));
foreach ($this->getTotalCollector()->getCollectors() as $model) {
// this is the loop where totals are collected
$model->collect($this);
}
Mage::dispatchEvent($this->_eventPrefix . '_collect_totals_after', array($this->_eventObject => $this));
return $this;
}
to fix this kind of issue you have to define in config.xml of a custom module totals dependencies defining <after> and <before> where necessary
<config>
...
<global>
<sales>
<quote>
<totals>
<tax_subtotal>
<class>tax/sales_total_quote_subtotal</class>
<after>subtotal,nominal,shipping,freeshipping</after>
<before>tax,discount</before>
</tax_subtotal>
</totals>
</quote>
</sales>
</global>
...
</config>
Thanks again Magento for making my day always more interesting!
In administration go to settings > sales > tax > calculation -
And here set “tax based on” to the last item (package origin, or something like that).
Terms are not perfect,
Or you can change setting accordingly as you want in your cart.
if your code it perfect then you are just missing some configuration on it.
Also you can go throw all the inner tabs fo tax calculation.
i hope it will sure help you

magento minimal price of grouped product

I want to display minimal price of grouped product in our magento online shop. I used
<?php echo $this->getPriceHtml($_product, true) ?>
But it does not work for grouped product. It only works for simple product.
$_product->getMinimalPrice () ;

Subtotal less coupons/discounts on order confirmation page of Magento

On the Order Confirmation page of Magento 1.5 (using the template , I have the a number of analytics conversion code scripts (like Google AdWords Conversion tracking).
The code that is currently used to get the subtotal is
<?php $order_id = Mage::getSingleton('checkout/session')->getLastRealOrderId(); ?>
<?php $order_details = Mage::getModel('sales/order')->loadByIncrementId($order_id); ?>
<?php $subtotal = $order_details->subtotal; ?>
And then the $subtotal variable is used throughout. The problem is that this is the subtotal BEFORE any coupons or discounts are applied. I need it to be the total AFTER coupons or discounts.
Can anyone help me with the code to get at that value?
You can call var_dump($order_details->debug()) to see all the data fields of the order object. I don't see anything that matches the subtotal with discount, but I do see a discount_amount field, which has the total discount amount (as a negative number); add this to your subtotal.
If you want the grand total, with discounts and shipping included, use the grand_total field.

Magento: Get Product Backordered Quantity in New Order Email

I'm trying to add the number of backorder products to the email template that comes out in the new order email.
So far I've managed to get the product but I just can't seem to get it's quantity. I've tried a variety of methods but nothing seems to work. Here is my latest attempt:
The file is app/design/frontend/base/default/template/email/order/items/order/default/phtml
<?php
// 1. Get Qty of Product in Store.
// 2. Get Qty of product from order
// 3. IF qty from order > qty in store then get number over
// 4. Display number over
$_sku = $this->getItem()->getSku();
$_product = Mage::getModel('catalog/product')->loadByAttribute('sku', $_sku);
//print_r($_product);
echo 'qty in shop: '.$qtyInStock = $_product->getStockItem()->getQty(); //debugging
echo 'qty ordered: '.$qtyOrdered = $_item->getQtyOrdered()*1; //debugging
?>
<?php if($qtyOrdered > $qtyInStock): $back_order = $qtyOrdered - $qtyInStock; ?>
<p>* This product is not available in the requested quantity. <?php echo $back_order; ?> of the item(s) will be backordered.</p>
<?php endif; ?>
I'm not finished with the logic yet. I'm just stuck on getting the products quantity.
$_product->getStockItem()->getQty();
Any help most appreciated.
Billy
Found a solution:
$_product = Mage::getModel('catalog/product')->loadByAttribute('sku', $_sku);
$stock_count = (int) Mage::getModel('cataloginventory/stock_item')->loadByProduct($_product)->getQty();
Seems quite roundabout but it does the job.
Feel free to suggest better...

Magento - show the stock indicator on product list

how can I show the stock indicator on Magento product list ?
Thanks a lot.
To show the quantity of items left in stock use this:
<?php echo (int) Mage::getModel('cataloginventory/stock_item')->loadByProduct($_product)->getQty(); ?>

Resources