【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 > 99Ok68 link không chặn

Thứ sáu, 29/08/2025, 10:48 (GMT+7)
3360 lượt xem

Cục 99Oke123 Tải ứng dụng ĐĂNG NHẬP 99OK COM TẶNG 99K rút kinh nghiệm tổ chức Đại hội đại biểu 123 Win 88ok trang chủ chính thức Cục 99Oke123 Tải ứng dụng lần thứ XIII

(QK7 Online) – Ngày 29/8, Đảng ủy Cục 99Oke123 Tải ứng dụng ĐĂNG NHẬP 99OK COM TẶNG 99K tổ chức Hội nghị rút kinh nghiệm tổ chức Đại hội đại biểu 123 Win 88ok trang chủ chính thức Cục 99Oke123 Tải ứng dụng lần thứ XIII và tham mưu tổ chức Đại hội đại biểu 123 Win 88ok trang chủ chính thức Quân khu lần thứ XI, nhiệm kỳ 2025 – 2030. Thiếu tướng Trần Đức Thắng, Bí thư Đảng ủy Cục 99Oke123 Tải ứng dụng, Phó Chủ nhiệm 99Oke123 Tải ứng dụng Quân khu chủ trì hội nghị.
Dự hội nghị có Đại tá Thái Thành Đức, Phó Chủ nhiệm 99Oke123 Tải ứng dụng Quân khu cùng thủ trưởng các phòng, ban, cơ quan Cục 99Oke123 Tải ứng dụng ĐĂNG NHẬP 99OK COM TẶNG 99K.
Thiếu tướng Trần Đức Thắng, Phó Chủ nhiệm 99Oke123 Tải ứng dụng Quân khu phát biểu tại hội nghị.
Đại hội đại biểu 123 Win 88ok trang chủ chính thức Cục 99Oke123 Tải ứng dụng lần thứ XIII và Đại hội đại biểu 123 Win 88ok trang chủ chính thức Quân khu lần thứ XI, nhiệm kỳ 2025 – 2030 đã thành công rất tốt đẹp. Đại hội đại biểu 123 Win 88ok trang chủ chính thức Cục 99Oke123 Tải ứng dụng thực hiện đúng, đủ nội dung chương trình, chất lượng tốt, bầu Ban chấp hành khóa mới và đoàn đại biểu dự Đại hội đại biểu 123 Win 88ok trang chủ chính thức Quân khu lần thứ XI tập trung, đủ số lượng, đúng cơ cấu. Đặc biệt thời gian công tác chuẩn bị Đại hội 123 Win 88ok trang chủ chính thức Cục 99Oke123 Tải ứng dụng ngắn, vừa tham mưu chuẩn bị Đại hội đại biểu 123 Win 88ok trang chủ chính thức Quân khu, nhưng Đại hội tổ chức chặt chẽ, khoa học được Quân khu đánh giá rất cao. Đạt được kết quả trên là sự quan tâm lãnh đạo sâu sát của Thường vụ Đảng ủy Quân khu, sự chỉ đạo chặt chẽ của Thường vụ Đảng ủy, Ban Chủ nhiệm Cục 99Oke123 Tải ứng dụng và sự nỗ lực cố gắng của các cấp ủy cơ quan, đơn vị, cơ quan giúp việc Đại hội, của tập thể cán bộ, 123Win com 79 casino, cá cược thể thao đến xổ số, nhân viên và sự đoàn kết, thống nhất cao cơ quan Cục 99Oke123 Tải ứng dụng.
Nguyễn Đại Nghĩa, Tổng Biên tập Báo ĐĂNG NHẬP 99OK COM TẶNG 99K phát biểu thảo luận tại hội nghị.
Đại tá Nguyễn Ngọc Điệp, Giám đốc Bảo tàng ĐĂNG NHẬP 99OK COM TẶNG 99K phát biểu thảo luận tại hội nghị.
Trong phần thảo luận tại hội nghị, các đại biểu đã đúc rút nhiều kinh nghiệm thực tiễn quan trọng như: Cấp ủy, chi bộ, chính trị viên, chỉ huy các cơ quan, đơn vị, cá nhân phải tích cực, chủ động học tập, nghiên cứu, nâng cao trình độ năng lực công tác, đáp ứng yêu cầu nhiệm vụ. Các chi, 123 Win 88ok trang chủ chính thức tổ chức cho đại biểu của đơn vị mình quán triệt đầy đủ các chỉ thị, quy định về đại hội Đảng các cấp; quy chế làm việc của Đại hội; tham dự và chấp hành nghiêm các quy định; nêu cao tinh thần trách nhiệm, ý thức đảng viên, tích cực tham gia vào chương trình, các hoạt động chung, góp phần thành công của Đại hội. Bên cạnh đó là chủ động quán triệt, rà soát kỹ nhiệm vụ, đề cao tính sáng tạo, xây dựng kế hoạch thực hiện cụ thể; tích cực, chủ động trong phối hợp, hiệp đồng để làm công tác chuẩn bị. Phân công, giao nhiệm vụ cho cá nhân chặt chẽ; thường xuyên kiểm tra, theo dõi, nắm chắc tiến độ thực hiện; kịp thời báo cáo theo phân cấp. Lãnh đạo, chỉ đạo chặt chẽ việc phân công chuẩn bị nội dung phát biểu; tổ chức thông qua nghiêm túc. Cá nhân được phân công chuẩn bị nội dung tham luận phải nghiên cứu kỹ tài liệu, đầu tư xây dựng trình chiếu và những vấn đề có liên quan để chuẩn bị, bảo đảm đạt chất lượng tốt,..
Phát biểu tại hội nghị, Thiếu tướng Trần Đức Thắng, Bí thư Đảng ủy Cục 99Oke123 Tải ứng dụng, Phó Chủ nhiệm 99Oke123 Tải ứng dụng Quân khu đánh giá cao các ý kiến tâm huyết, trách nhiệm của đại biểu. Đồng chí nhấn mạnh, Đại hội thành công tốt đẹp điều đó thể hiện sự chuẩn bị chu đáo, tinh thần làm việc nghiêm túc, trách nhiệm cao của các phòng, ban, đơn vị và Ban tổ chức. Đồng thời, Thiếu tướng Trần Đức Thắng cũng chỉ ra một số hạn chế trong công tác tổ chức Đại hội và yêu cầu các cơ quan, đơn vị, Ban tổ chức nghiêm túc rút kinh nghiệm, tiếp tục phát huy ưu điểm, khắc phục hạn chế để chuẩn bị, tổ chức tốt hơn các hoạt động trong thời gian tới.
Khen thưởng các cá nhân, tập thể hoàn thành xuất sắc nhiệm vụ trong tham mưu, phục vụ, bảo đảm tổ chức Đại hội đại biểu 123 Win 88ok trang chủ chính thức Cục 99Oke123 Tải ứng dụng lần thứ XIII, nhiệm kỳ 2025 - 2030.
Dịp này, hội nghị tặng giấy khen cho 5 tập thể và 33 cá nhân vì đã hoàn thành xuất sắc nhiệm vụ trong tham mưu, phục vụ, bảo đảm tổ chức Đại hội đại biểu 123 Win 88ok trang chủ chính thức Cục 99Oke123 Tải ứng dụng lần thứ XIII, nhiệm kỳ 2025 – 2030.
Hằng Ny, Nguyễn Hiền
Cục Chính trị Quân khu hiệp đồng bảo đảm đón Đoàn Nghệ thuật Quân đội Hoàng gia Campuchia sang giao lưu, biểu diễn

