Как применять значки в подсчете боковой панели, используя Mirage2 в качестве темы - PullRequest
0 голосов
/ 16 октября 2018

Я хотел бы применить значки к числам, найденным в фасетах боковой панели.

Из этого:

original sidebar

На это:

enter image description here

Не удается найти нужный файл для редактирования.Я попытался отредактировать SidebarFacetsTransformer.java в строке 248 и строке 260:

if (i < shownFacets - 1) {
    String displayedValue = value.getDisplayedValue();
    String filterQuery = value.getAsFilterQuery();
    String filterType = value.getFilterType();
    if (fqs.contains(getSearchService().toFilterQuery(context, field.getIndexFieldName(), value.getFilterType(), value.getAsFilterQuery()).getFilterQuery())) {
        filterValsList.addItem(Math.random() + "", "selected").addContent(displayedValue + " <span class=\"badge\">" + value.getCount() + "</span>");
        } else {
            String paramsQuery = retrieveParameters(request);

            filterValsList.addItem().addXref(
                    contextPath +
                            (dso == null ? "" : "/handle/" + dso.getHandle()) +
                            "/discover?" +
                            paramsQuery +
                            "filtertype=" + field.getIndexFieldName() +
                                                "&filter_relational_operator="+ filterType  +
                            "&filter=" + encodeForURL(filterQuery),
                            displayedValue + " <span class=\"badge\">" + value.getCount() + "</span>"
                    );
            }
    }

, но после перестройки DSpace также отобразились теги <span class="badge">:

enter image description here

Так какой файл я должен отредактировать, чтобы применить значки к количеству боковых панелей?Я видел один репозиторий, использующий Mirage2 в качестве базовой темы и применяющий значки на счетчиках боковой панели: Исследовательский центр университета Вайкато .

enter image description here

Заранее спасибо!

ОБНОВЛЕНИЕ

После применения кода из ответа @schweerelos я получил желаемый результат, кроме боковой панели для Имеетфайлы (s) .Вместо цифр он просто показывает Нет .

enter image description here

Ответы [ 3 ]

0 голосов
/ 17 октября 2018

Для значков Research Commons мы изменили dspace-xmlui-mirage2/src/main/webapp/xsl/preprocess.xsl и перехватили рендеринг соответствующих элементов, т.е.

