How to sort product collection on stock status












1















I want to sort product collection on category page so that the in stock products shall appear before out of stock products. All the out of stock products will be displayed after the in stock products. I have already rewritten the Mage_Product_Block_List block. After rewriting I have tried the following:



protected function _getProductCollection()
{
if (is_null($this->_productCollection)) {
$layer = $this->getLayer();
/* @var $layer Mage_Catalog_Model_Layer */
if ($this->getShowRootCategory()) {
$this->setCategoryId(Mage::app()->getStore()->getRootCategoryId());
}

// if this is a product view page
if (Mage::registry('product')) {
// get collection of categories this product is associated with
$categories = Mage::registry('product')->getCategoryCollection()
->setPage(1, 1)
->load();
// if the product is associated with any category
if ($categories->count()) {
// show products from this category
$this->setCategoryId(current($categories->getIterator()));
}
}

$origCategory = null;
if ($this->getCategoryId()) {
$category = Mage::getModel('catalog/category')->load($this->getCategoryId());
if ($category->getId()) {
$origCategory = $layer->getCurrentCategory();
$layer->setCurrentCategory($category);
$this->addModelTags($category);
}
}
**$this->_productCollection = $layer->getProductCollection()->addAttributeToSort('stock_status', desc);**

$this->prepareSortableFieldsByCategory($layer->getCurrentCategory());

if ($origCategory) {
$layer->setCurrentCategory($origCategory);
}
}

return $this->_productCollection;
}









share|improve this question
















bumped to the homepage by Community 2 days ago


This question has answers that may be good or bad; the system has marked it active so that they can be reviewed.
















  • can you please provide me code?? what you have tried so far

    – Murtuza Zabuawala
    Sep 3 '16 at 8:12











  • I have also tried to sort with inventory_stock_availability, is_in_stock, etc. and none worked out for me.

    – Abhishek Dhanraj Shahdeo
    Sep 3 '16 at 8:22











  • any update on this??

    – Murtuza Zabuawala
    Sep 5 '16 at 8:05











  • Try My answer and let me know

    – Murtuza Zabuawala
    Sep 6 '16 at 16:38
















1















I want to sort product collection on category page so that the in stock products shall appear before out of stock products. All the out of stock products will be displayed after the in stock products. I have already rewritten the Mage_Product_Block_List block. After rewriting I have tried the following:



protected function _getProductCollection()
{
if (is_null($this->_productCollection)) {
$layer = $this->getLayer();
/* @var $layer Mage_Catalog_Model_Layer */
if ($this->getShowRootCategory()) {
$this->setCategoryId(Mage::app()->getStore()->getRootCategoryId());
}

// if this is a product view page
if (Mage::registry('product')) {
// get collection of categories this product is associated with
$categories = Mage::registry('product')->getCategoryCollection()
->setPage(1, 1)
->load();
// if the product is associated with any category
if ($categories->count()) {
// show products from this category
$this->setCategoryId(current($categories->getIterator()));
}
}

$origCategory = null;
if ($this->getCategoryId()) {
$category = Mage::getModel('catalog/category')->load($this->getCategoryId());
if ($category->getId()) {
$origCategory = $layer->getCurrentCategory();
$layer->setCurrentCategory($category);
$this->addModelTags($category);
}
}
**$this->_productCollection = $layer->getProductCollection()->addAttributeToSort('stock_status', desc);**

$this->prepareSortableFieldsByCategory($layer->getCurrentCategory());

if ($origCategory) {
$layer->setCurrentCategory($origCategory);
}
}

return $this->_productCollection;
}









share|improve this question
















bumped to the homepage by Community 2 days ago


This question has answers that may be good or bad; the system has marked it active so that they can be reviewed.
















  • can you please provide me code?? what you have tried so far

    – Murtuza Zabuawala
    Sep 3 '16 at 8:12











  • I have also tried to sort with inventory_stock_availability, is_in_stock, etc. and none worked out for me.

    – Abhishek Dhanraj Shahdeo
    Sep 3 '16 at 8:22











  • any update on this??

    – Murtuza Zabuawala
    Sep 5 '16 at 8:05











  • Try My answer and let me know

    – Murtuza Zabuawala
    Sep 6 '16 at 16:38














1












1








1








I want to sort product collection on category page so that the in stock products shall appear before out of stock products. All the out of stock products will be displayed after the in stock products. I have already rewritten the Mage_Product_Block_List block. After rewriting I have tried the following:



