【99OK】 Link vào 99OK Casino mới nhất 2025 ✔️

Link 99OK hot nhất

99OK - Nhà Cái Thể Thao, Nổ Hũ, Bắn Cá Uy Tín

123 Win 88ok hiện đang mở - Hậu cần - Kỹ thuật > Hậu cần

Thứ năm, 04/06/2026, 17:42 (GMT+7)
225 lượt xem

Cục Hậu cần – Kỹ thuật Quân khu phát động phong trào thi đua “Đổi mới sáng tạo, phát triển khoa học, công nghệ, chuyển đổi số, chuyển đổi xanh”

(QK7 Online) – Ngày 4/6, Cục Hậu cần – Kỹ thuật Quân khu phát động phong trào thi đua “Đổi mới sáng tạo, phát triển khoa học, công nghệ, chuyển đổi số, chuyển đổi xanh”. Đại tá Trần Văn Long, Phó Chính ủy Cục Hậu cần – Kỹ thuật Quân khu chủ trì lễ phát động.
Lễ phát động phong trào thi đua “Đổi mới sáng tạo, phát triển khoa học, công nghệ, chuyển đổi số, chuyển đổi xanh” nhằm tạo khí thế thi đua sôi nổi, khơi dậy tinh thần chủ động, sáng tạo, trách nhiệm của cấp ủy, chỉ huy các cấp và cán bộ, 123Win com 79 casino, cá cược thể thao đến xổ số trong ứng dụng khoa học, công nghệ, thúc đẩy đổi mới sáng tạo, chuyển đổi số, chuyển đổi xanh vào hoạt động quản lý, chỉ huy, điều hành cơ quan, đơn vị, góp phần thực hiện thắng lợi các mục tiêu, nhiệm vụ phát triển đất nước theo tinh thần 99Oke được xếp hạng cao nhất Đại hội lần thứ XIV của Đảng và 99Oke được xếp hạng cao nhất của các cấp nhiệm kỳ 2025 – 2030.
Thượng tá Lê Long Khương, Phó Chủ nhiệm 99Oke123 Tải ứng dụng Cục Hậu cần – Kỹ thuật Quân khu báo cáo sơ kết đợt thi đua cao điểm chào mừng bầu cử đại biểu Quốc hội khóa XVI và bầu cử đại biểu HĐND các cấp nhiệm kỳ 2026 – 2031; chào mừng kỷ niệm 136 năm Ngày sinh Chủ tịch Hồ Chí Minh.
Phong trào thi đua “Đổi mới sáng tạo, phát triển khoa học, công nghệ, chuyển đổi số, chuyển đổi xanh” được tổ chức thực hiện qua hai giai đoạn, gồm giai đoạn 2026–2027 và giai đoạn 2028–2030. Nội dung tập trung đẩy mạnh xây dựng cơ quan số, đơn vị số, quân nhân số gắn với phong trào "Bình dân học vụ số" và các nền tảng số nhằm thực hiện tốt mục tiêu "3 An" (an ninh, an toàn, an dân), đẩy mạnh ứng dụng khoa học, công nghệ, chuyển đổi số, chuyển đổi xanh trong thực hiện các nghị quyết, chiến lược, chương trình hành động, nhiệm vụ chính trị của các cơ quan, đơn vị. Tích cực trọng dụng nhân lực chất lượng cao đáp ứng yêu cầu phát triển khoa học, công nghệ, đổi mới sáng tạo; bảo đảm đầu tư đồng bộ hạ tầng số, tạo nền tảng vững chắc cho chuyển đổi số, chuyển đổi xanh. Thực hiện tốt chức năng đội quân chiến đấu, đội quân công tác, đội quân lao động, sản xuất; đi đầu trong các lĩnh vực như: Tham gia phòng, chống 99Ok là nhà cái cá cược uy tín hàng đầu tại Việt Nam, Link Truy Cập 99Ok Bản Pro 123Win Nhận Code Vip, bảo vệ môi trường. Bên cạnh đó là gắn phong trào thi đua với triển khai thực hiện đề án "Xây dựng xã hội học tập trong Quân đội đến năm 2030 và những năm tiếp theo", các phong trào thi đua đang triển khai trong LLVT Quân khu, Cục Hậu cần - Kỹ thuật.
Đại tá Trần Văn Long, Phó Chính ủy Cục Hậu cần – Kỹ thuật Quân khu phát động phong trào thi đua “Đổi mới sáng tạo, phát triển khoa học, công nghệ, chuyển đổi số, chuyển đổi xanh”.
Để phong trào thi đua được triển khai và tổ chức thực hiện toàn diện, thống nhất, hiệu quả, Đại tá Trần Văn Long yêu cầu cấp ủy, chỉ huy, các cơ quan, đơn vị tập trung lãnh đạo tổ chức tuyên truyền, quán triệt sâu kỹ tinh thần các 99Oke được xếp hạng cao nhất của Đảng, Quân ủy Trung ương, Quân khu, Cục Hậu cần - Kỹ thuật cho cán bộ, 123Win com 79 casino, cá cược thể thao đến xổ số nắm chắc các nội dung, mục tiêu thi đua và cụ thể hóa sát với đặc điểm, chức năng, nhiệm vụ của từng cơ quan, đơn vị. Tổ chức phát động, quán triệt, đăng ký giao ước thi đua và thực hiện ở các cấp chặt chẽ, nghiêm túc, hiệu quả, thiết thực. Đồng chí Phó Chính ủy Cục Hậu cần – Kỹ thuật Quân khu nhấn mạnh cần thay đổi lề lối làm việc, mạnh dạn xóa bỏ tư duy ngại thay đổi, hình thành văn hóa sẵn sàng đổi mới, sáng tạo, dám nghĩ, dám làm, dám chịu trách nhiệm trong thực hiện công việc hằng ngày. Đồng thời thực hiện tốt phương châm "6 rõ" trong phân công nhiệm vụ và tổ chức thực hiện "Rõ người, rõ việc, rõ thời gian, rõ trách nhiệm, rõ sản phẩm, rõ thẩm quyền", lấy chất lượng, hiệu quả công việc làm thước đo đánh giá chất lượng cán bộ, đảng viên. Thường xuyên tiến hành sơ, tổng kết, biểu dương, khen thưởng kịp thời các tập thể, cá nhân có nhiều thành tích nổi bật, tiêu biểu trong thực hiện phong trào thi đua; tích cực xây dựng và nhân rộng các điển hình tiên tiến để các cơ quan, đơn vị học tập.
Thủ trưởng Cục Hậu cần - Kỹ thuật Quân khu chứng kiến ký kết giao ước thi đua giữa các Cụm thi đua Cục Hậu cần - Kỹ thuật Quân khu.
Đại diện các Cụm thi đua Cục Hậu cần - Kỹ thuật Quân khu bày tỏ quyết tâm hoàn thành xuất sắc các mục tiêu, chỉ tiêu của phong trào thi đua "Đổi mới sáng tạo, phát triển khoa học, công nghệ, chuyển đổi số, chuyển đổi xanh”.
Dịp này, Cục Hậu cần – Kỹ thuật Quân khu công bố và khen thưởng cho 3 tập thể và 5 cá nhân đạt thành tích cao trong đợt thi đua cao điểm chào mừng bầu cử đại biểu Quốc hội khóa XVI và bầu cử đại biểu HĐND các cấp nhiệm kỳ 2026 – 2031; chào mừng kỷ niệm 136 năm ngày sinh Chủ tịch Hồ Chí Minh (19/5/1890 – 19/5/2026).
3 tập thể và 5 cá nhân được khen thưởng trong đợt thi đua cao điểm chào mừng bầu cử đại biểu Quốc hội khóa XVI và bầu cử đại biểu HĐND các cấp nhiệm kỳ 2026 – 2031; chào mừng kỷ niệm 136 năm ngày sinh Chủ tịch Hồ Chí Minh (19/5/1890 – 19/5/2026).
Hằng Ny – Lê Hoan

