哪里可以更改产品上的Magento默认选项卡?
我正在努力解决一个问题,希望你能对此有所帮助。哪里可以更改产品上的Magento默认选项卡?
我需要改变我的产品页面上默认产品标签,但我无法改变它在后端,只设置了不同的属性。
我已经把范围缩小到一个catalog.xml文件,但我不知道确切的代码被控制的选项卡。
我试着改变一下代码,但没有效果。我的Magento的安装也很慢,这是推动我疯了......
任何想法?
在此先感谢...
我建议你覆盖本地模块中的核心文件,而不是直接更改核心文件。 下面是一个例子如何覆盖Mage_Adminhtml_Catalog_Product_Edit_Tabs.php
创建模块例如MyNameSpace_ModuleName内部应用程序/代码/本地/
要注册模块创建应用的/ etc /模块/ MyNameSpace_ModuleName .XML
<?xml version="1.0"?>
<config>
<modules>
<MyNameSpace_ModuleName>
<codePool>local</codePool>
<active>true</active>
</MyNameSpace_ModuleName>
</modules>
</config>
myNameSpace对象/模块名的/ etc/config.xm升
<?xml version="1.0" encoding="utf-8"?>
<config>
<modules>
<MyNameSpace_ModuleName>
<version>0.1.0</version>
</MyNameSpace_ModuleName>
</modules>
<global>
<blocks>
<adminhtml>
<rewrite>
<cataolg_product_edit_tabs>MyNameSpace_ModuleName_Block_Adminhtml_catalog_product_edit_tabs</cataolg_product_edit_tabs>
</rewrite>
</adminhtml>
</blocks>
</global>
</config>
了myNameSpace /模块名/座/ Adminhtml /目录/产品/编辑/ tabs.php
class MyNameSpace_ModuleName_Block_Adminhtml_Catalog_Product_Edit_Tabs extends Mage_Adminhtml_Block_Catalog_Product_Edit_Tabs
{
protected $_attributeTabBlock = 'adminhtml/catalog_product_edit_tab_attributes';
public function __construct()
{
parent::__construct();
$this->setId('product_info_tabs');
$this->setDestElementId('product_edit_form');
$this->setTitle(Mage::helper('catalog')->__('Product Information'));
}
protected function _prepareLayout()
{
$product = $this->getProduct();
if (!($setId = $product->getAttributeSetId())) {
$setId = $this->getRequest()->getParam('set', null);
}
if ($setId) {
$groupCollection = Mage::getResourceModel('eav/entity_attribute_group_collection')
->setAttributeSetFilter($setId)
->setSortOrder()
->load();
foreach ($groupCollection as $group) {
$attributes = $product->getAttributes($group->getId(), true);
// do not add groups without attributes
foreach ($attributes as $key => $attribute) {
if(!$attribute->getIsVisible()) {
unset($attributes[$key]);
}
}
if (count($attributes)==0) {
continue;
}
$this->addTab('group_'.$group->getId(), array(
'label' => Mage::helper('catalog')->__($group->getAttributeGroupName()),
'content' => $this->_translateHtml($this->getLayout()->createBlock($this->getAttributeTabBlock(),
'adminhtml.catalog.product.edit.tab.attributes')->setGroup($group)
->setGroupAttributes($attributes)
->toHtml()),
));
}
if (Mage::helper('core')->isModuleEnabled('Mage_CatalogInventory')) {
$this->addTab('inventory', array(
'label' => Mage::helper('catalog')->__('Inventory'),
'content' => $this->_translateHtml($this->getLayout()
->createBlock('adminhtml/catalog_product_edit_tab_inventory')->toHtml()),
));
}
/**
* Don't display website tab for single mode
*/
if (!Mage::app()->isSingleStoreMode()) {
$this->addTab('websites', array(
'label' => Mage::helper('catalog')->__('Websites'),
'content' => $this->_translateHtml($this->getLayout()
->createBlock('adminhtml/catalog_product_edit_tab_websites')->toHtml()),
));
}
$this->addTab('categories', array(
'label' => Mage::helper('catalog')->__('Categories'),
'url' => $this->getUrl('*/*/categories', array('_current' => true)),
'class' => 'ajax',
));
$this->addTab('related', array(
'label' => Mage::helper('catalog')->__('Related Products'),
'url' => $this->getUrl('*/*/related', array('_current' => true)),
'class' => 'ajax',
));
$this->addTab('upsell', array(
'label' => Mage::helper('catalog')->__('Up-sells'),
'url' => $this->getUrl('*/*/upsell', array('_current' => true)),
'class' => 'ajax',
));
$this->addTab('crosssell', array(
'label' => Mage::helper('catalog')->__('Cross-sells'),
'url' => $this->getUrl('*/*/crosssell', array('_current' => true)),
'class' => 'ajax',
));
$storeId = 0;
if ($this->getRequest()->getParam('store')) {
$storeId = Mage::app()->getStore($this->getRequest()->getParam('store'))->getId();
}
$alertPriceAllow = Mage::getStoreConfig('catalog/productalert/allow_price');
$alertStockAllow = Mage::getStoreConfig('catalog/productalert/allow_stock');
if (($alertPriceAllow || $alertStockAllow) && !$product->isGrouped()) {
$this->addTab('productalert', array(
'label' => Mage::helper('catalog')->__('Product Alerts'),
'content' => $this->_translateHtml($this->getLayout()
->createBlock('adminhtml/catalog_product_edit_tab_alerts', 'admin.alerts.products')->toHtml())
));
}
if($this->getRequest()->getParam('id', false)) {
if (Mage::helper('catalog')->isModuleEnabled('Mage_Review')) {
if (Mage::getSingleton('admin/session')->isAllowed('admin/catalog/reviews_ratings')){
$this->addTab('reviews', array(
'label' => Mage::helper('catalog')->__('Product Reviews'),
'url' => $this->getUrl('*/*/reviews', array('_current' => true)),
'class' => 'ajax',
));
}
}
if (Mage::helper('catalog')->isModuleEnabled('Mage_Tag')) {
if (Mage::getSingleton('admin/session')->isAllowed('admin/catalog/tag')){
$this->addTab('tags', array(
'label' => Mage::helper('catalog')->__('Product Tags'),
'url' => $this->getUrl('*/*/tagGrid', array('_current' => true)),
'class' => 'ajax',
));
$this->addTab('customers_tags', array(
'label' => Mage::helper('catalog')->__('Customers Tagged Product'),
'url' => $this->getUrl('*/*/tagCustomerGrid', array('_current' => true)),
'class' => 'ajax',
));
}
}
}
/**
* Do not change this tab id
* @see Mage_Adminhtml_Block_Catalog_Product_Edit_Tabs_Configurable
* @see Mage_Bundle_Block_Adminhtml_Catalog_Product_Edit_Tabs
*/
if (!$product->isGrouped()) {
$this->addTab('customer_options', array(
'label' => Mage::helper('catalog')->__('Custom Options'),
'url' => $this->getUrl('*/*/options', array('_current' => true)),
'class' => 'ajax',
));
}
}
else {
$this->addTab('set', array(
'label' => Mage::helper('catalog')->__('Settings'),
'content' => $this->_translateHtml($this->getLayout()
->createBlock('adminhtml/catalog_product_edit_tab_settings')->toHtml()),
'active' => true
));
}
return parent::_prepareLayout();
}
}
您可以添加内部_preparelayout新的选项卡()函数。以同样的方式,你也可以覆盖其他文件,并可以改变任何你想改变的东西。
为了正确反映更改,请确保清理缓存。
你可以找到在此块文件app \代码\核心选项卡\法师\ Adminhtml \块\目录\产品\编辑\ Tabs.php
如果你是看着这个标签,你可以找到标签
例如相关产品,它具有这种类型的网址$this->getUrl('*/*/related', array('_current' => true)),
此网址依次调用此adminhtml_catalog_product_related操作,此操作在catalog.xml中指定。
<adminhtml_catalog_product_related>
<block type="core/text_list" name="root" output="toHtml">
<block type="adminhtml/catalog_product_edit_tab_related" name="catalog.product.edit.tab.related"/>
<block type="adminhtml/widget_grid_serializer" name="related_grid_serializer">
<reference name="related_grid_serializer">
<action method="initSerializerBlock">
<grid_block_name>catalog.product.edit.tab.related</grid_block_name>
<data_callback>getSelectedRelatedProducts</data_callback>
<hidden_input_name>links[related]</hidden_input_name>
<reload_param_name>products_related</reload_param_name>
</action>
<action method="addColumnInputName">
<input_name>position</input_name>
</action>
</reference>
</block>
</block>
</adminhtml_catalog_product_related>
所以你可以轻松找到你想要改变的东西。
谢谢,我找到了该文件,我会检查出来。 – 2013-05-10 12:27:07
伟大的信息。我一定会尝试一下并尽快回复。 – 2013-05-10 14:55:11
我现在已经设置了文件夹,但是如何激活该模块? – 2013-05-10 14:57:45
@RenéHansen:要注册你的模块,你只需要在app/etc/modules /文件夹内创建一个xml文件MyNameSpace_ModuleName.xml。为了您的理解,我正在更新代码。 – 2013-05-11 18:25:45