ข้ามไปที่เนื้อหาหลัก

Joomla วิธีทำให้หน้า VirtueMart Category Layout แสดงปุ่ม หยิบใส่ตะกร้า (Add-to-Cart)


ได้แนวคิดมาจาก comment ของ MobileMeMS https://forum.virtuemart.net/index.php?topic=102339.0

แล้วของ outthebox ก็ทำให้แล้ว แต่เลขบรรทัดไม่ตรงกัน ก็เลยไม่ได้อ่านละเอียด http://forum.virtuemart.net/index.php?topic=90961.90 แต่เลขบรรทัดมันไม่ตรงกัน

สุดท้ายก็งมเอง ได้ความประมาณนี้
  1. ไปเอา Code ที่ไฟล์ ชื่อไซต์\components\com_virtuemart\views\productdetails\tmpl\default_addtocart.php - copy Code ตั้งแต่ บรรทัด <div class="addtocart-area">(บรรทัด 22) ไปจนบรรทัดสุดท้าย </div>(บรรทัด 108)
  2. ไปที่ไฟล์ ชื่อไซต์\components\com_virtuemart\views\category\tmpl\default.php
  3. - แทรก Code ที่ copy มาให้อยู่ระหว่างบรรทัด (บรรทัด 311) และบรรทัด (บรรทัด 407)
  4. จากนั้นให้ find and replace คำว่า $this->product แล้วแทนด้วย $product ***ทำเฉพาะส่วนโค้ดที่แทรกเข้ามาเท่านั้น
เท่านี้ก็ได้ปุ่มหยิบใส่ตะกร้าแล้ว 

โค้ดที่แก้ไขแล้ว พร้อมวางแทรกได้ ตามข้างล่างนี้เลย

<!-- -------------------------------------------JaJaEdit Add-to-Cart---------Start-------------------------------------------------- -->

<div>

<form method="post" action="<?php echo JRoute::_ ('index.php'); ?>"> <?php // Product custom_fields if (!empty($product->customfieldsCart)) { ?> <div> <?php foreach ($product->customfieldsCart as $field) { ?> <div> <span><span><strong><?php echo JText::_ ($field->custom_title) ?></strong></span> <?php if ($field->custom_tip) { echo JHTML::tooltip ($field->custom_tip, JText::_ ($field->custom_title), 'tooltip.png'); } ?></span> <span><?php echo $field->display ?></span>

<span><?php echo $field->custom_field_desc ?></span> </div><br/> <?php } ?> </div> <?php } /* Product custom Childs * to display a simple link use $field->virtuemart_product_id as link to child product_id * custom_value is relation value to child */

if (!empty($product->customsChilds)) { ?> <div> <?php foreach ($product->customsChilds as $field) { ?> <div> <span><strong><?php echo JText::_ ($field->field->custom_title) ?></strong></span> <span><?php echo JText::_ ($field->field->custom_value) ?></span> <span><?php echo $field->display ?></span>

</div><br/> <?php } ?> </div> <?php } ?>

<div>

<?php // Display the quantity box

