_external-dragging-dragula.html 3.8 KB

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