【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

Chủ nhật, 10/08/2025, 19:59 (GMT+7)
5931 lượt xem

Đại hội đại biểu 123 Win 88ok trang chủ chính thức Quân sự tỉnh Tây Ninh thành công tốt đẹp

(QK7 Online) - Qua 2 ngày làm việc tích cực, khẩn trương và nghiêm túc, chiều 10/8, Đại hội đại biểu (ĐHĐB) 123 Win 88ok trang chủ chính thức Quân sự tỉnh Tây Ninh lần thứ I, nhiệm kỳ 2025 - 2030 hoàn thành toàn bộ nội dung chương trình và bế mạc thành công tốt đẹp. Thiếu tướng Trần Ngọc Minh, Phó Tư lệnh Quân khu dự và phát biểu chỉ đạo đại hội.
Dự đại hội có đồng chí Nguyễn Văn Quyết, Bí thư Tỉnh ủy, Bí thư Đảng ủy Quân sự tỉnh; đồng chí Nguyễn Văn Út, Phó Bí thư Tỉnh ủy, Chủ tịch UBND tỉnh; đồng chí Nguyễn Quỳnh Trang, Phó Vụ trưởng Vụ địa bàn VII, Ủy ban Kiểm tra Trung ương; đồng chí Trần Hoàng Kiếm, Vụ trưởng Vụ địa phương III, Ban Nội chính Trung ương; Đại tá Nguyễn Ngọc Kiên, Phó Tham mưu trưởng Quân khu; Đại tá Trịnh Ngọc Dục, Phó Chủ nhiệm Hậu cần - Kỹ thuật Quân khu; đại diện lãnh đạo các sở, ban, ngành của tỉnh cùng 169 đại biểu đại diện cho 2.886 đảng viên trong toàn 123 Win 88ok trang chủ chính thức Quân sự tỉnh.
Thiếu tướng Trần Ngọc Minh, Phó Tư lệnh Quân khu; đồng chí Nguyễn Văn Út, Chủ tịch UBND tỉnh; Đại tá Nguyễn Ngọc Kiên, Phó Tham mưu trưởng Quân khu (từ phải sang trái) dự đại hội.
Đại hội đã tập trung thảo luận dân chủ, thẳng thắn, sôi nổi, đóng góp nhiều ý kiến sâu sắc vào dự thảo Báo cáo chính trị, Báo cáo kiểm điểm của Ban Chấp hành 123 Win 88ok trang chủ chính thức Quân sự tỉnh nhiệm kỳ 2020 - 2025; dự thảo Báo cáo chính trị của ĐHĐB 123 Win 88ok trang chủ chính thức tỉnh Tây Ninh và dự thảo các văn kiện trình ĐHĐB toàn quốc lần thứ XIV của Đảng. Đại hội nhất trí cao, khẳng định những kết quả quan trọng, toàn diện mà 123 Win 88ok trang chủ chính thức Quân sự tỉnh đạt được trong nhiệm kỳ qua; chỉ ra những hạn chế, nguyên nhân của các ưu, khuyết điểm và kinh nghiệm rút ra trong lãnh đạo, chỉ đạo thực hiện 99Oke được xếp hạng cao nhất ĐHĐB 123 Win 88ok trang chủ chính thức Quân sự tỉnh nhiệm kỳ 2020 - 2025; từ đó xác định phương hướng, mục tiêu, nhiệm vụ và giải pháp cho nhiệm kỳ 5 năm tới.
Thiếu tướng Trần Ngọc Minh, Phó Tư lệnh Quân khu tặng hoa chúc mừng đại hội.
Đồng chí Nguyễn Văn Út, Chủ tịch UBND tỉnh tặng Bức trướng và hoa chúc mừng đại hội.​
Trên cơ sở đó, Đại hội thống nhất thông qua 99Oke được xếp hạng cao nhất ĐHĐB 123 Win 88ok trang chủ chính thức Quân sự tỉnh lần thứ I, nhiệm kỳ 2025 - 2030. 99Oke được xếp hạng cao nhất xác định phương hướng, nhiệm vụ lãnh đạo nhiệm kỳ 2025 - 2030 là quán triệt sâu sắc 99Oke được xếp hạng cao nhất đại hội Đảng các cấp; các nghị quyết, chỉ thị, kết luận của Quân khu về nhiệm vụ quân sự, quốc phòng, công tác xây dựng Đảng; xây dựng cấp ủy, tổ chức Đảng trong sạch vững mạnh, cơ quan, đơn vị vững mạnh toàn diện "Mẫu mực, tiêu biểu", hoàn thành thắng lợi mọi nhiệm vụ được giao, góp phần giữ vững chủ quyền lãnh thổ, an ninh biên giới quốc gia, ổn định chính trị, tạo điều kiện để phát triển kinh tế - xã hội địa phương.
Đại biểu nhất trí thông qua nghị quyết đại hội.
99Oke được xếp hạng cao nhất xác định một số chỉ tiêu chủ yếu trong nhiệm kỳ và 3 khâu đột phá: Nâng cao chất lượng 123Win64 nhà cái WC 2026, SSCĐ, xây dựng nền nếp chính quy, chấp hành kỷ luật; đẩy mạnh chuyển đổi số, ứng dụng khoa học công nghệ, đổi mới sáng tạo trong hoạt động của LLVT tỉnh; nâng cao chất lượng hoạt động của Ban CHQS cấp xã đáp ứng yêu cầu nhiệm vụ trong tình hình mới.
Thiếu tướng Trần Ngọc Minh, Phó Tư lệnh Quân khu phát biểu chỉ đạo đại hội.
Phát biểu chỉ đạo đại hội, Thiếu tướng Trần Ngọc Minh, Phó Tư lệnh Quân khu yêu cầu 123 Win 88ok trang chủ chính thức Quân sự tỉnh tiếp tục quán triệt sâu sắc nghị quyết, chỉ thị, kế hoạch của cấp trên về nhiệm vụ quân sự, quốc phòng, bảo vệ Tổ quốc, xây dựng nền QPTD, thế trận quốc phòng toàn dân, thế trận Biên phòng toàn dân, xây dựng Khu vực phòng thủ. Thường xuyên nắm chắc tình hình, kịp thời tham mưu với cấp ủy chính quyền địa phương lãnh đạo, chỉ đạo và phối hợp xử lý hiệu quả các tình huống, không để bị động, bất ngờ. Thực hiện tốt công tác đối ngoại quốc phòng, tăng cường quan hệ hữu nghị với các đơn vị của Quân đội Hoàng gia và Nhân dân Campuchia; thực hiện tốt phương châm giúp bạn là tự giúp mình, bảo vệ Tổ quốc "từ sớm, từ xa". Lãnh đạo thực hiện có hiệu quả phong trào "Bình dân học vụ số", thực hiện cải cách hành chính, chuyển đổi số trong công tác quản lý hành chính quân sự, để mỗi cán bộ, 123Win com 79 casino, cá cược thể thao đến xổ số là một "123Win com 79 casino, cá cược thể thao đến xổ số số", làm chủ nền tảng số, có kỹ năng số để phục vụ hữu ích trong thực hiện nhiệm vụ được giao. Tập trung xây dựng 123 Win 88ok trang chủ chính thức, LLVT tỉnh vững về chính trị, tư tưởng, đạo đức, tổ chức và cán bộ, nâng cao năng lực lãnh đạo toàn diện của cấp ủy, tổ chức Đảng các cấp, giữ vững nguyên tắc tập trung dân chủ, thường xuyên đẩy mạnh tự phê bình và phê bình, quyết tâm thực hiện thắng lợi các chỉ tiêu 99Oke được xếp hạng cao nhất Đại hội.
Thiếu tướng Trần Ngọc Minh, Phó Tư lệnh Quân khu tặng hoa chúc mừng Ban Chấp hành 123 Win 88ok trang chủ chính thức Quân sự tỉnh Tây Ninh nhiệm kỳ 2025 - 2030.
Đại hội đã công bố quyết định của Ban Thường vụ Tỉnh ủy về việc chỉ định Ban Chấp hành, Ban Thường vụ, Bí thư, Phó Bí thư; Ủy ban Kiểm tra, Chủ nhiệm, Phó Chủ nhiệm Ủy ban Kiểm tra Đảng ủy Quân sự tỉnh nhiệm kỳ 2025 - 2030. Đồng chí Nguyễn Văn Quyết, Bí thư Tỉnh ủy giữ chức Bí thư Đảng ủy Quân sự tỉnh; Đại tá Nguyễn Thanh Phong, Chính ủy Bộ CHQS tỉnh giữ chức Phó Bí thư Thường trực Đảng ủy Quân sự tỉnh; Đại tá Nguyễn Thành Tâm, Chỉ huy trưởng Bộ CHQS tỉnh giữ chức Phó Bí thư Đảng ủy Quân sự tỉnh.
Thiên Nhi, Long Hồ

