78735 Resultados disponibles

Filtrar:

Se ha producido un error al procesar la plantilla.
The following has evaluated to null or missing:
==> esResponse.getAggregationResult(specificationKey + "_with_organismos")  [in template "34352066712900#33336#362186" at line 67, column 33]

----
Tip: If the failing expression is known to legally refer to something that's sometimes null or missing, either specify a default value like myOptionalVar!myDefault, or use <#if myOptionalVar??>when-present<#else>when-missing</#if>. (These only cover the last step of the expression; to cover the whole expression, use parenthesis: (myOptionalVar.foo)!myDefault, (myOptionalVar.foo)??
----

----
FTL stack trace ("~" means nesting-related):
	- Failed at: #local aggregationResult = esResponse...  [in template "34352066712900#33336#362186" in function "getAggregationResult" at line 67, column 5]
----
1<#-- Variables --> 
2<#assign specificationName          = 'ctn' /> 
3<#assign paramNameSpecificationName = cpSpecificationOptionsSearchFacetDisplayContext.getParameterName() /> 
4<#assign isDebug                    = false /> 
5<#assign showAllSpecificationsName  = false /> 
6<#assign staticHost                 = getCXConfig("ecom-static-files") /> 
7 
8<#-- ========================= --> 
9<#-- Functions freemaker       --> 
10<#-- ========================= --> 
11<#function getCXConfig clientExtensionName field="webApiUrl"> 
12    <#if !clientExtensionName?has_content><#return "" /></#if> 
13    <#local encoded = urlCodec.encodeURL(clientExtensionName) /> 
14    <#local items   = restClient.get("/c/customconfigs/?fields=clientExtensionConfig&filter=clientExtensionName eq '" + encoded + "'").items![] /> 
15    <#return items?has_content?then(items[0].clientExtensionConfig?eval[field]!"", "") /> 
16</#function> 
17 
18<#function getTaxonomyVocabularyId vocabularyName> 
19    <#local response = restClient.get("/headless-admin-taxonomy/v1.0/sites/" + groupId + "/taxonomy-vocabularies?filter=contains(name,'" + vocabularyName + "')&pageSize=1")!{} /> 
20    <#local items    = response.items![] /> 
21    <#return items?has_content?then(items[0].id, "") /> 
22</#function> 
23 
24<#function getTaxonomyCategoryMap vocabularyId pageSize=200> 
25    <#local response   = restClient.get("/headless-admin-taxonomy/v1.0/taxonomy-vocabularies/" + vocabularyId + "/taxonomy-categories?pageSize=" + pageSize)!{} /> 
26    <#local categoryMap = {} /> 
27    <#list response.items![] as cat> 
28        <#local categoryMap = categoryMap + {vocabularyId + "-" + cat.id: cat.name} /> 
29    </#list> 
30    <#return categoryMap /> 
31</#function> 
32 
33<#function getSpecOrganismosMap organismoMap aggResult> 
34    <#local specMap = {} /> 
35    <#if !aggResult?has_content || !organismoMap?has_content><#return specMap /></#if> 
36    <#list aggResult.getBuckets() as specBucket> 
37        <#local specKey      = specBucket.getKey() /> 
38        <#local organismoAgg = specBucket.getChildAggregationResult("organismos") /> 
39        <#local orgNames     = [] /> 
40        <#if organismoAgg?has_content> 
41            <#list organismoAgg.getBuckets() as orgBucket> 
42                <#local orgName  = organismoMap[orgBucket.getKey()]!"" /> 
43                <#if orgName?has_content> 
44                    <#local orgNames = orgNames + [orgName] /> 
45                </#if> 
46            </#list> 
47        </#if> 
48        <#if orgNames?has_content> 
49            <#local specMap = specMap + {specKey: orgNames} /> 
50        </#if> 
51    </#list> 
52    <#return specMap /> 
53</#function> 
54 
55<#function getAggregationResult specificationKey> 
56    <#if !specificationKey?has_content><#return "" /></#if> 
57 
58    <#local sharedSearchResponse = renderRequest.getAttribute("LIFERAY_SHARED_PortletSharedSearchResponse") /> 
59    <#if !sharedSearchResponse?has_content><#return "" /></#if> 
60 
61    <#local searchResponse = sharedSearchResponse.get() /> 
62    <#if !searchResponse?has_content><#return "" /></#if> 
63 
64    <#local esResponse = searchResponse.getSearchResponse() /> 
65    <#if !esResponse?has_content><#return "" /></#if> 
66 
67    <#local aggregationResult = esResponse.getAggregationResult(specificationKey + "_with_organismos") /> 
68    <#if !aggregationResult?has_content><#return "" /></#if> 
69 
70    <#return aggregationResult /> 
71</#function> 
72 
73 
74 
75<#if paramNameSpecificationName == specificationName || showAllSpecificationsName> 
76 
77    <#-- ========================= --> 
78    <#-- Datos                     --> 
79    <#-- ========================= --> 
80	<#assign organismoVocabId  = getTaxonomyVocabularyId("organismos") /> 
81	<#assign organismoMap      = getTaxonomyCategoryMap(organismoVocabId) /> 
82	<#assign aggResult         = getAggregationResult(paramNameSpecificationName)! /> 
83	<#assign specOrganismosMap = getSpecOrganismosMap(organismoMap, aggResult) /> 
84			 
85 
86			 
87 
88    <#-- ========================= --> 
89    <#-- Debug                     --> 
90    <#-- ========================= --> 
91    <#if isDebug> 
92        <div style="background:#f0f0f0;padding:8px;margin-bottom:8px;font-size:11px;border:1px solid #ccc;"> 
93            <p><strong>paramName:</strong> ${paramNameSpecificationName}</p> 
94            <p><strong>organismoMap size:</strong> ${organismoMap?size}</p> 
95            <p><strong>specOrganismosMap size:</strong> ${specOrganismosMap?size}</p> 
96            <#list specOrganismosMap?keys as spec> 
97                <p>${spec}: ${specOrganismosMap[spec]?join(", ")}</p> 
98            </#list> 
99        </div> 
100    </#if> 
101 
102    <#-- Variables --> 
103    <#assign facetId    = "facet-" + paramNameSpecificationName + "-" + renderResponse.getNamespace() /> 
104    <#assign facetClass = "facet-" + paramNameSpecificationName + "-combo-search-wrapper" /> 
105 
106    <#-- ========================= --> 
107    <#-- TOM SELECT framework      --> 
108    <#-- ========================= --> 
109    <@liferay_util["html-top"] outputKey="tom-select"> 
110        <link href="${staticHost}/scripts/vendor/tom-select/tom-select.css" rel="stylesheet"> 
111        <script src="${staticHost}/scripts/vendor/tom-select/tom-select.complete.min.js"></script> 
112    </@> 
113 
114    <#-- ========================= --> 
115    <#-- CSS                       --> 
116    <#-- ========================= --> 
117    <style> 
118        #${facetId} { 
119            --facet-font-family: Inter; 
120            --facet-font-size: 14px; 
121            --facet-font-weight: 400; 
122            --facet-line-height: 18px; 
123            --facet-letter-spacing: 0.5px; 
124            --facet-color: #66757f; 
125
126        #${facetId}-select { 
127            appearance: none; 
128            -webkit-appearance: none; 
129            visibility: hidden; 
130            position: absolute; 
131
132        #${facetId} .ts-wrapper { 
133            width: 100%; 
134            margin-bottom: 16px; 
135            opacity: 0; 
136            transition: opacity 0.1s ease; 
137
138        #${facetId} .ts-wrapper .ts-control { 
139            padding: 15.5px 16px; 
140            font-family: var(--facet-font-family); 
141            font-size: var(--facet-font-size); 
142            font-weight: var(--facet-font-weight); 
143            line-height: var(--facet-line-height); 
144            letter-spacing: var(--facet-letter-spacing); 
145            color: var(--facet-color); 
146            text-align: left; 
147            height: 55px; 
148            width: 100%; 
149            border-radius: 4px; 
150            border: none; 
151            background-color: #F5F5F5; 
152            background-image: url(/documents/d/global/ico-chevron-down-2); 
153            background-repeat: no-repeat; 
154            background-position: right 1rem center; 
155            background-size: 18px 10px; 
156            box-shadow: none; 
157            cursor: pointer; 
158            box-sizing: border-box; 
159
160        #${facetId} .ts-wrapper .ts-control:focus, 
161        #${facetId} .ts-wrapper .ts-control:focus-visible { 
162            background-image: url(/documents/d/global/ico-chevron-down-2); 
163            background-position: right 1rem center; 
164            background-size: 18px 10px; 
165            outline: none; 
166            box-shadow: none; 
167
168        #${facetId} .ts-wrapper .ts-control .item { 
169            padding-right: 0.75rem; 
170            overflow: hidden; 
171            text-overflow: ellipsis; 
172            max-width: calc(100% - 0.75rem); 
173
174        #${facetId} .ts-wrapper.single .ts-control::after { 
175            display: none; 
176
177        #${facetId} .ts-dropdown .dropdown-input-wrap .dropdown-input { 
178            font-family: var(--facet-font-family); 
179            font-size: var(--facet-font-size); 
180            font-weight: var(--facet-font-weight); 
181            line-height: var(--facet-line-height); 
182            letter-spacing: var(--facet-letter-spacing); 
183            color: var(--facet-color); 
184            padding: 8px 16px; 
185            border: none; 
186            border-bottom: 1px solid #d9d9d9; 
187            background-color: #fff; 
188            width: 100%; 
189            box-sizing: border-box; 
190
191        #${facetId} .ts-dropdown .dropdown-input-wrap .dropdown-input:focus { 
192            outline: none; 
193            box-shadow: none; 
194
195        #${facetId} .ts-dropdown .ts-dropdown-content .option { 
196            font-family: var(--facet-font-family); 
197            font-size: var(--facet-font-size); 
198            font-weight: var(--facet-font-weight); 
199            line-height: var(--facet-line-height); 
200            letter-spacing: var(--facet-letter-spacing); 
201            color: var(--facet-color); 
202            padding: 8px 16px; 
203
204        #${facetId} .ts-dropdown .ts-dropdown-content .option:hover, 
205        #${facetId} .ts-dropdown .ts-dropdown-content .option.active { 
206            background-color: #6a9bd3; 
207            color: #fff; 
208
209        #${facetId} .ts-dropdown .ts-dropdown-content .option:hover .badge, 
210        #${facetId} .ts-dropdown .ts-dropdown-content .option.active .badge { 
211            background-color: #fff; 
212            color: #3a6a9b; 
213
214    </style> 
215 
216    <div class="checks-container ${facetClass}" id="${facetId}"> 
217        <div class="d-flex flex-column w-100"> 
218            <label class="panel-title mb-2" for="${facetId}-select"> 
219                ${languageUtil.get(locale, "norma." + paramNameSpecificationName)} 
220                <#if isDebug> 
221                    <p style="font-size:11px;color:#999;font-weight:normal;"> 
222                        (total options: ${entries?size}) 
223                    </p> 
224                    <p style="font-size:11px;color:#999;font-weight:normal;"> 
225                        (facetId: ${facetId}) 
226                    </p> 
227                </#if> 
228            </label> 
229 
230            <#-- ========================= --> 
231            <#-- SELECT UI                 --> 
232            <#-- ========================= --> 
233             
234 
235             
236            <select id="${facetId}-select" data-parameter-name="${paramNameSpecificationName}"> 
237                <option value="">${languageUtil.get(locale, "search.cualquiera")}</option> 
238                <#list entries?sort_by("displayName") as entry> 
239                    <#assign specName = entry.getDisplayName() /> 
240                    <#assign orgNames = specOrganismosMap[specName]![] /> 
241						 
242 
243LOOKUP KEY: [${specName}] 
244FOUND?: ${(specOrganismosMap[specName]?has_content)?c} 
245							 
246									 
247                    <option value="${htmlUtil.escape(specName)}" 
248                        <#if entry.isSelected()>selected</#if> 
249                        data-organismos="${htmlUtil.escape(orgNames?join(","))}"> 
250                        ${htmlUtil.escape(specName)} (${entry.getFrequency()}) 
251                    </option> 
252                </#list> 
253            </select> 
254        </div> 
255    </div> 
256 
257    <#-- ========================= --> 
258    <#-- SCRIPT                    --> 
259    <#-- ========================= --> 
260    <script> 
261        (function () { 
262            var FACET_ID   = '${facetId}'; 
263            var PARAM_NAME = '${paramNameSpecificationName}'; 
264 
265            function applyUrlFilter(value) { 
266                var url = new URL(window.location.href); 
267                if (value) { 
268                    url.searchParams.set(PARAM_NAME, value); 
269                } else { 
270                    url.searchParams.delete(PARAM_NAME); 
271
272                window.location.href = url.toString(); 
273
274 
275            function initFacet() { 
276                var select = document.getElementById(FACET_ID + '-select'); 
277                if (!select) return; 
278                if (select.tomselect) select.tomselect.destroy(); 
279                if (select.dataset.bound === 'true') return; 
280                select.dataset.bound = 'true'; 
281 
282                new TomSelect(select, { 
283                    allowEmptyOption: true, 
284                    maxItems: 1, 
285                    create: false, 
286                    render: { 
287                        option: function(data, escape) { 
288                            var organismos = data.$option ? data.$option.getAttribute('data-organismos') : ''; 
289                            var badges = ''; 
290                            if (organismos) { 
291                                organismos.split(',').forEach(function(org) { 
292                                    badges += '<span class="badge badge-secondary mr-1">' + escape(org.trim()) + '</span>'; 
293                                }); 
294
295                            return '<div class="option py-1">' + escape(data.text) + '<div class="mt-1">' + badges + '</div></div>'; 
296                        }, 
297                        no_results: function(data, escape) { 
298                            return '<div class="no-results">${languageUtil.get(locale, "occurrence-not-found")}</div>'; 
299
300                    }, 
301                    plugins: { 
302                        dropdown_input: {} 
303                    }, 
304                    onDelete: function(value) { 
305                        this.isDelete = true; 
306                    }, 
307                    onChange: function(value) { 
308                        if (value) { 
309                            this.lastValidValue = value; 
310                            applyUrlFilter(value); 
311                            return; 
312
313                        this.lastValidValue = ''; 
314                        applyUrlFilter(''); 
315                    }, 
316                    onInitialize: function() { 
317                        this.lastValidValue = this.getValue() || ''; 
318                        this.isDelete = false; 
319                        var wrapper = document.querySelector('#' + FACET_ID + ' .ts-wrapper'); 
320                        if (wrapper) wrapper.style.opacity = '1'; 
321
322                }); 
323
324 
325            if (document.readyState === 'loading') { 
326                document.addEventListener('DOMContentLoaded', initFacet); 
327            } else { 
328                initFacet(); 
329
330        })(); 
331    </script> 
332 
333</#if> 
Se ha producido un error al procesar la plantilla.
The following has evaluated to null or missing:
==> esResponse.getAggregationResult(specificationKey + "_with_organismos")  [in template "34352066712900#33336#362204" at line 67, column 33]

----
Tip: If the failing expression is known to legally refer to something that's sometimes null or missing, either specify a default value like myOptionalVar!myDefault, or use <#if myOptionalVar??>when-present<#else>when-missing</#if>. (These only cover the last step of the expression; to cover the whole expression, use parenthesis: (myOptionalVar.foo)!myDefault, (myOptionalVar.foo)??
----

----
FTL stack trace ("~" means nesting-related):
	- Failed at: #local aggregationResult = esResponse...  [in template "34352066712900#33336#362204" in function "getAggregationResult" at line 67, column 5]
----
1<#-- Variables --> 
2<#assign specificationName          = 'ics' /> 
3<#assign paramNameSpecificationName = cpSpecificationOptionsSearchFacetDisplayContext.getParameterName() /> 
4<#assign isDebug                    = false /> 
5<#assign showAllSpecificationsName  = false /> 
6<#assign staticHost                 = getCXConfig("ecom-static-files") /> 
7 
8<#-- ========================= --> 
9<#-- Functions freemaker       --> 
10<#-- ========================= --> 
11<#function getCXConfig clientExtensionName field="webApiUrl"> 
12    <#if !clientExtensionName?has_content><#return "" /></#if> 
13    <#local encoded = urlCodec.encodeURL(clientExtensionName) /> 
14    <#local items   = restClient.get("/c/customconfigs/?fields=clientExtensionConfig&filter=clientExtensionName eq '" + encoded + "'").items![] /> 
15    <#return items?has_content?then(items[0].clientExtensionConfig?eval[field]!"", "") /> 
16</#function> 
17 
18<#function getTaxonomyVocabularyId vocabularyName> 
19    <#local response = restClient.get("/headless-admin-taxonomy/v1.0/sites/" + groupId + "/taxonomy-vocabularies?filter=contains(name,'" + vocabularyName + "')&pageSize=1")!{} /> 
20    <#local items    = response.items![] /> 
21    <#return items?has_content?then(items[0].id, "") /> 
22</#function> 
23 
24<#function getTaxonomyCategoryMap vocabularyId pageSize=200> 
25    <#local response   = restClient.get("/headless-admin-taxonomy/v1.0/taxonomy-vocabularies/" + vocabularyId + "/taxonomy-categories?pageSize=" + pageSize)!{} /> 
26    <#local categoryMap = {} /> 
27    <#list response.items![] as cat> 
28        <#local categoryMap = categoryMap + {vocabularyId + "-" + cat.id: cat.name} /> 
29    </#list> 
30    <#return categoryMap /> 
31</#function> 
32 
33<#function getSpecOrganismosMap organismoMap aggResult> 
34    <#local specMap = {} /> 
35    <#if !aggResult?has_content || !organismoMap?has_content><#return specMap /></#if> 
36    <#list aggResult.getBuckets() as specBucket> 
37        <#local specKey      = specBucket.getKey() /> 
38        <#local organismoAgg = specBucket.getChildAggregationResult("organismos") /> 
39        <#local orgNames     = [] /> 
40        <#if organismoAgg?has_content> 
41            <#list organismoAgg.getBuckets() as orgBucket> 
42                <#local orgName  = organismoMap[orgBucket.getKey()]!"" /> 
43                <#if orgName?has_content> 
44                    <#local orgNames = orgNames + [orgName] /> 
45                </#if> 
46            </#list> 
47        </#if> 
48        <#if orgNames?has_content> 
49            <#local specMap = specMap + {specKey: orgNames} /> 
50        </#if> 
51    </#list> 
52    <#return specMap /> 
53</#function> 
54 
55<#function getAggregationResult specificationKey> 
56    <#if !specificationKey?has_content><#return "" /></#if> 
57 
58    <#local sharedSearchResponse = renderRequest.getAttribute("LIFERAY_SHARED_PortletSharedSearchResponse") /> 
59    <#if !sharedSearchResponse?has_content><#return "" /></#if> 
60 
61    <#local searchResponse = sharedSearchResponse.get() /> 
62    <#if !searchResponse?has_content><#return "" /></#if> 
63 
64    <#local esResponse = searchResponse.getSearchResponse() /> 
65    <#if !esResponse?has_content><#return "" /></#if> 
66 
67    <#local aggregationResult = esResponse.getAggregationResult(specificationKey + "_with_organismos") /> 
68    <#if !aggregationResult?has_content><#return "" /></#if> 
69 
70    <#return aggregationResult /> 
71</#function> 
72 
73 
74 
75 
76<#if paramNameSpecificationName == specificationName || showAllSpecificationsName> 
77 
78    <#-- ========================= --> 
79    <#-- Datos                     --> 
80    <#-- ========================= --> 
81	<#assign organismoVocabId  = getTaxonomyVocabularyId("organismos") /> 
82	<#assign organismoMap      = getTaxonomyCategoryMap(organismoVocabId) /> 
83	<#assign aggResult         = getAggregationResult(paramNameSpecificationName)! /> 
84	<#assign specOrganismosMap = getSpecOrganismosMap(organismoMap, aggResult) /> 
85 
86    <#-- ========================= --> 
87    <#-- Debug                     --> 
88    <#-- ========================= --> 
89    <#if isDebug> 
90        <div style="background:#f0f0f0;padding:8px;margin-bottom:8px;font-size:11px;border:1px solid #ccc;"> 
91            <p><strong>paramName:</strong> ${paramNameSpecificationName}</p> 
92            <p><strong>organismoMap size:</strong> ${organismoMap?size}</p> 
93            <p><strong>specOrganismosMap size:</strong> ${specOrganismosMap?size}</p> 
94            <#list specOrganismosMap?keys as spec> 
95                <p>${spec}: ${specOrganismosMap[spec]?join(", ")}</p> 
96            </#list> 
97        </div> 
98    </#if> 
99 
100    <#-- Variables --> 
101    <#assign facetId    = "facet-" + paramNameSpecificationName + "-" + renderResponse.getNamespace() /> 
102    <#assign facetClass = "facet-" + paramNameSpecificationName + "-combo-search-wrapper" /> 
103 
104    <#-- ========================= --> 
105    <#-- TOM SELECT framework      --> 
106    <#-- ========================= --> 
107    <@liferay_util["html-top"] outputKey="tom-select"> 
108        <link href="${staticHost}/scripts/vendor/tom-select/tom-select.css" rel="stylesheet"> 
109        <script src="${staticHost}/scripts/vendor/tom-select/tom-select.complete.min.js"></script> 
110    </@> 
111 
112    <#-- ========================= --> 
113    <#-- CSS                       --> 
114    <#-- ========================= --> 
115    <style> 
116        #${facetId} { 
117            --facet-font-family: Inter; 
118            --facet-font-size: 14px; 
119            --facet-font-weight: 400; 
120            --facet-line-height: 18px; 
121            --facet-letter-spacing: 0.5px; 
122            --facet-color: #66757f; 
123
124        #${facetId}-select { 
125            appearance: none; 
126            -webkit-appearance: none; 
127            visibility: hidden; 
128            position: absolute; 
129
130        #${facetId} .ts-wrapper { 
131            width: 100%; 
132            margin-bottom: 16px; 
133            opacity: 0; 
134            transition: opacity 0.1s ease; 
135
136        #${facetId} .ts-wrapper .ts-control { 
137            padding: 15.5px 16px; 
138            font-family: var(--facet-font-family); 
139            font-size: var(--facet-font-size); 
140            font-weight: var(--facet-font-weight); 
141            line-height: var(--facet-line-height); 
142            letter-spacing: var(--facet-letter-spacing); 
143            color: var(--facet-color); 
144            text-align: left; 
145            height: 55px; 
146            width: 100%; 
147            border-radius: 4px; 
148            border: none; 
149            background-color: #F5F5F5; 
150            background-image: url(/documents/d/global/ico-chevron-down-2); 
151            background-repeat: no-repeat; 
152            background-position: right 1rem center; 
153            background-size: 18px 10px; 
154            box-shadow: none; 
155            cursor: pointer; 
156            box-sizing: border-box; 
157
158        #${facetId} .ts-wrapper .ts-control:focus, 
159        #${facetId} .ts-wrapper .ts-control:focus-visible { 
160            background-image: url(/documents/d/global/ico-chevron-down-2); 
161            background-position: right 1rem center; 
162            background-size: 18px 10px; 
163            outline: none; 
164            box-shadow: none; 
165
166        #${facetId} .ts-wrapper .ts-control .item { 
167            padding-right: 0.75rem; 
168            overflow: hidden; 
169            text-overflow: ellipsis; 
170            max-width: calc(100% - 0.75rem); 
171
172        #${facetId} .ts-wrapper.single .ts-control::after { 
173            display: none; 
174
175        #${facetId} .ts-dropdown .dropdown-input-wrap .dropdown-input { 
176            font-family: var(--facet-font-family); 
177            font-size: var(--facet-font-size); 
178            font-weight: var(--facet-font-weight); 
179            line-height: var(--facet-line-height); 
180            letter-spacing: var(--facet-letter-spacing); 
181            color: var(--facet-color); 
182            padding: 8px 16px; 
183            border: none; 
184            border-bottom: 1px solid #d9d9d9; 
185            background-color: #fff; 
186            width: 100%; 
187            box-sizing: border-box; 
188
189        #${facetId} .ts-dropdown .dropdown-input-wrap .dropdown-input:focus { 
190            outline: none; 
191            box-shadow: none; 
192
193        #${facetId} .ts-dropdown .ts-dropdown-content .option { 
194            font-family: var(--facet-font-family); 
195            font-size: var(--facet-font-size); 
196            font-weight: var(--facet-font-weight); 
197            line-height: var(--facet-line-height); 
198            letter-spacing: var(--facet-letter-spacing); 
199            color: var(--facet-color); 
200            padding: 8px 16px; 
201
202        #${facetId} .ts-dropdown .ts-dropdown-content .option:hover, 
203        #${facetId} .ts-dropdown .ts-dropdown-content .option.active { 
204            background-color: #6a9bd3; 
205            color: #fff; 
206
207        #${facetId} .ts-dropdown .ts-dropdown-content .option:hover .badge, 
208        #${facetId} .ts-dropdown .ts-dropdown-content .option.active .badge { 
209            background-color: #fff; 
210            color: #3a6a9b; 
211
212    </style> 
213 
214    <div class="checks-container ${facetClass}" id="${facetId}"> 
215        <div class="d-flex flex-column w-100"> 
216            <label class="panel-title mb-2" for="${facetId}-select"> 
217                ${languageUtil.get(locale, "norma." + paramNameSpecificationName)} 
218                <#if isDebug> 
219                    <p style="font-size:11px;color:#999;font-weight:normal;"> 
220                        (total options: ${entries?size}) 
221                    </p> 
222                    <p style="font-size:11px;color:#999;font-weight:normal;"> 
223                        (facetId: ${facetId}) 
224                    </p> 
225                </#if> 
226            </label> 
227 
228            <#-- ========================= --> 
229            <#-- SELECT UI                 --> 
230            <#-- ========================= --> 
231            <select id="${facetId}-select" data-parameter-name="${paramNameSpecificationName}"> 
232                <option value="">${languageUtil.get(locale, "search.cualquiera")}</option> 
233                <#list entries?sort_by("displayName") as entry> 
234                    <#assign specName = entry.getDisplayName() /> 
235                    <#assign orgNames = specOrganismosMap[specName]![] /> 
236                    <option value="${htmlUtil.escape(specName)}" 
237                        <#if entry.isSelected()>selected</#if> 
238                        data-organismos="${htmlUtil.escape(orgNames?join(","))}"> 
239                        ${htmlUtil.escape(specName)} (${entry.getFrequency()}) 
240                    </option> 
241                </#list> 
242            </select> 
243        </div> 
244    </div> 
245 
246    <#-- ========================= --> 
247    <#-- SCRIPT                    --> 
248    <#-- ========================= --> 
249    <script> 
250        (function () { 
251            var FACET_ID   = '${facetId}'; 
252            var PARAM_NAME = '${paramNameSpecificationName}'; 
253 
254            function applyUrlFilter(value) { 
255                var url = new URL(window.location.href); 
256                if (value) { 
257                    url.searchParams.set(PARAM_NAME, value); 
258                } else { 
259                    url.searchParams.delete(PARAM_NAME); 
260
261                window.location.href = url.toString(); 
262
263 
264            function initFacet() { 
265                var select = document.getElementById(FACET_ID + '-select'); 
266                if (!select) return; 
267                if (select.tomselect) select.tomselect.destroy(); 
268                if (select.dataset.bound === 'true') return; 
269                select.dataset.bound = 'true'; 
270 
271                new TomSelect(select, { 
272                    allowEmptyOption: true, 
273                    maxItems: 1, 
274                    create: false, 
275                    render: { 
276                        option: function(data, escape) { 
277                            var organismos = data.$option ? data.$option.getAttribute('data-organismos') : ''; 
278                            var badges = ''; 
279                            if (organismos) { 
280                                organismos.split(',').forEach(function(org) { 
281                                    badges += '<span class="badge badge-secondary mr-1">' + escape(org.trim()) + '</span>'; 
282                                }); 
283
284                            return '<div class="option py-1">' + escape(data.text) + '<div class="mt-1">' + badges + '</div></div>'; 
285                        }, 
286                        no_results: function(data, escape) { 
287                            return '<div class="no-results">${languageUtil.get(locale, "occurrence-not-found")}</div>'; 
288
289                    }, 
290                    plugins: { 
291                        dropdown_input: {} 
292                    }, 
293                    onDelete: function(value) { 
294                        this.isDelete = true; 
295                    }, 
296                    onChange: function(value) { 
297                        if (value) { 
298                            this.lastValidValue = value; 
299                            applyUrlFilter(value); 
300                            return; 
301
302                        this.lastValidValue = ''; 
303                        applyUrlFilter(''); 
304                    }, 
305                    onInitialize: function() { 
306                        this.lastValidValue = this.getValue() || ''; 
307                        this.isDelete = false; 
308                        var wrapper = document.querySelector('#' + FACET_ID + ' .ts-wrapper'); 
309                        if (wrapper) wrapper.style.opacity = '1'; 
310
311                }); 
312
313 
314            if (document.readyState === 'loading') { 
315                document.addEventListener('DOMContentLoaded', initFacet); 
316            } else { 
317                initFacet(); 
318
319        })(); 
320    </script> 
321 
322</#if> 
(37753)
(36846)
(4136)
UNE

UNE-EN 494:2013+A1:2017

En Vigor
2017-06-07
Placas onduladas o nervadas de cemento reforzado con fibras y sus piezas complementarias. Especificación de producto y métodos de ensayo.
UNE

UNE-EN 12041:2015

En Vigor
2015-04-01
Maquinaria para el procesado de alimentos. Moldeadoras. Requisitos de seguridad e higiene.
UNE

UNE-EN ISO 5089:2017

En Vigor
2017-05-31
Textiles. Preparación de muestras de ensayo de laboratorio y probetas de ensayo para ensayos químicos. (ISO 5089:1977).
UNE

UNE-EN 62026-3:2015

En Vigor
2015-05-01
Aparamenta de baja tensión. Interfaces para dispositivos controladores (CDIs). Parte 3: Red de dispositivos. (Ratificada por AENOR en mayo de 2015.)