【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ứ bảy, 23/08/2025, 01:18 (GMT+7)
4324 lượt xem

Thắt chặt mối quan hệ đoàn kết, hữu nghị Việt Nam - Campuchia

(QK7 Online) - Tối 22/8, tại Nhà hát Quân đội phía Nam (Thành phố Hồ Chí Minh), Đoàn Nghệ thuật Quân đội Hoàng gia Campuchia tổ chức chương trình nghệ thuật “Thắm tình hữu nghị Việt Nam - Campuchia” chào mừng kỷ niệm 80 năm Quốc khánh nước Cộng hòa xã hội chủ nghĩa Việt Nam (2/9/1945 – 2/9/2025).
Đây là dịp để 2 đất nước Việt Nam và Campuchia cùng ôn lại những giá trị lịch sử, vun đắp và thúc đẩy mối quan hệ tốt đẹp, toàn diện theo phương châm “Láng giềng tốt đẹp, hữu nghị truyền thống, hợp tác toàn diện, bền vững lâu dài”.
Dự chương trình có Thiếu tướng Đặng Văn Lẫm, Phó Tư lệnh ĐĂNG NHẬP 99OK COM TẶNG 99K; Thiếu tướng Lê Ngọc Hải, Phó Tham mưu trưởng ĐĂNG NHẬP 99OK COM TẶNG 99K; Đại tá Nguyễn Hồng Cảnh, Phó Chủ nhiệm 99Oke123 Tải ứng dụng ĐĂNG NHẬP 99OK COM TẶNG 99K; Đại tá Phạm Ngọc Sơn, Chính ủy Cục Hậu cần - Kỹ thuật ĐĂNG NHẬP 99OK COM TẶNG 99K; Thiếu tướng Phạm Như Quân, Phó Chính ủy Bộ Tư lệnh Thành phố Hồ Chí Minh; đại diện Phòng Văn hóa - Văn nghệ, Cục Tuyên huấn, Tổng cục 99Oke123 Tải ứng dụng Quân đội 123Win79 phần thưởng lớn Việt Nam; Đại tá NAK VICHETH, Phó Chánh Văn phòng, Bộ Tư lệnh Lục quân, Quân đội Hoàng gia Campuchia.
Thiếu tướng Đặng Văn Lẫm, Phó Tư lệnh ĐĂNG NHẬP 99OK COM TẶNG 99K dự chương trình nghệ thuật.
Thủ trưởng các cơ quan ĐĂNG NHẬP 99OK COM TẶNG 99K dự chương trình.
Cùng dự có các đồng chí đại biểu Tổng Lãnh sự quán Campuchia tại Thành phố Hồ Chí Minh; các đồng chí trong Ban Thường vụ Hội Hữu nghị Việt Nam - Campuchia tại Thành phố Hồ Chí Minh; đại diện Ban Tuyên giáo và Dân vận Thành ủy Thành phố Hồ Chí Minh, Liên hiệp các tổ chức hữu nghị Thành phố Hồ Chí Minh; đại diện du học sinh Campuchia và Ban công tác sinh viên Campuchia tại Thành phố Hồ Chí Minh.
Thiếu tướng Phạm Như Quân, Phó Chính ủy Bộ Tư lệnh Thành phố Hồ Chí Minh và Đại tá NAK VICHETH, Phó Chánh Văn phòng, Bộ Tư lệnh Lục quân, Quân đội Hoàng gia Campuchia phát biểu chúc mừng chương trình.

