75908 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                    = true /> 
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    <#-- Debug                     --> 
87    <#-- ========================= --> 
88    <#if isDebug > 
89        <div style="background:#f0f0f0;padding:8px;margin-bottom:8px;font-size:11px;border:1px solid #ccc;"> 
90            <p><strong>paramName:</strong> ${paramNameSpecificationName}</p> 
91            <p><strong>organismoMap size:</strong> ${organismoMap?size}</p> 
92            <p><strong>specOrganismosMap size:</strong> ${specOrganismosMap?size}</p> 
93            <#list specOrganismosMap?keys as spec> 
94                <p>${spec}: ${specOrganismosMap[spec]?join(", ")}</p> 
95            </#list> 
96        </div> 
97    </#if> 
98 
99    <#-- Variables --> 
100    <#assign facetId    = "facet-" + paramNameSpecificationName + "-" + renderResponse.getNamespace() /> 
101    <#assign facetClass = "facet-" + paramNameSpecificationName + "-combo-search-wrapper" /> 
102 
103    <#-- ========================= --> 
104    <#-- TOM SELECT framework      --> 
105    <#-- ========================= --> 
106    <@liferay_util["html-top"] outputKey="tom-select"> 
107        <link href="${staticHost}/scripts/vendor/tom-select/tom-select.css" rel="stylesheet"> 
108        <script src="${staticHost}/scripts/vendor/tom-select/tom-select.complete.min.js"></script> 
109    </@> 
110 
111    <#-- ========================= --> 
112    <#-- CSS                       --> 
113    <#-- ========================= --> 
114    <style> 
115        #${facetId} { 
116            --facet-font-family: Inter; 
117            --facet-font-size: 14px; 
118            --facet-font-weight: 400; 
119            --facet-line-height: 18px; 
120            --facet-letter-spacing: 0.5px; 
121            --facet-color: #66757f; 
122
123        #${facetId}-select { 
124            appearance: none; 
125            -webkit-appearance: none; 
126            visibility: hidden; 
127            position: absolute; 
128
129        #${facetId} .ts-wrapper { 
130            width: 100%; 
131            margin-bottom: 16px; 
132            opacity: 0; 
133            transition: opacity 0.1s ease; 
134
135        #${facetId} .ts-wrapper .ts-control { 
136            padding: 15.5px 16px; 
137            font-family: var(--facet-font-family); 
138            font-size: var(--facet-font-size); 
139            font-weight: var(--facet-font-weight); 
140            line-height: var(--facet-line-height); 
141            letter-spacing: var(--facet-letter-spacing); 
142            color: var(--facet-color); 
143            text-align: left; 
144            height: 55px; 
145            width: 100%; 
146            border-radius: 4px; 
147            border: none; 
148            background-color: #F5F5F5; 
149            background-image: url(/documents/d/global/ico-chevron-down-2); 
150            background-repeat: no-repeat; 
151            background-position: right 1rem center; 
152            background-size: 18px 10px; 
153            box-shadow: none; 
154            cursor: pointer; 
155            box-sizing: border-box; 
156
157        #${facetId} .ts-wrapper .ts-control:focus, 
158        #${facetId} .ts-wrapper .ts-control:focus-visible { 
159            background-image: url(/documents/d/global/ico-chevron-down-2); 
160            background-position: right 1rem center; 
161            background-size: 18px 10px; 
162            outline: none; 
163            box-shadow: none; 
164
165        #${facetId} .ts-wrapper .ts-control .item { 
166            padding-right: 0.75rem; 
167            overflow: hidden; 
168            text-overflow: ellipsis; 
169            max-width: calc(100% - 0.75rem); 
170
171        #${facetId} .ts-wrapper.single .ts-control::after { 
172            display: none; 
173
174        #${facetId} .ts-dropdown .dropdown-input-wrap .dropdown-input { 
175            font-family: var(--facet-font-family); 
176            font-size: var(--facet-font-size); 
177            font-weight: var(--facet-font-weight); 
178            line-height: var(--facet-line-height); 
179            letter-spacing: var(--facet-letter-spacing); 
180            color: var(--facet-color); 
181            padding: 8px 16px; 
182            border: none; 
183            border-bottom: 1px solid #d9d9d9; 
184            background-color: #fff; 
185            width: 100%; 
186            box-sizing: border-box; 
187
188        #${facetId} .ts-dropdown .dropdown-input-wrap .dropdown-input:focus { 
189            outline: none; 
190            box-shadow: none; 
191
192        #${facetId} .ts-dropdown .ts-dropdown-content .option { 
193            font-family: var(--facet-font-family); 
194            font-size: var(--facet-font-size); 
195            font-weight: var(--facet-font-weight); 
196            line-height: var(--facet-line-height); 
197            letter-spacing: var(--facet-letter-spacing); 
198            color: var(--facet-color); 
199            padding: 8px 16px; 
200
201        #${facetId} .ts-dropdown .ts-dropdown-content .option:hover, 
202        #${facetId} .ts-dropdown .ts-dropdown-content .option.active { 
203            background-color: #6a9bd3; 
204            color: #fff; 
205
206        #${facetId} .ts-dropdown .ts-dropdown-content .option:hover .badge, 
207        #${facetId} .ts-dropdown .ts-dropdown-content .option.active .badge { 
208            background-color: #fff; 
209            color: #3a6a9b; 
210
211    </style> 
212 
213    <div class="checks-container ${facetClass}" id="${facetId}"> 
214        <div class="d-flex flex-column w-100"> 
215            <label class="panel-title mb-2" for="${facetId}-select"> 
216                ${languageUtil.get(locale, "norma." + paramNameSpecificationName)} 
217                <#if isDebug> 
218                    <p style="font-size:11px;color:#999;font-weight:normal;"> 
219                        (total options: ${entries?size}) 
220                    </p> 
221                    <p style="font-size:11px;color:#999;font-weight:normal;"> 
222                        (facetId: ${facetId}) 
223                    </p> 
224                </#if> 
225            </label> 
226 
227            <#-- ========================= --> 
228            <#-- SELECT UI                 --> 
229            <#-- ========================= --> 
230            <select id="${facetId}-select" data-parameter-name="${paramNameSpecificationName}"> 
231                <option value="">${languageUtil.get(locale, "search.cualquiera")}</option> 
232                <#list entries?sort_by("displayName") as entry> 
233                    <#assign specName = entry.getDisplayName() /> 
234                    <#assign orgNames = specOrganismosMap[specName]![] /> 
235                    <option value="${htmlUtil.escape(specName)}" 
236                        <#if entry.isSelected()>selected</#if> 
237                        data-organismos="${htmlUtil.escape(orgNames?join(","))}"> 
238                        ${htmlUtil.escape(specName)} (${entry.getFrequency()}) 
239                    </option> 
240                </#list> 
241            </select> 
242        </div> 
243    </div> 
244 
245    <#-- ========================= --> 
246    <#-- SCRIPT                    --> 
247    <#-- ========================= --> 
248    <script> 
249        (function () { 
250            var FACET_ID   = '${facetId}'; 
251            var PARAM_NAME = '${paramNameSpecificationName}'; 
252 
253            function applyUrlFilter(value) { 
254                var url = new URL(window.location.href); 
255                if (value) { 
256                    url.searchParams.set(PARAM_NAME, value); 
257                } else { 
258                    url.searchParams.delete(PARAM_NAME); 
259
260                window.location.href = url.toString(); 
261
262 
263            function initFacet() { 
264                var select = document.getElementById(FACET_ID + '-select'); 
265                if (!select) return; 
266                if (select.tomselect) select.tomselect.destroy(); 
267                if (select.dataset.bound === 'true') return; 
268                select.dataset.bound = 'true'; 
269 
270                new TomSelect(select, { 
271                    allowEmptyOption: true, 
272                    maxItems: 1, 
273                    create: false, 
274                    render: { 
275                        option: function(data, escape) { 
276                            var organismos = data.$option ? data.$option.getAttribute('data-organismos') : ''; 
277                            var badges = ''; 
278                            if (organismos) { 
279                                organismos.split(',').forEach(function(org) { 
280                                    badges += '<span class="badge badge-secondary mr-1">' + escape(org.trim()) + '</span>'; 
281                                }); 
282
283                            return '<div class="option py-1">' + escape(data.text) + '<div class="mt-1">' + badges + '</div></div>'; 
284                        }, 
285                        no_results: function(data, escape) { 
286                            return '<div class="no-results">${languageUtil.get(locale, "occurrence-not-found")}</div>'; 
287
288                    }, 
289                    plugins: { 
290                        dropdown_input: {} 
291                    }, 
292                    onDelete: function(value) { 
293                        this.isDelete = true; 
294                    }, 
295                    onChange: function(value) { 
296                        if (value) { 
297                            this.lastValidValue = value; 
298                            applyUrlFilter(value); 
299                            return; 
300
301                        this.lastValidValue = ''; 
302                        applyUrlFilter(''); 
303                    }, 
304                    onInitialize: function() { 
305                        this.lastValidValue = this.getValue() || ''; 
306                        this.isDelete = false; 
307                        var wrapper = document.querySelector('#' + FACET_ID + ' .ts-wrapper'); 
308                        if (wrapper) wrapper.style.opacity = '1'; 
309
310                }); 
311
312 
313            if (document.readyState === 'loading') { 
314                document.addEventListener('DOMContentLoaded', initFacet); 
315            } else { 
316                initFacet(); 
317
318        })(); 
319    </script> 
320 
321</#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                    = true /> 
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 && 1==0> 
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> 
(40288)
(35620)
(0)
AFNOR

NF EN ISO 15607

Anulada
2020-02-11
Specification and qualification of welding procedures for metallic materials - General rules
AFNOR

NF EN 61347-2-12/A1

En Vigor
2011-06-01
Lamp controlgear - Part 2-12 : particular requirements for d.c. or a.c. supplied electronic ballasts for discharge lamps (excluding fluorescent lamps)
AFNOR

NF EN ISO 23131

En Vigor
2022-11-09
Ellipsometry - Principles
AFNOR

NF EN 15069

En Vigor
2017-12-22
Safety gas connection valves for metal hose assemblies used for the connection of domestic appliances using gaseous fuel
AFNOR

NF EN 12440

Anulada
2017-12-29
Natural stone - Denomination criteria
AFNOR

NF EN IEC 60335-2-104

En Vigor
2025-05-16
Household and similar electrical appliances - Safety - Part 2-104 : particular requirements for appliances to recover and/or recycle refrigerant from air conditioning and refrigeration equipment
AFNOR

NF D36-121/A1

En Vigor
2011-12-01
Household economy - End fittings with seal gasket for corrugated metallic flexible piping for the external connection of domestic appliances using gaseous fuels distributed by networks
AFNOR

NF EN 12722/IN1

En Vigor
2013-12-27
Furniture - Assessment of surface resistance to dry heat
AFNOR

NF EN 527-1

Anulada
2011-08-13
Office furniture - Work tables and desks - Part 1 : dimensions
AFNOR

NF EN IEC 60335-2-103/A1

En Vigor
2023-05-12
Household and similar electrical appliances - Safety - Part 2-103: Particular requirements for drives for gates, doors and windows
AFNOR

NF EN ISO 22044

En Vigor
2022-01-19
Commercial beverage coolers — Classification, requirements and test conditions
AFNOR

NF EN 60601-2-37/A1

En Vigor
2015-11-07
Medical electrical equipment - Part 2-37 : particular requirements for the basic safety and essential performance of ultrasonic medical diagnostic and monitoring equipment
AFNOR

NF EN 15493

En Vigor
2019-10-23
Candles - Specification for fire safety
AFNOR

NF EN IEC 62061

En Vigor
2021-07-23
Safety of machinery - Functional safety of safety-related control systems
AFNOR

NF EN 62198

En Vigor
2014-05-16
Managing risk in projects - Application guidelines
AFNOR

NF EN 10226-1

En Vigor
2004-11-01
Pipe threads where pressure tight joints are made on the threads - Part 1 : taper external threads and parallel internal threads - Dimensions, tolerances and designation
AFNOR

NF EN 60554-2

En Vigor
2003-05-01
Cellulosic papers for electrical purposes - Part 2 : methods of test
AFNOR

NF EN ISO 6412-2

Anulada
2018-03-13
Technical drawings. Simplified representation of pipelines. Part 2 : isometric projection.
AFNOR

NF EN 61000-4-28/A1

En Vigor
2004-08-01
Electromagnetic compatibility (EMC) - Part 4-28 : testing and measurement techniques - Variation of power frequency, immunity test
AFNOR

NF EN 60851-5/A2

En Vigor
2019-11-15
Winding wires - Test methods - Part 5 : electrical properties
AFNOR

NF EN ISO 22081

En Vigor
2021-02-17
Geometrical product specifications (GPS) - Geometrical tolerancing - General geometrical specifications and general size specifications
AFNOR

NF EN 60384-18-2

En Vigor
2008-05-01
Fixed capacitors for use in electronic equipment - Part 18-2 : blank detail specification - Fixed aluminium electrolytic surface mount capacitors with non-solid electrolyte - Assessment level EZ
AFNOR

NF EN 50363-8/A1

En Vigor
2012-02-01
Insulating, sheathing and covering materials for low voltage energy cables - Part 8 : Halogen-free, thermoplastic sheathing compounds
AFNOR

NF EN 60512-11-7

En Vigor
2003-12-01
Connectors for electronic equipment - Tests and measurements - Part 11-7 : climatic tests - Test 11g : flowing mixed gas corrosion test
AFNOR

NF EN IEC 60051-9

En Vigor
2021-04-30
Direct acting indicating analogue electrical measuring instruments and their accessories - Part 9 : recommended test methods
AFNOR

NF EN 1093-2/IN1

En Vigor
2008-08-01
Safety of machinery - Evaluation of the emission of airborne hazardous substances - Part 2 : tracer gas method for the measurement of the emission rate of a given pollutant
AFNOR

NF EN ISO 13385-1

Anulada
2019-12-25
Geometrical product specifications (GPS) -- Dimensional measuring equipment -- Part 1: Callipers# Design and metrological characteristics
AFNOR

NF EN IEC 61158-6-21

En Vigor
2019-08-23
Industrial communication networks - Fieldbus specifications - Part 6-21 : application layer protocol specification - Type 21 elements
AFNOR

GA E17-901

Anulada
2015-12-09
Application guide for the European Standards of the EN 13757 series "Communication systems for and remote reading of meters"
AFNOR

NF EN 10200

Anulada
2011-08-20
Chemical analysis of ferrous materials. Determination of bore in steel. Spectrophotometric method.
AFNOR

NF ISO 464

En Vigor
2016-02-13
Rolling bearings - Radial bearings with locating snap ring - Dimensions, geometrical product specifications (GPS) and tolerance values
AFNOR

NF EN 10179

En Vigor
2024-06-19
Steels - Determination of nitrogen (trace amounts) - Spectrophotometric method
AFNOR

NF ISO 12297-1

En Vigor
2022-02-12
Rolling bearings - Cylindrical rollers - Part 1 : boundary dimensions, geometrical product specifications (GPS) and tolerance values for steel rollers
AFNOR

NF EN ISO 16526-3

En Vigor
2020-03-03
Non-destructive testing - Measurement and evaluation of the X-ray tube voltage - Part 3: Spectrometric method (ISO 16526-3:2011)
AFNOR

XP ISO/TS 14521

En Vigor
2020-06-17
Gears — Calculation of load capacity of worm gears
AFNOR

NF EN 62751-2

En Vigor
2015-01-17
Power losses in voltage sourced converter (VSC) valves for high-voltage direct current (HVDC) systems - Part 2 : modular multilevel converters
AFNOR

NF EN 14831

En Vigor
2005-07-01
Fasteners - Tightening performance - Torque/Angle simplified test method
AFNOR

NF EN 10253-4

Anulada
2025-07-09
Butt-welding pipe fittings - Part 4 : wrought austenitic and austenitic-ferritic (duplex) stainless steels with specific inspection requirements
AFNOR

NF C58-311

En Vigor
1990-03-01
Procedure for type tests for rectifier-battery charger and batteries.
AFNOR

NF EN ISO 7434

En Vigor
2024-06-26
Fasteners - Slotted set screws with cone point
AFNOR

NF A65-727

En Vigor
1988-09-01
Semi-finished products made of magnesium alloys. Rectangular section exruded bars. Dimensions and tolerances.
AFNOR

NF EN 61009-1

Anulada
2010-10-08
Residual current operated circuit-breakers with integral overcurrent protection for household and similar uses (rcbo'S). Part 1 : general requirements.
AFNOR

NF EN ISO 17279-1

En Vigor
2018-11-07
Welding — Micro joining of 2nd generation high temperature superconductors — Part 1: General requirements for the procedure
AFNOR

NF EN ISO 15983

En Vigor
2003-01-01
Open end blind rivets with break pull mandrel and protruding head - A2/A2
AFNOR

NF ISO 20523

En Vigor
2018-02-24
Carbon based films - Classification and designations
AFNOR

NF C61-750

En Vigor
1988-08-01
Electronic devices of automatic load limitation.
AFNOR

NF EN 818-1/IN1

En Vigor
2008-06-01
Short link chain for lifting purposes - Safety - Part 1 : general conditions of acceptance
AFNOR

NF EN 23909

En Vigor
1994-01-01
Hardmetals. Determination of cobalt. Potentiometric method.
AFNOR

NF C66-103

En Vigor
1975-09-01
Insulators and fittings for overhead lines. Insulators of ceramic material for voltages lower than 1000 V double-shed insulators with grooved heda (cdc).
AFNOR

FD CEN/TR 17081

En Vigor
2019-04-03
Design of fastenings for use in concrete - Plastic design of fastenings with headed and post-installed fasteners
AFNOR

NF EN IEC 62386-103

En Vigor
2022-12-23
Digital addressable lighting interface - Part 103 : general requirements - Control devices
AFNOR

NF EN 820-4

En Vigor
2009-10-01
Advanced technical ceramics - Thermomechanical properties of monolithic ceramics - Part 4 : determination of flexural creep deformation at elevated temperatures
AFNOR

NF EN 12570

En Vigor
2001-08-01
Industrial valves - Method for sizing the operating element
AFNOR

NF B53-669

En Vigor
2023-06-07
Wood flooring and parquet - Use classification of parquet and test methods for characterization of parquet coatings
AFNOR

NF EN IEC 62885-5

En Vigor
2018-10-26
Surface cleaning appliances - Part 5 : high pressure cleaners and steam cleaners for household and commercial use - Methods for measuring performance
AFNOR

NF EN 50341-2-1

En Vigor
2022-10-28
Overhead electrical lines exceeding AC 1 kV - Part 2-1: National Normative Aspects (NNAs) for Austria (based on EN 50341 1:2012)
AFNOR

NF EN ISO 22434

En Vigor
2022-04-27
Gas cylinders - Inspection and maintenance of valves
AFNOR

NF EN 50614

En Vigor
2020-02-07
Requirements for the preparing for re-use of waste electrical and electronic equipment
AFNOR

NF EN IEC 60335-2-115

En Vigor
2023-05-12
Household and similar electrical appliances - Safety - Part 2-115 : particular requirements for skin beauty care appliances
AFNOR

NF EN 60068-2-47

Anulada
2000-06-20
Basic environmental testing procedures. Part 2 : tests. Mounting of components, equipment and other articles for dynamic tests including shock (ea), bump (Eb), vibration (Fc and Fd) and steady-state acceleration (Ga) and guidance.