external-dragging.html 3.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153
  1. <!DOCTYPE html>
  2. <html>
  3. <head>
  4. <meta charset='utf-8' />
  5. <link href='../fullcalendar.css' rel='stylesheet' />
  6. <link href='../fullcalendar.print.css' rel='stylesheet' media='print' />
  7. <script src='../lib/moment.min.js'></script>
  8. <script src='../lib/jquery.min.js'></script>
  9. <script src='../lib/jquery-ui.custom.min.js'></script>
  10. <script src='../fullcalendar.min.js'></script>
  11. <script>
  12. $(document).ready(function() {
  13. /* initialize the external events
  14. -----------------------------------------------------------------*/
  15. $('#external-events .fc-event').each(function() {
  16. // create an Event Object (http://arshaw.com/fullcalendar/docs/event_data/Event_Object/)
  17. // it doesn't need to have a start or end
  18. var eventObject = {
  19. title: $.trim($(this).text()) // use the element's text as the event title
  20. };
  21. // store the Event Object in the DOM element so we can get to it later
  22. $(this).data('eventObject', eventObject);
  23. // make the event draggable using jQuery UI
  24. $(this).draggable({
  25. zIndex: 999,
  26. revert: true, // will cause the event to go back to its
  27. revertDuration: 0 // original position after the drag
  28. });
  29. });
  30. /* initialize the calendar
  31. -----------------------------------------------------------------*/
  32. $('#calendar').fullCalendar({
  33. header: {
  34. left: 'prev,next today',
  35. center: 'title',
  36. right: 'month,agendaWeek,agendaDay'
  37. },
  38. editable: true,
  39. droppable: true, // this allows things to be dropped onto the calendar !!!
  40. drop: function(date) { // this function is called when something is dropped
  41. // retrieve the dropped element's stored Event Object
  42. var originalEventObject = $(this).data('eventObject');
  43. // we need to copy it, so that multiple events don't have a reference to the same object
  44. var copiedEventObject = $.extend({}, originalEventObject);
  45. // assign it the date that was reported
  46. copiedEventObject.start = date;
  47. // render the event on the calendar
  48. // the last `true` argument determines if the event "sticks" (http://arshaw.com/fullcalendar/docs/event_rendering/renderEvent/)
  49. $('#calendar').fullCalendar('renderEvent', copiedEventObject, true);
  50. // is the "remove after drop" checkbox checked?
  51. if ($('#drop-remove').is(':checked')) {
  52. // if so, remove the element from the "Draggable Events" list
  53. $(this).remove();
  54. }
  55. }
  56. });
  57. });
  58. </script>
  59. <style>
  60. body {
  61. margin-top: 40px;
  62. text-align: center;
  63. font-size: 14px;
  64. font-family: "Lucida Grande",Helvetica,Arial,Verdana,sans-serif;
  65. }
  66. #wrap {
  67. width: 1100px;
  68. margin: 0 auto;
  69. }
  70. #external-events {
  71. float: left;
  72. width: 150px;
  73. padding: 0 10px;
  74. border: 1px solid #ccc;
  75. background: #eee;
  76. text-align: left;
  77. }
  78. #external-events h4 {
  79. font-size: 16px;
  80. margin-top: 0;
  81. padding-top: 1em;
  82. }
  83. #external-events .fc-event {
  84. margin: 10px 0;
  85. cursor: pointer;
  86. }
  87. #external-events p {
  88. margin: 1.5em 0;
  89. font-size: 11px;
  90. color: #666;
  91. }
  92. #external-events p input {
  93. margin: 0;
  94. vertical-align: middle;
  95. }
  96. #calendar {
  97. float: right;
  98. width: 900px;
  99. }
  100. </style>
  101. </head>
  102. <body>
  103. <div id='wrap'>
  104. <div id='external-events'>
  105. <h4>Draggable Events</h4>
  106. <div class='fc-event'>My Event 1</div>
  107. <div class='fc-event'>My Event 2</div>
  108. <div class='fc-event'>My Event 3</div>
  109. <div class='fc-event'>My Event 4</div>
  110. <div class='fc-event'>My Event 5</div>
  111. <p>
  112. <input type='checkbox' id='drop-remove' />
  113. <label for='drop-remove'>remove after drop</label>
  114. </p>
  115. </div>
  116. <div id='calendar'></div>
  117. <div style='clear:both'></div>
  118. </div>
  119. </body>
  120. </html>