Documentation v8.2.4

Downloads Preview

Overview

Fullcalendar is one of the most popular Javascript Calendar. It's powerful and lightweight and suitable for just about anything. For more info see the official site and the Github repository.

Basic Example

Here's how a basic Fullcalendar will look like with data populated.
<template>
<FullCalendar
        class="demo-app-calendar"
        :options="calendarOptions"
></FullCalendar>
</template>

<script lang="ts">
    import { defineComponent } from "vue";
    import FullCalendar, { type CalendarOptions, EventApi } from "@fullcalendar/vue3";
    import dayGridPlugin from "@fullcalendar/daygrid";
    import timeGridPlugin from "@fullcalendar/timegrid";
    import listPlugin from "@fullcalendar/list";
    import moment from "moment";

    export default defineComponent({
        components: {
            FullCalendar,
        },
        data() {
            const todayDate = moment().startOf("day");
            const YM = todayDate.format("YYYY-MM");
            const YESTERDAY = todayDate.clone().subtract(1, "day").format("YYYY-MM-DD");
            const TODAY = todayDate.format("YYYY-MM-DD");
            const TOMORROW = todayDate.clone().add(1, "day").format("YYYY-MM-DD");
            return {
                calendarOptions: {
                    plugins: [dayGridPlugin, timeGridPlugin, listPlugin],
                    headerToolbar: {
                        left: "prev,next today",
                        center: "title",
                        right: "dayGridMonth,timeGridWeek,timeGridDay,listMonth",
                    },

                    height: 800,
                    contentHeight: 780,
                    aspectRatio: 3, // see: https://fullcalendar.io/docs/aspectRatio

                    nowIndicator: true,
                    now: TODAY + "T09:25:00", // just for demo

                    views: {
                        dayGridMonth: { buttonText: "month" },
                        timeGridWeek: { buttonText: "week" },
                        timeGridDay: { buttonText: "day" },
                    },

                    initialView: "dayGridMonth",
                    initialDate: TODAY,

                    editable: true,
                    dayMaxEvents: true, // allow "more" link when too many events
                    navLinks: true,
                    events: [
                        {
                            title: "All Day Event",
                            start: YM + "-01",
                            description: "Toto lorem ipsum dolor sit incid idunt ut",
                            className: "fc-event-danger fc-event-solid-warning",
                        },
                        {
                            title: "Reporting",
                            start: YM + "-14T13:30:00",
                            description: "Lorem ipsum dolor incid idunt ut labore",
                            end: YM + "-14",
                            className: "fc-event-success",
                        },
                        {
                            title: "Company Trip",
                            start: YM + "-02",
                            description: "Lorem ipsum dolor sit tempor incid",
                            end: YM + "-03",
                            className: "fc-event-primary",
                        },
                        {
                            title: "ICT Expo 2017 - Product Release",
                            start: YM + "-03",
                            description: "Lorem ipsum dolor sit tempor inci",
                            end: YM + "-05",
                            className: "fc-event-light fc-event-solid-primary",
                        },
                        {
                            title: "Dinner",
                            start: YM + "-12",
                            description: "Lorem ipsum dolor sit amet, conse ctetur",
                            end: YM + "-10",
                        },
                        {
                            id: 999,
                            title: "Repeating Event",
                            start: YM + "-09T16:00:00",
                            description: "Lorem ipsum dolor sit ncididunt ut labore",
                            className: "fc-event-danger",
                        },
                        {
                            id: 1000,
                            title: "Repeating Event",
                            description: "Lorem ipsum dolor sit amet, labore",
                            start: YM + "-16T16:00:00",
                        },
                        {
                            title: "Conference",
                            start: YESTERDAY,
                            end: TOMORROW,
                            description: "Lorem ipsum dolor eius mod tempor labore",
                            className: "fc-event-primary",
                        },
                        {
                            title: "Meeting",
                            start: TODAY + "T10:30:00",
                            end: TODAY + "T12:30:00",
                            description: "Lorem ipsum dolor eiu idunt ut labore",
                        },
                        {
                            title: "Lunch",
                            start: TODAY + "T12:00:00",
                            className: "fc-event-info",
                            description: "Lorem ipsum dolor sit amet, ut labore",
                        },
                        {
                            title: "Meeting",
                            start: TODAY + "T14:30:00",
                            className: "fc-event-warning",
                            description: "Lorem ipsum conse ctetur adipi scing",
                        },
                        {
                            title: "Happy Hour",
                            start: TODAY + "T17:30:00",
                            className: "fc-event-info",
                            description: "Lorem ipsum dolor sit amet, conse ctetur",
                        },
                        {
                            title: "Dinner",
                            start: TOMORROW + "T05:00:00",
                            className: "fc-event-solid-danger fc-event-light",
                            description: "Lorem ipsum dolor sit ctetur adipi scing",
                        },
                        {
                            title: "Birthday Party",
                            start: TOMORROW + "T07:00:00",
                            className: "fc-event-primary",
                            description: "Lorem ipsum dolor sit amet, scing",
                        },
                        {
                            title: "Click for Google",
                            url: "http://google.com/",
                            start: YM + "-28",
                            className: "fc-event-solid-info fc-event-light",
                            description: "Lorem ipsum dolor sit amet, labore",
                        },
                    ],
                } as CalendarOptions,
                currentEvents: [] as EventApi[],
            };
        },
    });
</script>

<style lang="scss">
    .fc .fc-button {
        padding: 0.75rem 1.25rem;
        box-shadow: none !important;
        border: 0 !important;
        border-radius: 0.475rem;
        vertical-align: middle;
        font-weight: 500;
        text-transform: capitalize;
    }
</style>
Preview Get Help Buy Now