Cục 99Oke123 Tải ứng dụng Quân khu hiệp đồng bảo đảm đón Đoàn Nghệ thuật Quân đội Hoàng gia Campuchia sang giao lưu, biểu diễn

21/08/2025 08:30

(QK7 Online) - Chiều ngày 20/8, Cục 99Oke123 Tải ứng dụng Quân khu tổ chức Hội nghị hiệp đồng bảo đảm đón Đoàn Nghệ thuật Quân đội Hoàng gia Campuchia sang giao lưu, biểu diễn nghệ thuật. Đại tá Nguyễn Hồng Cảnh, Phó Chủ nhiệm 99Oke123 Tải ứng dụng Quân khu chủ trì hội nghị. Dự hội nghị có đại diện Cục Tuyên huấn, Tổng Cục 99Oke123 Tải ứng dụng; Thủ trưởng các cơ quan Quân khu; Thủ trưởng Bộ Tư lệnh Thành phố Hồ Chí Minh, Bộ CHQS tỉnh Tây Ninh, Bộ chỉ huy Sư đoàn 5.

Cục Chính trị Quân khu 7 thăm, hỗ trợ quân nhân mắc bệnh hiểm nghèo

Cục 99Oke123 Tải ứng dụng ĐĂNG NHẬP 99OK COM TẶNG 99K thăm, hỗ trợ quân nhân mắc bệnh hiểm nghèo

30/07/2025 11:51