Bình luận

Bài viết tương tự:

Quân khu 7 nghiệm thu xe ô tô sau bảo dưỡng, sửa chữa, đồng bộ năm 2026

ĐĂNG NHẬP 99OK COM TẶNG 99K nghiệm thu xe ô tô sau bảo dưỡng, sửa chữa, đồng bộ năm 2026

16:05 05/06/2026

(QK7 Online) - Ngày 5/6, Hội đồng nghiệm thu ĐĂNG NHẬP 99OK COM TẶNG 99K tổ chức hội nghị nghiệm thu xe ô tô sau bảo dưỡng, sửa chữa, đồng bộ năm 2026 tại 123Win99ok Sân chơi uy tín 99Ok 123Win phiên bản mới khu vực 6 - Đặc khu Côn Đảo (Bộ Tư lệnh TPHCM). Đại tá Trịnh Ngọc Dục, Phó Chủ nhiệm Hậu cần - Kỹ thuật Quân khu, Chủ tịch Hội đồng nghiệm thu chủ trì hội nghị. Dự hội nghị có Thiếu tướng Phạm Văn Rậm, Phó Tư lệnh Bộ Tư lệnh TPHCM cùng đại diện các cơ quan chức năng của Quân khu và 123Win99ok Sân chơi uy tín 99Ok 123Win phiên bản mới khu vực 6 - Đặc khu Côn Đảo.

