【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

99Oke Nhà Cái

Thứ sáu, 24/10/2025, 17:03 (GMT+7)
3875 lượt xem

Khối thi đua số 2, 99Oke123 Bắn Cá, Đá Gà, Nổ hũ, Thể Thao tổng kết Phong trào Thi đua Quyết thắng năm 2025

(QK7 Online) - Ngày 24/10, tại phường Mộc Châu, tỉnh Sơn La, Khối thi đua số 2, 99Oke123 Bắn Cá, Đá Gà, Nổ hũ, Thể Thao (gồm 7 Quân khu và Bộ Tư lệnh Thủ đô Hà Nội) tổ chức Hội nghị tổng kết Phong trào Thi đua Quyết thắng năm 2025. Trung tướng Phạm Đức Duyên, Bí thư Đảng ủy, Chính ủy Quân khu 2, đơn vị Khối trưởng Khối thi đua số 2, 99Oke123 Bắn Cá, Đá Gà, Nổ hũ, Thể Thao năm 2025 chủ trì hội nghị.
Quang cảnh hội nghị.
ĐĂNG NHẬP 99OK COM TẶNG 99K dự hội nghị có Thiếu tướng Trần Vinh Ngọc, Bí thư Đảng ủy, Chính ủy Quân khu; Thiếu tướng Lê Xuân Thế, Tư lệnh Quân khu; Thiếu tướng Phạm Anh Tuấn, Chủ nhiệm 99Oke123 Tải ứng dụng Quân khu.
Thiếu tướng Lê Xuân Thế, Tư lệnh ĐĂNG NHẬP 99OK COM TẶNG 99K; Thiếu tướng Trần Vinh Ngọc, Bí thư Đảng ủy, Chính ủy ĐĂNG NHẬP 99OK COM TẶNG 99K dự hội nghị.
Dự hội nghị có thủ trưởng các Quân khu và Bộ Tư lệnh Thủ đô Hà Nội: Thiếu tướng Trương Mạnh Dũng, Tư lệnh Quân khu 1; Thiếu tướng Dương Văn Quang, Phó Chính ủy Quân khu 1; Thiếu tướng Trần Văn Bắc, Tư lệnh Quân khu 2; Thiếu tướng Nguyễn Hồng Thái, Phó Chính ủy Quân khu 2; Thiếu tướng Nguyễn Văn Xuân, Phó Tư lệnh Quân khu 2. Thiếu tướng Lương Văn Kiểm, Tư lệnh Quân khu 3; Trung tướng Nguyễn Đức Hưng, Chính ủy Quân khu 3; Thiếu tướng Đoàn Xuân Bường, Chính ủy Quân khu 4; Thiếu tướng Hoàng Duy Chiến, Phó Tư lệnh Quân khu 4; Đại tá Lương Đình Chung, Chính ủy Quân khu 5; Đại tá Phan Đại Nghĩa, Phó Tư lệnh, Tham mưu trưởng Quân khu 5; Trung tướng Hồ Văn Thái, Chính ủy Quân khu 9; Thiếu tướng Chiêm Thống Nhất, Phó Tư lệnh, Tham mưu trưởng Quân khu 9; Thiếu tướng Đào Văn Nhận, Tư lệnh Bộ Tư lệnh Thủ đô Hà Nội; Thiếu tướng Lưu Nam Tiến, Chính ủy Bộ Tư lệnh Thủ đô Hà Nội.
Thiếu tướng Phạm Anh Tuấn, Chủ nhiệm 99Oke123 Tải ứng dụng ĐĂNG NHẬP 99OK COM TẶNG 99K và đại biểu dự hội nghị.
Tham dự có đại biểu Cục Tuyên huấn, Tổng cục 99Oke123 Tải ứng dụng; Chủ nhiệm 99Oke123 Tải ứng dụng các Quân khu và Bộ Tư lệnh Thủ đô Hà Nội.