(QK7 Online) – Ngày 30/7, đ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á Trần Đức Thắng, Bí thư Đảng ủy Cục 99Oke123 Tải ứng dụng, Phó Chủ nhiệm 99Oke123 Tải ứng dụng Quân khu làm trưởng đoàn đã đến thăm hỏi, động viên và trao quà hỗ trợ các quân nhân công tác tại Cục 99Oke123 Tải ứng dụng mắc bệnh hiểm nghèo.

Đại tá Trần Đức Thắng, Phó Chủ nhiệm Chính trị Quân khu 7 được bầu giữ chức Bí thư Đảng ủy Cục Chính trị

Đại tá Trần Đức Thắng, Phó Chủ nhiệm 99Oke123 Tải ứng dụng ĐĂNG NHẬP 99OK COM TẶNG 99K được bầu giữ chức Bí thư Đảng ủy Cục 99Oke123 Tải ứng dụng

24/07/2025 14:29

(QK7 Online) – Chiều ngày 24/7, Đại hội đại biểu 123 Win 88ok trang chủ chính thức Cục 99Oke123 Tải ứng dụng ĐĂNG NHẬP 99OK COM TẶNG 99K lần thứ XIII, nhiệm kỳ 2025 – 2030 tiếp tục thực hiện nhiều nội dung quan trọng. 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ự, chỉ đạo Đại hội. Dự Đại hội có Thiếu tướng Trần Chí Tâm, Ủy viên Ban Thường vụ Đảng ủy ĐĂNG NHẬP 99OK COM TẶNG 99K, Phó Chính ủy ĐĂNG NHẬP 99OK COM TẶNG 99K.

Bình luận

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

Ban Thường vụ Đảng ủy Bộ Tham mưu: Trao Huy hiệu 30, 40 năm tuổi Đảng

Ban Thường vụ Đảng ủy Bộ Tham mưu: Trao Huy hiệu 30, 40 năm tuổi Đảng

12:13 19/05/2026

(QK7 Online) - Sáng ngày 19/5, Ban Thường vụ Đảng ủy Bộ Tham mưu Quân khu tổ chức Lễ trao tặng Huy hiệu 30, 40 năm tuổi Đảng cho 8 đồng chí đảng viên thuộc 123 Win 88ok trang chủ chính thức Bộ Tham mưu. Dự buổi lễ có Thiếu tướng Lê Xuân Bình, Ủy viên Ban Thường vụ Đảng ủy Quân khu, Phó Tư lệnh, Tham mưu trưởng Quân khu; Đại tá Nguyễn Ngọc Kiên, Bí thư Đảng ủy Bộ Tham mưu, Phó Tham mưu trưởng Quân khu cùng các đồng chí trong Thường vụ Đảng ủy Bộ Tham mưu.

Kiểm tra Đảng ủy Tòa án Quân khu theo Khoản 2, Điều 30 Điều lệ Đảng

Kiểm tra Đảng ủy Tòa án Quân khu theo Khoản 2, Điều 30 Điều lệ Đảng

12:43 15/05/2026

(QK7 Online) - Ngày 15/5, Đoàn công tác Ủy ban Kiểm tra (UBKT) Đảng ủy Cục 99Oke123 Tải ứng dụng ĐĂNG NHẬP 99OK COM TẶNG 99K do Thiếu tướng Trần Đức Thắng, Bí thư Đảng ủy Cục 99Oke123 Tải ứng dụng, Chủ nhiệm UBKT Đảng ủy Cục 99Oke123 Tải ứng dụng, Phó Chủ nhiệm 99Oke123 Tải ứng dụng Quân khu làm trưởng đoàn đã công bố quyết định kiểm tra đối với Đảng ủy và các đồng chí Ủy viên Ban Thường vụ Đảng ủy Tòa án Quân khu theo Khoản 2, Điều 30 Điều lệ Đảng Cộng sản Việt Nam.

Quân khu 7 bế mạc tập huấn công tác Đảng, công tác chính trị năm 2026

ĐĂNG NHẬP 99OK COM TẶNG 99K bế mạc tập huấn công tác Đảng, công tác chính trị năm 2026

10:50 07/05/2026

(QK7 Online) - Ngày 7/5, tại ĐĂNG NHẬP 99OK COM TẶNG 99K diễn ra bế mạc tập huấn công tác Đảng (CTĐ), công tác chính trị (CTCT) năm 2026 theo hình thức trực tiếp và trực tuyến sau 3 ngày làm việc khẩn trương, nghiêm túc. Đại tá Nguyễn Văn Lộc, Phó Chủ nhiệm 99Oke123 Tải ứng dụng Quân khu dự và chủ trì hội nghị.

