如何在完整日历中自定义时段?

时间:2018-05-31 13:29:27

标签: javascript twitter-bootstrap fullcalendar momentjs

我正在使用fullcalendar.io的完整日历,并且无法自定义其时间段。

enter image description here

我想添加早餐,午餐,晚餐等时段,用户也可以添加他/她自己的插槽。如何根据插槽数设置固定高度?另外,我想设置早餐,午餐等插槽列文本,而不是早上12点,早上6点。这是我到目前为止所做的事情:



var today = moment();
$('#calendar').fullCalendar({
                    droppable: true,
                    defaultView: 'Week',
                    header: false,
                    defaultDate: today,
                    navLinks: false, // can click day/week names to navigate views
                    editable: true,
                    eventLimit: true, // allow "more" link when too many events
                    schedulerLicenseKey: 'GPL-My-Project-Is-Open-Source',
                    /*events: [

                        {
                            title  : 'event1',
                            start  : today,
                            imageurl:'assets/images/recipe/salad.jpg'
                        }

                    ],*/
                    /*views: {
                        agendaWeek: {
                            agendaEventMinHeight: 150,
                            allDaySlot: false,
                            slotLabelInterval: { hours: 6},
                            slotDuration: { hours: 1},
                            duration: { days: 7}
                        }
                    },*/
                    eventRender: function (event, element) {
                        element.find(".fc-event-title").remove();
                        element.find(".fc-event-time").remove();
                        var new_description = '#';
                        element.append(new_description);

                    },
                    now: today,
                    /*header: {
                        left: 'promptResource',
                        center: '',
                        right: ''

                    },*/
                    footer: {
                        left:   'promptResource',
                        center: '',
                        right:  ''
                    },
                    customButtons: {
                        promptResource: {
                            text: '+ add course',
                            click: function() {
                                var title = prompt('Course name');
                                if (title) {
                                    $('#calendar').fullCalendar(
                                        'addResource',
                                        { title: title },
                                        true // scroll to the new resource?
                                    );
                                }
                            }
                        }
                    },
                    views: {
                        Week: {
                            type: 'timeline',
                            duration: { Days: '7' },
                            slotLabelInterval: { hours: 24},
                            slotDuration: { hours: 24},
                        }
                    },
                    resourceLabelText: 'Meal',
                    resourceRender: function(resource, cellEls) {
                        cellEls.on('click', function() {
                            if (confirm('Are you sure you want to delete ' + resource.title + '?')) {
                                $('#calendar').fullCalendar('removeResource', resource);
                            }
                        });
                    },
                    resources: [
                        { id: 'a', title: 'Breakfast' , eventColor: 'red'},
                        { id: 'b', title: 'Lunch', eventColor: 'green' },
                        { id: 'c', title: 'Dinner', eventColor: 'orange' },
                        { id: 'd', title: 'Other', eventColor: 'grey'},
                        ],

                    events: [
                        { id: '1', resourceId: 'b', start: today, end: today, title: 'event 1' },
                        { id: '2', resourceId: 'c', start: '2018-04-07T05:00:00', end: '2018-04-07T22:00:00', title: 'event 2' },
                        { id: '3', resourceId: 'd', start: '2018-04-06', end: '2018-04-08', title: 'event 3' },
                        { id: '4', resourceId: 'e', start: '2018-04-07T03:00:00', end: '2018-04-07T08:00:00', title: 'event 4' },
                        { id: '5', resourceId: 'f', start: '2018-04-07T00:30:00', end: '2018-04-07T02:30:00', title: 'event 5' }
                    ]

                });

<link href="https://cdnjs.cloudflare.com/ajax/libs/fullcalendar/3.9.0/fullcalendar.min.css" data-print="true" rel="stylesheet" />
<script src="https://cdnjs.cloudflare.com/ajax/libs/moment.js/2.22.2/moment.min.js"></script>
<script src="https://ajax.googleapis.com/ajax/libs/jquery/3.2.1/jquery.min.js"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/fullcalendar/3.9.0/fullcalendar.min.js"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/fullcalendar-scheduler/1.9.4/scheduler.min.js"></script>
<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/fullcalendar-scheduler/1.9.4/scheduler.min.css" />
<div id="calendar"></div>
&#13;
&#13;
&#13;

任何帮助都会非常感激。

修改 这就是我实际想要实现的内容。 Design 在设计中,您可以看到一天中的时间并不重要。我希望用户尽可能多地每天添加多餐。我只想要添加餐的标题(活动)。并删除左侧的时间段。

更新 我在某种程度上设法解决了这个问题。现在看看它的外观:enter image description here 但仍然存在一些问题,比如如何更改columnHeader中的日期格式以及如何为行和列提供修复大小?

0 个答案:

没有答案