ميدياويكي:Gadget-countdown-timer.js

ملاحظة: بعد النشر، أنت قد تحتاج إلى إفراغ الكاش الخاص بمتصفحك لرؤية التغييرات.

  • فايرفوكس / سافاري: أمسك Shift أثناء ضغط Reload، أو اضغط على إما Ctrl-F5 أو Ctrl-R (⌘-R على ماك)
  • جوجل كروم: اضغط Ctrl-Shift-R (⌘-Shift-R على ماك)
  • إنترنت إكسبلورر/إيدج: أمسك Ctrl أثناء ضغط Refresh، أو اضغط Ctrl-F5
  • أوبرا: اضغط Ctrl-F5.
/**
 * Countdown Timer
 * 
 * works with [[:ar:Module:countdown]]
 * 
 * by [[:ar:User:حبيشان]]
 * 
 */
$( function() {
  var cdt = []
  var cdt_params = ['date1', 'date2', 'eventbefore', 'eventstart', 'eventstart2', 'eventend', 'event', 'other', 'color']
  const cminute=60,chour=cminute* 60, cday=chour*24, cweek=cday * 7;
  const time_parts_values = [cweek, cday, chour, cminute, 1]
  function get_parts(ms_time) {
    ret = {}
    ms_time = Math.floor(ms_time / 1000)
    ret.week = Math.floor(ms_time / cweek);
    ret.day = Math.floor((ms_time % cweek) / cday);
    ret.hour = Math.floor((ms_time % cday) / chour);
    ret.minute = Math.floor((ms_time % chour) / cminute);
    ret.second = Math.floor((ms_time % cminute));
    return ret
  }
  
  function formatMessage(text, ms_time, parts, color)
  {
    time_parts = ['week','day','hour','minute','second']
    var maj = (text.indexOf('@مدة مجرورة@')>-1)
    time_plural= [
      ['', 'أسبوع واحد', 'أسبوعان', 'أسابيع', 'أسبوعًا', 'أسبوعٍ'],
      ['', 'يوم واحد', 'يومان', 'أيام', 'يومًا', 'يومٍ'],
      ['', 'ساعة واحدة', 'ساعتان', 'ساعات', 'ساعةً', 'ساعةٍ'],
      ['', 'دقيقة واحدة', 'دقيقتان', 'دقائق', 'دقيقةً', 'دقيقةٍ'],
      ['', 'ثانية واحدة', 'ثانيان', 'ثوانٍ', 'ثانيةً', 'ثانيةٍ']
    ]
    var tt = get_parts(ms_time);
    var last_part;
    parts = (parts>0)? parts : 2;
    var part_count=0
    ret = '';
    for(var i = 0; i < time_parts.length; i++) {
      if (tt[time_parts[i]] > 0) {
        ret = ((ret.length>0)? ret + ' و' : '') + 
          ((tt[time_parts[i]] < 3) ? '' : ('<span style="color: ' + (color || '#F00') + '; font-weight: bold;">' + String(tt[time_parts[i]] + '</span> '))) + 
          ((tt[time_parts[i]]==2 && maj)? time_plural[i][2].slice(0,-2) + 'ين' : mw.language.convertPlural(tt[time_parts[i]], time_plural[i]));
        part_count ++;
        last_part = i;
        if (part_count>=parts) break;
      }
    }

    if (text !='') {
      ret=text.replace((maj? '@مدة مجرورة@': '@مدة@'), ret)
    }
    return [ret, last_part]
  }
  
  function update_cdt(i) {
    var time_to_start,time_to_end
    var text,last_part;
    cdt[i].parts = cdt[i].other && parseInt(cdt[i].other) || 2
    

    if (cdt[i].date1) {
      time_to_start = cdt[i].date1 - Date.now()
    }
    
    if (cdt[i].date2) {
      time_to_end = cdt[i].date2 - Date.now()
    }
    
    if (time_to_start>0) {
      cdt[i].eventbefore = cdt[i].eventbefore ||
        cdt[i].event && ('بقي @مدة@ على بداية «' + cdt[i].event + '».') || '';
      [text, last_part] = formatMessage(cdt[i].eventbefore, time_to_start, cdt[i].parts, cdt[i].color);
    } else if (time_to_end) {
      if (time_to_end > 0) {
        cdt[i].eventstart2 = cdt[i].eventstart2 ||
          cdt[i].event &&  ("بداية «" + cdt[i].event + "» وستكون النهاية بعد @مدة مجرورة@") || '';
        [text, last_part] = formatMessage(cdt[i].eventstart2, time_to_end, cdt[i].parts,cdt[i].color);
      } else {
        text = cdt[i].eventend || cdt[i].event && ("انتهاء «" + cdt[i].event + "».") || '';
      }
    } else {
      text = cdt[i].eventstart || cdt[i].event && ("بداية «" + cdt[i].event + '».') || '';
    }
    
    $('#cdt' + i )[0].innerHTML = text;
    
    if (last_part) {
      var ms = (new Date()) % (time_parts_values[last_part] * 1000);
      setTimeout( function () {
        update_cdt(i);
      }, (time_parts_values[last_part] * 1000) + 100 - ms );
    }
  }
  
  
  l = $('.countdown-timer')
  for (i = 0; i < l.length; i++) {
    l[i].id = 'cdt' + i
    cdt[i] = { 'element': l[i] }
    for (var j = 0; j < cdt_params.length; j++) {
      param = $(l[i]).data(cdt_params[j]);
      if (param !== undefined) {
        if (cdt_params[j].slice(0, -1) == 'date') {
          cdt[i][cdt_params[j]] = new Date(param.substring(0, 19) + 'Z')
        } else {
          cdt[i][cdt_params[j]] = param
        }
      }
    }
    update_cdt(i);
  }
  });