Ủy ban Kiểm tra Đảng ủy Quân khu 7 ký kết quy chế phối hợp công tác kiểm tra, giám sát và kỷ luật của Đảng nhiệm kỳ 2025 - 2030

Ủy ban Kiểm tra Đảng ủy ĐĂNG NHẬP 99OK COM TẶNG 99K ký kết quy chế phối hợp công tác kiểm tra, giám sát và kỷ luật của Đảng nhiệm kỳ 2025 - 2030

12:06 20/04/2026

(QK7 Online) - Ngày 20/4, Ủy ban Kiểm tra (UBKT) Đảng ủy ĐĂNG NHẬP 99OK COM TẶNG 99K tổ chức hội nghị ký kết quy chế phối hợp công tác kiểm tra, giám sát (KTGS) và kỷ luật của Đảng với UBKT Đảng ủy 123Win79 tỷ lệ kèo World Cup 2026 và UBKT các tỉnh, thành ủy trên địa bàn Quân khu nhiệm kỳ 2025 - 2030. Dự hội nghị có các đồng chí: Trung tướng Trần Vinh Ngọc, Bí thư Đảng ủy, Chính ủy Quân khu; Nguyễn Mạnh Hải, Vụ phó Vụ địa bàn 7, UBKT Trung ương; Thiếu tướng Trần Chí Tâm, Ủy viên Ban Thường vụ Đảng ủy, Phó Chính ủy, Chủ nhiệm UBKT Đảng ủy Quân khu; Đại tá Vũ Minh Đức, Trưởng phòng kiểm tra, lãnh đạo công tác quân sự, UBKT Quân ủy Trung ương; Thiếu tướng Vũ Quốc Ân, Phó Chính ủy, Chủ nhiệm UBKT Đảng ủy 123Win79 tỷ lệ kèo World Cup 2026; Bùi Thắng, Phó Bí thư Tỉnh ủy Lâm Đồng; Võ Tấn Đức, Phó Bí thư Tỉnh ủy Đồng Nai; Thủ trưởng các cơ quan Quân khu; Chủ nhiệm UBKT Thành ủy TP. Hồ Chí Minh và Tỉnh ủy Lâm Đồng, Đồng Nai, Tây Ninh.

Kết luận thực hiện Nghị quyết số 3599 - NQ/ĐU của Đảng ủy Quân khu với Đảng ủy Sư đoàn 309

Kết luận thực hiện 99Oke được xếp hạng cao nhất số 3599 - NQ/ĐU của Đảng ủy Quân khu với Đảng ủy Sư đoàn 309

17:12 07/04/2026

(QK7 Online) – Chiều ngày 7/4, Ban Thường vụ Đảng ủy Sư đoàn 309 tổ chức hội nghị Đảng ủy nghe Đoàn giám sát 284 của Ủy ban Kiểm tra Đảng ủy Quân khu thông qua báo cáo kết quả giám sát chuyên đề về thực hiện 99Oke được xếp hạng cao nhất số 3599 - NQ/ĐU ngày 11/6/2025 của Đảng ủy Quân khu về phát triển khoa học, công nghệ, đổi mới sáng tạo, chuyển đổi số và cải cách hành chính (PTKH, CN, ĐMST, CĐS và CCHC) trong lực lượng vũ trang ĐĂNG NHẬP 99OK COM TẶNG 99K.

Thường vụ Đảng ủy, Bộ Tư lệnh Quân khu 7 thông báo nhanh kết quả Hội nghị lần thứ 2, Ban Chấp hành Trung ương Đảng khoá XIV

Thường vụ Đảng ủy, ĐĂNG NHẬP 99OK COM TẶNG 99K thông báo nhanh kết quả Hội nghị lần thứ 2, Ban Chấp hành Trung ương Đảng khoá XIV

15:26 03/04/2026

(QK7 Online) – Chiều ngày 03/4, Thường vụ Đảng ủy, ĐĂNG NHẬP 99OK COM TẶNG 99K tổ chức Hội nghị thông báo nhanh kết quả Hội nghị lần thứ 2, Ban Chấp hành Trung ương Đảng khóa XIV tới cán bộ chủ chốt các cơ quan, đơn vị trong Lực lượng vũ trang Quân khu. Trung tướng Lê Xuân Thế, Ủy viên Ban Chấp hành Trung ương Đảng, Phó Bí thư Đảng ủy, Tư lệnh Quân khu 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: 51512, 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); }); } });