liquid_feedback_frontend

annotate static/js/dragdrop.js @ 75:733f65c0c0a0

Bugfixes, feature enhancements, code-cleanup, and major work on API

Details:
- API
-- Allow relation name to be passed to helper function util.autoapi{...}
-- Added area API
-- Bugfixes in API
--- Correctly return initiatives (bug #162)
--- Correctly process "id" parameter for initiative API
--- Bugfix related to "state" parameter (bug #165)
--- Changed constant "discussion" to "accepted" (in model/issue.lua, used by API)
--- Fixed JSON encoding in auto_api (bug #181)
--- Ignore list filter "voted" in case of public access
--- Enable access to API without session
- Work on RSS feed (incomplete yet)
- Other bugfixes
-- Handle empty browser identification string
-- Handle invalid date in member/update.lua (bugs #24 #109 #115 #136)
-- Better handle errors while converting uploaded images. (bug #79 +5 duplicates)
-- Don't display revoked initiatives in list of new drafts (bug #134)
-- Fixed syntax error in app/main/member/_action/update_name.lua throwing unexpected error, when new name was too short
-- Do not display refresh support button for revoked initiatives
-- Repaired issue search (bug #150)
-- Fixed typos in german translation files
--- "initi(i)erte"
--- "Er(g)eignisse" (bug #161)
- Code cleanup
-- Removed deprecated motd files locale/motd/de.txt and locale/motd/de_public.txt
-- Removed redundant code in app/main/index/_updated_drafts.lua
- New features and (optical) enhancements
-- Support change of notify email; notification of not approved address added to start page
-- Settings dialog splitted into single pages
-- Mark deactivated members
-- Calendar for birthday selection in profile
-- Policy list public readable when public access is enabled
author bsw
date Thu Jul 08 18:44:02 2010 +0200 (2010-07-08)
parents 8d91bccab0bf
children 7492497005bd
rev   line source
bsw/jbe@5 1 window.addEventListener("load", function(event) {
bsw/jbe@5 2 var originalElement;
bsw/jbe@5 3 var draggedElement;
bsw/jbe@5 4 var mouseX;
bsw/jbe@5 5 var mouseY;
bsw/jbe@5 6 var mouseOffsetX;
bsw/jbe@5 7 var mouseOffsetY;
bsw/jbe@5 8 var elementOffsetX;
bsw/jbe@5 9 var elementOffsetY;
bsw/jbe@5 10 var dropFunc;
bsw/jbe@5 11 var dragElement = function(element, func) {
bsw/jbe@5 12 //if (typeof(element) == "string") element = document.getElementById(element);
bsw/jbe@5 13 originalElement = element;
bsw/jbe@5 14 draggedElement = originalElement.cloneNode(true);
bsw/jbe@5 15 originalElement.style.visibility = "hidden";
bsw/jbe@5 16 draggedElement.style.margin = 0;
bsw/jbe@5 17 draggedElement.style.position = "absolute";
bsw/jbe@5 18 draggedElement.style.left = elementOffsetX = originalElement.offsetLeft;
bsw/jbe@5 19 draggedElement.style.top = elementOffsetY = originalElement.offsetTop;
bsw/jbe@5 20 draggedElement.style.width = originalElement.clientWidth;
bsw/jbe@5 21 draggedElement.style.height = originalElement.clientHeight;
bsw/jbe@5 22 draggedElement.style.backgroundColor = "#eee";
bsw/jbe@5 23 draggedElement.style.opacity = 0.8;
bsw/jbe@5 24 originalElement.offsetParent.appendChild(draggedElement);
bsw/jbe@5 25 // workaround for wrong clientWidth and clientHeight information:
bsw/jbe@5 26 draggedElement.style.width = 2*originalElement.clientWidth - draggedElement.clientWidth;
bsw/jbe@5 27 draggedElement.style.height = 2*originalElement.clientHeight - draggedElement.clientHeight;
bsw/jbe@5 28 mouseOffsetX = mouseX;
bsw/jbe@5 29 mouseOffsetY = mouseY;
bsw/jbe@5 30 dropFunc = func;
bsw/jbe@5 31 };
bsw/jbe@5 32 window.addEventListener("mousemove", function(event) {
bsw/jbe@5 33 mouseX = event.pageX;
bsw/jbe@5 34 mouseY = event.pageY;
bsw/jbe@5 35 if (draggedElement) {
bsw/jbe@5 36 draggedElement.style.left = elementOffsetX + mouseX - mouseOffsetX;
bsw/jbe@5 37 draggedElement.style.top = elementOffsetY + mouseY - mouseOffsetY;
bsw/jbe@5 38 }
bsw/jbe@5 39 }, true);
bsw/jbe@5 40 var mouseDrop = function(event) {
bsw/jbe@5 41 if (draggedElement) {
bsw/jbe@5 42 dropFunc(
bsw/jbe@5 43 originalElement,
bsw/jbe@5 44 elementOffsetX + mouseX - mouseOffsetX,
bsw/jbe@5 45 elementOffsetY + mouseY - mouseOffsetY
bsw/jbe@5 46 );
bsw/jbe@5 47 originalElement.style.visibility = '';
bsw/jbe@5 48 draggedElement.parentNode.removeChild(draggedElement);
bsw/jbe@5 49 originalElement = null;
bsw/jbe@5 50 draggedElement = null;
bsw/jbe@5 51 }
bsw/jbe@5 52 };
bsw/jbe@5 53 window.addEventListener("mouseup", mouseDrop, true);
bsw/jbe@5 54 window.addEventListener("mousedown", mouseDrop, true);
bsw/jbe@5 55 var elements = document.getElementsByTagName("*");
bsw/jbe@5 56 for (var i=0; i<elements.length; i++) {
bsw/jbe@5 57 var element = elements[i];
bsw/jbe@5 58 if (element.className == "movable") {
bsw/jbe@5 59 element.addEventListener("mousedown", function(event) {
bsw/jbe@5 60 event.target.style.cursor = "move";
bsw/jbe@5 61 dragElement(event.currentTarget, function(element, dropX, dropY) {
bsw/jbe@6 62 event.target.style.cursor = '';
bsw/jbe@5 63 elementDropped(element, dropX, dropY);
bsw/jbe@5 64 });
bsw/jbe@5 65 event.preventDefault();
bsw/jbe@5 66 }, false);
bsw/jbe@5 67 } else if (element.className == "clickable") {
bsw/jbe@5 68 element.addEventListener("mousedown", function(event) {
bsw/jbe@5 69 event.stopPropagation();
bsw/jbe@5 70 }, false);
bsw/jbe@5 71 }
bsw/jbe@5 72 }
bsw/jbe@5 73 }, false);

Impressum / About Us