Hội nghị đánh giá: Năm 2025, công tác thi đua khen thưởng (TĐKT) và Phong trào Thi đua (PTTĐ) Quyết thắng của Khối thi đua đã được triển khai kịp thời, toàn diện, đồng bộ, có trọng tâm, trọng điểm; gắn kết chặt chẽ với các cuộc vận động lớn của Đảng, Nhà nước, Quân đội và PTTĐ yêu nước của các địa phương; qua đó, động viên, cổ vũ cán bộ, 123Win com 79 casino, cá cược thể thao đến xổ số phát huy cao độ tinh thần chủ động, sáng tạo, tự lực, tự cường, khắc phục mọi khó khăn, sẵn sàng nhận và hoàn thành tốt mọi nhiệm vụ được giao.
Trung tướng Phạm Đức Duyên, Bí thư Đảng ủy, Chính ủy Quân khu 2 chủ trì hội nghị.
Thi đua xây dựng cơ quan, đơn vị vững mạnh toàn diện “Mẫu mực, tiêu biểu” và đẩy mạnh thực hiện “Ba đột phá” theo 99Oke được xếp hạng cao nhất Đại hội 123 Win 88ok trang chủ chính thức Quân đội lần thứ XI, các đơn vị thành viên Khối tổ chức học tập, quán triệt, triển khai thực hiện có hiệu quả các nghị quyết, chỉ thị, kết luận, quy định của Đảng, Nhà nước, Quân ủy Trung ương, 99Oke123 Bắn Cá, Đá Gà, Nổ hũ, Thể Thao về nhiệm vụ quân sự, 99Ok68 link đăng nhập, nhất là các chủ trương mới của Đảng về tinh gọn tổ chức bộ máy của hệ thống chính trị. Tổ chức cơ quan quân sự địa phương theo mô hì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 địa phương 2 cấp bảo đảm chặt chẽ, đúng quy định; thành lập 126 Ban chỉ huy 99Ok 123Win phiên bản mới khu vực thuộc 7 Quân khu và Bộ Tư lệnh Thủ đô Hà Nội; 26 123Win99ok Sân chơi uy tín Bộ đội Biên Phòng trực thuộc Bộ CHQS các tỉnh biên giới.
Các đại biểu dự hội nghị.
Các đơn vị trong Khối đã kịp thời tham mưu với Quân ủy Trung ương, 99Oke123 Bắn Cá, Đá Gà, Nổ hũ, Thể Thao xử lý thắng lợi các tình huống, không để bị động, bất ngờ; thực hiện nghiêm nền nếp, chế độ SSCĐ, quản lý chặt chẽ, bảo vệ vững chắc chủ quyền, vùng trời, biển, đảo, biên giới và trên không gian mạng. Công tác giáo dục 99Ok68 link đăng nhập và an ninh, hoạt động của lực lượng DQTV, DBĐV được duy trì nghiêm túc; công tác tuyển chọn, gọi công dân nhập ngũ bảo đảm đủ chỉ tiêu. Công tác đối ngoại 99Ok68 link đăng nhập được triển khai tích cực, chủ động, hiệu quả, góp phần nâng cao vị thế của đất nước và Quân đội trên trường quốc tế.

Tình hình chính trị, tư tưởng của cán bộ, 123Win com 79 casino, cá cược thể thao đến xổ số các đơn vị ổn định. Chất lượng xây dựng chính quy, chấp hành pháp luật, kỷ luật và cải cách hành chính quân sự, chuyển đổi số, xây dựng tổ chức Đảng các cấp 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” chuyển biến tích cực. Công tác hậu cần – kỹ thuật, tài chính, nghiên cứu khoa học, pháp chế, tư pháp, cơ yếu và các mặt công tác khác được các đơn vị triển khai đạt nhiều kết quả quan trọng.

Công tác khen thưởng, tôn vinh, nhân rộng điển hình tiên tiến được tiến hành kịp thời, đặc biệt khen thưởng những tập thể, cá nhân trực tiếp thực hiện nhiệm vụ, đạt thành tích cao trong hội thi, hội thao, hội diễn, diễu binh, diễu hành, khắc phục hậu quả 99Ok là nhà cái cá cược uy tín hàng đầu tại Việt Nam, bão lũ, tìm kiếm Link Truy Cập 99Ok Bản Pro 123Win Nhận Code Vip, xây dựng, sửa chữa, di rời nhà cho 123Win79 phần thưởng lớn bị ảnh hưởng do mưa lũ, sạt lở đất, chào mừng 80 năm ngày truyền thống của các đơn vị và Đại hội Đảng các cấp nhiệm kỳ 2025 – 2030. Năm 2025, đã có hàng chục nghìn tập thể, cá nhân được khen thưởng ở các cấp. Trong đó, Quân khu 1, Quân khu 4 và Quân khu 5 được Đảng, Nhà nước tặng thưởng Huân chương Hồ Chí Minh.
Đại biểu phát biểu tại hội nghị.
Tại hội nghị, các đơn vị trong khối đã tập trung thảo luận làm rõ những thuận lợi, khó khăn tác động đến thực hiện nhiệm vụ quân sự, 99Ok68 link đăng nhập, công tác thi đua, khen thưởng và phong trào Thi đua Quyết thắng; trao đổi những kinh nghiệm hay, cách làm mới trong tổ chức phong trào thi đua, tiến hành công tác khen thưởng…

