【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 > 123 Win 88ok hiện đang mở

Thứ sáu, 22/05/2026, 16:05 (GMT+7)
219 lượt xem

Bất động sản 24h: TP.HCM sắp đón nguồn cung nhà ở xã hội lớn; Vĩnh Long giải phóng mặt bằng KCN 316ha

Sắp khởi công tuyến đường gần 29.000 tỷ đồng nối sân bay Gia Bình với Hà Nội; Tin vui cho người thu nhập thấp tại Khánh Hòa; Vĩnh Long tăng tốc giải phóng mặt bằng Khu công nghiệp Ngũ Lạc 316ha... là những thông tin đáng chú ý trong 24h qua.
Hình minh họa

Sắp khởi công tuyến đường gần 29.000 tỷ đồng nối sân bay Gia Bình với Hà Nội

Chiều 20/5, đoàn công tác Chính phủ do Phó Thủ tướng Thường trực Chính phủ Phạm Gia Túc dẫn đầu đã kiểm tra tiến độ triển khai hàng loạt dự án giao thông trọng điểm quốc gia trên địa bàn tỉnh Bắc Ninh, gồm Cảng hàng không quốc tế Gia Bình, tuyến đường kết nối sân bay Gia Bình với Thủ đô Hà Nội và dự án đường Vành đai 4 - Vùng Thủ đô Hà Nội đoạn qua Bắc Ninh.
Báo cáo tại buổi làm việc, Chủ tịch UBND tỉnh Bắc Ninh Phạm Hoàng Sơn cho biết tỉnh đang tập trung cao cho công tác giải phóng mặt bằng, tái định cư và triển khai thi công nhằm bảo đảm tiến độ các dự án phục vụ Hội nghị APEC 2027 cũng như tạo động lực phát triển kinh tế - xã hội trong giai đoạn tới.
Đối với dự án Cảng hàng không quốc tế Gia Bình, công trình có tổng diện tích khoảng 1.960 ha, tổng mức đầu tư hơn 196.000 tỷ đồng và được triển khai theo cơ chế đặc thù của Chính phủ. Đến nay, toàn bộ diện tích đất nông nghiệp thuộc dự án đã hoàn thành giải phóng mặt bằng.
Tuy nhiên, phần đất ở vẫn là khối lượng công việc lớn khi dự án cần di dời hơn 8.000 hộ dân để bố trí tái định cư. Riêng khu vực phục vụ Hội nghị APEC 2027 có 1.555 hộ dân thuộc 5 thôn của 2 xã Gia Bình và Lương Tài phải di dời sớm để bàn giao mặt bằng thi công.
Theo tỉnh Bắc Ninh, hiện đã có hơn 230 hộ dân đồng thuận nhận tiền và chuyển nơi ở mới; khoảng 94,6% hộ dân đăng ký bốc thăm vị trí lô đất tái định cư. Địa phương dự kiến bắt đầu tổ chức di dân từ ngày 31/5.

Vĩnh Long tăng tốc giải phóng mặt bằng Khu công nghiệp Ngũ Lạc 316ha

Ngày 21/5, Phó Chủ tịch UBND tỉnh Vĩnh Long Nguyễn Quỳnh Thiện chủ trì cuộc họp nghe báo cáo tình hình giải phóng mặt bằng thực hiện dự án Khu công nghiệp Ngũ Lạc - một trong những dự án công nghiệp quy mô lớn đang được địa phương thúc đẩy triển khai.
Dự án Khu công nghiệp Ngũ Lạc có tổng diện tích 316ha, nằm tại ấp Cây Da và ấp Cây Xoài, xã Ngũ Lạc, thuộc Khu kinh tế Định An. Chủ đầu tư dự án là Công ty Cổ phần Green i-Park Định An với tổng vốn đăng ký đầu tư khoảng 3.000 tỷ đồng.
Mục tiêu là xây dựng và kinh doanh hạ tầng khu công nghiệp theo quy hoạch được phê duyệt, góp phần thúc đẩy phát triển kinh tế - xã hội, tạo việc làm cho người dân địa phương.
Theo định hướng, Khu công nghiệp Ngũ Lạc sẽ thu hút các ngành công nghiệp phụ trợ, đóng tàu, cơ khí lắp ráp, công nghiệp sử dụng nhiều năng lượng, cùng các lĩnh vực công nghệ sinh học, vật liệu mới và tiểu thủ công nghiệp.
Khi đi vào hoạt động, dự án dự kiến tạo ra hơn 25.000 cơ hội việc làm, góp phần thúc đẩy chuyển dịch cơ cấu kinh tế theo hướng công nghiệp hóa, hiện đại hóa. Đây cũng là yếu tố thúc đẩy thị trường bất động sản Vĩnh Long phân khúc công nghiệp và phụ trợ gia tăng giá trị.

Tin vui cho người thu nhập thấp tại Khánh Hòa