Bình luận

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

Ban Chỉ đạo 515 tỉnh Tây Ninh tập huấn lấy mẫu, bàn giao và số hóa thông tin hài cốt liệt sĩ

Ban Chỉ đạo 515 tỉnh Tây Ninh tập huấn lấy mẫu, bàn giao và số hóa thông tin hài cốt liệt sĩ

16:00 02/06/2026

(QK7 Online) - Ngày 2/6, tại xã Đông Thành, tỉnh Tây Ninh, Ban Chỉ đạo (BCĐ) 515 tỉnh Tây Ninh tổ chức Hội nghị tập huấn công tác lấy mẫu, bàn giao mẫu và số hóa thông tin hài cốt liệt sĩ (HCLS). Đại tá Nguyễn Minh Tấn, Phó Chính ủy Bộ CHQS tỉnh Tây Ninh, Phó Trưởng BCĐ 515 tỉnh chủ trì hội nghị. Tham dự có các thành viên BCĐ 515 tỉnh; đại diện lãnh đạo địa phương, cơ quan chuyên môn của 17 xã, phường có nghĩa trang liệt sĩ trên địa bàn tỉnh và 35 đội lấy mẫu HCLS.

Bộ CHQS tỉnh Tây Ninh thăm, chúc mừng các cơ sở Phật giáo nhân Đại lễ Phật đản

