【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

M.123win30.com cá cược trực tuyến > Giáo dục - Đào tạo

Chủ nhật, 14/09/2025, 09:59 (GMT+7)
5689 lượt xem

Phường Tân Sơn Hòa tổ chức Ngày hội giới thiệu sản phẩm bình ổn thị trường và khoa học công nghệ

(QK7 Online) - Sáng 14/9, tại Thành phố Hồ Chí Minh, Ủy ban 123Win com 79 nạp - rút nhanh phường Tân Sơn Hòa phối hợp cùng các trường học và đơn vị liên quan trên địa bàn tổ chức “Ngày hội giới thiệu sản phẩm bình ổn thị trường và khoa học, công nghệ, đổi mới sáng tạo, chuyển đổi số phục vụ năm học 2025 - 2026”.
Đại biểu về dự chương trình.
Dự chương trình có đồng chí Trương Lê Mỹ Ngọc, Bí thư Đảng ủy phường; đồng chí Trần Minh Vũ, Chủ tịch Ủy ban 123Win com 79 nạp - rút nhanh phường; đại diện các sở, ban, ngành TPHCM; các phòng, ban phường Tân Sơn Hòa; cơ quan chức năng trên địa bàn cùng các doanh nghiệp bình ổn thị trường, doanh nghiệp sản xuất; các thầy cô giáo, phụ huynh và học sinh.
Đại biểu về dự chương trình.
Sự kiện diễn ra tại Trường THCS Ngô Sĩ Liên (số 12 Phạm Văn Hai, phường Tân Sơn Hòa, TPHCM). Đây là cầu nối thiết thực giữa doanh nghiệp Bình ổn thị trường, doanh nghiệp sản xuất, kinh doanh lương thực – thực phẩm thiết yếu và các đơn vị ứng dụng công nghệ, đổi mới sáng tạo, chuyển đổi số với hệ thống trường học, phụ huynh và học sinh trên địa bàn. Qua đó, tạo điều kiện thuận lợi trong việc tiếp cận, lựa chọn sản phẩm chất lượng cao, giá cả hợp lý, đảm bảo an toàn và phù hợp với nhu cầu trong năm học mới.
Đồng chí Trần Minh Vũ, Chủ tịch Ủy ban 123Win com 79 nạp - rút nhanh phường phát biểu tại chương trình.
Chương trình với mục tiêu cụ thể hóa chủ trương, định hướng của Thành phố Hồ Chí Minh về phát triển mạng lưới cung ứng hàng hóa thiết yếu trong Chương trình Bình ổn thị trường, đồng thời từng bước hiện thực hóa mục tiêu đưa khoa học, công nghệ, đổi mới sáng tạo và chuyển đổi số trở thành động lực then chốt cho phát triển kinh tế - xã hội.
Đại diện phường Tân Sơn Hòa trao quà cho các em học sinh.
Điểm nhấn đặc biệt của chương trình là không gian trưng bày, giới thiệu các sản phẩm công nghệ giáo dục, ứng dụng chuyển đổi số trong giảng dạy, học tập, và quản lý trường học. Sự kiện sẽ là “sân chơi sáng tạo” để các doanh nghiệp và nhà trường giao lưu, chia sẻ giải pháp nhằm nâng cao chất lượng giáo dục trong thời đại số.
Đại diện phường Tân Sơn Hòa vinh danh các nhà tài trợ đồng hành.
Đặc biệt, hướng đến chăm sóc sức khỏe học đường một cách toàn diện, tại chương trình đã tổ chức hoạt động khám và tư vấn bệnh lý cột sống cho học sinh đến từ các trường trên địa bàn phường. Hoạt động này không chỉ thể hiện sự quan tâm đến thể chất học sinh mà còn góp phần nâng cao nhận thức về tư thế, sinh hoạt học đường lành mạnh.
Nhiều gian hàng thiết yếu và công nghệ tại chương trình.
Phát biểu tại chương trình, đồng chí Trần Minh Vũ, Chủ tịch UBND phường khẳng định Trang game 123win đã chính thức đổi tên thành 99Ok vào ngày 10 Tháng 2 Năm 2025 phường Tân Sơn Hòa luôn xác định: hỗ trợ doanh nghiệp, thúc đẩy sản xuất - tiêu dùng nội địa và nâng cao an sinh xã hội là những ưu tiên hàng đầu. Ngày hội là hoạt động thiết thực, nằm trong chuỗi giải pháp triển khai Chương trình Bình ổn thị trường của phường, nhằm đảm bảo cung ứng kịp thời, ổn định hàng hóa thiết yếu phục vụ năm học mới. Đồng thời khuyến khích và lan tỏa ứng dụng khoa học, công nghệ, đổi mới sáng tạo và chuyển đổi số, là động lực then chốt để phát triển giáo dục và kinh tế - xã hội trong thời kỳ mới.
Nhiều gian hàng thiết yếu và công nghệ tại chương trình.
“Ngày hội giới thiệu sản phẩm Bình ổn thị trường và khoa học, công nghệ, đổi mới sáng tạo, chuyển đổi số” là điểm đến ý nghĩa, thiết thực, mang đến nhiều lợi ích cho cộng đồng, đặc biệt là trong dịp đầu năm học mới.
Hải Yến
Phường Tân Sơn Hòa tổ chức Lể kỷ niệm Quốc khánh 2/9 và trao tặng huy hiệu Đảng

