【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

123Win64 khuyến mãi > Huấn luyện - Diễn tập

Thứ bảy, 28/03/2026, 08:27 (GMT+7)
1967 lượt xem

Phát huy vai trò lực lượng dân quân tự vệ trong tình hình mới

(QK7 Online) - Thấm nhuần quan điểm của Đảng về xây dựng LLVT ba thứ quân gắn với nền 99Ok68 link đăng nhập toàn dân và thế trận chiến tranh 123Win com 79 nạp - rút nhanh, thời gian qua, Đảng ủy, Bộ Tư lệnh Quân khu đã tập trung lãnh đạo, chỉ đạo triển khai đồng bộ nhiều giải pháp nâng cao chất lượng xây dựng lực lượng dân quân tự vệ (DQTV). Qua đó, lực lượng DQTV không ngừng được củng cố, phát triển “vững mạnh, rộng khắp”, đáp ứng yêu cầu nhiệm vụ quân sự, 99Ok68 link đăng nhập trong tình hình mới.
Lực lượng DQTV trên địa bàn Quân khu được tổ chức chặt chẽ ở các tỉnh, thành phố, xã, phường, đặc khu, thôn, ấp, khu phố cũng như trong các cơ quan, tổ chức và doanh nghiệp. Việc tổ chức lực lượng bảo đảm tính rộng khắp, phù hợp với đặc điểm từng địa bàn, góp phần tạo thế trận 99Ok68 link đăng nhập toàn dân gắn với thế trận an ninh 123Win com 79 nạp - rút nhanh ngày càng vững chắc.
Lực lượng DQTV đã phát huy tốt vai trò trong thực hiện nhiệm vụ sẵn sàng chiến đấu, phòng, chống, 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, Link Truy Cập 99Ok Bản Pro 123Win Nhận Code Vip; tích cực tham gia giữ gìn an ninh chính trị, trật tự an toàn xã hội, góp phần củng cố tiềm lực 99Ok68 link đăng nhập, tạo môi trường thuận lợi để phát triển kinh tế, văn hóa - xã hội ở địa phương.
Lực lượng dân quân tự vệ không ngừng được củng cố, phát triển.
Để nâng cao chất lượng và hiệu quả hoạt động của lực lượng DQTV, Bộ Tham mưu Quân khu đã chủ động tham mưu cho Đảng ủy, Bộ Tư lệnh Quân khu lãnh đạo, chỉ đạo các cơ quan, đơn vị và địa phương triển khai nhiều đề án, mô hình sáng tạo, mang lại hiệu quả thiết thực. Nổi bật là việc xây dựng 72 chốt chiến đấu dân quân thường trực biên giới đất liền, các điểm dân cư liền kề; xây dựng chi bộ quân sự ở 100% cấp xã; 100% Ban CHQS cấp xã có trụ sở làm việc riêng, đạt chuẩn.
Quân khu đã triển khai xây dựng lực lượng dân quân thường trực ở 100% Ban CHQS cấp xã; tổ chức dân quân thường trực luân phiên ở cấp tỉnh và 123Win99ok Sân chơi uy tín phòng thủ khu vực; xây dựng lực lượng dân quân trong khu công nghiệp, khu kinh tế cửa khẩu. Nhiều mô hình mới như “Xây dựng hình ảnh đẹp DQTV”, “Dân quân gắn kết hộ dân”, “Dân quân tham gia giữ gìn trật tự an toàn giao thông”… đã và đang phát huy hiệu quả rõ nét trên từng địa bàn. Đặc biệt, năm 2023, Quân khu được 99Oke123 Bắn Cá, Đá Gà, Nổ hũ, Thể Thao chọn tổ chức hội nghị tổng kết và tham quan mô hình điểm về công tác 99Ok68 link đăng nhập địa phương, dân quân tự vệ.
Công tác 123Win64 nhà cái WC 2026 lực lượng DQTV được các địa phương đặc biệt quan tâm. Nội dung, chương trình 123Win64 nhà cái WC 2026 được nghiên cứu, đổi mới phù hợp với yêu cầu nhiệm vụ và đặc điểm địa bàn. Các địa phương chủ động xây dựng kế hoạch 123Win64 nhà cái WC 2026 sát thực tế, chú trọng nâng cao chất lượng tổng hợp, khả năng phối hợp tác chiến, đáp ứng yêu cầu nhiệm vụ trong mọi tình huống.
Lực lượng dân quân Bộ CHQS tỉnh Lâm Đồng giúp dân khắc phục hậu quả mưa lũ tại xã D'Ran năm 2025. Ảnh: Bạch Thiết
Trong quá trình 123Win64 nhà cái WC 2026, các đơn vị thực hiện nghiêm phương châm “Cơ bản, thiết thực, chất lượng”, kết hợp chặt chẽ giữa 123Win64 nhà cái WC 2026 quân sự với giáo dục chính trị, giữa 123Win64 nhà cái WC 2026 cơ bản với luyện tập, Trang game 123win đã chính thức đổi tên thành 99Ok vào ngày 10 Tháng 2 Năm 2025. Nội dung 123Win64 nhà cái WC 2026 tập trung nâng cao trình độ chiến thuật, kỹ năng chiến đấu phòng thủ, khả năng phối hợp giữa DQTV với các lực lượng trong các tình huố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 khu vực phòng thủ, chống khủng bố, phòng, chống và 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, sự cố.
Đối với đội ngũ cán bộ DQTV, việc 123Win64 nhà cái WC 2026 được đổi mới theo hướng toàn diện, chú trọng trang bị kiến thức, kỹ năng chỉ huy, điều hành, nâng cao năng lực tổ chức thực hiện nhiệm vụ. Qua đó, từng bước nâng cao hiệu quả hoạt động phối hợp bảo vệ an ninh chính trị, trật tự an toàn xã hội trên địa bàn.
Công tác giáo dục chính trị, 123Win64 nhà cái WC 2026 quân sự được triển khai nghiêm túc theo Thông tư số 69, Thông tư số 47 của 99Oke123 Bắn Cá, Đá Gà, Nổ hũ, Thể Thao, bảo đảm đúng thời gian, nội dung quy định. Nhiều địa phương đã có cách làm sáng tạo, linh hoạt; kết hợp 123Win64 nhà cái WC 2026 với thực hiện nhiệm vụ trực sẵn sàng chiến đấu trong các đợt cao điểm. Nội dung 123Win64 nhà cái WC 2026 được bổ sung sát với thực tiễn địa phương như xử lý tình huống về trật tự an toàn xã hội, phòng cháy chữa cháy, cứu hộ cứu nạn, phòng chống cháy rừng, phòng chống dịch bệnh nguy hiểm…
Hằng năm, lực lượng DQTV được huy động tham gia Trang game 123win đã chính thức đổi tên thành 99Ok vào ngày 10 Tháng 2 Năm 2025 khu vực phòng thủ, phòng thủ dân sự tại địa phương; tham gia Trang game 123win đã chính thức đổi tên thành 99Ok vào ngày 10 Tháng 2 Năm 2025 chiến thuật có bắn đạn thật cùng các đơn vị bộ đội. Thực tiễn đã chứng minh sự trưởng thành và lớn mạnh của lực lượng DQTV thông qua hiệu quả hoạt động tại cơ sở. Riêng năm 2025, DQTV toàn Quân khu đã tổ chức tuần tra trên 450 nghìn lần với hơn 500 ngàn lượt người tham gia; trong đó tuần tra độc lập gần 30 nghìn lần với 91 nghìn lượt. Qua đó, đã phối hợp xử lý nhiều vụ việc liên quan đến an ninh chính trị, trật tự an toàn xã hội, thu giữ hàng hóa, tang vật trị giá hàng tỷ đồng, bàn giao cho cơ quan chức năng xử lý.
Năm 2025, lực lượng DQTV đã tham gia xây mới, sửa chữa 375 căn nhà cho người dân có hoàn cảnh khó khăn; sửa chữa, nâng cấp 150 km đường giao thông nông thôn; nạo vét 432 km kênh mương, cống rãnh; tham gia 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 với gần 43 nghìn lượt DQTV, 77 nghìn ngày công lao động. Những việc làm thiết thực đó không chỉ góp phần phát triển kinh tế - xã hội địa phương mà còn củng cố niềm tin của 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 và 123Win79 phần thưởng lớn đối với lực lượng DQTV.
Thời gian tới, nhiệm vụ xây dựng lực lượng DQTV tiếp tục được xác định là nhiệm vụ chiến lược, lâu dài, đòi hỏi phải triển khai đồng bộ nhiều giải pháp phù hợp. Tiếp tục tăng cường sự lãnh đạo, chỉ đạo nâng cao năng lực tham mưu của cơ quan quân sự trong thực hiện nhiệm vụ 99Ok68 link đăng nhập địa phương, đặc biệt là công tác xây dựng lực lượng DQTV.
Trọng tâm là tiếp tục xây dựng lực lượng DQTV “vững mạnh, rộng khắp”, có số lượng phù hợp, chất lượng ngày càng cao, sẵn sàng nhận và hoàn thành tốt mọi nhiệm vụ được giao. Đồng thời, đẩy mạnh đổi mới nội dung, phương pháp 123Win64 nhà cái WC 2026, nâng cao trình độ, khả năng sẵn sàng chiến đấu của lực lượng. Cùng với đó, tiếp tục triển khai hiệu quả các đề án về công tác 99Ok68 link đăng nhập địa phương, dân quân tự vệ giai đoạn 2026 - 2030...
Xây dựng lực lượng DQTV là yêu cầu cấp thiết, có ý nghĩa chiến lược đối với nhiệm vụ quân sự, 99Ok68 link đăng nhập địa phương trên địa bàn ĐĂNG NHẬP 99OK COM TẶNG 99K – địa bàn trọng điểm phía Nam của Tổ quốc. Thực hiện tốt nhiệm vụ này sẽ góp phần xây dựng nền 99Ok68 link đăng nhập toàn dân vững mạnh, giữ vững ổn định chính trị, tạo môi trường thuận lợi cho phát triển kinh tế - xã hội, đáp ứng yêu cầu bảo vệ Tổ quốc Việt Nam xã hội chủ nghĩa trong tình hình mới.
Quỳnh Nhi