protected function _getProductCollection()
{
if (is_null($this->_productCollection)) {
$layer = $this->getLayer();
/* @var $layer Mage_Catalog_Model_Layer */
if ($this->getShowRootCategory()) {
$this->setCategoryId(Mage::app()->getStore()->getRootCategoryId());
}

// if this is a product view page
if (Mage::registry('product')) {
// get collection of categories this product is associated with
$categories = Mage::registry('product')->getCategoryCollection()
->setPage(1, 1)
->load();
// if the product is associated with any category
if ($categories->count()) {
// show products from this category
$this->setCategoryId(current($categories->getIterator()));
}
}

$origCategory = null;
if ($this->getCategoryId()) {
$category = Mage::getModel('catalog/category')->load($this->getCategoryId());
if ($category->getId()) {
$origCategory = $layer->getCurrentCategory();
$layer->setCurrentCategory($category);
$this->addModelTags($category);
}
}
**$this->_productCollection = $layer->getProductCollection()->addAttributeToSort('stock_status', desc);**

$this->prepareSortableFieldsByCategory($layer->getCurrentCategory());

if ($origCategory) {
$layer->setCurrentCategory($origCategory);
}
}

return $this->_productCollection;
}









share|improve this question
















I want to sort product collection on category page so that the in stock products shall appear before out of stock products. All the out of stock products will be displayed after the in stock products. I have already rewritten the Mage_Product_Block_List block. After rewriting I have tried the following:



protected function _getProductCollection()
{
if (is_null($this->_productCollection)) {
$layer = $this->getLayer();
/* @var $layer Mage_Catalog_Model_Layer */
if ($this->getShowRootCategory()) {
$this->setCategoryId(Mage::app()->getStore()->getRootCategoryId());
}

// if this is a product view page
if (Mage::registry('product')) {
// get collection of categories this product is associated with
$categories = Mage::registry('product')->getCategoryCollection()
->setPage(1, 1)
->load();
// if the product is associated with any category
if ($categories->count()) {
// show products from this category
$this->setCategoryId(current($categories->getIterator()));
}
}

$origCategory = null;
if ($this->getCategoryId()) {
$category = Mage::getModel('catalog/category')->load($this->getCategoryId());
if ($category->getId()) {
$origCategory = $layer->getCurrentCategory();
$layer->setCurrentCategory($category);
$this->addModelTags($category);
}
}
**$this->_productCollection = $layer->getProductCollection()->addAttributeToSort('stock_status', desc);**

$this->prepareSortableFieldsByCategory($layer->getCurrentCategory());

if ($origCategory) {
$layer->setCurrentCategory($origCategory);
}
}

return $this->_productCollection;
}






magento-1.9 stock-status






share|improve this question















share|improve this question













share|improve this question




share|improve this question








edited Sep 3 '16 at 8:20







Abhishek Dhanraj Shahdeo

















asked Sep 3 '16 at 8:02









Abhishek Dhanraj ShahdeoAbhishek Dhanraj Shahdeo

2972722




2972722





bumped to the homepage by Community 2 days ago


This question has answers that may be good or bad; the system has marked it active so that they can be reviewed.







bumped to the homepage by Community 2 days ago


This question has answers that may be good or bad; the system has marked it active so that they can be reviewed.















  • can you please provide me code?? what you have tried so far

    – Murtuza Zabuawala
    Sep 3 '16 at 8:12











  • I have also tried to sort with inventory_stock_availability, is_in_stock, etc. and none worked out for me.

    – Abhishek Dhanraj Shahdeo
    Sep 3 '16 at 8:22











  • any update on this??

    – Murtuza Zabuawala
    Sep 5 '16 at 8:05











  • Try My answer and let me know

    – Murtuza Zabuawala
    Sep 6 '16 at 16:38



















  • can you please provide me code?? what you have tried so far

    – Murtuza Zabuawala
    Sep 3 '16 at 8:12











  • I have also tried to sort with inventory_stock_availability, is_in_stock, etc. and none worked out for me.

    – Abhishek Dhanraj Shahdeo
    Sep 3 '16 at 8:22











  • any update on this??

    – Murtuza Zabuawala
    Sep 5 '16 at 8:05











  • Try My answer and let me know

    – Murtuza Zabuawala
    Sep 6 '16 at 16:38

















can you please provide me code?? what you have tried so far

– Murtuza Zabuawala
Sep 3 '16 at 8:12





can you please provide me code?? what you have tried so far

– Murtuza Zabuawala
Sep 3 '16 at 8:12













I have also tried to sort with inventory_stock_availability, is_in_stock, etc. and none worked out for me.

– Abhishek Dhanraj Shahdeo
Sep 3 '16 at 8:22





I have also tried to sort with inventory_stock_availability, is_in_stock, etc. and none worked out for me.

– Abhishek Dhanraj Shahdeo
Sep 3 '16 at 8:22













any update on this??

– Murtuza Zabuawala
Sep 5 '16 at 8:05





any update on this??

– Murtuza Zabuawala
Sep 5 '16 at 8:05













Try My answer and let me know

– Murtuza Zabuawala
Sep 6 '16 at 16:38





Try My answer and let me know

– Murtuza Zabuawala
Sep 6 '16 at 16:38










1 Answer
1






active

oldest

votes


















0














you can not do as