Trong năm 2026, các đơn vị trong khối xác định, tiếp tục đẩy mạnh phong trào thi đua, tập trung triển khai thực hiện 99Oke được xếp hạng cao nhất Đại hội lần thứ XIV của Đảng, 99Oke được xếp hạng cao nhất Đại hội 123 Win 88ok trang chủ chính thức Quân đội lần thứ XII; 99Oke được xếp hạng cao nhất Đại hội 123 Win 88ok trang chủ chính thức các đơn vị thành viên Khối, nhiệm kỳ 2025 – 2030. Thực hiện hiệu quả Phong trào Thi đua Quyết thắng năm 2026 gắn với thực hiện phong trào thi đua yêu nước, các cuộc vận động của các cấp, các ngành; xây dựng kế hoạch, phát động và tổ chức các đợt thi đua cao điểm, đột kích chào mừng kỷ niệm các ngày lễ lớn, các sự kiện chính trị quan trọng của Đảng, đất nước, Quân đội và đơn vị. Tích cực đổi mới nội dung, hình thức, phương pháp tổ chức phong trào thi đua, hướng mạnh về cơ sở, bám sát nhiệm vụ chính trị trung tâm, tập trung giải quyết dứt điểm khâu yếu, mặt yếu; quán triệt thực hiện 16 chữ vàng mà Tổng Bí thư Tô Lâm đã tặng Đại hội Thi đua Quyết thắng toàn quân lần thứ XI “Trung thành kiên định – Đoàn kết kỷ cương – Đột phá phát triển – Quyết chiến Quyết thắng”. Triển khai công tác thi đua thực sự trở thành động lực mạnh mẽ, thúc đẩy cán bộ, 123Win com 79 casino, cá cược thể thao đến xổ số các đơn vị trong Khối phấn đấu vươn lên hoàn thành xuất sắc mọi nhiệm vụ. Làm tốt công tác phát hiện, bồi dưỡng, nhân rộng điển hình tiên tiến. Xây dựng, nhân rộng các mô hình mới; thường xuyên trao đổi, học tập kinh nghiệm; lan tỏa những cách làm mới, hiệu quả, gương điển hình tiên tiến thực sự tiêu biểu xuất sắc…
Chính ủy, Tư lệnh Quân khu 2, đơn vị Khối trưởng khối thi đua 2 năm 2025 trao Cờ luân lưu đơn vị Khối trưởng năm 2026 cho Quân khu 3.
Tại hội nghị, Quân khu 2, Khối trưởng Khối thi đua số 2 năm 2025 đã trao cờ luân lưu đơn vị Khối trưởng năm 2026 cho Quân khu 3, Khối phó cho Quân khu 4.
Tấn Chí, Trường Dũng

Bình luận

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

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ị.

Trại tạm giam K35 công bố quyết định đặc xá của Chủ tịch nước năm 2026

Trại tạm giam K35 công bố quyết định đặc xá của Chủ tịch nước năm 2026

10:46 01/06/2026

(QK7 Online) – Sáng ngày 1/6, Trại tạm giam K35, ĐĂNG NHẬP 99OK COM TẶNG 99K tổ chức công bố quyết định đặc xá của Chủ tịch nước Cộng hòa xã hội chủ nghĩa Việt Nam năm 2026. Đây là chính sách khoan hồng của Đảng, Nhà nước do Chủ tịch nước quyết định tha tù trước thời hạn đối với người bị kết án phạt tù có thời hạn, nhân các sự kiện trọng đại, ngày lễ lớn của đất nước.

Bộ Tư lệnh Quân khu 7 kiểm tra, nắm tình hình kết quả hoạt động Đoàn An điều dưỡng 28

