26 марта 2013
Нет комментариев
Для новых записей — в настройках обсуждения. Для всех, ранее созданных — в phpmyadmin:
UPDATE `wp_posts` SET `ping_status`='closed';
Для новых записей — в настройках обсуждения. Для всех, ранее созданных — в phpmyadmin:
UPDATE `wp_posts` SET `ping_status`='closed';
15 — id документа.
Core_Entity::factory('Document', 15)->Document_Versions->getCurrent()->execute();
Где dopphoto
— XML-тег дополнительного свойства.
<xsl:for-each select="property_value[tag_name='dopphoto']"> <a href="{../dir}{file}" target="_blank"><img src="{../dir}{file_small}" /></a> </xsl:for-each>
Где dopphoto
— XML-тег дополнительного свойства.
<a href="{dir}{property_value[tag_name='dopphoto']/file}" target="_blank"> <img src="{dir}{property_value[tag_name='dopphoto']/file_small}" /> </a>
Где color
— XML-тег дополнительного свойства.
<xsl:value-of select="property_value[tag_name='color']/value"/>
В примере будут отображаться товары с дополнительным свойством типа «флажок», где он отмечен. (Нужно было отображать товары, вручную отмеченные как новинки)
66 — id
дополнительного свойства
$Shop_Controller_Show ->shopItems() ->queryBuilder() ->join('property_value_ints', 'property_value_ints.entity_id', '=', 'shop_items.id') ->where('property_value_ints.property_id', '=', 66) ->where('property_value_ints.value', '=', 1) ->clearOrderBy() ->orderBy('id','DESC');
1. Модификация xsl карточки товара (по умолчанию /hostcmsfiles/xsl/56.xsl)
В начале документа:
xmlns:php="http://php.net/xsl"
т.е. до вида:
<xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform" xmlns:php="http://php.net/xsl" xmlns:hostcms="http://www.hostcms.ru/" exclude-result-prefixes="hostcms">
Где будет отображаться блок:
<xsl:value-of disable-output-escaping="yes" select="php:function('GetSpecialPrices',string(@id),string(price))" />
2. В /bootstrap.php
function GetSpecialPrices($id,$price) { $out=''; $oCore_QueryBuilder_Select = Core_QueryBuilder::select() ->from('shop_specialprices') ->where('shop_item_id', '=', $id); $sRows = $oCore_QueryBuilder_Select->execute()->asAssoc()->result(); $out='<table cellpadding="3" cellspacing="0" class="item_special_prices">'; $out.='<tr><td colspan="7">Цена за сутки</td></tr>'; $out.='<tr><td>1 д.</td><td>2-3 д.</td><td>4-7 д.</td><td>8-15 д.</td><td>16-30 д.</td><td>Свыше 30 д.</td></tr>'; $spec_2=$spec_4=$spec_8=$spec_16=$spec_30=0; foreach ($sRows as $spec) { if ($spec['min_quantity']==2) { $spec_price_2=ceil($spec['price']); $spec_2=1; } if ($spec['min_quantity']==4) { $spec_price_4=ceil($spec['price']); $spec_4=1; } if ($spec['min_quantity']==8) { $spec_price_8=ceil($spec['price']); $spec_8=1; } if ($spec['min_quantity']==16) { $spec_price_16=ceil($spec['price']); $spec_16=1; } if ($spec['min_quantity']==30) { $spec_price_30=ceil($spec['price']); $spec_30=1; } } if ($spec_2==0) { $spec_price_2="—"; } if ($spec_4==0) { $spec_price_4="—"; } if ($spec_8==0) { $spec_price_8="—"; } if ($spec_16==0) { $spec_price_16="—"; } if ($spec_30==0) { $spec_price_30="—"; } $out.='<tr><td>'.ceil($price).'</td><td>'.$spec_price_2.'</td><td>'.$spec_price_4.'</td><td>'.$spec_price_8.'</td><td>'.$spec_price_16.'</td><td>'.$spec_price_30.'</td></tr>'; $out.='</table>'; return $out; }
Недостатки: диапазон специальных цен вписан статикой, но для конкретного случая такое решение подошло.