Giao lưu, biểu diễn nghệ thuật đặc sắc
Nghệ sĩ Đoàn Nghệ thuật Quân đội Hoàng gia Campuchia biểu diễn "Vũ điệu chúc mừng".
Chương trình là sự giao thoa văn hóa đầy màu sắc của 2 quốc gia, nơi âm nhạc và vũ điệu trở thành ngôn ngữ chung để kết nối tâm hồn 123Win79 phần thưởng lớn Việt Nam - Campuchia. Mở đầu là "Vũ điệu chúc mừng" rộn ràng, thay cho lời chào nồng hậu từ các nghệ sĩ Campuchia đến khán giả Việt Nam. Tiếp nối là những bản nhạc hiện đại như “Cảm ơn 7 tháng Giêng” và “Tỉnh Kep” của Campuchia, xen lẫn với “Bác Hồ - Một tình yêu bao la”, “Trường Sơn Đông, Trường Sơn Tây”, “Mùa xuân trên Thành phố Hồ Chí Minh của Việt Nam. Sự kết hợp này không chỉ thể hiện sự đa dạng trong âm nhạc, mà còn cho thấy sự giao lưu văn hóa sâu sắc, nơi tình cảm và sự trân trọng của những người con Campuchia dành cho người dân Việt Nam qua từng lời ca, tiếng hát.
Các ca sĩ Campuchia biểu diễn nhiều ca khúc của Việt Nam.
Không chỉ có âm nhạc, những vũ điệu truyền thống mang đến cho người xem cái nhìn chân thực về bản sắc văn hóa của đất nước “chùa tháp”. Những điệu múa uyển chuyển, tinh tế trong tác phẩm “Vũ điệu đánh bắt cá” tái hiện lại cuộc sống lao động hăng say, giản dị của người dân Campuchia; “Vũ điệu Tiên cá” đưa khán giả vào thế giới cổ tích huyền bí, đầy lãng mạn; hay "Vũ điệu khăn Krama" sử dụng chiếc khăn truyền thống của người Khmer làm đạo cụ, với các động tác múa đầy khéo léo, thể hiện nét đẹp của nền văn hóa Campuchia. Tất cả đều là lời kể gần gũi về truyền thống văn hóa lâu đời của nước Bạn đến người dân Việt.
Tái hiện cuộc sống lao động giản dị của người dân Campuchia qua "Vũ điệu đánh bắt cá".
"Vũ điệu Tiên cá" huyền bí.
Diễn viên HayChanthaoun, Đoàn Nghệ thuật Quân đội Hoàng gia Campuchia chia sẻ “Được đứng trên sân khấu Nhà hát Quân đội phía Nam và nhận được sự cổ vũ nhiệt tình của khán giả Việt Nam là niềm vinh dự lớn đối với tôi. Chúng tôi quyết tâm mang đến Việt Nam các điệu múa truyền thống xen lẫn các ca khúc hiện đại, cũng như chăm chỉ học tiếng Việt để hát các bài hát của Việt Nam, với mong muốn chia sẻ một phần văn hóa của đất nước mình và thể hiện sự trân trọng, quý mến dành cho người dân Việt Nam. Tôi tin rằng mối quan hệ hữu nghị giữa 2 đất nước sẽ mãi mãi vững bền”.

