Diferencia entre revisiones de «MediaWiki:Filtros.js»

De Diccionario Interactivo Ceán Bermúdez
Ir a la navegación Ir a la búsqueda
Línea 69: Línea 69:
 
             var letter1 = this.firstChild.nodeValue.toLowerCase().trim();
 
             var letter1 = this.firstChild.nodeValue.toLowerCase().trim();
 
             abbrs[letter1] = this;
 
             abbrs[letter1] = this;
             if(letter1 == '-'){
+
             if(this == '-'){
 
             $(this).closest('li').removeClass('ln--').addClass('ln-'+letter1);
 
             $(this).closest('li').removeClass('ln--').addClass('ln-'+letter1);
 
             }
 
             }

Revisión del 12:31 22 jun 2021

jQuery(document).ready(function($){

	if($(".iframe-libro").length){
		$(".iframe-libro").html('<iframe id="Iframe1" class="iframe-paginas" data-delay="50" width="100%" height="700" frameborder="0" src="' + $(".iframe-libro").data("src") + '"></iframe>')
	}
	if($(".tomos").length){
		$(".tomos a").click(function(e){
			var ulrTomo = $(this).attr("href");
			console.log(ulrTomo);
			$(".l-tomo").addClass("hide");
			$(ulrTomo).removeClass("hide");
			$(".tomos a span").removeClass("active");
			$("span",this).addClass("active");
			e.preventDefault();
		})
	}
	
	function listFilter(input, list) { 
    var sc = true;
    $(input)
      .change( function () {
        var filter = $(this).val();        
        if(filter) {
          $(list).find("li:not(:Contains(" + filter + "))").slideUp(function(){
              if($(this).closest('.mw-category-group').find('li:visible').length == 0){ 
                if($(this).closest('.mw-category-group').is(':visible')) { 
                  $(this).closest('.mw-category-group').slideUp();                
                }
              } else {
                if(!$(this).closest('.mw-category-group').is(':visible')) {
                  $(this).closest('.mw-category-group').slideDown();
                }
              }            
          });

          $(list).find("li:Contains(" + filter + ")").slideDown(function(){
            if(!$(this).closest('.mw-category-group').is(':visible')) {
              $(this).closest('.mw-category-group').slideDown();            
            }
          });
          
          
        } else {
          $(list).find("li").slideDown();
          $('.mw-category-group').slideDown();
        }
        return false;
      })
    .keyup( function () { 
        $(this).change();
         if(sc) {$("html, body").animate({ scrollTop: $(".filtro").offset().top - 80 }, 500);sc=false;}
    });
  }
  
  setTimeout(function(){ 
    if($('.mw-category').length > 0){
        var filtro = $('<div class="filtro"><img src="/skins/Vector/images/search.png?39f97"><input type="text" id="filtro" /></div>');
        $('.mw-category').prepend(filtro);
        listFilter($('#filtro'),$('.mw-category '));	
    }
    
    if($('#listwidget-1-nav').length > 0){
        var filtro = $('<div class="filtro"><img src="/skins/Vector/images/search.png?39f97"><input type="text" placeholder="Busca en el listado" class="createboxInput" id="filtro" /></div>');
        $('#listwidget-1-nav').append(filtro);
        
        var abbrs = {};
        $("ul#listwidget-1 li a").each(function (i) {
        	if(this.firstChild.nodeValue!=null){
            	var letter1 = this.firstChild.nodeValue.toLowerCase().trim();
            	abbrs[letter1] = this;
            	if(this == '-'){
            		$(this).closest('li').removeClass('ln--').addClass('ln-'+letter1);
            	}
        	}
        });
        console.log(abbrs);
        var abbrsLetters = {};
        $(".ln-letters a").each(function (i) {
        	if(this.firstChild.nodeValue!=null){
	            var letter =  this.firstChild.nodeValue.toLowerCase().trim();
	            letter = letter.replace("-", "");
	            if(letter == "09") letter="_";
	            if(letter == "...") letter="-"; 
	            //console.log("#listwidget-1 li.ln-" + letter)
	            abbrsLetters[letter] = $("#listwidget-1 li.ln-" + letter ).length;
        	}
        });
        console.log(abbrsLetters)
        
        $("#filtro").on("keyup", function() {
        var filterBy = this.value.toLowerCase().trim();
        if(filterBy.length > 3){
            for (var abbr in abbrs) {
                var li = abbrs[abbr];
                if (abbr.indexOf(filterBy) !== -1) {
                    $(li).parent().parent().parent().show()
                    //console.log(li)
                    // show li
                }else{
                    $(li).parent().parent().parent().hide()
                }
            }
        }else{
            for (var abbr in abbrs) {
                var li = abbrs[abbr];
                $(li).parent().parent().parent().show()
            }
        }
        });	
        
        // Ponemos número de búsquedas:
        for (var lt in abbrsLetters) {
            var lnum = abbrsLetters[lt];
            $("." + lt).append(" <span>(" + lnum + ")</span>")
            //console.log(lt + ">" + lnum)
        }
        
    }
    },500)
  
});