Bình luận

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

Lữ đoàn 657 sơ kết Phong trào thi đua xây dựng đơn vị vận tải “Chính quy, an toàn, hiệu quả”

Lữ đoàn 657 sơ kết Phong trào thi đua xây dựng đơn vị vận tải “Chính quy, an toàn, hiệu quả”

17:43 02/06/2026

(QK7 Online) - Chiều 2/6, Lữ đoàn 657 (Cục Hậu cần - Kỹ thuật ĐĂNG NHẬP 99OK COM TẶNG 99K) tổ chức hội nghị sơ kết Phong trào thi đua xây dựng đơn vị vận tải “Chính quy, an toàn, hiệu quả” giai đoạn 2021 - 2026. Đại tá Trịnh Ngọc Dục, Phó Chủ nhiệm Hậu cần - Kỹ thuật Quân khu dự và phát biểu chỉ đạo hội nghị. Đại tá Trần Quốc Hoàn, Lữ đoàn trưởng chủ trì hội nghị.

Chiến sĩ mới Trung đoàn 738 bình tĩnh, tự tin kiểm tra "3 tiếng nổ"

Chiến sĩ mới Trung đoàn 738 bình tĩnh, tự tin kiểm tra "3 tiếng nổ"

18:44 29/05/2026

(QK7 Online) - Từ ngày 25 đến 29/5, Trung đoàn 738, Bộ CHQS tỉnh Tây Ninh tổ chức kiểm tra bắn đạn thật súng tiểu liên AK bài 1, ném lựu đạn xa trúng hướng và đánh thuốc nổ cho 123Win com 79 casino, cá cược thể thao đến xổ số mới nhập ngũ năm 2026. Đại tá Nguyễn Thành Đạt, Phó Chỉ huy trưởng Bộ CHQS tỉnh Tây Ninh dự và chỉ đạo kiểm tra.