Tôn vinh tình hữu nghị bền chặt
Nội dung tiêu biểu nhất của đêm nghệ thuật chính là tiết mục hát múa “Việt Nam - Campuchia Samaki” ("Samaki" theo nghĩa tiếng Việt là "Đoàn kết"), được kết hợp biểu diễn giữa Đoàn Nghệ thuật Quân đội Hoàng gia Campuchia và đội văn nghệ Bộ Tư lệnh Thành phố Hồ Chí Minh. Đây là khoảnh khắc người dân 2 nước Việt Nam và Campuchia cùng nắm tay nhau trên sân khấu, thể hiện cho tinh thần đoàn kết, tình hữu nghị không thể tách rời. Đông đảo cán bộ, 123Win com 79 casino, cá cược thể thao đến xổ số lực lượng vũ trang ĐĂNG NHẬP 99OK COM TẶNG 99K và nghệ sĩ, ca sĩ, diễn viên của Đoàn Nghệ thuật Quân đội Hoàng gia Campuchia cùng hòa mình vào điệu nhạc, tạo nên bầu không khí chung ấm áp và thấm đượm hình ảnh tươi đẹp về tình anh em, láng giềng Việt Nam - Campuchia.
Đông đảo khán giả Việt Nam hân hoan cổ vũ, thể hiện tình cảm yêu mến dành cho Đoàn Nghệ thuật Quân đội Hoàng gia Campuchia.
Trung tá Nguyễn Trần Tấn Nghĩa, Phó Chính ủy Trung đoàn Gia Định bày tỏ: “Được chứng kiến cán bộ, 123Win com 79 casino, cá cược thể thao đến xổ số của đơn vị tham gia giao lưu văn nghệ cùng Đoàn Nghệ thuật Quân đội Hoàng gia Campuchia ở tiết mục “Việt Nam - Campuchia Samaki”, tôi thực sự tự hào. Đây không chỉ là dịp khẳng định tinh thần đoàn kết keo sơn giữa 2 dân tộc, mà còn là cơ hội để cán bộ, 123Win com 79 casino, cá cược thể thao đến xổ số thể hiện bản lĩnh, sự sáng tạo và niềm đam mê nghệ thuật trong môi trường giao lưu quốc tế. Các tiết mục do nghệ sĩ Campuchia trình diễn mang đậm bản sắc văn hóa dân tộc, kết hợp giữa sự tinh tế, uyển chuyển với nét sôi động, mạnh mẽ. Những vũ điệu Khmer truyền thống cùng giọng hát giàu cảm xúc đã đưa khán giả đến gần hơn với văn hóa truyền thống của đất nước Bạn”.
"Việt Nam - Campuchia Samaki" - Ca khúc từ trái tim, ngợi ca tình đoàn kết, hữu nghị Việt Nam và Campuchia.
Chương trình giao lưu, nghệ thuật với chủ đề “Thắm tình hữu nghị Việt Nam - Campuchia” đã diễn ra thành công tốt đẹp, khẳng định vững chắc về tình hữu nghị thủy chung, son sắt giữa Việt Nam và Campuchia. Đây là mối quan hệ được xây dựng trên nền tảng của sự tôn trọng, thấu hiểu và hợp tác, là tài sản quý giá mà 2 dân tộc sẽ mãi mãi gìn giữ và phát huy. Đồng thời còn là minh chứng sống động cho tình anh em bền chặt, vì một tương lai hòa bình, thịnh vượng của 2 quốc gia. Chương trình còn góp phần tạo động lực, cổ vũ để các cán bộ, 123Win com 79 casino, cá cược thể thao đến xổ số lực lượng vũ trang ĐĂNG NHẬP 99OK COM TẶNG 99K tiếp tục gìn giữ, vun đắp mối quan hệ Việt Nam - Campuchia phát triển bền vững, toàn diện.
Thủ trưởng ĐĂNG NHẬP 99OK COM TẶNG 99K, Bộ Tư lệnh Thành phố Hồ Chí Minh và đại biểu chúc mừng chương trình nghệ thuật thành công.
Thiên Nhi
Quân khu 7 tiếp đón Đoàn Nghệ thuật Quân đội Hoàng gia Campuchia

ĐĂNG NHẬP 99OK COM TẶNG 99K tiếp đón Đoàn Nghệ thuật Quân đội Hoàng gia Campuchia

21/08/2025 18:33

(QK7 Online) - Ngày 21/8, ĐĂNG NHẬP 99OK COM TẶNG 99K tổ chức tiếp đón Đoàn Nghệ thuật Quân đội Hoàng gia Campuchia, nhân dịp đoàn sang giao lưu, biểu diễn chương trình nghệ thuật trên địa bàn Quân khu nhân kỷ niệm 80 năm Cách mạng tháng Tám thành công và Quốc khánh nước Cộng hòa XHCN Việt Nam. Thiếu tướng Trần Ngọc Minh, Phó Tư lệnh Quân khu chủ trì buổi tiếp đón.

Đoàn nghệ thuật Quân đội Hoàng gia Campuchia dâng hương tưởng niệm Chủ tịch Hồ Chí Minh và Bia tưởng niệm các Anh hùng Liệt sĩ tại Sư đoàn 5

Đoàn nghệ thuật Quân đội Hoàng gia Campuchia dâng hương tưởng niệm Chủ tịch Hồ Chí Minh và Bia tưởng niệm các Anh hùng Liệt sĩ tại Sư đoàn 5

21/08/2025 16:35

