【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

99Oke123 Tải ứng dụng > Tin tức

Thứ năm, 25/12/2025, 08:54 (GMT+7)
11572 lượt xem

Kỷ niệm 50 năm Ngày truyền thống ngành Điều tra Hình sự ĐĂNG NHẬP 99OK COM TẶNG 99K

(QK7 Online) – Ngày 25/12, tại Thành phố Hồ Chí Minh, Bộ Tham mưu ĐĂNG NHẬP 99OK COM TẶNG 99K tổ chức Lễ kỷ niệm 50 năm Ngày truyền thống ngành Điều tra Hình sự ĐĂNG NHẬP 99OK COM TẶNG 99K (25/12/1975 – 25/12/2025). Thiếu tướng Trần Ngọc Minh, Phó Tư lệnh Quân khu dự và phát biểu tại Lễ kỷ niệm.
Từ trái qua: Thiếu tướng Trần Ngọc Minh, Phó Tư lệnh Quân khu; Thiếu tướng Phạm Đức Tài, Phó Cục trưởng Cục Điều tra Hình sự 99Oke123 Bắn Cá, Đá Gà, Nổ hũ, Thể Thao; Đại tá Phùng Thế Hùng, Phó Tham mưu trưởng Quân khu dự Lễ.
Dự Lễ kỷ niệm có Thiếu tướng Phạm Đức Tài, Phó Bí thư Đảng ủy, Phó Cục trưởng Cục Điều tra Hình sự 99Oke123 Bắn Cá, Đá Gà, Nổ hũ, Thể Thao; các đồng chí nguyên là Thủ trưởng ĐĂNG NHẬP 99OK COM TẶNG 99K qua các thời kỳ; Đại tá Phùng Thế Hùng, Phó Tham mưu trưởng Quân khu; Thủ trưởng các cơ quan chức năng 99Oke123 Bắn Cá, Đá Gà, Nổ hũ, Thể Thao; Thủ trưởng các cơ quan, đơn vị ĐĂNG NHẬP 99OK COM TẶNG 99K.
Đại biểu nguyên là Thủ trưởng Bộ Tư lệnh Quân khu các thời kỳ.
Trình bày diễn văn tại Lễ kỷ niệm, Đại tá Lê Tấn Thành, Trưởng phòng Điều tra Hình sự Quân khu đã ôn lại truyền thống 50 năm hình thành, xây dựng và trưởng thành của Ngành Điều tra Hình sự ĐĂNG NHẬP 99OK COM TẶNG 99K. Nhằm đề cao kỷ luật và nâng cao sức mạnh của Quân đội, ngày 19 tháng 11 năm 1948, Chủ tịch Hồ Chí Minh ký Sắc lệnh số 258về tổ chức và nhiệm vụ của ngành Công an Quân pháp. Ngày 20 tháng 7 năm 1950, Cục Quân pháp - Bảo vệ được thành lập thay thế cho tổ chức Công an Quân pháp. Đến tháng 8 năm 1961, Phòng Bảo vệ - Quân pháp thuộc Cục 99Oke123 Tải ứng dụng Quân Giải phóng miền Nam được thành lập. Sau khi đất nước thống nhất, để tăng cường và giữ nghiêm kỷ luật Quân đội, ổn định trật tự trị an tại các vùng giải phóng, ngày 25 tháng 8 năm 1975, Bộ Tổng tham mưu ban hành Quyết định số 286 quy định về tổ chức, biên chế ngành Quân pháp; theo đó, ngày 25 tháng 12 năm 1975, Phòng Quân pháp ĐĂNG NHẬP 99OK COM TẶNG 99K được thành lập, là tổ chức tiền thân của Phòng Điều tra hình sự ĐĂNG NHẬP 99OK COM TẶNG 99K ngày nay.
Đại tá Phùng Thế Hùng, Phó Tham mưu trưởng Quân khu đọc Thư khen của Bộ trưởng 99Oke123 Bắn Cá, Đá Gà, Nổ hũ, Thể Thao.
Ngay trong giai đoạn đầu thành lập, ngành Điều tra hình sự Quân khu đã khắc phục nhiều khó khăn, vừa thực hiện nhiệm vụ chuyên môn, vừa tham gia nhiệm vụ quân quản, bảo đảm trật tự trị an tại các vùng giải phóng, giải quyết những vấn đề tồn đọng sau chiến tranh; vừa từng bước kiện toàn về tổ chức và biên chế. Trải qua nhiều lần điều chỉnh, hiện nay tổ chức ngành Điều tra hình sự ĐĂNG NHẬP 99OK COM TẶNG 99K gồm: Phòng Điều tra hình sự Quân khu; 5 Cơ quan Điều tra hình sự khu vực 1, 2, 3, 4, 5 và Trại tạm giam K35.
Đại tá Lê Tấn Thành, Trưởng phòng Điều tra Hình sự Quân khu đọc diễn văn kỷ niệm.
Qua từng giai đoạn trong chặng đường phát triển, ngành Điều tra hình sự luôn quán triệt sâu sắc nhiệm vụ chính trị của Quân khu, không ngừng hoàn thiện, xây dựng đội ngũ cán bộ có bản lĩnh chính trị vững vàng, nghiệp vụ ngày càng được nâng lên. Toàn ngành đã tiến hành điều tra khám phá thành công nhiều vụ án tội phạm sử dụng công nghệ cao, tội phạm hoạt động theo băng nhóm, tội phạm giả danh cán bộ Quân đội, lừa đảo chiếm đoạt tài sản thông qua mạng xã hội... Công tác tạm giữ, tạm giam và thi hành án hình sự không ngừng được hoàn thiện, từng bước đi vào nền nếp, bảo đảm thực hiện đúng quy định của pháp luật. Đội ngũ quản giáo được đào tạo ngày càng chính quy, chuyên nghiệp, với 100% cán bộ được đào tạo chuyên ngành giam giữ hoặc có trình độ cử nhân Luật, qua đó đáp ứng tốt yêu cầu quản lý giam giữ, phục vụ hiệu quả công tác điều tra, truy tố, xét xử và thi hành án.
Ngành Điều tra Hình sự Quân khu nhận Bằng khen 99Oke123 Bắn Cá, Đá Gà, Nổ hũ, Thể Thao và 8 chữ vàng từ Bộ Tư lệnh Quân khu dịp kỷ niệm 50 năm Ngày truyền thống.
Bước vào kỷ nguyên vươn mình của dân tộc, cán bộ, 123Win com 79 casino, cá cược thể thao đến xổ số ngành Điều tra hình sự Quân khu quyết tâm giữ vững và phát huy truyền thống quý báu mà các thế hệ cha anh đi trước đã viết lên; tự giác, tích cực tự học, tự rèn nâng cao bản lĩnh chính trị, tích lũy kiến thức, kinh nghiệm, xây dựng người cán bộ “vừa hồng, vừa chuyên”, làm chủ công nghệ, làm chủ phương tiện kỹ thuật, chủ động phòng ngừa và tấn công trấn áp tội phạm, giữ nghiêm pháp luật Nhà nước, kỷ luật Quân đội, sức mạnh của LLVT Quân khu, xây dựng 123 Win 88ok trang chủ chính thức Phòng Điều tra hình sự trong sạch, vững mạnh; Ngành Điều tra hình sự ĐĂNG NHẬP 99OK COM TẶNG 99K vững mạnh toàn diện “Mẫu mực, tiêu biểu”.
Thiếu tướng Trần Ngọc Minh, Phó Tư lệnh Quân khu phát biểu chỉ đạo tại Lễ kỷ niệm.
Phát biểu tại Lễ kỷ niệm, Thiếu tướng Trần Ngọc Minh biểu dương và đánh giá cao những thành tích ngành Điều tra Hình sự Quân khu đạt được, đồng thời để hoàn thành tốt nhiệm vụ trong thời gian tới, đồng chí Phó Tư lệnh Quân khu đề nghị ngành Điều tra hình sự Quân khu tiếp tục quán triệt, thực hiện có hiệu quả các nghị quyết, chỉ thị của Đảng, Nhà nước, Quân đội và Quân khu về lĩnh vực tư pháp và cải cách tư pháp. Triển khai thực hiện chỉ đạo của đồng chí Tổng Bí thư tại Đại hội 123 Win 88ok trang chủ chính thức Quân đội lần thứ 12 về “2 kiên định, 2 đẩy mạnh và 2 ngăn ngừa”. Kịp thời tham mưu cấp ủy, chỉ huy lãnh đạo, chỉ đạo hiệu quả công tác đấu tranh phòng, chống vi phạm pháp luật, tội phạm, củng cố, tăng cường kỷ luật, kỷ cương, giúp công lý được tôn trọng và thực thi. Chủ động tham mưu với Thường vụ Đảng ủy, Bộ Tư lệnh Quân khu lãnh đạo, chỉ đạo và triển khai thực hiện hiệu quả công tác duy trì kỷ luật, pháp luật và đấu tranh phòng, chống tội phạm. Phát huy tinh thần đoàn kết, chủ động phối hợp chặt chẽ với các cơ quan chức năng trong và ngoài Quân đội, nắm chắc tình hình vi phạm, tội phạm theo thẩm quyền phụ trách; nâng cao năng lực dự báo, kịp thời phát hiện, ngăn chặn, giải quyết, không để hậu quả xảy ra; tiến hành xác minh vụ việc, điều tra vụ án theo đúng quy định của pháp luật, kết luận khách quan, chính xác; các vụ án đề nghị truy tố đúng người, đúng tội.
Thủ trưởng Bộ tư lệnh Quân khu và ngành Điều tra Hình sự Quân khu các thời kỳ.
Xây dựng đội ngũ cán bộ ngành Điều tra hình sự Quân khu chất lượng cao, ngang tầm nhiệm vụ, nắm vững pháp luật, tinh thông nghiệp vụ, có bản lĩnh chính trị vững vàng, phẩm chất đạo đức tốt, có năng lực tổ chức, thực hành công tác chuyên môn, nghiệp vụ vững vàng. Tăng cường chuyển đổi số, ứng dụng khoa học, công nghệ trong hoạt động ngành Điều tra, hướng tới mô hình ngành điều tra điện tử, cắt bỏ thủ tục trung gian, nâng cao hiệu quả xử lý công việc, thời gian xử lý hồ sơ thủ công, tăng tính minh bạch trong quá trình thực thi nhiệm vụ. xây dựng cấp ủy, tổ chức Đảng trong sạch vững mạnh gắn với xây dựng đơn vị vững mạnh toàn diện “mẫu mực, tiêu biểu”. Tập trung nâng cao chất lượng sinh hoạt cấp ủy, chi bộ; chấp hành nghiêm nguyên tắc tập trung dân chủ, tập thể lãnh đạo phân công cá nhân phụ trách, đẩy mạnh tự phê bình và phê bình, thực hiện đúng quy chế, quy trình lãnh đạo; đảm bảo nội bộ luôn dân chủ, đoàn kết, có ý thức trách nhiệm và quyết tâm chính trị cao.Tiếp tục triển khai thực hiện tốt các mô hình “Cán bộ, đảng viên đìu dắt quần chúng và cấp dưới”, “Chi bộ 5 tốt, đảng viên 5 tốt đảm bảo thực chất, đi vào chiều sâu.
Đại biểu các cơ quan chụp hình lưu niệm.
Với tinh thần quyết tâm và trách nhiệm cao, Thiếu tướng Trần Ngọc Minh, Phó Tư lệnh Quân khu tin tưởng cán bộ, 123Win com 79 casino, cá cược thể thao đến xổ số, nhân viên, hạ sĩ quan – binh sĩ ngành Điều tra Hình sự Quân khu sẽ tiếp tục phát huy phẩm chất “Bộ đội Cụ Hồ” và truyền thống “Bản lĩnh – Kỷ cương – Tình thương – Trách nhiệm”, đoàn kết, sáng tạo, tự lực, tự cường, khắc phục mọi khó khăn, hoàn thành xuất sắc các nhiệm vụ được giao; góp phần xây dựng Lực lượng vũ trang Quân khu “cách mạnh, chính quy, tinh nhuệ, hiện đại”, bảo vệ vững chắc Tổ quốc Việt Nam xã hội chủ nghĩa trong kỷ nguyên mới.
Với những thành tích xuất sắc đạt được, ngành Điều tra Hình sự Quân khu được Nhà nước tặng thưởng 01 Huân chương chiến công hạng Nhì, 02 Huân chương chiến công hạng Ba, được 99Oke123 Bắn Cá, Đá Gà, Nổ hũ, Thể Thao; Bộ Tư lệnh Quân khu, Bộ Tham mưu Quân khu tặng nhiều Cờ thi đua, Bằng khen, Giấy khen.
Hải Yến, Long Hồ