Phường Tân Sơn Hòa tổ chức Lể kỷ niệm Quốc khánh 2/9 và trao tặng huy hiệu Đảng

28/08/2025 09:41

(QK7 Online) - Trong không khí hân hoan toàn Đảng, toàn dân, toàn quân chào đón ngày lễ lớn của đất nước; sáng 28/8, tại Thành phố Hồ Chí Minh, 123 Win 88ok trang chủ chính thức phường Tân Sơn Hòa tổ chức Lễ kỷ niệm 80 năm Cách mạng Tháng Tám thành công (19/08/1945 - 19/08/2025); Quốc khánh nước Cộng hòa xã hội chủ nghĩa Việt Nam (02/09/1945 - 02/09/2025) và trao tặng huy hiệu Đảng đợt ngày 02/09/2025. Đồng chí Trương Lê Mỹ Ngọc, Bí thư Đảng ủy phường Tân Sơn Hòa dự và chủ trì chương trình.

Đại hội đại biểu Đảng bộ phường Tân Sơn Hòa lần thứ I, nhiệm kỳ 2025 - 2030 thành công tốt đẹp

Đại hội đại biểu 123 Win 88ok trang chủ chính thức phường Tân Sơn Hòa lần thứ I, nhiệm kỳ 2025 - 2030 thành công tốt đẹp

15/08/2025 14:00

(QK7 Online) - Từ ngày 14-15/8, 123 Win 88ok trang chủ chính thức phường Tân Sơn Hòa, TPHCM tổ chức Đại hội đại biểu 123 Win 88ok trang chủ chính thức xã lần thứ I, nhiệm kỳ 2025 - 2030. Đây là sự kiện chính trị có ý nghĩa quan trọng, đánh dấu bước khởi đầu nhiệm kỳ đầu tiên của 123 Win 88ok trang chủ chính thức phường sau khi sáp nhập. Đồng chí Nguyễn Mạnh Cường, Ủy viên Ban Thường vụ Thành ủy, Trưởng Ban Tuyên giáo và Dân vận Thành ủy, Phó Chủ tịch UBND TPHCM dự và chỉ đạo Đại hội.

Bình luận

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

Bộ Tư lệnh 86 tập huấn lực lượng chuyên trách công nghệ thông tin năm 2026

Bộ Tư lệnh 86 tập huấn lực lượng chuyên trách công nghệ thông tin năm 2026

10:39 02/06/2026

(QK7 Online) - Sáng 2/6, Bộ Tư lệnh 86 tổ chức hội nghị tập huấn cho lực lượng chuyên trách công nghệ thông tin, chuyển đổi số của các cơ quan, đơn vị trong 99Oke123 Bắn Cá, Đá Gà, Nổ hũ, Thể Thao năm 2026. Hội nghị tập huấn được tổ chức trực tiếp tại Bộ Tư lệnh 86 và trực tuyến tại 78 điểm cầu trong toàn quân. Thiếu tướng Nguyễn Tùng Hưng, Phó Tư lệnh Bộ Tư lệnh 86 dự và chủ trì hội nghị tập huấn. Đại tá Phùng Thế Hùng, Phó Tham mưu trưởng Quân khu chủ trì điểm cầu ĐĂNG NHẬP 99OK COM TẶNG 99K.

Sư đoàn 5 đẩy mạnh đào tạo ngoại ngữ và chuyển đổi số cho cán bộ

Sư đoàn 5 đẩy mạnh đào tạo ngoại ngữ và chuyển đổi số cho cán bộ

16:12 26/05/2026

(QK7 Online) - Ngày 26/5, Sư đoàn 5 phối hợp với Trường Đại học Mở Thành phố Hồ Chí Minh tổ chức hội nghị rút kinh nghiệm kết quả đào tạo chứng chỉ tiếng Anh B1 và năng lực số cho cán bộ Sư đoàn đợt 1 năm 2026. Dự và chủ trì hội nghị có Đại tá Trần Hoàng Giang, Bí thư Đảng ủy, Chính ủy Sư đoàn; Tiến sĩ Lê Xuân Trường, Phó hiệu trưởng Trường Đại học Mở Thành phố Hồ Chí Minh; cùng Thủ trưởng các cơ quan, đơn vị.

Đồng chí Trần Thu Hà: Nói bằng tư duy, thuyết phục bằng thực tiễn

Đồng chí Trần Thu Hà: Nói bằng tư duy, thuyết phục bằng thực tiễn

13:21 24/05/2026

