我需要向订单模型(“ dynamics_ord ”)添加自定义属性。
此属性需要由管理员定义,在成功保存订单后,最好在主订单块中的admin/sales_order/view上。
它需要独立于发票/发货等 - 可能附加到订单“ edit
”事件。
我为其他实体(尤其是客户)制作了许多自定义属性。我意识到这是同一个过程。但我不清楚如何使用此属性修改订单,因为没有明显的“更新”操作。“编辑”可能有意义,但我不想不必要地重复订单。
一旦这个 attr 就位,我想在sales_order/index网格中显示它。(注意=查看此相关线程以获取有效的解决方案。)
此模块的最终状态(以及需要此解决方案的任何其他人):
/sales_order/view/截图:
WACI_SalesExt
app/local/WACI/SalesExt
/Block
/Adminhtml
/Sales
-Dynamicsord.php
/controllers
/Adminhtml
/Sales
- OrderController.php
/etc
- config.xml
/Helper
- Data.php
/sql
/waci_salesext_setup
-mysql4-install-0.2.0.php
配置文件
<?xml version="1.0"?>
<config>
<modules>
<WACI_SalesExt>
<version>0.2.0</version>
</WACI_SalesExt>
</modules>
<global>
<helpers>
<WACI_SalesExt>
<class>WACI_SalesExt_Helper</class>
</WACI_SalesExt>
</helpers>
<blocks>
<WACI_SalesExt>
<class>WACI_SalesExt_Block</class>
</WACI_SalesExt>
<adminhtml> <!-- unclear if i need this second declaration for admin-->
<WACI_SalesExt>
<class>WACI_SalesExt_Block</class>
</WACI_SalesExt>
</adminhtml>
</blocks>
<models>
<WACI_SalesExt>
<class>WACI_SalesExt_Model</class>
<resourceModel>salesext_mysql4</resourceModel>
</WACI_SalesExt>
</models>
<resources>
<waci_salesext_setup>
<setup>
<module>WACI_SalesExt</module>
<class>Mage_Sales_Model_Mysql4_Setup</class>
</setup>
<connection>
<use>core_setup</use>
</connection>
</waci_salesext_setup>
<waci_salesext_write>
<connection>
<use>core_write</use>
</connection>
</waci_salesext_write>
<waci_salesext_read>
<connection>
<use>core_read</use>
</connection>
</waci_salesext_read>
</resources>
</global>
<admin>
<routers>
<adminhtml>
<use>admin</use>
<args>
<modules>
<WACI_SalesExt after="Mage_Adminhtml_Sales">WACI_SalesExt_Adminhtml</WACI_SalesExt>
</modules>
</args>
</adminhtml>
</routers>
</admin>
</config>
WACI / SalesExt / sql / waci_salesext_setup / mysql4-install-0.2.0.php
$installer = $this;
$installer->startSetup();
$installer->addAttribute('order', 'dynamics_ord', array(
'type' =>'varchar',
'visible' => true,
'required' => false,
'is_user_defined' => false,
'note' => 'Dynamics ORD')
);
$installer->getConnection()->addColumn($installer->getTable('sales_flat_order'), 'dynamics_ord','VARCHAR(255) NULL DEFAULT NULL');
$installer->getConnection()->addColumn($installer->getTable('sales_flat_order_grid'), 'dynamics_ord','VARCHAR(255) NULL DEFAULT NULL');
$installer->endSetup();
模板/销售/订单/视图/info.phtml
<?php echo $this->getLayout()->createBlock('WACI_SalesExt/adminhtml_sales_dynamicsord')->setOrderId($_order->getId())->toHtml() ?>
模板/销售/ord_form.phtml
<?php if ('sales_order' == Mage::app()->getRequest()->getControllerName() ): ?>
<tr>
<td class="label"><label for="dynamics_ord">Dynamics ORD</label></td>
<td class="value">
<form action="<?php echo $this->getFormUrl(); ?>" method="post" id="ord_form">
<input type="hidden" name="form_key" value="<?php echo $this->getFormKey(); ?>" />
<input type="hidden" name="token" value="<?php echo $this->getToken(); ?>" />
<div class="">
<input type="text" class="input-text" name="dynamics_ord" value="<?php echo $this->getOrder()->getData('dynamics_ord'); ?>" style="width:150px; float:left; display:inline;" />
<button onclick="editForm.submit()" style="float:left;margin:3px 10px 0;">Update</button>
</div>
</form>
<script type="text/javascript">
editForm = new varienForm('ord_form');
</script>
</td>
</tr>
<?php endif; ?>
WACI_SalesExt_Block_Adminhtml_Sales_Dynamicsord
class WACI_SalesExt_Block_Adminhtml_Sales_Dynamicsord extends Mage_Adminhtml_Block_Template
{
public function __construct()
{
parent::__construct();
$this->setTemplate('sales/ord_form.phtml');
}
public function getOrder(){
return Mage::registry('current_order');
}
public function getFormUrl(){
return Mage::helper("adminhtml")->getUrl('*/sales_order/editord', array('order_id'=>$this->getOrder()->getId()) );
}
}
WACI_SalesExt_Adminhtml_Sales_OrderController
include_once Mage::getModuleDir('controllers', 'Mage_Adminhtml') . DS . 'Sales' . DS . 'OrderController.php';
class WACI_SalesExt_Adminhtml_Sales_OrderController extends Mage_Adminhtml_Sales_OrderController
{
public function editordAction()
{
$postData = $this->getRequest()->getPost();
Mage::log('WACI_SalesExt_Adminhtml_Sales_OrderController::ordEditAction'.print_r($postData, true) );
$id = $this->getRequest()->getParam('order_id');
$order = Mage::getModel('sales/order')->load($id);
$order->setDynamicsOrd($postData['dynamics_ord']);
$order->save();
// return to sales_order view
Mage::app()->getResponse()->setRedirect(Mage::helper('adminhtml')->getUrl("adminhtml/sales_order/view", array('order_id'=> $id)));
}
}
一直在寻找关于这个问题的一些信息,这个 SO 线程似乎非常接近我想要做的事情。但尚不清楚我能否通过此工作流程创建可编辑的输入。
我会注意到我在 Mage 1.11 - 我已经收集到标准 EAV 模式不再用于订单模型。
干杯 -
更新
(注意“当前”模块内容。)
- 该字段已添加到 sales_flat_order
- WACI_SalesExt_Block_Adminhtml_Sales_Dynamicsord 块正在正确构建
- 我有一些正确的测试数据
在这一点上,我认为我的路由器设置不正确。在您的示例中,您调用了<?php echo $this->getEditFormUrl(); ?>
. 我不确定这是否应该输出格式化的操作 url,但事实并非如此。我把自己的放进去,但它仍然没有正确地击中路由器。
目前,表单中的值 action =
action ="http://my.domain.com/index.php/my_admin/sales_order/editord/key/2e56d7f560dc4d356e3ef9519764b8a84858e5cd40d3c1f5821a423b949b9a6a/"
并且只是点击“找不到页面”。据我所知,路由器在这里应该是准确的。我尝试了许多不同的组合;我显然在管理路由器问题上遗漏了一些重要的东西。我知道key/ee6
... 可能会惹恼我,但我不清楚如何适当地处理它。
更新
路由问题是一个简单的错误,我不必要地复杂化:我有一个拼写错误的目录名称“AdminHtml”与“Adminhtml” - 导致路由器迷路。
哦,Magento...
感谢@RS 的帮助。