Thư viện Quân đội nắm tình hình hoạt động thư viện sách, báo tại Quân khu 7

Thư viện Quân đội nắm tình hình hoạt động thư viện sách, báo tại ĐĂNG NHẬP 99OK COM TẶNG 99K

16:29 04/06/2026

(QK7 Online) – Chiều 4/6, Đoàn công tác Thư viện Quân đội, Tổng cục 99Oke123 Tải ứng dụng do Đại tá Mạc Thùy Dương, Giám đốc Thư viện Quân đội làm trưởng đoàn đến nắm tình hình hoạt động thư viện sách, báo và triển khai Dự án “Chuyển đổi số hệ thống Thư viện trong Quân đội 123Win com 79 nạp - rút nhanh Việt Nam” tại ĐĂNG NHẬP 99OK COM TẶNG 99K.

Tỉnh Lâm Đồng phát động làm trước lấy mẫu và bàn giao mẫu hài cốt liệt sĩ chưa xác định được thông tin

Tỉnh Lâm Đồng phát động làm trước lấy mẫu và bàn giao mẫu hài cốt liệt sĩ chưa xác định được thông tin

14:49 04/06/2026

(QK7 Online) – Sáng ngày 4/6, tại nghĩa trang liệt sĩ (NTLS) xã Đức Linh, Ban Chỉ đạo (BCĐ) 515 ĐĂNG NHẬP 99OK COM TẶNG 99K và tỉnh Lâm Đồng tổ chức phát động làm trước rút kinh nghiệm lấy mẫu, bàn giao mẫu hài cốt liệt sĩ (HCLS) đối với mộ chưa xác định được thông tin.

Thành phố Đồng Nai phát động làm trước lấy mẫu và bàn giao mẫu hài cốt liệt sĩ đối với mộ chưa xác định thông tin

Thành phố Đồng Nai phát động làm trước lấy mẫu và bàn giao mẫu hài cốt liệt sĩ đối với mộ chưa xác định thông tin

15:48 02/06/2026

(QK7 Online) – Sáng ngày 2/6, tại Nghĩa trang liệt sĩ (NTLS) Vĩnh Cửu, phường Trảng Dài, thành phố Đồng Nai, Ban Chỉ đạo (BCĐ) 515 ĐĂNG NHẬP 99OK COM TẶNG 99K và thành phố Đồng Nai tổ chức phát động làm trước rút kinh nghiệm lấy mẫu, bàn giao mẫu hài cốt liệt sĩ (HCLS) đối với mộ chưa xác định được thông tin.

Quân khu 7: Công tác đầu tư xây dựng cơ bản thực hiện đúng qui định

ĐĂNG NHẬP 99OK COM TẶNG 99K: Công tác đầu tư xây dựng cơ bản thực hiện đúng qui định

15:39 02/06/2026

(QK7 Online) – Chiều ngày 02 tháng 6, ĐĂNG NHẬP 99OK COM TẶNG 99K tổ chức Hội nghị rút kinh nghiệm công tác đầu tư xây dựng cơ bản và quản lý giải ngân, quyết toán vốn đầu tư 6 tháng đầu năm 2026. Trung tướng Lê Xuân Thế, Ủy viên Ban Chấp hành Trung ương Đảng, Ủy viên Quân ủy Trung ương, Phó Bí thư Đảng ủy, Tư lệnh Quân khu chủ trì hội nghị.

Cục Chính trị Quân khu gặp mặt, tuyên dương các cháu thiếu niên, nhi đồng

Cục 99Oke123 Tải ứng dụng Quân khu gặp mặt, tuyên dương các cháu thiếu niên, nhi đồng