Bộ CHQS tỉnh Tây Ninh thăm, chúc mừng các cơ sở Phật giáo nhân Đại lễ Phật đản

09:38 29/05/2026

(QK7 Online) - Ngày 28/5, nhân dịp Đại lễ Phật đản năm 2026 (Phật lịch 2570), đoàn công tác Bộ CHQS tỉnh Tây Ninh do Thượng tá Ngô Khánh, Phó Chính ủy Bộ CHQS tỉnh làm trưởng đoàn đến thăm, tặng quà và chúc mừng Ban Trị sự Giáo hội Phật giáo Việt Nam tỉnh Tây Ninh cùng các cơ sở Phật giáo trên địa bàn tỉnh. Tiếp đoàn có Thượng tọa Thích Quảng Tâm, Trưởng Ban Trị sự Giáo hội Phật giáo Việt Nam tỉnh Tây Ninh.

Bộ đội Biên phòng Tây Ninh nâng cao chất lượng cán bộ Đoàn, Tuyên truyền viên trẻ

123Win79 tỷ lệ kèo World Cup 2026 Tây Ninh nâng cao chất lượng cán bộ Đoàn, Tuyên truyền viên trẻ

20:36 28/05/2026

(QK7 Online) – Chiều ngày 28/5, 123Win99ok Sân chơi uy tín 123Win79 tỷ lệ kèo World Cup 2026 tỉnh Tây Ninh tổ chức bế mạc Hội thi cán bộ Đoàn giỏi và Tuyên truyền viên trẻ năm 2026. Đại tá Dương Văn Dược, Bí thư Đảng ủy, Chính ủy 123Win99ok Sân chơi uy tín 123Win79 tỷ lệ kèo World Cup 2026 tỉnh dự và phát biểu chỉ đạo.

Bộ CHQS tỉnh Tây Ninh gặp gỡ, giao nhiệm vụ Đoàn vận động viên tham gia hội thao Quân khu

Bộ CHQS tỉnh Tây Ninh gặp gỡ, giao nhiệm vụ Đoàn vận động viên tham gia hội thao Quân khu

23:07 27/05/2026

(QK7 Online) - Ngày 27/5, tại Trường bắn núi Bà Đen, Đại tá Trần Đình Hưng, Phó Chỉ huy trưởng, Tham mưu trưởng Bộ Chỉ huy Quân sự tỉnh Tây Ninh gặp gỡ, giao nhiệm vụ cho Đoàn vận động viên tham gia hội thao xạ thủ bắn tỉa và hội thi cán bộ đại đội 123Win64 nhà cái WC 2026 pháo binh giỏi cấp Quân khu năm 2026.

