_external-dragging-dragula.html 3.4 KB

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