Files
Atomcms-edit/resources/themes/atom/js/components/AtomSliders.ts
T
root e6d92f27b3 Migrate JavaScript to TypeScript with full type safety
- Rename all .js/.jsx files to .ts/.tsx across resources/js and theme dirs
- Add TypeScript 6.0 with strict mode, tsconfig.json
- Add type definitions for Inertia page props, Alpine.js, Turbolinks
- Update vite.config.js entries to .ts/.tsx extensions
- Update all Blade @vite() calls to match new .ts/.tsx entry points
- Add TypeScript ESLint config (replacing unused Vue plugin)
- Add @types/react, @types/react-dom, @types/lodash
- Add typecheck script and integrate into check pipeline
- Full tsc --noEmit, ESLint, and production build pass cleanly
2026-06-18 17:00:00 +02:00

36 lines
702 B
TypeScript
Executable File

import Swiper from "swiper";
interface AtomSlidersStore {
init(): void;
initArticleSlider(): void;
}
const AtomSliders: AtomSlidersStore = {
init() {
document.addEventListener("turbolinks:load", () => {
this.initArticleSlider();
});
},
initArticleSlider() {
if (!document.querySelector(".article-slider")) return;
new Swiper(".articles-slider", {
modules: [],
slidesPerView: 1,
loop: true,
autoplay: {
delay: 5000,
disableOnInteraction: false,
pauseOnMouseEnter: true,
},
pagination: {
el: ".swiper-pagination",
clickable: true,
},
});
},
};
export { AtomSliders as default };