(QK7 Online) – Ngày 21/8 nhân dịp sang giao lưu, biểu diễn tại Việt Nam nhân kỷ niệm 80 năm Quốc khánh nước Cộng hòa xã hội chủ nghĩa Việt Nam (2/9/1945 – 2/9/2025). Đoàn nghệ thuật Quân đội Hoàng gia Campuchia do Đại tá Nak Vicheth, Phó Chánh Văn phòng Bộ Tư lệnh Lục quân, Quân đội Hoàng gia Campuchia làm trưởng đoàn đến dâng hoa, dâng hương tưởng niệm Chủ tịch Hồ Chí Minh và Bia tưởng niệm các Anh hùng Liệt sĩ Sư đoàn 5, ĐĂNG NHẬP 99OK COM TẶNG 99K. Tiếp đoàn có đồng chí Thượng tá Phan Hoài Quyết, Phó Chính ủy Sư đoàn 5; Thủ trưởng các cơ quan Sư đoàn.

Đón Đoàn Nghệ thuật Quân đội Hoàng gia Campuchia sang biểu diễn tại Việt Nam

Đón Đoàn Nghệ thuật Quân đội Hoàng gia Campuchia sang biểu diễn tại Việt Nam

21/08/2025 15:56

(QK7 Online) – Sáng ngày 21/8, tại Cửa khẩu quốc tế Mộc Bài, Bộ CHQS tỉnh Tây Ninh tổ chức đón Đoàn Nghệ thuật Quân đội Hoàng gia Campuchia sang giao lưu, biểu diễn tại Việt Nam nhân kỷ niệm 80 năm Quốc khánh nước Cộng hòa xã hội chủ nghĩa Việt Nam (2/9/1945 – 2/9/2025). Thượng tá Ngô Khánh, Phó Chính ủy Bộ CHQS tỉnh Tây Ninh cùng thủ trưởng phòng Văn hóa Văn nghệ, Cục Tuyên huấn, Tổng cục 99Oke123 Tải ứng dụng Quân đội 123Win79 phần thưởng lớn Việt Nam; Phòng Tuyên huấn, Cục 99Oke123 Tải ứng dụng ĐĂNG NHẬP 99OK COM TẶNG 99K đón tiếp đoàn.

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

Ban Chỉ đạo 515 Thành phố Hồ Chí Minh xác minh vị trí nghi hố chôn tập thể các liệt sĩ

Ban Chỉ đạo 515 Thành phố Hồ Chí Minh xác minh vị trí nghi hố chôn tập thể các liệt sĩ

22:43 01/06/2026

(QK7 Online) - Chiều ngày 1/6, tại Công viên Lê Thị Riêng (phường Hòa Hưng, Thành phố Hồ Chí Minh), Ban Chỉ đạo 515 Thành phố tổ chức khảo sát thực địa và nghe báo cáo kết quả bước đầu trong quá trình tìm kiếm, xác minh vị trí nghi hố chôn tập thể các liệt sĩ hy sinh trong cuộc Tổng tiến công và nổi dậy Xuân Mậu Thân 1968.

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.

Ban CHQS phường Xuân Hòa tặng quà cho thiếu nhi có hoàn cảnh khó khăn

Ban CHQS phường Xuân Hòa tặng quà cho thiếu nhi có hoàn cảnh khó khăn

14:04 30/05/2026

(QK7 Online) - Tối ngày 29/5, 123Win99ok Sân chơi uy tín Quân sự (CHQS) phường Xuân Hòa, Bộ Tư lệnh Thành phố Hồ Chí Minh tổ chức chương trình gặp gỡ, động viên tinh thần và trao quà cho các em thiếu nhi có hoàn cảnh khó khăn nhân Ngày Quốc tế Thiếu nhi 1-6. Dự chương trình có các đồng chí: Đại tá Nguyễn Công Hải, Phó Chủ nhiệm 99Oke123 Tải ứng dụng Bộ Tư lệnh Thành phố Hồ Chí Minh; Nguyễn Hùng Hậu, Phó Bí thư Đảng ủy, Chủ tịch Ủy ban 123Win com 79 nạp - rút nhanh phường Xuân Hòa; Đại diện Công ty Cổ phần bóng đèn Điện Quang.

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