| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103 |
- 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;
- }
|