external-dragging-builtin.html 3.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150
  1. <!DOCTYPE html>
  2. <html>
  3. <head>
  4. <meta charset='utf-8' />
  5. <link href='../lib/main.css' rel='stylesheet' />
  6. <script src='../lib/main.js'></script>
  7. <script>
  8. document.addEventListener('DOMContentLoaded', function() {
  9. /* initialize the external events
  10. -----------------------------------------------------------------*/
  11. var containerEl = document.getElementById('external-events-list');
  12. new FullCalendar.Draggable(containerEl, {
  13. itemSelector: '.fc-event',
  14. eventData: function(eventEl) {
  15. return {
  16. title: eventEl.innerText.trim()
  17. }
  18. }
  19. });
  20. //// the individual way to do it
  21. // var containerEl = document.getElementById('external-events-list');
  22. // var eventEls = Array.prototype.slice.call(
  23. // containerEl.querySelectorAll('.fc-event')
  24. // );
  25. // eventEls.forEach(function(eventEl) {
  26. // new FullCalendar.Draggable(eventEl, {
  27. // eventData: {
  28. // title: eventEl.innerText.trim(),
  29. // }
  30. // });
  31. // });
  32. /* initialize the calendar
  33. -----------------------------------------------------------------*/
  34. var calendarEl = document.getElementById('calendar');
  35. var calendar = new FullCalendar.Calendar(calendarEl, {
  36. headerToolbar: {
  37. left: 'prev,next today',
  38. center: 'title',
  39. right: 'dayGridMonth,timeGridWeek,timeGridDay,listWeek'
  40. },
  41. editable: true,
  42. droppable: true, // this allows things to be dropped onto the calendar
  43. drop: function(arg) {
  44. // is the "remove after drop" checkbox checked?
  45. if (document.getElementById('drop-remove').checked) {
  46. // if so, remove the element from the "Draggable Events" list
  47. arg.draggedEl.parentNode.removeChild(arg.draggedEl);
  48. }
  49. }
  50. });
  51. calendar.render();
  52. });
  53. </script>
  54. <style>
  55. body {
  56. margin-top: 40px;
  57. font-size: 14px;
  58. font-family: Arial, Helvetica Neue, Helvetica, sans-serif;
  59. }
  60. #external-events {
  61. position: fixed;
  62. left: 20px;
  63. top: 20px;
  64. width: 150px;
  65. padding: 0 10px;
  66. border: 1px solid #ccc;
  67. background: #eee;
  68. text-align: left;
  69. }
  70. #external-events h4 {
  71. font-size: 16px;
  72. margin-top: 0;
  73. padding-top: 1em;
  74. }
  75. #external-events .fc-event {
  76. margin: 3px 0;
  77. cursor: move;
  78. }
  79. #external-events p {
  80. margin: 1.5em 0;
  81. font-size: 11px;
  82. color: #666;
  83. }
  84. #external-events p input {
  85. margin: 0;
  86. vertical-align: middle;
  87. }
  88. #calendar-wrap {
  89. margin-left: 200px;
  90. }
  91. #calendar {
  92. max-width: 1100px;
  93. margin: 0 auto;
  94. }
  95. </style>
  96. </head>
  97. <body>
  98. <div id='wrap'>
  99. <div id='external-events'>
  100. <h4>Draggable Events</h4>
  101. <div id='external-events-list'>
  102. <div class='fc-event fc-h-event fc-daygrid-event fc-daygrid-block-event'>
  103. <div class='fc-event-main'>My Event 1</div>
  104. </div>
  105. <div class='fc-event fc-h-event fc-daygrid-event fc-daygrid-block-event'>
  106. <div class='fc-event-main'>My Event 2</div>
  107. </div>
  108. <div class='fc-event fc-h-event fc-daygrid-event fc-daygrid-block-event'>
  109. <div class='fc-event-main'>My Event 3</div>
  110. </div>
  111. <div class='fc-event fc-h-event fc-daygrid-event fc-daygrid-block-event'>
  112. <div class='fc-event-main'>My Event 4</div>
  113. </div>
  114. <div class='fc-event fc-h-event fc-daygrid-event fc-daygrid-block-event'>
  115. <div class='fc-event-main'>My Event 5</div>
  116. </div>
  117. </div>
  118. <p>
  119. <input type='checkbox' id='drop-remove' />
  120. <label for='drop-remove'>remove after drop</label>
  121. </p>
  122. </div>
  123. <div id='calendar-wrap'>
  124. <div id='calendar'></div>
  125. </div>
  126. </div>
  127. </body>
  128. </html>