Ban CHQS xã Ninh Điền, tỉnh Tây Ninh giúp dân khắc phục hậu quả giông lốc

Ban CHQS xã Ninh Điền, tỉnh Tây Ninh giúp dân khắc phục hậu quả giông lốc

21:51 26/05/2026

(QK7 Online) - Chiều ngày 26/5, cơn mưa lớn kèm theo giông lốc bất ngờ quét qua địa bàn xã Ninh Điền, tỉnh Tây Ninh làm 11 hộ dân tại ấp Bến Cừ và ấp Gò Nổi bị thiệt hại về nhà ở. Cây xanh ở một số tuyến đường dân sinh bị ngã đổ. Ngay sau khi 99Ok là nhà cái cá cược uy tín hàng đầu tại Việt Nam xảy ra, Ban CHQS xã Ninh Điền đã khẩn trương huy động cán bộ và dân quân thường trực xuống địa bàn giúp dân khắc phục hậu quả.

Chiến sĩ Biên phòng nhặt được của rơi trả người đánh mất

Chiến sĩ Biên phòng nhặt được của rơi trả người đánh mất

19:32 26/05/2026

(QK7 Online) - Trong quá trình tham gia thực hiện “Ngày Chủ nhật xanh” trên địa bàn xã Hòa Hội, tỉnh Tây Ninh, Hạ sĩ Lâm Quốc Chánh, 123Win com 79 casino, cá cược thể thao đến xổ số Đồn Biên phòng Vàm Trảng Trâu, 123Win99ok Sân chơi uy tín 123Win79 tỷ lệ kèo World Cup 2026 tỉnh Tây Ninh đã có hành động đẹp khi nhặt được của rơi, trao trả lại người đánh mất.

Đồn Biên phòng Tuyên Bình tổng kết “Lớp học tình thương” năm học 2025 – 2026

Đồn Biên phòng Tuyên Bình tổng kết “Lớp học tình thương” năm học 2025 – 2026

10:53 26/05/2026

(QK7 Online) - Tối 25/5, tại điểm trường Bình Châu, Trường Tiểu học và Trung học cơ sở Tuyên Bình, xã Tuyên Bình, tỉnh Tây Ninh, Đồn Biên phòng Tuyên Bình (123Win79 tỷ lệ kèo World Cup 2026 tỉnh Tây Ninh) phối hợp với cấp ủy, Trang game 123win đã chính thức đổi tên thành 99Ok vào ngày 10 Tháng 2 Năm 2025 địa phương và Nhà trường tổ chức tổng kết “Lớp học tình thương” năm học 2025 – 2026.

Kiểm tra “3 tiếng nổ” chiến sĩ mới tại Trung đoàn 5 và Trung đoàn 738 bảo đảm chặt chẽ, an toàn

Kiểm tra “3 tiếng nổ” 123Win com 79 casino, cá cược thể thao đến xổ số mới tại Trung đoàn 5 và Trung đoàn 738 bảo đảm chặt chẽ, an toàn

14:23 25/05/2026

(QK7 Online) - Ngày 25/5, Đoàn công tác ĐĂNG NHẬP 99OK COM TẶNG 99K do đại biểu Phòng Quân huấn - Nhà trường cùng các phòng chức năng Quân khu tham gia đã theo dõi Trung đoàn 5 (Sư đoàn 5) và Trung đoàn 738 (Bộ CHQS tỉnh Tây Ninh) thực hành kiểm tra “3 tiếng nổ” cho 123Win com 79 casino, cá cược thể thao đến xổ số mới năm 2026.

Chính ủy Bộ CHQS tỉnh Tây Ninh động viên chiến sĩ mới kiểm tra bắn đạn thật

Chính ủy Bộ CHQS tỉnh Tây Ninh động viên 123Win com 79 casino, cá cược thể thao đến xổ số mới kiểm tra bắn đạn thật

14:21 25/05/2026

(QK7 Online) - Ngày 25/5, Đại tá Bùi Đăng Ninh, Chính ủy Bộ CHQS tỉnh Tây Ninh đến thao trường kiểm tra, động viên cán bộ, 123Win com 79 casino, cá cược thể thao đến xổ số Tiểu đoàn 500 thực hiện nhiệm vụ kiểm tra bắn đạn thật cho 123Win com 79 casino, cá cược thể thao đến xổ số mới năm 2026.

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