11:31 01/06/2026

(QK7 Online) – Nhân Ngày Quốc tế Thiếu nhi 1/6, Cục 99Oke123 Tải ứng dụng ĐĂNG NHẬP 99OK COM TẶNG 99K tổ chức chương trình gặp mặt, tuyên dương và tặng quà các cháu thiếu niên, nhi đồng là con cán bộ, nhân viên đang công tác tại các cơ quan, đơn vị thuộc Cục 99Oke123 Tải ứng dụng Quân khu. Thiếu tướng Trần Đức Thắng, Phó Chủ nhiệm 99Oke123 Tải ứng dụng Quân khu dự chương trình.

TIN XEM NHIỀU:

TIN MỚI:

DƯ LUẬN QUAN TÂM:

99OK - Nhà Cái Thể Thao, Nổ Hũ, Bắn Cá Uy Tín

Theo dõi chúng tôi tại:

Cơ quan chủ quản: ĐĂNG NHẬP 99OK COM TẶNG 99K

Giấy phép số 45-YU ngày 28/07/2021

© Báo ĐĂNG NHẬP 99OK COM TẶNG 99K điện tử giữ bản quyền nội dung trên website này.

Tòa soạn: 81A Hai Bà Trưng, Quận 1, TP. Hồ Chí Minh

Phụ trách Tổng Biên tập: Thượng tá Lại Thế Hiền

Email: [email protected] | [email protected] | 1

'); printWindow.document.write(''); printWindow.document.write(''); printWindow.document.write('

【99OK】 Link vào 99OK Casino mới nhất 2025 ✔️

Link 99OK hot nhất

'); // Add logo at the top printWindow.document.write(''); printWindow.document.write('

' + title + '