Khánh Hòa hiện đang đẩy mạnh phát triển nhà ở xã hội nhằm đáp ứng nhu cầu an cư của người thu nhập thấp, công nhân và người lao động tại các khu công nghiệp.
Ông Nguyễn Văn Sinh, Thứ trưởng Bộ Xây dựng vừa có buổi làm việc với UBND tỉnh Khánh Hòa về phát triển nhà ở xã hội. Theo báo cáo của Sở Xây dựng tại buổi làm việc, giai đoạn 2026 - 2030, tỉnh Khánh Hòa được Chính phủ giao phát triển 10.088 căn nhà ở xã hội, trong đó năm 2026 là 3.200 căn.
UBND tỉnh Khánh Hòa đã giao chỉ tiêu năm 2026 là 3.251 căn cho các dự án đang triển khai. Tính đến tháng 5/2026, trên địa bàn tỉnh có 13 dự án nhà ở xã hội (gồm 2 dự án nhà ở cho lực lượng vũ trang) với tổng diện tích khoảng 114,40 ha, quy mô 19.447 căn hộ và tổng mức đầu tư khoảng 30.342 tỷ đồng.
Trong đó có 7 dự án đã khởi công, đang triển khai thi công xây dựng với khoảng 10.300 căn; 4 dự án đã được chấp thuận chủ trương đầu tư, giao chủ đầu tư nhưng chưa thi công với khoảng 5.356 căn; 2 dự án nhà ở cho lực lượng vũ trang với 3.791 căn.

Triển khai thực hiện Chương trình phát triển đô thị TP Cần Thơ đến năm 2030

UBND TP Cần Thơ vừa ban hành Công văn 2495/UBND-XDĐT yêu cầu triển khai thực hiện Chương trình phát triển đô thị TP Cần Thơ đến năm 2030, tầm nhìn đến năm 2045 của Thành ủy Cần Thơ.
Chương trình phát triển đô thị TP Cần Thơ đến năm 2030, tầm nhìn đến năm 2045 của Thành ủy Cần Thơ (Chương trình số 20-CTr/TU ngày 29-4-2026) xác định phấn đấu đến năm 2030: thành phố trở thành một cực tăng trưởng của quốc gia, giữ vai trò động lực phát triển, lan tỏa cả vùng. Là trung tâm của vùng về thương mại, du lịch logistics, kinh tế biển, công nghiệp chế biến, công nghệ chiến lược, nông nghiệp ứng dụng công nghệ cao, giáo dục và đào tạo, y tế chuyên sâu, trung tâm khởi nghiệp, khoa học công nghệ và đổi mới sáng tạo, phát triển văn hóa, thể thao; là đô thị hạt nhân của vùng ĐBSCL.
Tập trung nguồn lực phát triển một số ngành, lĩnh vực, địa bàn có vị trí địa lý, kết cấu hạ tầng kinh tế, xã hội, nguồn nhân lực chất lượng cao và các tiềm năng, lợi thế khác cho phát triển để hình thành các cực tăng trưởng, vùng động lực và hành lang kinh tế, tạo hiệu ứng lan tỏa, thúc đẩy kinh tế thành phố phát triển nhanh, hiệu quả, bền vững, chú trọng khai thác các hành lang kinh tế gắn với sông Hậu, cảng biển Trần Đề.
Đến năm 2045, xây dựng Cần Thơ trở thành đô thị sinh thái, văn minh, hiện đại; là trung tâm động lực phát triển của vùng ĐBSCL, phát triển theo hướng xanh, thông minh và thích ứng biến đổi khí hậu. Hệ thống hạ tầng đồng bộ, kinh tế đô thị dựa trên đổi mới sáng tạo, dịch vụ chất lượng cao và kinh tế số; chất lượng sống và môi trường đạt tiêu chuẩn cao, bản sắc văn hóa được bảo tồn và phát huy. Phấn đấu thuộc nhóm các thành phố phát triển khá của châu Á, trở thành thành phố đáng sống của Việt Nam.

Nguồn cung 10.500 căn nhà ở xã hội sắp đổ bộ thị trường TP.HCM

Chiều 21/5, Thường trực Thành ủy TP.HCM đã làm việc với Tập đoàn Đầu tư và Phát triển Công nghiệp Becamex về nhà ở, nhà lưu trú cho công nhân thuê trên địa bàn thành phố.
Tại buổi làm việc, đại diện Becamex cho biết, trong năm 2026, tập đoàn triển khai 6 dự án nhà ở xã hội với tổng quy mô gần 10.500 căn, phục vụ khoảng 31.000 người.
Cụ thể, đã thi công 2 dự án chung cư cao tầng là nhà ở xã hội Khu 6 Việt Sing (phường Thuận Giao) và nhà ở xã hội Khu 5 Định Hòa (phường Chánh Hiệp) với hơn 4.200 căn. 4 dự án còn lại: Khu 3 Định Hòa GĐ1, Khu 4 Định Hòa, Khu 2 Việt Sing, Khu 7 Việt Sing tại các phường Chánh Hiệp, Thuận Giao, An Phú, quy mô hơn 6.200 căn, dự kiến khởi công ngày 2/7 tới, nhân kỷ niệm 50 năm Thành phố Sài Gòn - Gia Định vinh dự mang tên Chủ tịch Hồ Chí Minh.
Trong giai đoạn tiếp theo, Becamex sẽ thực hiện các dự án nhà ở xã hội còn lại với tổng quy mô dự kiến hơn 34.000 căn hộ trên quỹ đất sạch gần 70 ha đã có hạ tầng, đáp ứng chỗ ở cho 100.000 người.
Theo Phó chủ tịch Thường trực Liên đoàn Lao động TP.HCM Võ Khắc Thái, qua rà soát đến giữa tháng 5, tổng nhu cầu thuê nhà ở xã hội trên địa bàn là 3.181 người, trong khi nhu cầu thuê mua và mua nhà ở xã hội lên tới 30.339 người.
Hoàng An

