mirror of
https://github.com/opencv/opencv.git
synced 2024-12-16 10:29:11 +08:00
4398e0b62b
doc: fix the position of toggle button #26340 Close #26339 ### Pull Request Readiness Checklist See details at https://github.com/opencv/opencv/wiki/How_to_contribute#making-a-good-pull-request - [x] I agree to contribute to the project under Apache 2 License. - [x] To the best of my knowledge, the proposed patch is not based on a code under GPL or another license that is incompatible with OpenCV - [x] The PR is proposed to the proper branch - [x] There is a reference to the original bug report and related work - [ ] There is accuracy test, performance test and test data in opencv_extra repository, if applicable Patch to opencv_extra has the same branch name. - [ ] The feature is well documented and sample code can be built with the project CMake
104 lines
3.4 KiB
JavaScript
104 lines
3.4 KiB
JavaScript
function getLabelName(innerHTML) {
|
|
var str = innerHTML.toLowerCase();
|
|
// Replace all '+' with 'p'
|
|
str = str.split('+').join('p');
|
|
// Replace all ' ' with '_'
|
|
str = str.split(' ').join('_');
|
|
// Replace all '#' with 'sharp'
|
|
str = str.split('#').join('sharp');
|
|
// Replace other special characters with 'ascii' + code
|
|
for (var i = 0; i < str.length; i++) {
|
|
var charCode = str.charCodeAt(i);
|
|
if (!(charCode == 95 || (charCode > 96 && charCode < 123) || (charCode > 47 && charCode < 58)))
|
|
str = str.substr(0, i) + 'ascii' + charCode + str.substr(i + 1);
|
|
}
|
|
return str;
|
|
}
|
|
|
|
function addToggle() {
|
|
var $getDiv = $('div.newInnerHTML').last();
|
|
var buttonName = $getDiv.html();
|
|
var label = getLabelName(buttonName.trim());
|
|
$getDiv.attr("title", label);
|
|
$getDiv.hide();
|
|
$getDiv = $getDiv.next();
|
|
$getDiv.attr("class", "toggleable_div label_" + label);
|
|
$getDiv.hide();
|
|
}
|
|
|
|
function addButton(label, buttonName) {
|
|
var b = document.createElement("BUTTON");
|
|
b.innerHTML = buttonName;
|
|
b.setAttribute('class', 'toggleable_button label_' + label);
|
|
b.onclick = function() {
|
|
$('.toggleable_button').css({
|
|
border: '2px outset',
|
|
'border-radius': '4px'
|
|
});
|
|
$('.toggleable_button.label_' + label).css({
|
|
border: '2px inset',
|
|
'border-radius': '4px'
|
|
});
|
|
$('.toggleable_div').css('display', 'none');
|
|
$('.toggleable_div.label_' + label).css('display', 'block');
|
|
};
|
|
b.style.border = '2px outset';
|
|
b.style.borderRadius = '4px';
|
|
b.style.margin = '2px';
|
|
return b;
|
|
}
|
|
|
|
function buttonsToAdd($elements, $heading, $type) {
|
|
if ($elements.length === 0) {
|
|
return;
|
|
}
|
|
var arr = jQuery.makeArray($elements);
|
|
var seen = {};
|
|
arr.forEach(function(e) {
|
|
var txt = e.innerHTML;
|
|
if (!seen[txt]) {
|
|
$button = addButton(e.title, txt);
|
|
if (Object.keys(seen).length == 0) {
|
|
var linebreak1 = document.createElement("br");
|
|
var linebreak2 = document.createElement("br");
|
|
($heading).append(linebreak1);
|
|
($heading).append(linebreak2);
|
|
}
|
|
($heading).append($button);
|
|
seen[txt] = true;
|
|
}
|
|
});
|
|
return;
|
|
}
|
|
|
|
function addTutorialsButtons() {
|
|
// See https://github.com/opencv/opencv/issues/26339
|
|
$lastHeader = undefined
|
|
$("h1,h2,h3,div.newInnerHTML").each(function() {
|
|
if( this.tagName.startsWith("H") ) {
|
|
$lastHeader = $(this)
|
|
return true // loop-continue
|
|
}
|
|
if( $lastHeader === undefined ) {
|
|
return true // loop-continue
|
|
}
|
|
var $toggleHeader = $lastHeader.tagName
|
|
var $elements = $lastHeader.nextUntil($toggleHeader)
|
|
var $lower = $elements.find("div.newInnerHTML")
|
|
$elements = $elements.add($lower)
|
|
$elements = $elements.filter("div.newInnerHTML")
|
|
buttonsToAdd($elements, $lastHeader, $toggleHeader)
|
|
$lastHeader = undefined
|
|
});
|
|
$(".toggleable_button").first().click();
|
|
var $clickDefault = $('.toggleable_button.label_python').first();
|
|
if ($clickDefault.length) {
|
|
$clickDefault.click();
|
|
}
|
|
$clickDefault = $('.toggleable_button.label_cpp').first();
|
|
if ($clickDefault.length) {
|
|
$clickDefault.click();
|
|
}
|
|
return;
|
|
}
|