external-dragging.html 4.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154
  1. <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
  2. <html>
  3. <head>
  4. <link rel='stylesheet' type='text/css' href='../fullcalendar/fullcalendar.css' />
  5. <link rel='stylesheet' type='text/css' href='../fullcalendar/fullcalendar.print.css' media='print' />
  6. <script type='text/javascript' src='../jquery/jquery-1.7.1.min.js'></script>
  7. <script type='text/javascript' src='../jquery/jquery-ui-1.8.17.custom.min.js'></script>
  8. <script type='text/javascript' src='../fullcalendar/fullcalendar.min.js'></script>
  9. <script type='text/javascript'>
  10. $(document).ready(function() {
  11. /* initialize the external events
  12. -----------------------------------------------------------------*/
  13. $('#external-events div.external-event').each(function() {
  14. // create an Event Object (http://arshaw.com/fullcalendar/docs/event_data/Event_Object/)
  15. // it doesn't need to have a start or end
  16. var eventObject = {
  17. title: $.trim($(this).text()) // use the element's text as the event title
  18. };
  19. // store the Event Object in the DOM element so we can get to it later
  20. $(this).data('eventObject', eventObject);
  21. // make the event draggable using jQuery UI
  22. $(this).draggable({
  23. zIndex: 999,
  24. revert: true, // will cause the event to go back to its
  25. revertDuration: 0 // original position after the drag
  26. });
  27. });
  28. /* initialize the calendar
  29. -----------------------------------------------------------------*/
  30. $('#calendar').fullCalendar({
  31. header: {
  32. left: 'prev,next today',
  33. center: 'title',
  34. right: 'month,agendaWeek,agendaDay'
  35. },
  36. editable: true,
  37. droppable: true, // this allows things to be dropped onto the calendar !!!
  38. drop: function(date, allDay) { // this function is called when something is dropped
  39. // retrieve the dropped element's stored Event Object
  40. var originalEventObject = $(this).data('eventObject');
  41. // we need to copy it, so that multiple events don't have a reference to the same object
  42. var copiedEventObject = $.extend({}, originalEventObject);
  43. // assign it the date that was reported
  44. copiedEventObject.start = date;
  45. copiedEventObject.allDay = allDay;
  46. // render the event on the calendar
  47. // the last `true` argument determines if the event "sticks" (http://arshaw.com/fullcalendar/docs/event_rendering/renderEvent/)
  48. $('#calendar').fullCalendar('renderEvent', copiedEventObject, true);
  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. $(this).remove();
  53. }
  54. }
  55. });
  56. });
  57. </script>
  58. <style type='text/css'>
  59. body {
  60. margin-top: 40px;
  61. text-align: center;
  62. font-size: 14px;
  63. font-family: "Lucida Grande",Helvetica,Arial,Verdana,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-event { /* try to mimick the look of a real event */
  83. margin: 10px 0;
  84. padding: 2px 4px;
  85. background: #3366CC;
  86. color: #fff;
  87. font-size: .85em;
  88. cursor: pointer;
  89. }
  90. #external-events p {
  91. margin: 1.5em 0;
  92. font-size: 11px;
  93. color: #666;
  94. }
  95. #external-events p input {
  96. margin: 0;
  97. vertical-align: middle;
  98. }
  99. #calendar {
  100. float: right;
  101. width: 900px;
  102. }
  103. </style>
  104. </head>
  105. <body>
  106. <div id='wrap'>
  107. <div id='external-events'>
  108. <h4>Draggable Events</h4>
  109. <div class='external-event'>My Event 1</div>
  110. <div class='external-event'>My Event 2</div>
  111. <div class='external-event'>My Event 3</div>
  112. <div class='external-event'>My Event 4</div>
  113. <div class='external-event'>My Event 5</div>
  114. <p>
  115. <input type='checkbox' id='drop-remove' /> <label for='drop-remove'>remove after drop</label>
  116. </p>
  117. </div>
  118. <div id='calendar'></div>
  119. <div style='clear:both'></div>
  120. </div>
  121. </body>
  122. </html>