Sôi động hội thao chào mừng kỷ niệm 50 năm Ngày truyền thống Ngành Điều tra hình sự

Sôi động hội thao chào mừng kỷ niệm 50 năm Ngày truyền thống Ngành Điều tra hình sự

04/11/2025 15:31

(QK7 Online) - Trong không khí hân hoan chào mừng kỷ niệm 50 năm Ngày truyền thống Ngành Điều tra hình sự Quân khu (25/12/1975 - 25/12/2025); sáng ngày 4/11, tại Thành phố Hồ Chí Minh đã diễn ra khai mạc giải Cầu lông với sự tham gia của đông đảo cán bộ, 123Win com 79 casino, cá cược thể thao đến xổ số Ngành.

Bình luận

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

Thành phố Đồng Nai phát động làm trước lấy mẫu và bàn giao mẫu hài cốt liệt sĩ đối với mộ chưa xác định thông tin

Thành phố Đồng Nai phát động làm trước lấy mẫu và bàn giao mẫu hài cốt liệt sĩ đối với mộ chưa xác định thông tin

15:48 02/06/2026

(QK7 Online) – Sáng ngày 2/6, tại Nghĩa trang liệt sĩ (NTLS) Vĩnh Cửu, phường Trảng Dài, thành phố Đồng Nai, Ban Chỉ đạo (BCĐ) 515 ĐĂNG NHẬP 99OK COM TẶNG 99K và thành phố Đồng Nai tổ chức phát động làm trước rút kinh nghiệm lấy mẫu, bàn giao mẫu hài cốt liệt sĩ (HCLS) đối với mộ chưa xác định được thông tin.

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