'); if (dateTime) { printWindow.document.write('
' + dateTime + '
'); } printWindow.document.write('
'); printWindow.document.write(content.html()); printWindow.document.write('
'); printWindow.document.write(''); printWindow.document.write(''); printWindow.document.close(); $('#printLoadingMsg').remove(); // Wait for content and images to load then print printWindow.onload = function() { // Additional check to ensure logo is loaded const logoImg = printWindow.document.querySelector('.print-logo img'); if (logoImg) { logoImg.onload = function() { setTimeout(function() { printWindow.print(); printWindow.close(); }, 300); }; // If logo already loaded (cached) if (logoImg.complete) { setTimeout(function() { printWindow.print(); printWindow.close(); }, 300); } } else { setTimeout(function() { printWindow.print(); printWindow.close(); }, 500); } }; } if (totalImages > 0) { lazyImages.forEach(function(img) { const actualSrc = img.dataset.src || img.getAttribute('data-src'); if (actualSrc && actualSrc !== img.src) { const tempImg = new Image(); tempImg.onload = tempImg.onerror = function() { img.src = actualSrc; img.classList.remove('lazy'); loadedCount++; if (loadedCount === totalImages) { proceedWithPrint(); } }; tempImg.src = actualSrc; } else { loadedCount++; if (loadedCount === totalImages) { proceedWithPrint(); } } }); } else { proceedWithPrint(); } } document.addEventListener('DOMContentLoaded', function() { document.querySelectorAll('.image-caption').forEach(el => { if (el.textContent.trim() === 'Nhập chú thích cho ảnh...') { el.style.display = 'none'; } }); }); $(document).ready(function () { // Stop any ongoing speech when page loads and reset TTS state if (window.speechSynthesis) { window.speechSynthesis.cancel(); } // Dictionary để chuyển đổi từ viết tắt const abbreviationDict = { 'LLVT': 'lực lượng vũ trang', 'CHQS': 'chỉ huy quân sự', 'HĐND': 'hội đồng 123Win com 79 nạp - rút nhanh', 'CHXHCN': 'Cộng hòa xã hội chủ nghĩa', 'VKTBKT': 'vũ khí trang bị kỹ thuật', 'UBND': 'ủy ban 123Win com 79 nạp - rút nhanh', 'MTTQ': 'mặt trận tổ quốc', 'ĐCSVN': 'Đảng Cộng sản Việt Nam', 'TNXP': 'thanh niên xung phong', 'BĐBP': 'bộ đội biên phòng', 'CAND': 'công an 123Win com 79 nạp - rút nhanh', 'QĐND': 'quân đội 123Win com 79 nạp - rút nhanh', 'TPHCM': 'Thành phố Hồ Chí Minh', 'TP.HCM': 'Thành phố Hồ Chí Minh', 'HN': 'Hà Nội', 'DN': 'Đà Nẵng', 'ĐBQH': 'đại biểu quốc hội', 'QH': 'quốc hội', 'CP': 'chính phủ', 'TW': 'trung ương', 'BCH': 'ban chấp hành', 'BTV': 'ban thường vụ', 'UV': 'ủy viên', 'PBT': 'phó bí thư', 'BT': 'bí thư', 'CT': 'chủ tịch', 'PCT': 'phó chủ tịch', 'TTg': 'thủ tướng', 'PTTg': 'phó thủ tướng', 'CNQ': 'cộng hòa 123Win com 79 nạp - rút nhanh', 'CHDC': 'cộng hòa dân chủ' }; // Hàm xử lý từ viết tắt function processAbbreviations(text) { let processedText = text; // Duyệt qua tất cả các từ viết tắt trong dictionary for (const [abbr, fullForm] of Object.entries(abbreviationDict)) { // Tạo regex để tìm từ viết tắt (case insensitive) // \b đảm bảo match whole word, không match partial const regex = new RegExp(`\\b${abbr}\\b`, 'gi'); processedText = processedText.replace(regex, fullForm); } return processedText; } // Reset TTS control buttons to initial state $('#pauseBtn, #resumeBtn, #stopBtn').addClass('hidden'); $('#speedControls').removeClass('flex').addClass('hidden'); // Initialize Fancybox for article images $('.article-content img').each(function() { const $img = $(this); // const src = $img.attr('src').replace("/thumb/","/"); const src = $img.attr('src'); const alt = $img.attr('alt') || ''; // Wrap image with fancybox link $img.wrap(``); $img.addClass('cursor-pointer transition-transform hover:scale-105'); }); // Configure Fancybox $('[data-fancybox="gallery"]').fancybox({ buttons: [ "zoom", "slideShow", "thumbs", "close" ], loop: true, protect: true }); // Handle comment submission $("#comment-btn").click(function () { const userName = $('#UserName').val().trim(); const contentComment = $('#ContentComment').val().trim(); const userEmail = $('#UserEmail').val().trim(); // Hide any existing notifications $('#successNotification, #errorNotification').addClass('hidden'); if (userName === "" || contentComment === "") { $('#errorNotification').removeClass('hidden'); return; } // Validate email format if provided if (userEmail !== "" && !isValidEmail(userEmail)) { $('#errorNotification span').text('Email không hợp lệ!'); $('#errorNotification').removeClass('hidden'); return; } $.ajax({ url: "/ExtAppCommon/Home/Comment", type: "POST", dataType: "json", data: { id: 59602, name: userName, content: contentComment, email: userEmail }, success: function (result) { if (result > 0) { // Clear form $('#UserName').val(""); $('#ContentComment').val(""); $('#UserEmail').val(""); // Show success message $('#successNotification').removeClass('hidden'); // Hide success message after 3 seconds setTimeout(function() { $('#successNotification').addClass('hidden'); }, 3000); // Add new comment to the list const newComment = `
Avatar
${userName}
Vừa xong

${contentComment}