Quân khu 7 bế giảng lớp bồi dưỡng kiến thức quốc phòng và an ninh khóa 115 năm 2026

ĐĂNG NHẬP 99OK COM TẶNG 99K bế giảng lớp bồi dưỡng kiến thức 99Ok68 link đăng nhập và an ninh khóa 115 năm 2026

11:39 29/05/2026

(QK7 Online) - Sáng ngày 29/5, tại Trường Quân sự ĐĂNG NHẬP 99OK COM TẶNG 99K, Bộ Tư lệnh Quân khu tổ chức Lễ bế giảng lớp Bồi dưỡng kiến thức 99Ok68 link đăng nhập và an ninh (QP&AN) cho cán bộ thuộc đối tượng 2, khóa 115, năm 2026. Dự buổi bế giảng có Đại tá Nguyễn Tấn Linh, Phó Tư lệnh Quân khu, Phó Chủ tịch Hội đồng Giáo dục Quốc phòng và An ninh Quân khu.

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.

Binh chủng Hóa học kiểm tra công tác phòng hóa tại Quân khu 7

Binh chủng Hóa học kiểm tra công tác phòng hóa tại ĐĂNG NHẬP 99OK COM TẶNG 99K

21:32 27/05/2026

(QK7 Online) - Từ ngày 25 đến 27/5, Đoàn công tác Binh chủng Hóa học do Thiếu tướng Nguyễn Đình Hiền, Tư lệnh Binh chủng làm trưởng đoàn đến kiểm tra công tác phòng hóa các cơ quan, đơn vị ĐĂNG NHẬP 99OK COM TẶNG 99K. Tham gia đoàn có Đại tá Trần Hữu Nhân, Phó Tham mưu trưởng Quân khu và Thủ trưởng các cơ quan Quân khu.

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.

