Изменение иерархии при обмене данными с 1С

Материал из Umicms
Перейти к:навигация, поиск

В статье Как_переместить_страницу_если_её_раздел_поменялся есть более простое решение

При импорте из CommerceML2.0 объекты располагаются в том иерархическом порядке, в котором они были в исходном файле, в дальнейшем, при обновлении данных средствами импорта их положение уже не изменяется, а обращение к объекту идёт напрямую по его идентификатору. Если требуется при обмене данными с 1С изменять иерархию в соответствии с импортируемыми данными, то необходимо добавить соответствующую обработку в шаблон импорт.
Перед импортом входящая информация из commerceML2.0 трансформируется по XSLT шаблону в формат UmiDump2.0. За иерархические связи в UmiDump отвечает нода <hierarchy>. Для того чтобы при импорте структура каталога обновлялась, необходимо чтобы после трансформации в UmiDump в нём были записи об иерархических связях. Для этого скопируем содержимое файла ~/xsl/import/commerceML2.xsl в ~/xsl/import/custom/commerceML2.xsl удалив строку <xsl:include href="custom/commerceML2.xsl" />. После этого находим шаблон

    <xsl:template match="/">

        <umidump xmlns:xlink="http://www.w3.org/TR/xlink" version="2.0">
            <xsl:apply-templates select="КоммерческаяИнформация/Классификатор" />
            <xsl:apply-templates select="КоммерческаяИнформация/Каталог" />

            <xsl:apply-templates select="КоммерческаяИнформация/ПакетПредложений" />

            <xsl:if test="count(КоммерческаяИнформация/Документ)">
                <xsl:apply-templates select="КоммерческаяИнформация" mode="document" />
            </xsl:if>
        </umidump>

    </xsl:template>

и изменяем его, подключив два шаблона

    <xsl:template match="/">

        <umidump xmlns:xlink="http://www.w3.org/TR/xlink" version="2.0">
            <xsl:apply-templates select="КоммерческаяИнформация/Классификатор" />
            <xsl:apply-templates select="КоммерческаяИнформация/Каталог" />
 
            <xsl:apply-templates select="КоммерческаяИнформация/ПакетПредложений" />
 
            <xsl:if test="count(КоммерческаяИнформация/Документ)">
                <xsl:apply-templates select="КоммерческаяИнформация" mode="document" />
            </xsl:if>
			
	    <xsl:variable name="classid" select="КоммерческаяИнформация/Классификатор/Ид" />
			
            <hierarchy>
                <xsl:apply-templates select="КоммерческаяИнформация/Каталог/Товары/Товар" mode="hierarchy"/>
                <xsl:apply-templates select="КоммерческаяИнформация/Классификатор/Группы" mode="hierarchy">
		    <xsl:with-param name="classid">
		        <xsl:copy-of select="$classid" />
		    </xsl:with-param>
		</xsl:apply-templates>					
            </hierarchy>
        </umidump>

    </xsl:template>

теперь добавим эти шаблоны в наш кастомный файл:

    <xsl:template match="КоммерческаяИнформация/Каталог/Товары/Товар" mode="hierarchy">
        <relation id="{Ид}" parent-id="{Группы/Ид}"/>
    </xsl:template>
 
    <xsl:template match="КоммерческаяИнформация/Классификатор/Группы" mode="hierarchy">
        <xsl:param name="classid" />
        <xsl:apply-templates select="//Группа" >
	    <xsl:with-param name="classid">
		<xsl:copy-of select="$classid" />
	    </xsl:with-param>
	</xsl:apply-templates>		
    </xsl:template>
 
    <xsl:template match="//Группа" >
	<xsl:param name="classid" />
	<xsl:if test="name(../../.) = 'Классификатор'">
		<relation id="{Ид}" parent-id="{$classid}"/>
	</xsl:if>	
        <xsl:apply-templates select="Группы/Группа" mode="ghierarchy">
            <xsl:with-param name="parent">
                <xsl:copy-of select="Ид" />
            </xsl:with-param>
        </xsl:apply-templates>
    </xsl:template>
 
    <xsl:template match="Группы/Группа" mode="ghierarchy">
        <xsl:param name="parent" />
	<relation id="{Ид}" parent-id="{$parent}"/>
	<xsl:apply-templates select="Группы/Группа" mode="ghierarchy">
            <xsl:with-param name="parent">
                <xsl:copy-of select="Ид" />
            </xsl:with-param>
	</xsl:apply-templates>			
    </xsl:template>

теперь при обмене данными с 1С иерархия будет изменятся в соответствии с иерархией из импортируемого файла.