<!-- render frequency counts in sidebar facets as badges -->
<xsl:template match="dri:list[@id='aspect.discovery.Navigation.list.discovery']/dri:list/dri:item/dri:xref">
  <xref>
    <xsl:call-template name="copy-attributes"/>
    <xsl:choose>
      <xsl:when test="contains(text(), ' (') and contains(substring-after(text(), ' ('), ')')">
        <xsl:variable name="title">
          <xsl:call-template name="substring-before-last">
            <xsl:with-param name="string" select="text()"/>
            <xsl:with-param name="separator"><xsl:text> (</xsl:text></xsl:with-param>
          </xsl:call-template>
        </xsl:variable>
        <xsl:variable name="count">
          <xsl:call-template name="remove-parens">
            <xsl:with-param name="string" select="normalize-space(substring-after(text(), $title))"/>
          </xsl:call-template>
        </xsl:variable>
        <xsl:value-of select="$title"/>
        <xsl:text> </xsl:text>
        <hi rend="badge">
          <xsl:value-of select="$count"/>
        </hi>
      </xsl:when>
      <xsl:otherwise>
        <xsl:apply-templates/>
      </xsl:otherwise>
    </xsl:choose>
  </xref>
</xsl:template>

и аналогичного шаблона для текущего выбранного значения фасета (что IIRC не являетсяссылка):

<!-- better highlight active co-author/subject etc in facet list, incl show count as badge -->
<xsl:template match="dri:list[@id='aspect.discovery.Navigation.list.discovery']/dri:list/dri:item[@rend='selected']">
  <item>
    <xsl:call-template name="copy-attributes"/>
    <xsl:attribute name="rend"><xsl:value-of select="@rend"/> disabled</xsl:attribute>
    <xsl:choose>
      <xsl:when test="contains(text(), ' (') and contains(substring-after(text(), ' ('), ')')">
        <xsl:variable name="title">
          <xsl:call-template name="substring-before-last">
            <xsl:with-param name="string" select="text()"/>
            <xsl:with-param name="separator"><xsl:text> (</xsl:text></xsl:with-param>
          </xsl:call-template>
        </xsl:variable>
        <xsl:variable name="count">
          <xsl:call-template name="remove-parens">
            <xsl:with-param name="string" select="normalize-space(substring-after(text(), $title))"/>
          </xsl:call-template>
        </xsl:variable>
       <xsl:value-of select="$title"/>
        <xsl:text> </xsl:text>
        <hi rend="badge">
         <xsl:value-of select="$count"/>
        </hi>
      </xsl:when>
      <xsl:otherwise>
        <xsl:apply-templates/>
      </xsl:otherwise>
    </xsl:choose>
  </item>
</xsl:template>

Вы увидите, что для обработки случаев, когда само значение фасета содержит круглые скобки, используется пара шаблонов утилит:

<xsl:template name="substring-before-last">
  <xsl:param name="string" select="''" />
  <xsl:param name="separator" select="''" />

  <xsl:if test="$string != '' and $separator != ''">
    <xsl:variable name="head" select="substring-before($string, $separator)" />
    <xsl:variable name="tail" select="substring-after($string, $separator)" />
    <xsl:value-of select="$head" />
    <xsl:if test="contains($tail, $separator)">
      <xsl:value-of select="$separator" />
      <xsl:call-template name="substring-before-last">
        <xsl:with-param name="string" select="$tail" />
        <xsl:with-param name="separator" select="$separator" />
      </xsl:call-template>
    </xsl:if>
  </xsl:if>
</xsl:template>

<xsl:template name="remove-parens">
  <xsl:param name="string" select="''" />
  <xsl:if test="starts-with($string, '(') and substring($string, string-length($string))=')'">
    <xsl:value-of select="substring($string, 2, string-length($string) - 2)"/>
  </xsl:if>
</xsl:template>

Просто добавим , что у нас есть локальные предпочтения для модификации файлов темы XSL по сравнению с изменением кода Java.Вы можете сделать это в коде Java в качестве альтернативы, но вам нужно будет работать в API DRI, например, вызывать .addHighlight("badge") вызовы методов Java вместе с addXref (DRI hi преобразуется в HTML span).См. Документацию DRI по адресу https://wiki.duraspace.org/display/DSDOC5x/DRI+Schema+Reference (для 5.x, но без изменений для 6.x).

Конвейер Cocoon - это Java, создающий DRI (XML) -> preprocess.xsl, и связанные файлы изменяют DRIи вывод по-прежнему DRI -> theme.xsl и связанные файлы преобразуют DRI в HTML.Вы пытаетесь создать HTML "слишком рано" в процессе разработки.Ваш необработанный HTML экранируется дальше по дорожке, поэтому вы видите теги на экране.

0 голосов
/ 18 октября 2018

Спасибо за @schweerelos за ее ответ, мне удалось применить ее код с некоторыми изменениями для решения проблемы в фасете Имеет файлы (ы) , который был представлен в DSpace версии 6.x.

Я раскомментировал этот код в utils.xsl:

<xsl:template match="//dri:list[@id='aspect.discovery.SidebarFacetsTransformer.list.has_content_in_original_bundle']/dri:item//text()">
    <xsl:choose>
        <xsl:when test="contains(.,'true')">
            <i18n:text>xmlui.ArtifactBrowser.AdvancedSearch.value_has_content_in_original_bundle_true</i18n:text>
        </xsl:when>
        <xsl:otherwise>
            <i18n:text>xmlui.ArtifactBrowser.AdvancedSearch.value_has_content_in_original_bundle_false</i18n:text>
        </xsl:otherwise>
    </xsl:choose>
    <xsl:text> </xsl:text>
    <xsl:value-of select="substring-after(.,' ')"/>
</xsl:template>

, а затем изменил код Андреа для отображения Нет или Да для записей, которые имеютОРИГИНАЛЬНЫЙ комплект:

<!-- render frequency counts in sidebar facets as badges -->
<xsl:template match="dri:list[@id='aspect.discovery.Navigation.list.discovery']/dri:list/dri:item/dri:xref" priority="9">
    <xref>
        <xsl:call-template name="copy-attributes"/>
        <xsl:choose>
            <xsl:when test="contains(text(), ' (') and contains(substring-after(text(), ' ('), ')')">
                <xsl:variable name="title">
                    <xsl:call-template name="substring-before-last">
                        <xsl:with-param name="string" select="text()"/>
                        <xsl:with-param name="separator"><xsl:text> (</xsl:text></xsl:with-param>
                    </xsl:call-template>
                </xsl:variable>
                <xsl:variable name="count">
                    <xsl:call-template name="remove-parens">
                        <xsl:with-param name="string" select="normalize-space(substring-after(text(), $title))"/>
                    </xsl:call-template>
                </xsl:variable>
                <xsl:choose>
                    <xsl:when test="contains(.,'true')">
                        <i18n:text>xmlui.ArtifactBrowser.AdvancedSearch.value_has_content_in_original_bundle_true</i18n:text>
                    </xsl:when>
                    <xsl:when test="contains(.,'false')">
                        <i18n:text>xmlui.ArtifactBrowser.AdvancedSearch.value_has_content_in_original_bundle_false</i18n:text>
                    </xsl:when>
                    <xsl:otherwise>
                        <xsl:value-of select="$title"/>
                    </xsl:otherwise>
                </xsl:choose>
                <xsl:text> </xsl:text>
                <hi rend="badge">
                    <xsl:value-of select="$count"/>
                </hi>
            </xsl:when>
            <xsl:otherwise>
                <xsl:apply-templates/>
            </xsl:otherwise>
        </xsl:choose>
    </xref>
</xsl:template>

Теперь он показывает мой желаемый результат:

enter image description here

0 голосов
/ 16 октября 2018

На данный момент, я думаю, вам просто нужно стилизовать элементы span.badge.

Глядя на исследовательский фонд Университета Вайкато, я вижу следующий CSS.

list-group-item>.badge {
    float: right;
}
.badge {
    display: inline-block;
    min-width: 10px;
    padding: 3px 7px;
    font-size: 12px;
    font-weight: bold;
    color: #fff;
    line-height: 1;
    vertical-align: baseline;
    white-space: nowrap;
    text-align: center;
    background-color: #777;
    border-radius: 10px;
}
...