_external-dragging-jqueryui.html 3.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143
  1. <!DOCTYPE html>
  2. <html>
  3. <head>
  4. <meta charset='utf-8' />
  5. <link href='../packages/core/dist/main.css' rel='stylesheet' />
  6. <link href='../packages/daygrid/dist/main.css' rel='stylesheet' />
  7. <link href='../packages/timegrid/dist/main.css' rel='stylesheet' />
  8. <script src='../node_modules/jquery/dist/jquery.js'></script>
  9. <script src='../node_modules/components-jqueryui/jquery-ui.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. new ThirdPartyDraggable({
  19. mirrorSelector: '.ui-draggable-dragging'
  20. })
  21. /* initialize the external events
  22. -----------------------------------------------------------------*/
  23. $('#external-events .fc-event').each(function() {
  24. // store data so the calendar knows to render an event upon drop
  25. $(this).attr('data-event', JSON.stringify({
  26. title: $.trim($(this).text()), // use the element's text as the event title
  27. stick: true // maintain when user navigates (see docs on the renderEvent method)
  28. }));
  29. // make the event draggable using jQuery UI
  30. $(this).draggable({
  31. zIndex: 999,
  32. revert: true, // will cause the event to go back to its
  33. revertDuration: 0 // original position after the drag
  34. });
  35. });
  36. /* initialize the calendar
  37. -----------------------------------------------------------------*/
  38. var calendarEl = document.getElementById('calendar');
  39. var calendar = new Calendar(calendarEl, {
  40. plugins: [ 'interaction', 'dayGrid', 'timeGrid' ],
  41. header: {
  42. left: 'prev,next today',
  43. center: 'title',
  44. right: 'dayGridMonth,timeGridWeek,timeGridDay'
  45. },
  46. editable: true,
  47. droppable: true, // this allows things to be dropped onto the calendar
  48. drop: function(arg) {
  49. // is the "remove after drop" checkbox checked?
  50. if ($('#drop-remove').is(':checked')) {
  51. // if so, remove the element from the "Draggable Events" list
  52. $(arg.draggedEl).remove();
  53. }
  54. }
  55. });
  56. calendar.render();
  57. });
  58. </script>
  59. <style>
  60. body {
  61. margin-top: 40px;
  62. font-size: 14px;
  63. font-family: Arial, Helvetica Neue, Helvetica, sans-serif;
  64. }
  65. #wrap {
  66. width: 1100px;
  67. margin: 0 auto;
  68. }
  69. #external-events {
  70. float: left;
  71. width: 150px;
  72. padding: 0 10px;
  73. border: 1px solid #ccc;
  74. background: #eee;
  75. text-align: left;
  76. }
  77. #external-events h4 {
  78. font-size: 16px;
  79. margin-top: 0;
  80. padding-top: 1em;
  81. }
  82. #external-events .fc-event {
  83. margin: 10px 0;
  84. cursor: pointer;
  85. }
  86. #external-events p {
  87. margin: 1.5em 0;
  88. font-size: 11px;
  89. color: #666;
  90. }
  91. #external-events p input {
  92. margin: 0;
  93. vertical-align: middle;
  94. }
  95. #calendar {
  96. float: right;
  97. width: 900px;
  98. }
  99. </style>
  100. </head>
  101. <body>
  102. <div id='wrap'>
  103. <div id='external-events'>
  104. <h4>Draggable Events</h4>
  105. <div class='fc-event'>My Event 1</div>
  106. <div class='fc-event'>My Event 2</div>
  107. <div class='fc-event'>My Event 3</div>
  108. <div class='fc-event'>My Event 4</div>
  109. <div class='fc-event'>My Event 5</div>
  110. <p>
  111. <input type='checkbox' id='drop-remove' />
  112. <label for='drop-remove'>remove after drop</label>
  113. </p>
  114. </div>
  115. <div id='calendar'></div>
  116. <div style='clear:both'></div>
  117. </div>
  118. </body>
  119. </html>