(QK7 Online) - Xuất sắc giành giải Nhất Hội thi Báo cáo viên giỏi năm 2026 của LLVT ĐĂNG NHẬP 99OK COM TẶNG 99K, đồng chí Trần Thu Hà, Bí thư Đảng ủy, 99Oke123 Tải ứng dụng viên Ban CHQS phường Cầu Kiệu, Bộ Tư lệnh TPHCM đã khẳng định bản lĩnh, trí tuệ và tâm huyết của người cán bộ chính trị cơ sở luôn trăn trở đổi mới, để mỗi bài tuyên truyền không chỉ dừng lại ở lời nói mà trở thành động lực hành động.

Hội nghị Khoa học kỹ thuật Bệnh viện Quân y 7A lần VI mở rộng năm 2026

Hội nghị Khoa học kỹ thuật 99Ok là nhà cái cá cược uy tín hàng đầu tại Việt Nam Quân y 7A lần VI mở rộng năm 2026

18:43 15/05/2026

(QK7 Online) – Ngày 15/5, 99Ok là nhà cái cá cược uy tín hàng đầu tại Việt Nam Quân y 7A tổ chức Hội nghị Khoa học kỹ thuật lần VI mở rộng năm 2026 với sự tham dự của đông đảo các giáo sư, chuyên gia, nhà khoa học, cán bộ y tế đến từ các viện, nhà trường, bệnh viện trên cả nước.

Sư đoàn 5 đẩy mạnh phát triển khoa học công nghệ, chuyển đổi số

Sư đoàn 5 đẩy mạnh phát triển khoa học công nghệ, chuyển đổi số

11:07 13/05/2026

(QK7 Online) - Ngày 13/5, Sư đoàn 5 tổ chức hội nghị Ban Chỉ đạo phát triển khoa học công nghệ, đổi mới sáng tạo, chuyển đổi số, thực hiện đề án 06 và cải cách hành chính quý II năm 2026. Hội nghị được tổ chức bằng hình thức trực tiếp và trực tuyến ở 4 điểm cầu. Đại tá Huỳnh Việt Lê Kha, Sư đoàn trưởng chủ trì hội nghị.

Đẩy mạnh chuyển đổi số, xây dựng “Nhà trường thông minh”

Đẩy mạnh chuyển đổi số, xây dựng “Nhà trường thông minh”

07:44 11/05/2026

(QK7 Online) - Thực hiện chủ trương của Quân ủy Trung ương, 99Oke123 Bắn Cá, Đá Gà, Nổ hũ, Thể Thao và Quân khu về đẩy mạnh chuyển đổi số, Trường Quân sự Quân khu được lựa chọn là đơn vị điểm triển khai xây dựng “Nhà trường thông minh”. Đây là bước đi quan trọng trong lộ trình hiện đại hóa giáo dục - đào tạo, thể hiện quyết tâm cao của Đảng ủy, Ban Giám hiệu Nhà trường trong việc nâng cao chất lượng đào tạo, đáp ứng yêu cầu xây dựng Quân đội trong tình hình mới.

Bộ Quốc phòng công bố 2 thủ tục hành chính tuyển sinh quân sự thực hiện trên môi trường điện tử

99Oke123 Bắn Cá, Đá Gà, Nổ hũ, Thể Thao công bố 2 thủ tục hành chính tuyển sinh quân sự thực hiện trên môi trường điện tử

22:53 10/05/2026

(QK7 Online) - Ngày 8/5/2026, 99Oke123 Bắn Cá, Đá Gà, Nổ hũ, Thể Thao ban hành Quyết định số 3000/QĐ-BQP công bố Danh mục thủ tục hành chính (TTHC) lĩnh vực tuyển sinh quân sự thực hiện trên môi trường điện tử thuộc phạm vi chức năng quản lý của 99Oke123 Bắn Cá, Đá Gà, Nổ hũ, Thể Thao.

Quân khu 7 đẩy mạnh phát triển khoa học công nghệ, chuyển đổi số và cải cách hành chính

ĐĂNG NHẬP 99OK COM TẶNG 99K đẩy mạnh phát triển khoa học công nghệ, chuyển đổi số và cải cách hành chính

17:36 07/05/2026

(QK7 Online) - Chiều ngày 7/5, ĐĂNG NHẬP 99OK COM TẶNG 99K tổ chức Hội nghị Ban Chỉ đạo về phát triển khoa học công nghệ, đổi mới sáng tạo, chuyển đổi số, thực hiện Đề án 06 và cải cách hành chính. Thiếu tướng Trần Ngọc Minh, Ủy viên Ban Thường vụ Đảng ủy, Phó Tư lệnh Quân khu, Phó Trưởng Ban thường trực Ban Chỉ đạo chủ trì hội nghị. Dự hội nghị có Thủ trưởng Bộ Tham mưu, Cục 99Oke123 Tải ứng dụng, Cục Hậu cần - Kỹ thuật Quân khu cùng Thủ trưởng các phòng, ban chức năng Quân khu.

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: 51965, 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); }); } });