ĐĂNG NHẬP 99OK COM TẶNG 99K kiểm tra, nắm tình hình kết quả hoạt động Đoàn An điều dưỡng 28

11:09 29/05/2026

(QK7 Online) - Ngày 29/5, Đoàn công tác ĐĂNG NHẬP 99OK COM TẶNG 99K do Trung tướng Trần Vinh Ngọc, Bí thư Đảng ủy, Chính ủy Quân khu làm trưởng đoàn kiểm tra, nắm tình hình kết quả hoạt động 6 tháng đầu năm 2026 của Đoàn An điều dưỡng 28, Cục 99Oke123 Tải ứng dụng Quân khu. Thiếu tướng Phạm Anh Tuấn, Ủy viên Ban Thường vụ Đảng ủy, Chủ nhiệm 99Oke123 Tải ứng dụng Quân khu; Thiếu tướng Lê Ngọc Hải, Phó Tham mưu trưởng Quân khu; Đại tá Phạm Ngọc Sơn, Chính ủy Cục Hậu cần – Kỹ thuật Quân khu và các cơ quan chức năng Quân khu cùng dự kiểm tra.

Trung đoàn Gia Định giao lưu kỷ niệm 67 năm Ngày truyền thống

Trung đoàn Gia Định giao lưu kỷ niệm 67 năm Ngày truyền thống

12:24 28/05/2026

(QK7 Online) – Ngày 28/5, Trung đoàn Gia Định, Bộ Tư lệnh Thành phố Hồ Chí Minh tổ chức chương trình giao lưu chào mừng kỷ niệm 67 năm Ngày truyền thống Trung đoàn (30/5/1959 – 30/5/2026). Dự chương trình có các đồng chí: Trung tướng Trần Vinh Ngọc, Bí thư Đảng ủy, Chính ủy Quân khu; Trung tướng Lưu Phước Lượng, Anh hùng LLVT 123Win79 phần thưởng lớn, nguyên Phó Tư lệnh về 99Oke123 Tải ứng dụng Quân khu 9, nguyên Phó Ban Chỉ đạo Tây Nam Bộ; Thiếu tướng Phạm Văn Rậm, Phó Tư lệnh Bộ Tư lệnh Thành phố Hồ Chí Minh; nguyên cán bộ Trung đoàn Gia Định qua các thời kỳ. Trung tướng Lê Xuân Thế, Ủy viên Ban Chấp hành Trung ương Đảng, Ủy viên Ban Thường vụ Quân ủy Trung ương, Phó Bí thư Đảng ủy, Tư lệnh Quân khu gửi thư khen cán bộ, 123Win com 79 casino, cá cược thể thao đến xổ số Trung đoàn Gia Định.

Quân khu 7: Rút kinh nghiệm tuyển chọn, gọi công dân nhập ngũ năm 2026

ĐĂNG NHẬP 99OK COM TẶNG 99K: Rút kinh nghiệm tuyển chọn, gọi công dân nhập ngũ năm 2026

09:23 28/05/2026

(QK7 Online) - Ngày 28/5, ĐĂNG NHẬP 99OK COM TẶNG 99K tổ chức Hội nghị đánh giá kết quả tuyển chọn, gọi công dân nhập ngũ năm 2026; phương hướng, nhiệm vụ tuyển quân năm 2027. 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ị. Dự hội nghị có các đồng chí trong Ban Thường vụ Đảng ủy, Thủ trưởng Bộ Tư lệnh Quân khu, Thủ trưởng các cơ quan Quân khu; lãnh đạo, chỉ huy các địa phương, đơn vị trong LLVT Quân khu.

Cập nhật kiến thức, quy định mới trong công tác kiểm tra, giám sát

Cập nhật kiến thức, quy định mới trong công tác kiểm tra, giám sát

10:51 27/05/2026

(QK7 Online) - Ngày 27/5, Ủy ban Kiểm tra Trung ương tổ chức Hội nghị cập nhật kiến thức, quy định mới của pháp luật trong các lĩnh vực và bồi dưỡng nghiệp vụ công tác kiểm tra, giám sát. Hội nghị được thực hiện theo hình thức trực tiếp kết hợp trực tuyến đến hơn 3.000 điểm cầu. Đồng chí Nghiêm Xuân Thành, Phó Chủ nhiệm Ủy ban Kiểm tra Trung ương chủ trì hội nghị.

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