MediaWiki:MarcEditorDynamicLinks.js: mudanças entre as edições
Ir para navegação
Ir para pesquisar
(teste) |
(replace jquery) |
||
Linha 5: | Linha 5: | ||
// make collapsible CSS clickable (space or enter to click) |
// make collapsible CSS clickable (space or enter to click) |
||
// from: https://alligator.io/css/collapsible/ |
// from: https://alligator.io/css/collapsible/ |
||
⚫ | |||
let myCollapsibleLabels = document.querySelectorAll(".lbl-toggle"); |
let myCollapsibleLabels = document.querySelectorAll(".lbl-toggle"); |
||
Array.from(myCollapsibleLabels).forEach(label => { |
Array.from(myCollapsibleLabels).forEach(label => { |
||
label.addEventListener("keydown", e => { |
label.addEventListener("keydown", e => { |
||
// 32 === spacebar |
// 32 === spacebar |
||
// 13 === enter |
// 13 === enter |
||
if (e.which === 32 || e.which === 13) { |
if (e.which === 32 || e.which === 13) { |
||
e.preventDefault(); |
e.preventDefault(); |
||
label.click(); |
label.click(); |
||
} |
} |
||
}); |
}); |
||
}); |
}); |
||
/////////////////////////////////////////////////////////////////// |
/////////////////////////////////////////////////////////////////// |
||
let tag = ""; |
let tag = ""; |
||
let tagFromDropdown = ""; |
let tagFromDropdown = ""; |
||
function createMarcFieldHelpLink() { |
|||
const tagInputs = document.body.querySelectorAll('.tagInput'); |
|||
tagInputs.forEach((elem) => { |
|||
const marcFieldHelpLink = document.createElement('a'); |
|||
marcFieldHelpLink.setAttribute('target', '_blank'); |
|||
marcFieldHelpLink.innerText = `(?)`; |
|||
const marcFieldHelpLinkClass = elem.closest('table').querySelector('.marcFieldHelpLink'); |
|||
marcFieldHelpLinkClass.appendChild(marcFieldHelpLink); |
|||
// find the tag value from the chosen dropdown |
|||
marcFieldHelpLinkClass.addEventListener('mouseover', (event) => { |
|||
tagFromDropdown = event.target.closest('.instanceMain').querySelector('.select2-selection__rendered').getAttribute('title'); |
|||
tagFromDropdown = tagFromDropdown.substring(0, 3); |
|||
marcFieldHelpLink.setAttribute('title', `Documentação do campo ${tagFromDropdown}`); |
|||
⚫ | |||
if (window.location.href.match(/A\d{6}/) || |
|||
window.location.href.match(/AutRecord/)) { |
|||
marcFieldHelpLink.setAttribute('href', 'http://marc.febab.org/a' + tagFromDropdown); |
|||
⚫ | |||
marcFieldHelpLink.setAttribute('href', `https://www.loc.gov/marc/bibliographic/bd${tagFromDropdown}.html`); |
|||
⚫ | |||
}); |
|||
}); |
|||
} |
|||
function createAuthorityLinks() { |
function createAuthorityLinks() { |
||
⚫ | |||
⚫ | |||
⚫ | |||
let authorityLink = $("<a>", { |
let authorityLink = $("<a>", { |
||
title: "Abre uma nova aba para criar ou editar um registro de autoridade", |
title: "Abre uma nova aba para criar ou editar um registro de autoridade", |
||
Linha 33: | Linha 59: | ||
authorityLink.hide(); |
authorityLink.hide(); |
||
$(this).closest("table").find(".createAuthorityLink").html(authorityLink); |
$(this).closest("table").find(".createAuthorityLink").html(authorityLink); |
||
$(this).focusout(function() { |
$(this).focusout(function () { |
||
// if already recorded |
// if already recorded |
||
if (pattern1.test($(this).val())) { |
if (pattern1.test($(this).val())) { |
||
// build the URL for Wikincat aut record edit |
// build the URL for Wikincat aut record edit |
||
authorityLink.text("Editar autoridade"); |
authorityLink.text("Editar autoridade"); |
||
authorityLink.attr("href", "/wiki/Special:FormEdit/AutRecord/Autoridade:" + |
authorityLink.attr("href", "/wiki/Special:FormEdit/AutRecord/Autoridade:" + |
||
$(this).val().match(/A\d{6}/)); |
$(this).val().match(/A\d{6}/)); |
||
} else if (pattern2.test($(this).val())) { |
} else if (pattern2.test($(this).val())) { |
||
// build the URL for BN aut record view |
|||
authorityLink.text("Ver autoridade na BN"); |
authorityLink.text("Ver autoridade na BN"); |
||
authorityLink.attr("href", "http://acervo.bn.br/sophia_web/autoridade/detalhe/" + |
authorityLink.attr("href", "http://acervo.bn.br/sophia_web/autoridade/detalhe/" + |
||
$(this).val().match(/\d{9}/)); |
$(this).val().match(/\d{9}/)); |
||
} else { |
|||
// find the tag value from the chosen dropdown |
// find the tag value from the chosen dropdown |
||
tagFromDropdown = $(this).closest(".instanceMain") |
tagFromDropdown = $(this).closest(".instanceMain") |
||
// PageForms 4.8 |
// PageForms 4.8 |
||
// .find(".select2-chosen").text(); |
// .find(".select2-chosen").text(); |
||
// Page forms 4.9.1 |
// Page forms 4.9.1 |
||
.find(".select2-selection__rendered").attr("title"); |
.find(".select2-selection__rendered").attr("title"); |
||
tagFromDropdown = tagFromDropdown.substring(0, 3); |
tagFromDropdown = tagFromDropdown.substring(0, 3); |
||
// find the tag value from checked radio button |
// find the tag value from checked radio button |
||
let tagFromRadio = $(this).closest(".instanceMain") |
let tagFromRadio = $(this).closest(".instanceMain") |
||
.find("input[origname='Field[authorityType]']:checked").val(); |
.find("input[origname='Field[authorityType]']:checked").val(); |
||
let authorityTypes = { |
let authorityTypes = { |
||
"Pessoa": "100", |
"Pessoa": "100", |
||
Linha 71: | Linha 97: | ||
// declare the indicators default values |
// declare the indicators default values |
||
let ind1 = $(this).closest(".instanceMain") |
let ind1 = $(this).closest(".instanceMain") |
||
.find("select[origname='Field[ind1]'] option:selected").val(); |
.find("select[origname='Field[ind1]'] option:selected").val(); |
||
let ind2 = $(this).closest(".instanceMain") |
let ind2 = $(this).closest(".instanceMain") |
||
.find("select[origname='Field[ind2]'] option:selected").val(); |
.find("select[origname='Field[ind2]'] option:selected").val(); |
||
// declare the 008 field default values |
// declare the 008 field default values |
||
let directOrIndirectGeogSubdiv = "", // 06 |
let directOrIndirectGeogSubdiv = "", // 06 |
||
kindOfRecord = "", // 09 |
kindOfRecord = "", // 09 |
||
descriptiveCatalogingRules = "c", // 10 |
descriptiveCatalogingRules = "c", // 10 |
||
subjectHeadingSystem = "n", // 11 |
subjectHeadingSystem = "n", // 11 |
||
typeOfSeries = "n", // 12 |
typeOfSeries = "n", // 12 |
||
numberedOrUnnumberedSeries = "n", // 13 |
numberedOrUnnumberedSeries = "n", // 13 |
||
headingUseMainOrAddedEntry = "a", // 14 |
headingUseMainOrAddedEntry = "a", // 14 |
||
headingUseSubjectAddedEntry= "a", // 15 |
headingUseSubjectAddedEntry = "a", // 15 |
||
headingUseSeriesAddedEntry = "b", // 16 |
headingUseSeriesAddedEntry = "b", // 16 |
||
typeOfSubjectSubdivision = "n", // 17 |
typeOfSubjectSubdivision = "n", // 17 |
||
undifferentiatedPersonalName = "n", // 32 |
undifferentiatedPersonalName = "n", // 32 |
||
levelOfEstablishment = "a"; // 33 |
levelOfEstablishment = "a"; // 33 |
||
// set the 008 field and indicadors specific values |
// set the 008 field and indicadors specific values |
||
Linha 117: | Linha 143: | ||
tagFromDropdown === "630" || |
tagFromDropdown === "630" || |
||
tagFromDropdown === "730") { |
tagFromDropdown === "730") { |
||
ind2 = ind1; // an inverted value happens here, see and |
ind2 = ind1; // an inverted value happens here, see and |
||
ind1 = ""; // compare bib. and auth. 130 MARC definitions |
ind1 = ""; // compare bib. and auth. 130 MARC definitions |
||
} |
} |
||
ind1 = ""; |
ind1 = ""; |
||
Linha 136: | Linha 162: | ||
authorityLink.text("Criar autoridade"); |
authorityLink.text("Criar autoridade"); |
||
authorityLink.attr("href", "/wiki/Special:FormEdit/AutRecord?" + |
authorityLink.attr("href", "/wiki/Special:FormEdit/AutRecord?" + |
||
decodeURIComponent($.param({ |
decodeURIComponent($.param({ |
||
"AutRecord": { |
"AutRecord": { |
||
"directOrIndirectGeogSubdiv": directOrIndirectGeogSubdiv, |
"directOrIndirectGeogSubdiv": directOrIndirectGeogSubdiv, |
||
"kindOfRecord": kindOfRecord, |
"kindOfRecord": kindOfRecord, |
||
"descriptiveCatalogingRules": descriptiveCatalogingRules, |
"descriptiveCatalogingRules": descriptiveCatalogingRules, |
||
"subjectHeadingSystem": subjectHeadingSystem, |
"subjectHeadingSystem": subjectHeadingSystem, |
||
"typeOfSeries": typeOfSeries, |
"typeOfSeries": typeOfSeries, |
||
"numberedOrUnnumberedSeries": numberedOrUnnumberedSeries, |
"numberedOrUnnumberedSeries": numberedOrUnnumberedSeries, |
||
"headingUseMainOrAddedEntry": headingUseMainOrAddedEntry, |
"headingUseMainOrAddedEntry": headingUseMainOrAddedEntry, |
||
"headingUseSubjectAddedEntry": headingUseSubjectAddedEntry, |
"headingUseSubjectAddedEntry": headingUseSubjectAddedEntry, |
||
"headingUseSeriesAddedEntry": headingUseSeriesAddedEntry, |
"headingUseSeriesAddedEntry": headingUseSeriesAddedEntry, |
||
"typeOfSubjectSubdivision": typeOfSubjectSubdivision, |
"typeOfSubjectSubdivision": typeOfSubjectSubdivision, |
||
"undifferentiatedPersonalName": undifferentiatedPersonalName, |
"undifferentiatedPersonalName": undifferentiatedPersonalName, |
||
"levelOfEstablishment": levelOfEstablishment |
"levelOfEstablishment": levelOfEstablishment |
||
⚫ | |||
⚫ | |||
⚫ | |||
⚫ | |||
⚫ | |||
⚫ | |||
⚫ | |||
⚫ | |||
⚫ | |||
⚫ | |||
⚫ | |||
}, |
}, |
||
" |
"Field": { |
||
" |
"1": { |
||
" |
"tag": "040", |
||
⚫ | |||
⚫ | |||
⚫ | |||
⚫ | |||
⚫ | |||
⚫ | |||
⚫ | |||
}, |
|||
⚫ | |||
⚫ | |||
"data": "$a+" |
|||
} |
|||
} |
} |
||
} |
}))); |
||
⚫ | |||
} |
} |
||
authorityLink.show(); |
authorityLink.show(); |
||
Linha 174: | Linha 200: | ||
} |
} |
||
$(document).ready(function(){ |
$(document).ready(function () { |
||
"use strict"; |
|||
// remove carriage return |
// remove carriage return |
||
$("span.inputSpan").find("textarea").each(function() { |
$("span.inputSpan").find("textarea").each(function () { |
||
let input = $(this).val(); |
let input = $(this).val(); |
||
input = input.replace(" ", "") |
input = input.replace(" ", "") |
||
// remove any html tags |
// remove any html tags |
||
.replace(/<(?:"[^"]*"['"]*|'[^']*'['"]*|[^'">])+>/g, ""); |
.replace(/<(?:"[^"]*"['"]*|'[^']*'['"]*|[^'">])+>/g, ""); |
||
$(this).val(input); |
$(this).val(input); |
||
}); |
}); |
||
// calls main functions |
// calls main functions |
||
createMarcFieldHelpLink(); |
|||
createAuthorityLinks(); |
createAuthorityLinks(); |
||
Linha 197: | Linha 222: | ||
// create an observer instance |
// create an observer instance |
||
let observer = new MutationObserver(function(mutations) { |
let observer = new MutationObserver(function (mutations) { |
||
mutations.forEach(function(mutation) { |
mutations.forEach(function (mutation) { |
||
let newNodes = mutation.addedNodes; // DOM NodeList |
let newNodes = mutation.addedNodes; // DOM NodeList |
||
if(newNodes.length !== 0) { // if there are new nodes added |
if (newNodes.length !== 0) { // if there are new nodes added |
||
createMarcFieldHelpLink(); |
|||
createAuthorityLinks(); |
createAuthorityLinks(); |
||
} |
} |
||
Linha 221: | Linha 246: | ||
// when save, remove text form hidden textareas |
// when save, remove text form hidden textareas |
||
$("#wpSave").click(function(){ |
$("#wpSave").click(function () { |
||
observer.disconnect(); |
observer.disconnect(); |
||
$("span.hiddenByPF").find("textarea").val(""); |
$("span.hiddenByPF").find("textarea").val(""); |
||
$("textarea").each(function() { |
$("textarea").each(function () { |
||
let input = $(this).val(); |
let input = $(this).val(); |
||
// normalize input |
// normalize input |
||
let normalizedInput = input |
let normalizedInput = input |
||
// "$a Bar \n$b Baz" > " $a Bar $b Baz" |
// "$a Bar \n$b Baz" > " $a Bar $b Baz" |
||
.replace(/\s*(\$[a-z0-8])\s*/g, " $1 ") |
.replace(/\s*(\$[a-z0-8])\s*/g, " $1 ") |
||
// "$a Bar\nFoo" > "$a Bar Foo" ou "$a Bar Foo" > "$a Bar Foo" |
// "$a Bar\nFoo" > "$a Bar Foo" ou "$a Bar Foo" > "$a Bar Foo" |
||
.replace(/\n|\s\s+|\t/g, " ") |
.replace(/\n|\s\s+|\t/g, " ") |
||
// replace "|" by "%7C" (Ex.: http://viaf.org/processed/WKP|Q2484404) |
// replace "|" by "%7C" (Ex.: http://viaf.org/processed/WKP|Q2484404) |
||
.replace("|", "%7C"); |
.replace("|", "%7C"); |
||
$(this).val(normalizedInput); |
$(this).val(normalizedInput); |
||
}); |
}); |
Edição das 09h49min de 7 de agosto de 2022
// Author: @vitorsilverio
// Author: @jaideraf
///////////////////////////////////////////////////////////////////
// make collapsible CSS clickable (space or enter to click)
// from: https://alligator.io/css/collapsible/
"use strict";
let myCollapsibleLabels = document.querySelectorAll(".lbl-toggle");
Array.from(myCollapsibleLabels).forEach(label => {
label.addEventListener("keydown", e => {
// 32 === spacebar
// 13 === enter
if (e.which === 32 || e.which === 13) {
e.preventDefault();
label.click();
}
});
});
///////////////////////////////////////////////////////////////////
let tag = "";
let tagFromDropdown = "";
function createMarcFieldHelpLink() {
const tagInputs = document.body.querySelectorAll('.tagInput');
tagInputs.forEach((elem) => {
const marcFieldHelpLink = document.createElement('a');
marcFieldHelpLink.setAttribute('target', '_blank');
marcFieldHelpLink.innerText = `(?)`;
const marcFieldHelpLinkClass = elem.closest('table').querySelector('.marcFieldHelpLink');
marcFieldHelpLinkClass.appendChild(marcFieldHelpLink);
// find the tag value from the chosen dropdown
marcFieldHelpLinkClass.addEventListener('mouseover', (event) => {
tagFromDropdown = event.target.closest('.instanceMain').querySelector('.select2-selection__rendered').getAttribute('title');
tagFromDropdown = tagFromDropdown.substring(0, 3);
marcFieldHelpLink.setAttribute('title', `Documentação do campo ${tagFromDropdown}`);
// build the URL
if (window.location.href.match(/A\d{6}/) ||
window.location.href.match(/AutRecord/)) {
marcFieldHelpLink.setAttribute('href', 'http://marc.febab.org/a' + tagFromDropdown);
} else {
marcFieldHelpLink.setAttribute('href', `https://www.loc.gov/marc/bibliographic/bd${tagFromDropdown}.html`);
}
});
});
}
function createAuthorityLinks() {
$("textarea").each(function () {
let authorityLink = $("<a>", {
title: "Abre uma nova aba para criar ou editar um registro de autoridade",
target: "_blank",
text: "Criar autoridade"
});
let pattern1 = /\$0\sA\d{6}/;
let pattern2 = /\$0\s\(BN\)\d{9}/;
authorityLink.hide();
$(this).closest("table").find(".createAuthorityLink").html(authorityLink);
$(this).focusout(function () {
// if already recorded
if (pattern1.test($(this).val())) {
// build the URL for Wikincat aut record edit
authorityLink.text("Editar autoridade");
authorityLink.attr("href", "/wiki/Special:FormEdit/AutRecord/Autoridade:" +
$(this).val().match(/A\d{6}/));
} else if (pattern2.test($(this).val())) {
// build the URL for BN aut record view
authorityLink.text("Ver autoridade na BN");
authorityLink.attr("href", "http://acervo.bn.br/sophia_web/autoridade/detalhe/" +
$(this).val().match(/\d{9}/));
} else {
// find the tag value from the chosen dropdown
tagFromDropdown = $(this).closest(".instanceMain")
// PageForms 4.8
// .find(".select2-chosen").text();
// Page forms 4.9.1
.find(".select2-selection__rendered").attr("title");
tagFromDropdown = tagFromDropdown.substring(0, 3);
// find the tag value from checked radio button
let tagFromRadio = $(this).closest(".instanceMain")
.find("input[origname='Field[authorityType]']:checked").val();
let authorityTypes = {
"Pessoa": "100",
"Entidade coletiva": "110",
"Evento": "111",
"Título uniforme": "130",
"Tópico": "150",
"Local": "151"
};
if (tagFromRadio in authorityTypes) {
tag = authorityTypes[tagFromRadio];
}
// declare the indicators default values
let ind1 = $(this).closest(".instanceMain")
.find("select[origname='Field[ind1]'] option:selected").val();
let ind2 = $(this).closest(".instanceMain")
.find("select[origname='Field[ind2]'] option:selected").val();
// declare the 008 field default values
let directOrIndirectGeogSubdiv = "", // 06
kindOfRecord = "", // 09
descriptiveCatalogingRules = "c", // 10
subjectHeadingSystem = "n", // 11
typeOfSeries = "n", // 12
numberedOrUnnumberedSeries = "n", // 13
headingUseMainOrAddedEntry = "a", // 14
headingUseSubjectAddedEntry = "a", // 15
headingUseSeriesAddedEntry = "b", // 16
typeOfSubjectSubdivision = "n", // 17
undifferentiatedPersonalName = "n", // 32
levelOfEstablishment = "a"; // 33
// set the 008 field and indicadors specific values
if (tag === "100") {
undifferentiatedPersonalName = "a";
ind2 = "";
}
if (tag === "110") {
// in case of autocomplete of 260
if (tagFromDropdown === "260") {
directOrIndirectGeogSubdiv = "n";
kindOfRecord = "b";
headingUseMainOrAddedEntry = "b";
headingUseSubjectAddedEntry = "b";
levelOfEstablishment = "n";
ind1 = "1";
}
ind2 = "";
}
if (tag === "111") {
ind1 = "2";
ind2 = "";
}
if (tag === "130") {
typeOfSeries = "a";
numberedOrUnnumberedSeries = "b";
headingUseSeriesAddedEntry = "a";
if (tagFromDropdown === "130" ||
tagFromDropdown === "630" ||
tagFromDropdown === "730") {
ind2 = ind1; // an inverted value happens here, see and
ind1 = ""; // compare bib. and auth. 130 MARC definitions
}
ind1 = "";
}
if (tag === "150" || tag === "151") {
descriptiveCatalogingRules = "n";
subjectHeadingSystem = "z";
headingUseMainOrAddedEntry = "b";
ind1 = ""; // 150 and 151 indicators must be empty in
ind2 = ""; // authority MARC records
if (tag === "151") {
typeOfSubjectSubdivision = "d";
}
}
// build the URL
authorityLink.text("Criar autoridade");
authorityLink.attr("href", "/wiki/Special:FormEdit/AutRecord?" +
decodeURIComponent($.param({
"AutRecord": {
"directOrIndirectGeogSubdiv": directOrIndirectGeogSubdiv,
"kindOfRecord": kindOfRecord,
"descriptiveCatalogingRules": descriptiveCatalogingRules,
"subjectHeadingSystem": subjectHeadingSystem,
"typeOfSeries": typeOfSeries,
"numberedOrUnnumberedSeries": numberedOrUnnumberedSeries,
"headingUseMainOrAddedEntry": headingUseMainOrAddedEntry,
"headingUseSubjectAddedEntry": headingUseSubjectAddedEntry,
"headingUseSeriesAddedEntry": headingUseSeriesAddedEntry,
"typeOfSubjectSubdivision": typeOfSubjectSubdivision,
"undifferentiatedPersonalName": undifferentiatedPersonalName,
"levelOfEstablishment": levelOfEstablishment
},
"Field": {
"1": {
"tag": "040",
"data": encodeURIComponent("$a BR-FlWIK $b por $c BR-FlWIK $d BR-FlUSC")
},
"2": {
"tag": tag,
"ind1": encodeURIComponent(ind1),
"ind2": encodeURIComponent(ind2),
"data": encodeURIComponent($(this).val())
},
"3": {
"tag": "670",
"data": "$a+"
}
}
})));
}
authorityLink.show();
});
});
}
$(document).ready(function () {
// remove carriage return
$("span.inputSpan").find("textarea").each(function () {
let input = $(this).val();
input = input.replace(" ", "")
// remove any html tags
.replace(/<(?:"[^"]*"['"]*|'[^']*'['"]*|[^'">])+>/g, "");
$(this).val(input);
});
// calls main functions
createMarcFieldHelpLink();
createAuthorityLinks();
// Como instâncias do formulário são criadas pelo botão "Adicionar campo",
// é necessário observar o DOM a partir da classe ".multipleTemplateList".
// Toda vez que o DOM é alterado (mais especificamente, quando uma nova
// child de ".multipleTemplateList" é criada), a função
// marcEditorDynamicLinks() é novamente chamada.
// https://developer.mozilla.org/en-US/docs/Web/API/MutationObserver
// create an observer instance
let observer = new MutationObserver(function (mutations) {
mutations.forEach(function (mutation) {
let newNodes = mutation.addedNodes; // DOM NodeList
if (newNodes.length !== 0) { // if there are new nodes added
createMarcFieldHelpLink();
createAuthorityLinks();
}
});
});
// select the target node
let target = document.querySelector(".multipleTemplateList");
// configuration of the observer
let config = {
childList: true,
attributes: false,
subtree: false
};
// pass in the target node, as well as the observer options
observer.observe(target, config);
// when save, remove text form hidden textareas
$("#wpSave").click(function () {
observer.disconnect();
$("span.hiddenByPF").find("textarea").val("");
$("textarea").each(function () {
let input = $(this).val();
// normalize input
let normalizedInput = input
// "$a Bar \n$b Baz" > " $a Bar $b Baz"
.replace(/\s*(\$[a-z0-8])\s*/g, " $1 ")
// "$a Bar\nFoo" > "$a Bar Foo" ou "$a Bar Foo" > "$a Bar Foo"
.replace(/\n|\s\s+|\t/g, " ")
// replace "|" by "%7C" (Ex.: http://viaf.org/processed/WKP|Q2484404)
.replace("|", "%7C");
$(this).val(normalizedInput);
});
});
});