external-dragging.html 4.8 KB

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