web/static/admin/js/admin/ordering.js
author veltr
Wed, 23 May 2012 18:16:27 +0200
changeset 66 37492d1ce841
parent 0 ecdfc63274bf
permissions -rw-r--r--
Added clustering
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
0
ecdfc63274bf first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
     1
addEvent(window, 'load', reorder_init);
ecdfc63274bf first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
     2
ecdfc63274bf first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
     3
var lis;
ecdfc63274bf first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
     4
var top = 0;
ecdfc63274bf first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
     5
var left = 0;
ecdfc63274bf first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
     6
var height = 30;
ecdfc63274bf first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
     7
ecdfc63274bf first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
     8
function reorder_init() {
ecdfc63274bf first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
     9
    lis = document.getElementsBySelector('ul#orderthese li');
ecdfc63274bf first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    10
    var input = document.getElementsBySelector('input[name=order_]')[0];
ecdfc63274bf first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    11
    setOrder(input.value.split(','));
ecdfc63274bf first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    12
    input.disabled = true;
ecdfc63274bf first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    13
    draw();
ecdfc63274bf first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    14
    // Now initialise the dragging behaviour
ecdfc63274bf first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    15
    var limit = (lis.length - 1) * height;
ecdfc63274bf first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    16
    for (var i = 0; i < lis.length; i++) {
ecdfc63274bf first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    17
        var li = lis[i];
ecdfc63274bf first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    18
        var img = document.getElementById('handle'+li.id);
ecdfc63274bf first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    19
        li.style.zIndex = 1;
ecdfc63274bf first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    20
        Drag.init(img, li, left + 10, left + 10, top + 10, top + 10 + limit);
ecdfc63274bf first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    21
        li.onDragStart = startDrag;
ecdfc63274bf first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    22
        li.onDragEnd = endDrag;
ecdfc63274bf first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    23
        img.style.cursor = 'move';
ecdfc63274bf first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    24
    }
ecdfc63274bf first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    25
}
ecdfc63274bf first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    26
ecdfc63274bf first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    27
function submitOrderForm() {
ecdfc63274bf first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    28
    var inputOrder = document.getElementsBySelector('input[name=order_]')[0];
ecdfc63274bf first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    29
    inputOrder.value = getOrder();
ecdfc63274bf first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    30
    inputOrder.disabled=false;
ecdfc63274bf first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    31
}
ecdfc63274bf first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    32
ecdfc63274bf first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    33
function startDrag() {
ecdfc63274bf first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    34
    this.style.zIndex = '10';
ecdfc63274bf first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    35
    this.className = 'dragging';
ecdfc63274bf first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    36
}
ecdfc63274bf first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    37
ecdfc63274bf first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    38
function endDrag(x, y) {
ecdfc63274bf first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    39
    this.style.zIndex = '1';
ecdfc63274bf first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    40
    this.className = '';
ecdfc63274bf first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    41
    // Work out how far along it has been dropped, using x co-ordinate
ecdfc63274bf first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    42
    var oldIndex = this.index;
ecdfc63274bf first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    43
    var newIndex = Math.round((y - 10 - top) / height);
ecdfc63274bf first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    44
    // 'Snap' to the correct position
ecdfc63274bf first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    45
    this.style.top = (10 + top + newIndex * height) + 'px';
ecdfc63274bf first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    46
    this.index = newIndex;
ecdfc63274bf first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    47
    moveItem(oldIndex, newIndex);
ecdfc63274bf first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    48
}
ecdfc63274bf first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    49
ecdfc63274bf first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    50
function moveItem(oldIndex, newIndex) {
ecdfc63274bf first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    51
    // Swaps two items, adjusts the index and left co-ord for all others
ecdfc63274bf first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    52
    if (oldIndex == newIndex) {
ecdfc63274bf first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    53
        return; // Nothing to swap;
ecdfc63274bf first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    54
    }
ecdfc63274bf first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    55
    var direction, lo, hi;
ecdfc63274bf first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    56
    if (newIndex > oldIndex) {
ecdfc63274bf first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    57
        lo = oldIndex;
ecdfc63274bf first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    58
        hi = newIndex;
ecdfc63274bf first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    59
        direction = -1;
ecdfc63274bf first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    60
    } else {
ecdfc63274bf first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    61
        direction = 1;
ecdfc63274bf first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    62
        hi = oldIndex;
ecdfc63274bf first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    63
        lo = newIndex;
ecdfc63274bf first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    64
    }
ecdfc63274bf first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    65
    var lis2 = new Array(); // We will build the new order in this array
ecdfc63274bf first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    66
    for (var i = 0; i < lis.length; i++) {
ecdfc63274bf first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    67
        if (i < lo || i > hi) {
ecdfc63274bf first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    68
            // Position of items not between the indexes is unaffected
ecdfc63274bf first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    69
            lis2[i] = lis[i];
ecdfc63274bf first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    70
            continue;
ecdfc63274bf first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    71
        } else if (i == newIndex) {
ecdfc63274bf first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    72
            lis2[i] = lis[oldIndex];
ecdfc63274bf first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    73
            continue;
ecdfc63274bf first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    74
        } else {
ecdfc63274bf first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    75
            // Item is between the two indexes - move it along 1
ecdfc63274bf first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    76
            lis2[i] = lis[i - direction];
ecdfc63274bf first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    77
        }
ecdfc63274bf first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    78
    }
ecdfc63274bf first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    79
    // Re-index everything
ecdfc63274bf first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    80
    reIndex(lis2);
ecdfc63274bf first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    81
    lis = lis2;
ecdfc63274bf first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    82
    draw();
ecdfc63274bf first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    83
//    document.getElementById('hiddenOrder').value = getOrder();
ecdfc63274bf first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    84
    document.getElementsBySelector('input[name=order_]')[0].value = getOrder();
ecdfc63274bf first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    85
}
ecdfc63274bf first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    86
ecdfc63274bf first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    87
function reIndex(lis) {
ecdfc63274bf first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    88
    for (var i = 0; i < lis.length; i++) {
ecdfc63274bf first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    89
        lis[i].index = i;
ecdfc63274bf first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    90
    }
ecdfc63274bf first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    91
}
ecdfc63274bf first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    92
ecdfc63274bf first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    93
function draw() {
ecdfc63274bf first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    94
    for (var i = 0; i < lis.length; i++) {
ecdfc63274bf first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    95
        var li = lis[i];
ecdfc63274bf first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    96
        li.index = i;
ecdfc63274bf first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    97
        li.style.position = 'absolute';
ecdfc63274bf first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    98
        li.style.left = (10 + left) + 'px';
ecdfc63274bf first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    99
        li.style.top = (10 + top + (i * height)) + 'px';
ecdfc63274bf first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   100
    }
ecdfc63274bf first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   101
}
ecdfc63274bf first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   102
ecdfc63274bf first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   103
function getOrder() {
ecdfc63274bf first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   104
    var order = new Array(lis.length);
ecdfc63274bf first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   105
    for (var i = 0; i < lis.length; i++) {
ecdfc63274bf first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   106
        order[i] = lis[i].id.substring(1, 100);
ecdfc63274bf first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   107
    }
ecdfc63274bf first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   108
    return order.join(',');
ecdfc63274bf first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   109
}
ecdfc63274bf first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   110
ecdfc63274bf first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   111
function setOrder(id_list) {
ecdfc63274bf first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   112
    /* Set the current order to match the lsit of IDs */
ecdfc63274bf first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   113
    var temp_lis = new Array();
ecdfc63274bf first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   114
    for (var i = 0; i < id_list.length; i++) {
ecdfc63274bf first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   115
        var id = 'p' + id_list[i];
ecdfc63274bf first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   116
        temp_lis[temp_lis.length] = document.getElementById(id);
ecdfc63274bf first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   117
    }
ecdfc63274bf first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   118
    reIndex(temp_lis);
ecdfc63274bf first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   119
    lis = temp_lis;
ecdfc63274bf first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   120
    draw();
ecdfc63274bf first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   121
}
ecdfc63274bf first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   122
ecdfc63274bf first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   123
function addEvent(elm, evType, fn, useCapture)
ecdfc63274bf first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   124
// addEvent and removeEvent
ecdfc63274bf first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   125
// cross-browser event handling for IE5+,  NS6 and Mozilla
ecdfc63274bf first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   126
// By Scott Andrew
ecdfc63274bf first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   127
{
ecdfc63274bf first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   128
  if (elm.addEventListener){
ecdfc63274bf first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   129
    elm.addEventListener(evType, fn, useCapture);
ecdfc63274bf first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   130
    return true;
ecdfc63274bf first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   131
  } else if (elm.attachEvent){
ecdfc63274bf first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   132
    var r = elm.attachEvent("on"+evType, fn);
ecdfc63274bf first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   133
    return r;
ecdfc63274bf first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   134
  } else {
ecdfc63274bf first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   135
    elm['on'+evType] = fn;
ecdfc63274bf first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   136
  }
ecdfc63274bf first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   137
}