- 01
- 02
- 03
- 04
- 05
- 06
- 07
- 08
- 09
- 10
- 11
- 12
- 13
- 14
- 15
- 16
- 17
- 18
- 19
- 20
- 21
- 22
- 23
- 24
- 25
- 26
- 27
- 28
- 29
- 30
- 31
- 32
- 33
- 34
- 35
- 36
- 37
- 38
function msglist_scroll_change() {
var mailbox = Mailbox.Get();
if (!mailbox.mList.length && (mailbox.state == 2)) { if (splash) splash_off(); return; }
var scroll_height = document.getElementById("msglist_container_id").style.height;
var scroll_top = document.getElementById("msglist_container_id").scrollTop;
var delta = parseInt((parseInt(scroll_height) / mailbox.mListItemHeight) + 2);
var first = parseInt((scroll_top / mailbox.mListItemHeight) - 1);
var last = parseInt(((parseInt(scroll_top) + parseInt(scroll_height)) / mailbox.mListItemHeight) + 1);
if (first < 0) first = 0;
if (last >= mailbox.mList.length) last = mailbox.mList.length - 1;
// проверка на то, что в область видимости попало неподгруженное письмо
var needToLoad = 0;
for (var i = first; i <= last; i++) if (mailbox.mList[i].STATE == 0) needToLoad++;
if (!needToLoad) return; // если не надо
var first = parseInt((scroll_top / mailbox.mListItemHeight) - 1 - delta);
var last = parseInt(((parseInt(scroll_top) + parseInt(scroll_height)) / mailbox.mListItemHeight) + 1 + delta);
if (first < 0) first = 0;
if (last >= mailbox.mList.length) last = mailbox.mList.length - 1;
var messages_part = new Array();
var k = 0;
targetDiv = gebi("msglist_container_id");
inn = "";
for (var i = first; i <= last; i++) {
if (mailbox.mList[i].STATE == 0) {
messages_part[k] = mailbox.mList[i].ID;
k++;
}
tmpl_msg_loading(mailbox.mList[i].ID);
}
if (messages_part.length) ajax_get_folder_msg_list_info_part(mailbox.fId, messages_part, mailbox.recvMListInfoData, mailbox);
else heatFolders();
}
Зачем-то два раза определяют first и last...
Может кто-нибудь объяснит?..
Lure Of Chaos 25.10.2010 16:19 # 0
bugmenot 25.10.2010 20:41 # 0
Lure Of Chaos 25.10.2010 22:50 # 0
ммм, что бы означало "горячие папки"?
Анонимус 25.10.2010 22:55 # +4
в оригинале было "горячие попки 3"
Lure Of Chaos 25.10.2010 23:10 # 0
istem 25.10.2010 23:29 # 0
//Mr. FROST - средство от "ненужных кликов"
[...]
function heatFolders() {
if (!frostFolders) return;
if (gebi('frost_f'))
gebi('frost_f').innerHTML = '';
frostFolders = 0;
}
Lure Of Chaos 26.10.2010 16:08 # 0
istem 26.10.2010 17:33 # 0
вот что делает инвертирование:
function freezeFolders() {
if (frostFolders) return;
var hor = gebi('folder_count').offsetWidth;
var ver = gebi('folder_count').offsetHeight;
if (gebi('frost_f'))
gebi('frost_f').innerHTML = '<div style="width:'+hor+'px;height:'+ver+'px; "><spacer/></div>';
frostFolders = 1;
}
bugmenot 26.10.2010 10:59 # +1
Lure Of Chaos 25.10.2010 16:20 # 0
istem 25.10.2010 16:30 # 0
user654321 25.10.2010 18:20 # 0
У меня такое же бывает, когда колесом мышки усердно пролистываешь код, а колесо в этот момент нажимается и код вставляется. Ну там, обычно, синтаксические ошибки вылезают.
istem 25.10.2010 19:34 # 0
bugmenot 25.10.2010 20:53 # +1
обезьяны ленивые, блжад
теперь смотри строки 5 и 6
код правился с чтением мантры "только бы не уронить, уволят же"
bugmenot 25.10.2010 20:45 # 0
Lure Of Chaos 25.10.2010 22:51 # 0
Анонимус 25.10.2010 22:56 # +2