$this->_productCollection = $layer->getProductCollection()->addAttributeToSort('stock_status', desc);


To achieve this you have to do left join



$this->_productCollection = $layer->getProductCollection()->joinLeft(array('bs'=>'cataloginventory/stock_status'), 'bs.product_id = e.entity_id', array('stock_status' => 'bs.stock_status'))->order("stock_status desc"); 


try this and let me know its working or not






share|improve this answer

























    Your Answer








    StackExchange.ready(function() {
    var channelOptions = {
    tags: "".split(" "),
    id: "479"
    };
    initTagRenderer("".split(" "), "".split(" "), channelOptions);

    StackExchange.using("externalEditor", function() {
    // Have to fire editor after snippets, if snippets enabled
    if (StackExchange.settings.snippets.snippetsEnabled) {
    StackExchange.using("snippets", function() {
    createEditor();
    });
    }
    else {
    createEditor();
    }
    });

    function createEditor() {
    StackExchange.prepareEditor({
    heartbeatType: 'answer',
    autoActivateHeartbeat: false,
    convertImagesToLinks: false,
    noModals: true,
    showLowRepImageUploadWarning: true,
    reputationToPostImages: null,
    bindNavPrevention: true,
    postfix: "",
    imageUploader: {
    brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
    contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
    allowUrls: true
    },
    onDemand: true,
    discardSelector: ".discard-answer"
    ,immediatelyShowMarkdownHelp:true
    });


    }
    });














    draft saved

    draft discarded


















    StackExchange.ready(
    function () {
    StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fmagento.stackexchange.com%2fquestions%2f134566%2fhow-to-sort-product-collection-on-stock-status%23new-answer', 'question_page');
    }
    );

    Post as a guest















    Required, but never shown

























    1 Answer
    1






    active

    oldest

    votes








    1 Answer
    1






    active

    oldest

    votes









    active

    oldest

    votes






    active

    oldest

    votes









    0














    you can not do as



    $this->_productCollection = $layer->getProductCollection()->addAttributeToSort('stock_status', desc);


    To achieve this you have to do left join



    $this->_productCollection = $layer->getProductCollection()->joinLeft(array('bs'=>'cataloginventory/stock_status'), 'bs.product_id = e.entity_id', array('stock_status' => 'bs.stock_status'))->order("stock_status desc"); 


    try this and let me know its working or not






    share|improve this answer






























      0














      you can not do as



      $this->_productCollection = $layer->getProductCollection()->addAttributeToSort('stock_status', desc);


      To achieve this you have to do left join



      $this->_productCollection = $layer->getProductCollection()->joinLeft(array('bs'=>'cataloginventory/stock_status'), 'bs.product_id = e.entity_id', array('stock_status' => 'bs.stock_status'))->order("stock_status desc"); 


      try this and let me know its working or not






      share|improve this answer




























        0












        0








        0







        you can not do as



        $this->_productCollection = $layer->getProductCollection()->addAttributeToSort('stock_status', desc);


        To achieve this you have to do left join



        $this->_productCollection = $layer->getProductCollection()->joinLeft(array('bs'=>'cataloginventory/stock_status'), 'bs.product_id = e.entity_id', array('stock_status' => 'bs.stock_status'))->order("stock_status desc"); 


        try this and let me know its working or not






        share|improve this answer















        you can not do as



        $this->_productCollection = $layer->getProductCollection()->addAttributeToSort('stock_status', desc);


        To achieve this you have to do left join



        $this->_productCollection = $layer->getProductCollection()->joinLeft(array('bs'=>'cataloginventory/stock_status'), 'bs.product_id = e.entity_id', array('stock_status' => 'bs.stock_status'))->order("stock_status desc"); 


        try this and let me know its working or not







        share|improve this answer














        share|improve this answer



        share|improve this answer








        edited Sep 3 '16 at 10:25

























        answered Sep 3 '16 at 9:42









        Murtuza ZabuawalaMurtuza Zabuawala

        12.3k73260




        12.3k73260






























            draft saved

            draft discarded




















































            Thanks for contributing an answer to Magento Stack Exchange!


            • Please be sure to answer the question. Provide details and share your research!

            But avoid



            • Asking for help, clarification, or responding to other answers.

            • Making statements based on opinion; back them up with references or personal experience.


            To learn more, see our tips on writing great answers.




            draft saved


            draft discarded














            StackExchange.ready(
            function () {
            StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fmagento.stackexchange.com%2fquestions%2f134566%2fhow-to-sort-product-collection-on-stock-status%23new-answer', 'question_page');
            }
            );

            Post as a guest















            Required, but never shown





















































            Required, but never shown














            Required, but never shown












            Required, but never shown







            Required, but never shown

































            Required, but never shown














            Required, but never shown












            Required, but never shown







            Required, but never shown







            Popular posts from this blog

            William S. Burroughs

            Eda skans

            What is the difference between apt, apt-get and git?