$stockhandle = VmConfig::get ('stockhandle', 'none'); if (($stockhandle == 'disableit' or $stockhandle == 'disableadd') and ($product->product_in_stock - $product->product_ordered) < 1) { ?> <a href="<?php echo JRoute::_ ('index.php?option=com_virtuemart&view=productdetails&layout=notify&virtuemart_product_id=' . $product->virtuemart_product_id); ?>"><?php echo JText::_ ('COM_VIRTUEMART_CART_NOTIFY') ?></a>

<?php } else { ?> <!-- <label for="quantity<?php echo $product->virtuemart_product_id; ?>"><?php echo JText::_ ('COM_VIRTUEMART_CART_QUANTITY'); ?>: </label> --> <span> <input type="text" name="quantity[]" value="<?php if (isset($product->min_order_level) && (int)$product->min_order_level > 0) { echo $product->min_order_level; } else { echo '1'; } ?>"/>    </span> <span> <input type="button"/> <input type="button"/>    </span> <?php // Display the quantity box END ?>

<?php // Display the add to cart button ?> <span> <?php echo shopFunctionsF::getAddToCartButton ($product->orderable); ?> </span> <?php } ?>

<div></div> </div>

<?php // Display the add to cart button END  ?> <input type="hidden" value="<?php echo $product->product_name ?>"/> <input type="hidden" name="option" value="com_virtuemart"/> <input type="hidden" name="view" value="cart"/> <noscript><input type="hidden" name="task" value="add"/></noscript> <input type="hidden" name="virtuemart_product_id[]" value="<?php echo $product->virtuemart_product_id ?>"/> </form>

<div></div></div>


<!-- -------------------------------------------JaJaEdit Add-to-Cart--End--------------------------------------------------------- -->




ปัญหาที่ยังเจอ เวลากดแล้วมันไม่ยอม Post ไปหน้าเดิมทำให้ตะกร้าไม่ update ต้องคอยกด refresh ใหม่

ความคิดเห็น

โพสต์ยอดนิยมจากบล็อกนี้

C# Databinding เทคนิคกรอง combobox OrderNo ที่มีการ Invoice แล้ว (How to refresh OrderNo list in combobox binding after invoiced without left outer join method)

เขียนโปรแกรมรับ Order และจ่าย Invoice เงื่อนไขคือ OrderNo จะต้องแสดงเฉพาะ OrderNo ที่ยังไม่ได้ผูกกับ Invoice เท่านั้น วิธีการที่เคยทำได้แก่ 1. ทำ Orders Left Outer Join Invoice เอาเฉพาะ Order ที่ยังไม่มีเลข Invoice ออกมา (ตามตำรา) - ถ้าไม่เขียน sql query ตอนสั่ง sqlselect command ก็ต้องไปใช้ LINQ to Object แล้วเอามา rebinding combobox.datasource ใหม่ เพราะ datasource ที่ผูกไว้กับ combobox มันไม่ refresh เช่น cboOrderNo.datasource.Clear; cboOrderNo.datasource = newList(); 2. เพิ่ม flag field ที่ table Orders ถ้ามีรับ invoice แล้ว ให้ flag = 1 แล้วใช้ dtOrder.defaultview.rowfilter = "flag=1"; ข้อมูลใน combobox จะไม่ต้อง rebinding อันนี้เห็นมาจากระบบอื่น 3. ใช้ Rowfilter = "Child(relation).Order = null" แต่วิธีนี้ใช้ไม่ได้ เพราะ Rowfilter จำกัดให้ใช้ได้เฉพาะ Parent เพราะถ้าเป็น Child แล้วจะ return หลายตัว ตามข้อมูลจาก link นี้ แต่อ้างอิงเป็นกลุ่มเช่น Sumchild(relation).Qty >20 ได้ เห็นแล้วก็นึกถึงไอเดียบรรเจิด ใช้ Rowfilter = Count(Child(relation)) <0 แ...

เทคนิคการสอบใบขับขี่รถยนต์ ท่าจอดรถเทียบฟุตบาทห่างไม่เกิน 25cm ด้วย "Sticker"

วันนี้พาพี่ที่บ้านไปสอบใบขับขี่รถยนต์ครั้งที่ 3 ซึ่งสอบตกท่าจอดรถเทียบฟุตบาท โดยคนขับรถเป็นแล้วจะรู้สึกว่าไม่เห็นจะยากตรงไหน แต่สำหรับคนที่เพิ่งหัดขับรถ ประกอบกับได้จับรถป้ายแดงที่เพิ่งถอยออกมาขับได้ ไม่ถึง 5 ชม. นั้นเป็นเรื่องที่ยากจะทำได้ ผมคนหนึ่งที่ได้ใบขับขี่มานาน แต่พอให้มาขับจอดเทียบฟุตบาทด้วยรถป้ายแดงใหม่เอี่ยมของคนอื่นแล้ว มีอันต้องจอดห่างทุกที ด้วยเวลาในการซ้อมขับที่เหลือไม่ถึง 3 ชม. ก่อนสอบจริง ทำให้ต้องคิดหาเทคนิควิธีต่าง ๆ ที่จะทำได้ใบขับขี่มา (เพราะเหนื่อยกับความพยายามสอบมา 2 ครั้งแล้ว) จนทำให้คิดเทคนิค "Sticker" นี้ขึ้นได้ โดยปกติแล้วถ้าขับรถจอดเทียบฟุตบาทแล้วพยายามมองกระจกข้างให้ล้อหลังชิดเส้นขอบพอดี ผลออกมาจะทำให้ล้อหน้าปีนฟุตบาท ไอ้ครั้นจะให้พี่ที่เพิ่งหัดขับรถมาได้ไม่ถึง 8 ชม. กะขนาดตัวรถให้ได้ (ซึ่งขนาดผมเองยังคงกะลำบาก) ภายในสิบห้านาทีนั้นโอกาสเป็นไปได้ยากมาก ด้วยการทดลองเทคนิคต่าง ๆ หลาย ๆ แบบ ที่พอจะนึกออกจากประสบการณ์และเวลาอันสั้นรวบรัด ก็ทำให้เกิดแนวคิดที่ว่า ทำอย่างไรให้สามารถมองล้อหน้าว่าติดเส้นขอบหรือเปล่า ได้เหมือนกับที่ใช้กระจก...

เขียนโปรแกรม Visual Studio 2008(.NETCF3.5) กับ Windows Mobile 6 ติดต่อกับ Database MSSQL Server 2008 โดยตรง (ไม่ได้ใช้ SQLCE)

รับ Requirement ให้เขียนโปรแกรมบน Windows Mobile 6 ติดต่อกับ Database MSSQL Server 2008 โดยตรง ตอนแรกก็ลองใช้ SQLCE แต่เท่าที่ดูมันไม่ได้เชื่อมต่อ กับ Database Server แต่มันใช้ Database ในเครื่อง Pocket PC แทน ซึ่งไม่ตรงกับ Requirement นัก เลยลองเขียนโปรแกรมเชื่อมต่อไปยัง SQL Server ตรง ๆ กับปรากฏว่า import System.data.SqlClient ไม่ได้ หาไปหามา พบว่า SqlClient มันอยู่ในไฟล์ System.Data ใน VS2008 ซึ่งถ้าใช้ .NETCF 3.5 มันไม่มีให้ใช้ ลองถามอากู๋ดูก็พบว่ามีคนเขียนแล้วใช้ได้ เลยสงสัยว่าใช้ได้ยังไง หมดไป 1 วันก็พบว่าเขา Add Reference file "System.data.SqlClient.dll" มาใช้กัน ซึ่งเป็นของ "VS2005" ถ้าเป็น VS2008 มันเอาไปรวมใน System.Data.dll แล้ว หมดสิทธิ์ใช้งานนะจ๊ะ ครั้นลองเอา System.data.dll ของ .NET framework ตัวเต็มมา Add ใส่แทนที่ ผลปรากฏว่าพังไม่เป็นท่าเลย หลังจากถอดใจแล้วผลอยหลับไปงีบ ตื่นมาก็อาศํยสิ่งศักดิ์สิทธิ์เสียหน่อย ท่องคาถาให้งานราบรื่น ปรากฏว่า "สิ้งศักดิ์สิทธิ์มีจริง ไม่เชื่ออย่าลบหลู่" ไปเจอ Link (ลิงก์พังแล้ว) นี้   ซึ่งม...