ميدياويكي:Common.js

من Sudan Memory
مراجعة ١٣:٠٤، ١٩ فبراير ٢٠٢٤ بواسطة Abdalla (نقاش | مساهمات)

اذهب إلى: تصفح، ابحث

ملاحظة: بعد الحفظ، قد تحتاج إلى إفراغ كاش متصفحك لرؤية التغييرات.

  • فايرفوكس / سفاري: اضغط Shift أثناء ضغط Reload، أو اضغط أيا من Ctrl-F5 أو Ctrl-R (⌘-R على ماك)
  • جوجل كروم: اضغط Ctrl-Shift-R (⌘-Shift-R على ماك)
  • إنترنت إكسبلورر: اضغط Ctrl أثناء ضغط Refresh، أو اضغط Ctrl-F5
  • كنكرر: اضغط Reload أو اضغط F5
  • أوبرا: أفرغ الكاش في Tools → Preferences
/* الجافاسكريبت الموضوع هنا سيتم تحميله لكل المستخدمين مع كل تحميل للصفحة. */
 
$(function () {
    function splitTrailingText(input) {
        const regex = /^(.*?[\u0620-\u064Aa-zA-Z])([^\u0620-\u064Aa-zA-Z]*)$/;
        const matches = input.match(regex);
 
        if (matches && matches.length > 1) {
            const alphabeticPart = matches[1];
            const nonAlphabeticPart = matches[2];
            return { alphabeticPart, nonAlphabeticPart };
        }
        return { alphabeticPart: input, nonAlphabeticPart: '' };
    }
    function parsePoem(text, vWidth) {
        let lines = text.split('\n');
        let formattedLines = lines.map(line => {
            if (line.trim() === "") {
                // Replace empty lines with a line break
                return '<br>';
            } else if (line.startsWith('  ')) { // Check for lines starting with two or more spaces
                const { alphabeticPart, nonAlphabeticPart } = splitTrailingText(line.trim());
                return `<p class="vTail"><span class="vTail" style="width:${vWidth}px">${alphabeticPart}</span><span class="vTrailer">${nonAlphabeticPart}</span></p>`;
            } else if (line.startsWith('--') && line.endsWith('--')) { // Check for lines delimited with '--'
                return `<p class="vMid" style="width:${vWidth}px">` + line.substring(2, line.length - 2).trim() + '</p>';
            } else {
                return `<p class="vHead" style="width:${0.9*vWidth}px">` + line.trim() + '</p>'; // Default to a regular paragraph for other lines
            }
        });
        return formattedLines.join('');
    }
 
    var poems = document.querySelectorAll('.poem');                         // Find all div elements with the class 'poem'
    poems.forEach(function(poem) {                                          // Loop through each poem element and format it
        var vWidth = poem.getAttribute('vWidth') || 350;                    // Verse width, default is for quads
        poem.innerHTML = parsePoem(poem.innerText, vWidth);
    });
 
    var toggler = document.getElementsByClassName("treeBranch");
    var i;
 
    for (i = 0; i < toggler.length; i++) {
        toggler[i].addEventListener("click", function() {
            this.parentElement.querySelector(".treeBranch-nested").classList.toggle("treeBranch-active");
            this.classList.toggle("treeBranch-down");
        });
    }
}());