// Control de parámetros para búsqueda resaltada
	var paramresalte = "find";
	//Recuperamos parámetros
	var get_params = function(search_string) {
	
	    var parse = function(params, pairs) {
	      var pair = pairs[0];
	      var parts = pair.split('=');
	      var key = decodeURIComponent(parts[0]);
	      var value = decodeURIComponent(parts.slice(1).join('='));
	  
	      // Handle multiple parameters of the same name
	      if (typeof params[key] === "undefined") {
	        params[key] = value;
	      } else {
	        params[key] = [].concat(params[key], value);
	      }
	  
	      return pairs.length == 1 ? params : parse(params, pairs.slice(1))
	    }
	  
	    // Get rid of leading ?
	    return search_string.length == 0 ? {} : parse({}, search_string.substr(1).split('&'));
	  }

	var params = get_params(location.search);
	if(params["search"]){
		document.querySelectorAll(".mw-search-result-heading a").forEach(a => {
            a.href = a.href + "?"+paramresalte+"="+params["search"];
        });
	}
	
	
	var InstantSearch = {

    "highlight": function (container, highlightText)
    {
        var internalHighlighter = function (options)
        {

            var id = {
                container: "container",
                tokens: "tokens",
                all: "all",
                token: "token",
                className: "className",
                sensitiveSearch: "sensitiveSearch"
            },
            tokens = options[id.tokens],
            allClassName = options[id.all][id.className],
            allSensitiveSearch = options[id.all][id.sensitiveSearch];


            function checkAndReplace(node, tokenArr, classNameAll, sensitiveSearchAll)
            {
                var nodeVal = node.nodeValue, parentNode = node.parentNode,
                    i, j, curToken, myToken, myClassName, mySensitiveSearch,
                    finalClassName, finalSensitiveSearch,
                    foundIndex, begin, matched, end,
                    textNode, span, isFirst;

                for (i = 0, j = tokenArr.length; i < j; i++)
                {
                    curToken = tokenArr[i];
                    myToken = curToken[id.token];
                    myClassName = curToken[id.className];
                    mySensitiveSearch = curToken[id.sensitiveSearch];

                    finalClassName = (classNameAll ? myClassName + " " + classNameAll : myClassName);

                    finalSensitiveSearch = (typeof sensitiveSearchAll !== "undefined" ? sensitiveSearchAll : mySensitiveSearch);

                    isFirst = true;
                    while (true)
                    {
                        if (finalSensitiveSearch)
                            foundIndex = nodeVal.indexOf(myToken);
                        else
                            foundIndex = nodeVal.toLowerCase().indexOf(myToken.toLowerCase());

                        if (foundIndex < 0)
                        {
                            if (isFirst)
                                break;

                            if (nodeVal)
                            {
                                textNode = document.createTextNode(nodeVal);
                                parentNode.insertBefore(textNode, node);
                            } // End if (nodeVal)

                            parentNode.removeChild(node);
                            break;
                        } // End if (foundIndex < 0)

                        isFirst = false;


                        begin = nodeVal.substring(0, foundIndex);
                        matched = nodeVal.substr(foundIndex, myToken.length);

                        if (begin)
                        {
                            textNode = document.createTextNode(begin);
                            parentNode.insertBefore(textNode, node);
                        } // End if (begin)

                        span = document.createElement("span");
                        span.className += finalClassName;
                        span.appendChild(document.createTextNode(matched));
                        parentNode.insertBefore(span, node);

                        nodeVal = nodeVal.substring(foundIndex + myToken.length);
                    } // Whend

                } // Next i 
            }; // End Function checkAndReplace 

            function iterator(p)
            {
                if (p === null) return;

                var children = Array.prototype.slice.call(p.childNodes), i, cur;

                if (children.length)
                {
                    for (i = 0; i < children.length; i++)
                    {
                        cur = children[i];
                        if (cur.nodeType === 3)
                        {
                            checkAndReplace(cur, tokens, allClassName, allSensitiveSearch);
                        }
                        else if (cur.nodeType === 1)
                        {
                            iterator(cur);
                        }
                    }
                }
            }; // End Function iterator

            iterator(options[id.container]);
        } // End Function highlighter
        ;


        internalHighlighter(
            {
                container: container
                , all:
                    {
                        className: "highlighter"
                    }
                , tokens: [
                    {
                        token: highlightText
                        , className: "highlight"
                        , sensitiveSearch: false
                    }
                ]
            }
        ); // End Call internalHighlighter 

    } // End Function highlight

};
	
	
	if(params[paramresalte]){
		var container = document.getElementById("mw-content-text");
		var findWord = params[paramresalte];
		findWord = findWord.replace(",", "");
		const regex = /(?<=")[^"]+(?=")/;
		var find1 = findWord.match(regex);
		console.log(find1);
		if(find1!=null){
			findWord = find1[0].replace("+", " ");
		}
		var findWordArr =  findWord.split("+");
		//$('html,body').animate({scrollTop:( )},1000,function(){});
		findWordArr.forEach(a => {
            InstantSearch.highlight(container, a);
        });
    	
	}
	
	if(params["redlink"]){
		if(params["redlink"] == "1"){
			var htmlModal =  ` 
			<h2>Vas a crear un nuevo contenido. ¿Esta nueva página corresponde con una obra?</h2>
			<div class="modal-txt">Si es una obra se asignará la categoría correspondiente y se recargará la página. Después podrás volver a editar la obra. Te recomendamos que edites <strong>mediante el formuario</strong>.</div>
			<div class="modal-btn">
				<div class="hide spinner">Un momento por favor...</div>
				<a class="btn" href="javascript://" onclick="modalAction(1)">Sí, es una obra</a>
				<a class="btn" href="javascript://" onclick="modalAction(0)">No, es una página</a>
			</div>
			`
			$("#content").append('<div id="modal-edit" class="modal-editar"><div class="modal-container"><div class="modal-editar-wrapper">'+htmlModal+'</div></div></div>')
			function modalAction(accion){
				switch(accion){
					case 1:
						//Ponemos la cateogoria
						$("textarea#wpTextbox1").val("{{Obra:footer}}[[Category:Obras]]");
						$(".btn").addClass("hide");
						$(".spinner").removeClass("hide");
						$("#editform").submit();
						break;
					case 0:
						$("#modal-edit").remove();
						break;
				}
			}
		}
	}
	
	//Aviso de contenido nuevo
	if($("body").hasClass("action-view") && $.trim($("#mw-content-text .mw-parser-output").text()) === "" && $("#mw-content-text .mw-parser-output").length > 0){
		if($("#catlinks").length > 0 ){
			if($.trim($("#catlinks").text()) != ""){
				var htmlModal =  ` 
				<h2>Gracias por ayudarnos a hacer crecer el diccionario</h2>
				<div class="modal-txt">Antes de que comiences la edición de la obra, sólo queremos que tengas en cuenta las siguientes recomendaciones:<br>
					<ul>
						<li>Para una correcta edición de todos los datos, es recomendable que edites <strong>mediante el formuario</strong>.</li>
						<li>Puedes encontrar la opción <strong>"Editar con formulario"</strong> en la parte del menú superior junto al buscador.</li>
						<li>No es necesario que se complenten todos los datos</li>
						<li>Si editas directamente, asegúrate de no borrar el código de la categoría asociada a la obra</li>
					</ul>
				</div>
				<div class="modal-btn">
					<div class="hide spinner">Un momento por favor...</div>
					<a class="btn" href="javascript://" onclick="$('#modal-edit').remove();">Continuar</a>
				</div>
				`
				$("#content").append('<div id="modal-edit" class="modal-editar"><div class="modal-container"><div class="modal-editar-wrapper">'+htmlModal+'</div></div></div>')
			}
		}
	}
	
	$('.add-referencia').click(function(e){
		e.preventDefault();
		
		var htmlModal =  ` 
				<h2>Nueva referencia bibliográfica</h2>
				<div class="modal-txt">
					<form id="form-referencia" class="filtro">
						<div class="bloque-tipo">
							<label>Tipo de referencia</label>
							<select name="tipo" id="tipo"  class="createboxInput webfonts-changed">
								<option value="libro">Libro</option>
								<option value="capitulo">Capítulo de libro</option>
								<option value="catalogo">Catálogo de exposición</option>
								<option value="ficha">Ficha de catálogo de exposición</option>
								<option value="revista">Artículo de revista</option>
								<option value="web">Página web</option>
							</select>
						</div>
						<div class="bloque-autores">
						<label>Autores: <a href="#" class="add-autor">Añadir autor</a></label>
						<div class="autores-container"></div>
						</div>
						
						<div class="form-block libro capitulo">
							<label>Título del libro</label>
							<input type="text" name="titulo-libro" id="titulo-libro" class="createboxInput webfonts-changed" />
						</div>
						<div class="form-block capitulo">
							<label>Capítulo del libro</label>
							<input type="text" name="capitulo-libro" id="capitulo-libro" class="createboxInput webfonts-changed" />
						</div>
						<div class="form-block capitulo ficha bloque-autores">
						<label>Editor / Comisario: <a href="#" class="add-editor">Añadir editor</a></label>
						<div class="editores-container"></div>
						</div>
						<div class="form-block ficha">
							<label>Título de la obra</label>
							<input type="text" name="titulo-obra" id="titulo-obra" class="createboxInput webfonts-changed" />
						</div>
						<div class="form-block catalogo ficha">
							<label>Título exposición</label>
							<input type="text" name="titulo-exposicion" id="titulo-exposicion" class="createboxInput webfonts-changed" />
						</div>
						<div class="form-block revista">
							<label>Título artículo</label>
							<input type="text" name="titulo-articulo" id="titulo-articulo" class="createboxInput webfonts-changed" />
						</div>
						<div class="form-block revista">
							<label>Título revista</label>
							<input type="text" name="titulo-revista" id="titulo-revista" class="createboxInput webfonts-changed" />
						</div>
						<div class="form-block web">
							<label>Título web</label>
							<input type="text" name="titulo-web" id="titulo-web" class="createboxInput webfonts-changed" />
						</div>
						<div class="form-block web">
							<label>Título publicación</label>
							<input type="text" name="titulo-publicacion-web" id="titulo-publicacion-web" class="createboxInput webfonts-changed" />
						</div>
						<div class="form-block libro capitulo">
							<label>Lugar de edición</label>
							<input type="text" name="lugar-edicion" id="lugar-edicion" class="createboxInput webfonts-changed" />
						</div>
						<div class="form-block catalogo ficha">
							<label>Lugar de la exposición</label>
							<input type="text" name="lugar-exposicion" id="lugar-exposicion" class="createboxInput webfonts-changed" />
						</div>
						<div class="form-block catalogo ficha">
							<label>Museo o institución</label>
							<input type="text" name="museo-institucion" id="museo-institucion" class="createboxInput webfonts-changed" />
						</div>
						
						<div class="form-block libro capitulo">
							<label>Año de edición</label>
							<input type="text" name="anyo-edicion" id="anyo-edicion" class="createboxInput webfonts-changed"/>
						</div>
						<div class="form-block catalogo ficha revista">
							<label>Año</label>
							<input type="text" name="anyo" id="anyo" class="createboxInput webfonts-changed"/>
						</div>
						<div class="form-block ficha revista">
							<label>Número</label>
							<input type="text" name="numero" id="numero" class="createboxInput webfonts-changed" />
						</div>
						<div class="form-block libro capitulo catalogo ficha revista">
							<label>Páginas</label>
							<input type="text" name="paginas" id="paginas" class="createboxInput webfonts-changed" />
						</div>
						<div class="form-block web">
							<label>URL</label>
							<input type="text" name="url" id="url" class="createboxInput webfonts-changed" />
						</div>
						<div class="form-block web">
							<label>Consultado en fecha</label>
							<input type="text" name="fecha_consulta" id="fecha_consulta" class="createboxInput webfonts-changed" />
						</div>
					</form>
				</div>
				<div class="modal-btn">
					<div class="hide spinner">Un momento por favor...</div>
					<a class="btn" href="javascript://" onclick="$('#modal-edit').remove();">Cancelar</a>
					<a class="btn" href="javascript://" onclick="insertar_referencia();$('#modal-edit').remove();" style="background:#e1251b">Insertar</a>
				</div>
				`
				$("#content").append('<div id="modal-edit" class="modal-editar modal-editar-ref"><div class="modal-container"><div class="modal-editar-wrapper">'+htmlModal+'</div></div></div>');
				$('.libro').slideDown({
				  start: function () {
				    $(this).css({
				      display: "flex"
				    })
				  }
				});
	});
	
	$('body').on('click','.add-autor',function(e){
		e.preventDefault();
		
		var html = `<div class="bloque-autor">
							<input type="text" name="iniciales[]" class="iniciales createboxInput webfonts-changed" placeholder="Inicial" />
							<input type="text" name="apellidos[]" class="apellidos createboxInput webfonts-changed" placeholder="Apellido" />
							<a href="#" class="borrar-autor">X</a>
						</div>`;
		$('.autores-container').append(html);
	});
	$('body').on('click','.add-editor',function(e){
		e.preventDefault();
		
		var html = `<div class="bloque-autor">
							<input type="text" name="iniciales_ed[]" class="iniciales_ed createboxInput webfonts-changed" placeholder="Inicial" />
							<input type="text" name="apellidos_ed[]" class="apellidos_ed createboxInput webfonts-changed" placeholder="Apellido" />
							<a href="#" class="borrar-autor">X</a>
						</div>`;
		$('.editores-container').append(html);
	});
	
	$('body').on('click','.borrar-autor',function(e){
		e.preventDefault();
		$(this).closest('.bloque-autor').remove();
	});
	
		
		$('body').on('change','#tipo',function(e){
			e.preventDefault();
			
			var tipo = $(this).find('option:selected').val();
			$('.form-block').hide();
			$('.'+tipo).slideDown({
			  start: function () {
			    $(this).css({
			      display: "flex"
			    })
			  }
			});
		});
		
		
	function insertar_referencia(){
		var tipo = $('#tipo').find('option:selected').val();
		var ref = "\n*";
		var editores = '';
		
		$('.iniciales').each(function(index){
			if(index < 2){
				ref = ref + $(this).val()+'.'+$('.apellidos:eq('+index+')').val()+', ';
			} else if(index == 2) {
				ref = ref + 'et al., ';
			}
		});
		
		$('.iniciales_ed').each(function(index){
			if(index < 2){
				editores = editores + $(this).val()+'.'+$('.apellidos_ed:eq('+index+')').val();
				if(index+1 < $('.iniciales_ed').length ){
					editores = editores+', ';
				}
			} else if(index == 2) {
				editores = editores + 'et al. ';
			}
		});
		if(tipo == 'capitulo' && editores.length > 0) editores = editores+' (eds.),';
		if(tipo == 'ficha' && editores.length > 0) editores = editores+' (coord.),';

		
		switch(tipo){
			case 'libro':
				ref = ref + "''" + $('#titulo-libro').val()+ "''" +', '+$('#lugar-edicion').val()+', '+$('#anyo-edicion').val()+', p.'+$('#paginas').val()+'.'
				break;
			case 'capitulo':
				ref = ref + '"Capítulo ' + $('#capitulo-libro').val()+'" en '+"''" + $('#titulo-libro').val()+ "''" +', '+' '+editores+' '+$('#lugar-edicion').val()+', '+$('#anyo-edicion').val()+', pp.'+$('#paginas').val()+'.'
				break;
			case 'catalogo':
				ref = ref + "''" + $('#titulo-exposicion').val()+ "'', cat.exp. " +', '+$('#lugar-exposicion').val()+', '+$('#museo-institucion').val()+', '+$('#anyo').val()+', p.'+$('#paginas').val()+'.'
				break;
			case 'ficha':
				ref = ref + '"' + $('#titulo-obra').val() + '", en '+' '+editores+' ' + "''" + $('#titulo-exposicion').val()+ "'', cat.exp." +', '+$('#lugar-exposicion').val()+', '+$('#museo-institucion').val()+', '+$('#anyo').val()+', n.'+$('#numero').val()+', pp.'+$('#paginas').val()+'.'
				break;
			case 'revista':
				ref = ref + '"' + $('#titulo-articulo').val() + '", '+ "''" + $('#titulo-revista').val()+ "''" +', n.'+$('#numero').val()+', ';
				if($('#anyo').val) {
					ref = ref + $('#anyo').val()+', ';
				}
				ref = ref + 'p.'+$('#paginas').val()+'.'
				break;
			case 'web':
				if($('#titulo-publicacion-web').val()){
					ref = ref + '"' + $('#titulo-web').val() + '", en ' + $('#titulo-publicacion-web').val() + '. Accesible en: ' + $('#url').val() + ' (consultado en ' + $('#fecha_consulta').val()+')';
				} else {
					ref = ref + $('#titulo-web').val() + ' [en línea], ' + $('#url').val()+ ' (consultado en ' + $('#fecha_consulta').val()+')';
				}
				break;
		}
		
		console.log(ref);
		var refs = $('textarea[name*="[ref_bibliografica]"]').val();
		$('textarea[name*="[ref_bibliografica]"]').val( refs + ref);
	}
	
	//$('#referencias-footer').append($('#referencias-obra'));
	//$('#referencias-obra').show();
	
	//$("#footer-info-lastmod").append(" El Diccionario interactivo de Ceán Bermúdez está subvencionado por la Dirección General de Bibliotecas, Archivos y Museos (Área de Gobierno de Cultura, Turismo y Deporte) del Ayuntamiento de Madrid con cargo a los presupuestos municipales del año 2020")