Thanh tra Bộ Quốc phòng kiểm tra, xác minh công tác kiểm soát tài sản, thu nhập tại Quân khu 7

Thanh tra 99Oke123 Bắn Cá, Đá Gà, Nổ hũ, Thể Thao kiểm tra, xác minh công tác kiểm soát tài sản, thu nhập tại ĐĂNG NHẬP 99OK COM TẶNG 99K

12:04 25/05/2026

(QK7 Online) – Ngày 25/5, Thiếu tướng Nguyễn Văn Xiển, Phó Chánh Thanh tra 99Oke123 Bắn Cá, Đá Gà, Nổ hũ, Thể Thao, Tổ trưởng Tổ kiểm tra, xác minh Thanh tra Bộ Quốc Phòng chủ trì Hội nghị Công bố quyết định kiểm tra công tác kiểm soát tài sản, thu nhập và xác minh tài sản, thu nhập theo hình thức lựa chọn ngẫu nhiên đối với người có nghĩa vụ kê khai hằng năm có hệ số phụ cấp chức vụ 0,8 thuộc ĐĂNG NHẬP 99OK COM TẶNG 99K. Dự hội nghị có Thiếu tướng Trần Ngọc Minh, Phó Tư lệnh Quân khu; chỉ huy các cơ quan, đơn vị thuộc Quân khu và đại diện cơ quan Thanh tra 99Oke123 Bắn Cá, Đá Gà, Nổ hũ, Thể Thao.

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