Bình luận

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

MB ghi dấu ấn với 5 giải thưởng Sao Khuê 2026

MB ghi dấu ấn với 5 giải thưởng Sao Khuê 2026

22:41 29/05/2026

(QK7 Online) - MB tiếp tục ghi dấu ấn trên hành trình chuyển đổi số với năm sản phẩm, giải pháp công nghệ được vinh danh trong Lễ trao Giải thưởng Sao Khuê 2026 diễn ra vào ngày 28/5 tại Hà Nội. Trong đó, nền tảng ngân hàng số dành cho doanh nghiệp BIZ MBBank lập “hat-trick” ấn tượng với ba giải thưởng dành cho sản phẩm số xuất sắc được xếp hạng trên trên Bản đồ Giải pháp Công nghệ số Việt Nam 2026.

Khẳng định vai trò, vị thế và đóng góp ngày càng quan trọng của Việt Nam

Khẳng định vai trò, vị thế và đóng góp ngày càng quan trọng của Việt Nam

09:41 26/05/2026

Tổng Bí thư, Chủ tịch nước Tô Lâm sẽ thăm cấp Nhà nước tới Singapore từ ngày 29 đến 31-5, tham dự và phát biểu dẫn đề tại Đối thoại Shangri-La ngày 29-5. Trước thềm chuyến công tác, đồng chí Nguyễn Mạnh Cường, Ủy viên Trung ương Đảng, Thứ trưởng Bộ Ngoại giao đã trả lời phỏng vấn báo chí.

Bộ Chính trị ban hành Nghị quyết về xây dựng và phát triển TP.HCM trong kỷ nguyên mới

Bộ 99Oke123 Tải ứng dụng ban hành 99Oke được xếp hạng cao nhất về xây dựng và phát triển TP.HCM trong kỷ nguyên mới

22:42 24/05/2026

(QK7 Online) - 99Oke được xếp hạng cao nhất 09 - NQ/TW của Bộ 99Oke123 Tải ứng dụng về xây dựng và phát triển TP.HCM trong kỷ nguyên mới do Tổng Bí thư, Chủ tịch nước Tô Lâm ký ban hành nhấn mạnh trong kỷ nguyên phát triển mới, TP.HCM cần phát huy vai trò là một đô thị đặc biệt; tiên phong mở đường về mô hình phát triển, thể chế và phương thức quản trị hiện đại; tạo sức lan tỏa mạnh mẽ, đóng góp ngày càng lớn cho sự phát triển nhanh, bền vững của đất nước.

MB mở rộng dấu ấn tại Nghệ An, đồng hành phát triển kinh tế và an sinh xã hội địa phương

MB mở rộng dấu ấn tại Nghệ An, đồng hành phát triển kinh tế và an sinh xã hội địa phương

23:29 23/05/2026

(QK7 Online) - Ngân hàng TMCP Quân đội (MB) chính thức khai trương chi nhánh MB Bắc Nghệ An tại số 228 Đại lộ V.I. Lê Nin, phường Vinh Phú, tỉnh Nghệ An. Sự kiện tiếp tục khẳng định định hướng mở rộng mạng lưới của MB, đồng thời nâng cao năng lực cung cấp các giải pháp tài chính toàn diện, hiện đại tới khách hàng cá nhân, doanh nghiệp và các tổ chức trên địa bàn.

Đồng Nai công bố giá đất biệt thự Aqua Dona 17 triệu/m2

Đồng Nai công bố giá đất biệt thự Aqua Dona 17 triệu/m2

18:00 22/05/2026

UBND Thành phố Đồng Nai vừa chính thức ban hành Quyết định số 171/QĐ-UBND phê duyệt giá đất cụ thể để tính tiền sử dụng đất và tiền thuê đất cho Công ty TNHH Thành phố Aqua Dona thực hiện dự án Aqua Dona tại phường Long Hưng, TP. Biên Hòa. Mức giá đất cụ thể cao nhất ghi nhận cho loại hình đất ở biệt thự sau điều chỉnh là hơn 17,4 triệu đồng/m².

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