Cục Chính trị Quân khu gặp mặt, tuyên dương các cháu thiếu niên, nhi đồng

Cục 99Oke123 Tải ứng dụng Quân khu gặp mặt, tuyên dương các cháu thiếu niên, nhi đồng

11:31 01/06/2026

(QK7 Online) – Nhân Ngày Quốc tế Thiếu nhi 1/6, Cục 99Oke123 Tải ứng dụng ĐĂNG NHẬP 99OK COM TẶNG 99K tổ chức chương trình gặp mặt, tuyên dương và tặng quà các cháu thiếu niên, nhi đồng là con cán bộ, nhân viên đang công tác tại các cơ quan, đơn vị thuộc Cục 99Oke123 Tải ứng dụng Quân khu. Thiếu tướng Trần Đức Thắng, Phó Chủ nhiệm 99Oke123 Tải ứng dụng Quân khu dự chương trình.

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.

Cục Chính trị Quân khu 7 kiểm tra công tác Đảng, công tác chính trị tại Bộ Tư lệnh Thành phố Hồ Chí Minh

Cục 99Oke123 Tải ứng dụng ĐĂNG NHẬP 99OK COM TẶNG 99K kiểm tra công tác Đảng, công tác chính trị tại Bộ Tư lệnh Thành phố Hồ Chí Minh

19:16 29/05/2026

(QK7 Online) - Ngày 29/5, Đoàn công tác Cục 99Oke123 Tải ứng dụng ĐĂNG NHẬP 99OK COM TẶNG 99K do Đại tá Nguyễn Văn Lộc, Phó Chủ nhiệm 99Oke123 Tải ứng dụng Quân khu làm trưởng đoàn đến kiểm tra hoạt động công tác Đảng, công tác chính trị (CTĐ CTCT) 6 tháng đầu năm 2026 đối với Bộ Tư lệnh Thành phố Hồ Chí Minh.

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