Abrir menú principal

Cambios

21 818 bytes añadidos ,  hace 2 años
sin resumen de edición
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);
//$('#Iframe1').attr("src", "https://"+ulrTomo);
$(".l-tomo").addClass("hide");
$(ulrTomo).removeClass("hide");
$(".tomos a span").removeClass("active");
$("span",this).addClass("active");
e.preventDefault();
})
}
function listFilter(input, list) {
}
});
 
}
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; var inicial = letter1[0]; if($(this).closest('li').hasClass('ln--')){ if(inicial == 'á') inicial = 'a'; else if(inicial == 'é') inicial = 'e'; else if(inicial == 'í') inicial = 'i'; else if(inicial == 'ó') inicial = 'o'; else if(inicial == 'ú') inicial = 'u'; $(this).closest('li').removeClass('ln--').addClass('ln-'+inicial); } } }); //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) $('.ln-last').hide(); $('.ln-selected').click(); $("#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ámetrospara búsqueda resaltada var paramresalte = "find";
//Recuperamos parámetros
var get_params = function(search_string) {
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 = /(?<=")[^"search]+(?=")/; 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;
}
}
}
}
function waitForEl(selector, callback){
var poller1 = setInterval(function(){
$jObject = jQuery(selector);
if($jObject.length < 1){
return;
}
clearInterval(poller1);
callback($jObject)
},5);
}
if(params["title"]){
waitForEl("#postedit-modqueued", function() {
$("#postedit-modqueued p").first().append('<p class="aviso-edit-form">Te recomendamos que edites el contenido <a href="/wiki/Especial:FormEdit/Obra/'+params["title"]+'">desde este formulario</a></p>')
$(".mw-notification").addClass("mw-edit-form");
$(".aviso-edit-form").slideDown();
});
}
//Añadir edición de formulario en modal de aviso de moderación
/*setTimeout(function(){
if($("#postedit-modqueued").length > 0 && params["title"]){
$("#postedit-modqueued p").first().append('<p class="aviso-edit-form">Te recomendamos que edites el contenido <a href="/wiki/Especial:FormEdit/Obra/'+params["title"]+'">desde este formulario</a></p>')
$(".mw-notification").addClass("mw-edit-form");
$(".aviso-edit-form").slideDown();
}
}, 500)*/
//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 completen 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")