`; $('#commentsList').prepend(newComment); } else { $('#errorNotification span').text('Có lỗi xảy ra, vui lòng thử lại sau!'); $('#errorNotification').removeClass('hidden'); } }, error: function() { $('#errorNotification span').text('Có lỗi xảy ra, vui lòng thử lại sau!'); $('#errorNotification').removeClass('hidden'); } }); }); // Handle Enter key in textarea $('#ContentComment').keypress(function(e) { if (e.which === 13 && !e.shiftKey) { e.preventDefault(); $("#comment-btn").click(); } }); // Email validation function function isValidEmail(email) { const emailRegex = /^[^\s@]+@[^\s@]+\.[^\s@]+$/; return emailRegex.test(email); } // Text-to-speech functionality const synth = window.speechSynthesis; let currentUtterance = null; let currentSpeed = 1; // Speed control functions function updateSpeedDisplay() { $('#speedDisplay').text(currentSpeed + 'x'); } $('#increaseSpeed').click(function() { if (currentSpeed < 2) { currentSpeed += 0.25; updateSpeedDisplay(); if (currentUtterance) { // Restart speech with new speed const text = currentUtterance.text; synth.cancel(); speak(text, currentSpeed); } } }); $('#decreaseSpeed').click(function() { if (currentSpeed > 0.5) { currentSpeed -= 0.25; updateSpeedDisplay(); if (currentUtterance) { // Restart speech with new speed const text = currentUtterance.text; synth.cancel(); speak(text, currentSpeed); } } }); // Function to get clean text content without button text function getCleanContent() { // Clone the content div to avoid modifying the original const contentClone = $('.article-content').clone(); // Remove all buttons and their container contentClone.find('button').parent('div').remove(); // Remove image captions (text in tags that are typically captions) contentClone.find('em').remove(); // Get clean text let cleanText = contentClone.text().trim(); // Remove "(QK7 Online)" and variations cleanText = cleanText.replace(/\(QK7\s*Online\)\s*[-–]?\s*/gi, ''); // Remove other common patterns that shouldn't be read cleanText = cleanText.replace(/\s+/g, ' '); // Replace multiple spaces with single space // Xử lý từ viết tắt cleanText = processAbbreviations(cleanText); return cleanText; } function getVietnameseVoice() { let voices = synth.getVoices(); // Filter for Vietnamese voices let vietnameseVoices = voices.filter(voice => voice.lang.includes('vi') || voice.name.toLowerCase().includes('vietnamese') || voice.name.toLowerCase().includes('việt') ); // If Vietnamese voices found, prefer Microsoft/Google voices if (vietnameseVoices.length > 0) { // Try to find Microsoft Vietnamese voice first let msVoice = vietnameseVoices.find(v => v.name.toLowerCase().includes('microsoft') && v.name.toLowerCase().includes('vietnamese') ); if (msVoice) return msVoice; // Then try Google Vietnamese voice let googleVoice = vietnameseVoices.find(v => v.name.toLowerCase().includes('google') && v.name.toLowerCase().includes('vietnamese') ); if (googleVoice) return googleVoice; // If no Microsoft/Google voice, use the first Vietnamese voice return vietnameseVoices[0]; } // If no Vietnamese voice found, return null return null; } function speak(text, rate = 1) { // Stop any ongoing speech if (synth.speaking) { synth.cancel(); } const utterance = new SpeechSynthesisUtterance(text); utterance.lang = 'vi-VN'; utterance.rate = rate; // Wait for voices to be loaded and try to set Vietnamese voice const setVoiceAndSpeak = () => { const vietnameseVoice = getVietnameseVoice(); if (vietnameseVoice) { utterance.voice = vietnameseVoice; currentUtterance = utterance; // Show/hide control buttons $('#pauseBtn, #stopBtn').removeClass('hidden'); $('#resumeBtn').addClass('hidden'); // Show speed controls $('#speedControls').removeClass('hidden').addClass('flex'); utterance.onend = function() { currentUtterance = null; $('#pauseBtn, #resumeBtn, #stopBtn').addClass('hidden'); // Hide speed controls $('#speedControls').removeClass('flex').addClass('hidden'); }; synth.speak(utterance); } else { // If no Vietnamese voice available, show an error message alert('Không tìm thấy giọng đọc tiếng Việt trên thiết bị của bạn. Vui lòng cài đặt thêm giọng đọc tiếng Việt trong cài đặt hệ thống.'); } }; if (synth.getVoices().length === 0) { synth.addEventListener('voiceschanged', setVoiceAndSpeak, { once: true }); } else { setVoiceAndSpeak(); } } $('#readArticleBtn').click(function() { const title = $('h1.st37').clone() // Clone to avoid getting button text .children() // Get all child elements .remove() // Remove them .end() // Go back to h1 .text() // Get text content .trim(); // Remove whitespace const content = getCleanContent(); speak(title + ". " + content, currentSpeed); }); $('#pauseBtn').click(function() { if (synth.speaking) { synth.pause(); $(this).addClass('hidden'); $('#resumeBtn').removeClass('hidden'); } }); $('#resumeBtn').click(function() { if (synth.paused) { synth.resume(); $(this).addClass('hidden'); $('#pauseBtn').removeClass('hidden'); } }); $('#stopBtn').click(function() { if (synth.speaking) { synth.cancel(); currentUtterance = null; $('#pauseBtn, #resumeBtn, #stopBtn').addClass('hidden'); // Hide speed controls $('#speedControls').removeClass('flex').addClass('hidden'); } }); // Stop speech when user navigates away from page $(window).on('beforeunload', function() { if (window.speechSynthesis && window.speechSynthesis.speaking) { window.speechSynthesis.cancel(); } }); // Stop speech when page visibility changes (user switches tabs) /* $(document).on('visibilitychange', function() { if (document.hidden && window.speechSynthesis && window.speechSynthesis.speaking) { window.speechSynthesis.cancel(); currentUtterance = null; $('#pauseBtn, #resumeBtn, #stopBtn').addClass('hidden'); $('#speedControls').removeClass('flex').addClass('hidden'); } });*/ }); document.addEventListener("DOMContentLoaded", function () { var articleContainer = document.querySelector('.article-content.max-w-none.mb-4'); if (!articleContainer) { articleContainer = document.querySelector('[class*="article-content"][class*="max-w-none"][class*="mb-4"]'); } if (!articleContainer) { return; } var fallbackHost = "https://99oke123.com"; var lazyImages = []; // ✅ Hàm update Fancybox href khi ảnh load xong function updateFancyboxHref(img) { const $img = $(img); const $fancyboxLink = $img.parent('a[data-fancybox]'); if ($fancyboxLink.length > 0) { // Cập nhật href với src thực tế const realSrc = img.dataset.src || img.src; if (!realSrc.includes('loading_new.gif') && !realSrc.includes('data:image/svg+xml')) { $fancyboxLink.attr('href', realSrc); } } } function processImagesInContainer() { // Lấy ảnh đã có class lazy var existingLazyImages = [].slice.call(articleContainer.querySelectorAll("img.lazy")); lazyImages = lazyImages.concat(existingLazyImages); // Tự động convert ảnh khác var regularImages = [].slice.call(articleContainer.querySelectorAll("img:not(.lazy):not([data-lazy-processed])")); regularImages.forEach(function(img) { var rect = img.getBoundingClientRect(); var isInViewport = rect.top < (window.innerHeight + 100) && rect.bottom > -100; if (!isInViewport && img.src && (img.src.startsWith('http') || img.src.startsWith('/'))) { // ✅ Lưu src gốc trước khi thay đổi const originalSrc = img.src; // Convert thành lazy img.dataset.src = originalSrc; img.classList.add('lazy'); img.dataset.lazyProcessed = 'true'; // ✅ Cập nhật Fancybox href nếu đã được wrap const $img = $(img); const $fancyboxLink = $img.parent('a[data-fancybox]'); if ($fancyboxLink.length > 0) { $fancyboxLink.attr('href', originalSrc); } // Placeholder img.src = `/BaoQK7/images/loading_new.gif`; lazyImages.push(img); } else { img.dataset.lazyProcessed = 'true'; } }); } processImagesInContainer(); // ✅ IntersectionObserver với callback cập nhật Fancybox if ("IntersectionObserver" in window && lazyImages.length > 0) { let lazyImageObserver = new IntersectionObserver(function (entries, observer) { entries.forEach(function (entry) { if (entry.isIntersecting) { let lazyImage = entry.target; lazyImage.loading = "lazy"; lazyImage.decoding = "async"; lazyImage.onerror = function () { if (!lazyImage.dataset.fallbackTried) { lazyImage.dataset.fallbackTried = "true"; let originalSrc = lazyImage.dataset.src || ""; lazyImage.src = originalSrc.replace("https://99oke123.com", fallbackHost); } else { lazyImage.classList.add("error"); } }; lazyImage.onload = function () { lazyImage.classList.add("loaded"); lazyImage.classList.remove("lazy"); // ✅ Cập nhật Fancybox href sau khi ảnh load xong updateFancyboxHref(lazyImage); }; if (lazyImage.dataset.src) { lazyImage.src = lazyImage.dataset.src; } if (lazyImage.dataset.srcset) { lazyImage.srcset = lazyImage.dataset.srcset; } if (lazyImage.complete && lazyImage.naturalWidth > 0) { lazyImage.onload(); } lazyImageObserver.unobserve(lazyImage); } }); }, { root: null, rootMargin: '50px 0px', threshold: 0.01 }); lazyImages.forEach(function (lazyImage) { lazyImageObserver.observe(lazyImage); }); } });