diff --git a/Manifest.txt b/Manifest.txt
index 650ab10a..260cf363 100644
--- a/Manifest.txt
+++ b/Manifest.txt
@@ -29,7 +29,6 @@ app/assets/javascripts/bootstrap/tab.js
app/assets/javascripts/bootstrap/transition.js
app/assets/javascripts/check_password.js
app/assets/javascripts/cookies.js
-app/assets/javascripts/datetimepicker.js
app/assets/javascripts/lang/ar_AR.js
app/assets/javascripts/lang/da_DK.js
app/assets/javascripts/lang/default.js
@@ -107,7 +106,6 @@ app/assets/stylesheets/bootstrap/mixins/_text-emphasis.scss
app/assets/stylesheets/bootstrap/mixins/_text-overflow.scss
app/assets/stylesheets/bootstrap/mixins/_vendor-prefixes.scss
app/assets/stylesheets/coderay.css
-app/assets/stylesheets/datetimepicker.css
app/assets/stylesheets/lightbox.css
app/assets/stylesheets/publify.css.scss
app/assets/stylesheets/publify_admin.css.scss
diff --git a/app/assets/javascripts/datetimepicker.js b/app/assets/javascripts/datetimepicker.js
deleted file mode 100644
index 71ebe19d..00000000
--- a/app/assets/javascripts/datetimepicker.js
+++ /dev/null
@@ -1,1470 +0,0 @@
-/**
- * @preserve jQuery DateTimePicker plugin v2.3.4
- * @homepage http://xdsoft.net/jqplugins/datetimepicker/
- * (c) 2014, Chupurnov Valeriy.
- */
-(function( $ ) {
- 'use strict';
- var default_options = {
- i18n:{
- bg:{ // Bulgarian
- months:[
- "Януари", "Февруари", "Март", "Април", "Май", "Юни", "Юли", "Август", "Септември", "Октомври", "Ноември", "Декември"
- ],
- dayOfWeek:[
- "Нд", "Пн", "Вт", "Ср", "Чт", "Пт", "Сб"
- ]
- },
- fa:{ // Persian/Farsi
- months:[
- 'فروردین', 'اردیبهشت', 'خرداد', 'تیر', 'مرداد', 'شهریور', 'مهر', 'آبان', 'آذر', 'دی', 'بهمن', 'اسفند'
- ],
- dayOfWeek:[
- 'یکشنبه', 'دوشنبه', 'سه شنبه', 'چهارشنبه', 'پنجشنبه', 'جمعه', 'شنبه'
- ]
- },
- ru:{ // Russian
- months:[
- 'Январь','Февраль','Март','Апрель','Май','Июнь','Июль','Август','Сентябрь','Октябрь','Ноябрь','Декабрь'
- ],
- dayOfWeek:[
- "Вск", "Пн", "Вт", "Ср", "Чт", "Пт", "Сб"
- ]
- },
- uk:{ // Ukrainian
- months:[
- 'Січень','Лютий','Березень','Квітень','Травень','Червень','Липень','Серпень','Вересень','Жовтень','Листопад','Грудень'
- ],
- dayOfWeek:[
- "Ндл", "Пнд", "Втр", "Срд", "Чтв", "Птн", "Сбт"
- ]
- },
- en:{ // English
- months: [
- "January", "February", "March", "April", "May", "June", "July", "August", "September", "October", "November", "December"
- ],
- dayOfWeek: [
- "Sun", "Mon", "Tue", "Wed", "Thu", "Fri", "Sat"
- ]
- },
- el:{ // Ελληνικά
- months: [
- "Ιανουάριος", "Φεβρουάριος", "Μάρτιος", "Απρίλιος", "Μάιος", "Ιούνιος", "Ιούλιος", "Αύγουστος", "Σεπτέμβριος", "Οκτώβριος", "Νοέμβριος", "Δεκέμβριος"
- ],
- dayOfWeek: [
- "Κυρ", "Δευ", "Τρι", "Τετ", "Πεμ", "Παρ", "Σαβ"
- ]
- },
- de:{ // German
- months:[
- 'Januar','Februar','März','April','Mai','Juni','Juli','August','September','Oktober','November','Dezember'
- ],
- dayOfWeek:[
- "So", "Mo", "Di", "Mi", "Do", "Fr", "Sa"
- ]
- },
- nl:{ // Dutch
- months:[
- "januari", "februari", "maart", "april", "mei", "juni", "juli", "augustus", "september", "oktober", "november", "december"
- ],
- dayOfWeek:[
- "zo", "ma", "di", "wo", "do", "vr", "za"
- ]
- },
- tr:{ // Turkish
- months:[
- "Ocak", "Şubat", "Mart", "Nisan", "Mayıs", "Haziran", "Temmuz", "Ağustos", "Eylül", "Ekim", "Kasım", "Aralık"
- ],
- dayOfWeek:[
- "Paz", "Pts", "Sal", "Çar", "Per", "Cum", "Cts"
- ]
- },
- fr:{ //French
- months:[
- "Janvier", "Février", "Mars", "Avril", "Mai", "Juin", "Juillet", "Août", "Septembre", "Octobre", "Novembre", "Décembre"
- ],
- dayOfWeek:[
- "Dim", "Lun", "Mar", "Mer", "Jeu", "Ven", "Sam"
- ]
- },
- es:{ // Spanish
- months: [
- "Enero", "Febrero", "Marzo", "Abril", "Mayo", "Junio", "Julio", "Agosto", "Septiembre", "Octubre", "Noviembre", "Diciembre"
- ],
- dayOfWeek: [
- "Dom", "Lun", "Mar", "Mié", "Jue", "Vie", "Sáb"
- ]
- },
- th:{ // Thai
- months:[
- 'มกราคม','กุมภาพันธ์','มีนาคม','เมษายน','พฤษภาคม','มิถุนายน','กรกฎาคม','สิงหาคม','กันยายน','ตุลาคม','พฤศจิกายน','ธันวาคม'
- ],
- dayOfWeek:[
- 'อา.','จ.','อ.','พ.','พฤ.','ศ.','ส.'
- ]
- },
- pl:{ // Polish
- months: [
- "styczeń", "luty", "marzec", "kwiecień", "maj", "czerwiec", "lipiec", "sierpień", "wrzesień", "październik", "listopad", "grudzień"
- ],
- dayOfWeek: [
- "nd", "pn", "wt", "śr", "cz", "pt", "sb"
- ]
- },
- pt:{ // Portuguese
- months: [
- "Janeiro", "Fevereiro", "Março", "Abril", "Maio", "Junho", "Julho", "Agosto", "Setembro", "Outubro", "Novembro", "Dezembro"
- ],
- dayOfWeek: [
- "Dom", "Seg", "Ter", "Qua", "Qui", "Sex", "Sab"
- ]
- },
- ch:{ // Simplified Chinese
- months: [
- "一月","二月","三月","四月","五月","六月","七月","八月","九月","十月","十一月","十二月"
- ],
- dayOfWeek: [
- "日", "一","二","三","四","五","六"
- ]
- },
- se:{ // Swedish
- months: [
- "Januari", "Februari", "Mars", "April", "Maj", "Juni", "Juli", "Augusti", "September","Oktober", "November", "December"
- ],
- dayOfWeek: [
- "Sön", "Mån", "Tis", "Ons", "Tor", "Fre", "Lör"
- ]
- },
- kr:{ // Korean
- months: [
- "1월", "2월", "3월", "4월", "5월", "6월", "7월", "8월", "9월", "10월", "11월", "12월"
- ],
- dayOfWeek: [
- "일", "월", "화", "수", "목", "금", "토"
- ]
- },
- it:{ // Italian
- months: [
- "Gennaio", "Febbraio", "Marzo", "Aprile", "Maggio", "Giugno", "Luglio", "Agosto", "Settembre", "Ottobre", "Novembre", "Dicembre"
- ],
- dayOfWeek: [
- "Dom", "Lun", "Mar", "Mer", "Gio", "Ven", "Sab"
- ]
- },
- da:{ // Dansk
- months: [
- "January", "Februar", "Marts", "April", "Maj", "Juni", "July", "August", "September", "Oktober", "November", "December"
- ],
- dayOfWeek: [
- "Søn", "Man", "Tir", "Ons", "Tor", "Fre", "Lør"
- ]
- },
- no:{ // Norwegian
- months: [
- "Januar", "Februar", "Mars", "April", "Mai", "Juni", "Juli", "August", "September", "Oktober", "November", "Desember"
- ],
- dayOfWeek: [
- "Søn", "Man", "Tir", "Ons", "Tor", "Fre", "Lør"
- ]
- },
- ja:{ // Japanese
- months: [
- "1月", "2月", "3月", "4月", "5月", "6月", "7月", "8月", "9月", "10月", "11月", "12月"
- ],
- dayOfWeek: [
- "日", "月", "火", "水", "木", "金", "土"
- ]
- },
- vi:{ // Vietnamese
- months: [
- "Tháng 1", "Tháng 2", "Tháng 3", "Tháng 4", "Tháng 5", "Tháng 6", "Tháng 7", "Tháng 8", "Tháng 9", "Tháng 10", "Tháng 11", "Tháng 12"
- ],
- dayOfWeek: [
- "CN", "T2", "T3", "T4", "T5", "T6", "T7"
- ]
- },
- sl:{ // Slovenščina
- months: [
- "Januar", "Februar", "Marec", "April", "Maj", "Junij", "Julij", "Avgust", "September", "Oktober", "November", "December"
- ],
- dayOfWeek: [
- "Ned", "Pon", "Tor", "Sre", "Čet", "Pet", "Sob"
- ]
- },
- cs:{ // Čeština
- months: [
- "Leden", "Únor", "Březen", "Duben", "Květen", "Červen", "Červenec", "Srpen", "Září", "Říjen", "Listopad", "Prosinec"
- ],
- dayOfWeek: [
- "Ne", "Po", "Út", "St", "Čt", "Pá", "So"
- ]
- },
- hu:{ // Hungarian
- months: [
- "Január", "Február", "Március", "Április", "Május", "Június", "Július", "Augusztus", "Szeptember", "Október", "November", "December"
- ],
- dayOfWeek: [
- "Va", "Hé", "Ke", "Sze", "Cs", "Pé", "Szo"
- ]
- }
- },
- value:'',
- lang:'en',
-
- format: 'Y/m/d H:i',
- formatTime: 'H:i',
- formatDate: 'Y/m/d',
-
- startDate: false, // new Date(), '1986/12/08', '-1970/01/05','-1970/01/05',
-
- step:60,
- monthChangeSpinner:true,
- closeOnDateSelect:false,
- closeOnWithoutClick:true,
- closeOnInputClick: true,
-
- timepicker:true,
- datepicker:true,
- weeks:false,
-
- defaultTime:false, // use formatTime format (ex. '10:00' for formatTime: 'H:i')
- defaultDate:false, // use formatDate format (ex new Date() or '1986/12/08' or '-1970/01/05' or '-1970/01/05')
-
- minDate:false,
- maxDate:false,
- minTime:false,
- maxTime:false,
-
- allowTimes:[],
- opened:false,
- initTime:true,
- inline:false,
-
- onSelectDate:function() {},
- onSelectTime:function() {},
- onChangeMonth:function() {},
- onChangeDateTime:function() {},
- onShow:function() {},
- onClose:function() {},
- onGenerate:function() {},
-
- withoutCopyright:true,
-
- inverseButton:false,
- hours12:false,
- next: 'xdsoft_next',
- prev : 'xdsoft_prev',
- dayOfWeekStart:0,
-
- timeHeightInTimePicker:25,
- timepickerScrollbar:true,
-
- todayButton:true, // 2.1.0
- defaultSelect:true, // 2.1.0
-
- scrollMonth:true,
- scrollTime:true,
- scrollInput:true,
-
- lazyInit:false,
-
- mask:false,
- validateOnBlur:true,
- allowBlank:true,
-
- yearStart:1950,
- yearEnd:2050,
-
- style:'',
- id:'',
-
- fixed: false,
-
- roundTime:'round', // ceil, floor
- className:'',
-
- weekends : [],
- yearOffset:0,
- beforeShowDay: null
- };
-
- // fix for ie8
- if ( !Array.prototype.indexOf ) {
- Array.prototype.indexOf = function(obj, start) {
- for (var i = (start || 0), j = this.length; i < j; i++) {
- if (this[i] === obj) { return i; }
- }
- return -1;
- }
- }
-
- Date.prototype.countDaysInMonth = function(){
- return new Date(this.getFullYear(), this.getMonth()+1, 0).getDate();
- };
-
- $.fn.xdsoftScroller = function( _percent ) {
- return this.each(function() {
- var timeboxparent = $(this);
- if( !$(this).hasClass('xdsoft_scroller_box') ) {
- var pointerEventToXY = function( e ) {
- var out = {x:0, y:0};
- if( e.type == 'touchstart' || e.type == 'touchmove' || e.type == 'touchend' || e.type == 'touchcancel' ) {
- var touch = e.originalEvent.touches[0] || e.originalEvent.changedTouches[0];
- out.x = touch.pageX;
- out.y = touch.pageY;
- }else if (e.type == 'mousedown' || e.type == 'mouseup' || e.type == 'mousemove' || e.type == 'mouseover'|| e.type=='mouseout' || e.type=='mouseenter' || e.type=='mouseleave') {
- out.x = e.pageX;
- out.y = e.pageY;
- }
- return out;
- },
- move = 0,
- timebox = timeboxparent.children().eq(0),
- parentHeight = timeboxparent[0].clientHeight,
- height = timebox[0].offsetHeight,
- scrollbar = $('
'),
- scroller = $('
'),
- maximumOffset = 100,
- start = false;
-
- scrollbar.append(scroller);
-
- timeboxparent.addClass('xdsoft_scroller_box').append(scrollbar);
- scroller.on('mousedown.xdsoft_scroller',function ( event ) {
- if( !parentHeight )
- timeboxparent.trigger('resize_scroll.xdsoft_scroller',[_percent]);
- var pageY = event.pageY,
- top = parseInt(scroller.css('margin-top')),
- h1 = scrollbar[0].offsetHeight;
- $(document.body).addClass('xdsoft_noselect');
- $([document.body,window]).on('mouseup.xdsoft_scroller',function arguments_callee() {
- $([document.body,window]).off('mouseup.xdsoft_scroller',arguments_callee)
- .off('mousemove.xdsoft_scroller',move)
- .removeClass('xdsoft_noselect');
- });
- $(document.body).on('mousemove.xdsoft_scroller',move = function(event) {
- var offset = event.pageY-pageY+top;
- if( offset<0 )
- offset = 0;
- if( offset+scroller[0].offsetHeight>h1 )
- offset = h1-scroller[0].offsetHeight;
- timeboxparent.trigger('scroll_element.xdsoft_scroller',[maximumOffset?offset/maximumOffset:0]);
- });
- });
-
- timeboxparent
- .on('scroll_element.xdsoft_scroller',function( event,percent ) {
- if( !parentHeight )
- timeboxparent.trigger('resize_scroll.xdsoft_scroller',[percent,true]);
- percent = percent>1?1:(percent<0||isNaN(percent))?0:percent;
- scroller.css('margin-top',maximumOffset*percent);
- timebox.css('marginTop',-parseInt((height-parentHeight)*percent))
- })
- .on('resize_scroll.xdsoft_scroller',function( event,_percent,noTriggerScroll ) {
- parentHeight = timeboxparent[0].clientHeight;
- height = timebox[0].offsetHeight;
- var percent = parentHeight/height,
- sh = percent*scrollbar[0].offsetHeight;
- if( percent>1 )
- scroller.hide();
- else{
- scroller.show();
- scroller.css('height',parseInt(sh>10?sh:10));
- maximumOffset = scrollbar[0].offsetHeight-scroller[0].offsetHeight;
- if( noTriggerScroll!==true )
- timeboxparent.trigger('scroll_element.xdsoft_scroller',[_percent?_percent:Math.abs(parseInt(timebox.css('marginTop')))/(height-parentHeight)]);
- }
- });
- timeboxparent.mousewheel&&timeboxparent.mousewheel(function(event, delta, deltaX, deltaY) {
- var top = Math.abs(parseInt(timebox.css('marginTop')));
- timeboxparent.trigger('scroll_element.xdsoft_scroller',[(top-delta*20)/(height-parentHeight)]);
- event.stopPropagation();
- return false;
- });
- timeboxparent.on('touchstart',function( event ) {
- start = pointerEventToXY(event);
- });
- timeboxparent.on('touchmove',function( event ) {
- if( start ) {
- var coord = pointerEventToXY(event), top = Math.abs(parseInt(timebox.css('marginTop')));
- timeboxparent.trigger('scroll_element.xdsoft_scroller',[(top-(coord.y-start.y))/(height-parentHeight)]);
- event.stopPropagation();
- event.preventDefault();
- start = pointerEventToXY(event);
- }
- });
- timeboxparent.on('touchend touchcancel',function( event ) {
- start = false;
- });
- }
- timeboxparent.trigger('resize_scroll.xdsoft_scroller',[_percent]);
- });
- };
- $.fn.datetimepicker = function( opt ) {
- var KEY0 = 48,
- KEY9 = 57,
- _KEY0 = 96,
- _KEY9 = 105,
- CTRLKEY = 17,
- DEL = 46,
- ENTER = 13,
- ESC = 27,
- BACKSPACE = 8,
- ARROWLEFT = 37,
- ARROWUP = 38,
- ARROWRIGHT = 39,
- ARROWDOWN = 40,
- TAB = 9,
- F5 = 116,
- AKEY = 65,
- CKEY = 67,
- VKEY = 86,
- ZKEY = 90,
- YKEY = 89,
- ctrlDown = false,
- options = ($.isPlainObject(opt)||!opt)?$.extend(true,{},default_options,opt):$.extend({},default_options),
-
- lazyInitTimer = 0,
-
- lazyInit = function( input ){
- input
- .on('open.xdsoft focusin.xdsoft mousedown.xdsoft',function initOnActionCallback(event) {
- if( input.is(':disabled')||input.is(':hidden')||!input.is(':visible')||input.data( 'xdsoft_datetimepicker') )
- return;
-
- clearTimeout(lazyInitTimer);
-
- lazyInitTimer = setTimeout(function() {
-
- if( !input.data( 'xdsoft_datetimepicker') )
- createDateTimePicker(input);
-
- input
- .off('open.xdsoft focusin.xdsoft mousedown.xdsoft',initOnActionCallback)
- .trigger('open.xdsoft');
- },100);
-
- });
- },
-
- createDateTimePicker = function( input ) {
-
- var datetimepicker = $('
'),
- xdsoft_copyright = $(''),
- datepicker = $('
'),
- mounth_picker = $(''),
- calendar = $('
'),
- timepicker = $(''),
- timeboxparent = timepicker.find('.xdsoft_time_box').eq(0),
- timebox = $('
'),
- scrollbar = $('
'),
- scroller = $('
'),
- monthselect =$(''),
- yearselect =$('');
-
- //constructor lego
- mounth_picker
- .find('.xdsoft_month span')
- .after(monthselect);
- mounth_picker
- .find('.xdsoft_year span')
- .after(yearselect);
-
- mounth_picker
- .find('.xdsoft_month,.xdsoft_year')
- .on('mousedown.xdsoft',function(event) {
- mounth_picker
- .find('.xdsoft_select')
- .hide();
-
- var select = $(this).find('.xdsoft_select').eq(0),
- val = 0,
- top = 0;
-
- if( _xdsoft_datetime.currentTime )
- val = _xdsoft_datetime.currentTime[$(this).hasClass('xdsoft_month')?'getMonth':'getFullYear']();
-
- select.show();
-
- for(var items = select.find('div.xdsoft_option'),i = 0;i=KEY0&&key<=KEY9 )||( key>=_KEY0&&key<=_KEY9 ))||(key==BACKSPACE||key==DEL):
- var pos = getCaretPos(this),
- digit = ( key!=BACKSPACE&&key!=DEL )?String.fromCharCode((_KEY0 <= key && key <= _KEY9)? key-KEY0 : key):'_';
-
- if( (key==BACKSPACE||key==DEL)&&pos ) {
- pos--;
- digit='_';
- }
-
- while( /[^0-9_]/.test(options.mask.substr(pos,1))&&pos0 )
- pos+=( key==BACKSPACE||key==DEL )?-1:1;
-
- val = val.substr(0,pos)+digit+val.substr(pos+1);
- if( $.trim(val)=='' ){
- val = options.mask.replace(/[0-9]/g,'_');
- }else{
- if( pos==options.mask.length )
- break;
- }
-
- pos+=(key==BACKSPACE||key==DEL)?0:1;
- while( /[^0-9_]/.test(options.mask.substr(pos,1))&&pos0 )
- pos+=(key==BACKSPACE||key==DEL)?-1:1;
-
- if( isValidValue( options.mask,val ) ) {
- this.value = val;
- setCaretPos(this,pos);
- }else if( $.trim(val)=='' )
- this.value = options.mask.replace(/[0-9]/g,'_');
- else{
- input.trigger('error_input.xdsoft');
- }
- break;
- case ( !!~([AKEY,CKEY,VKEY,ZKEY,YKEY].indexOf(key))&&ctrlDown ):
- case !!~([ESC,ARROWUP,ARROWDOWN,ARROWLEFT,ARROWRIGHT,F5,CTRLKEY,TAB,ENTER].indexOf(key)):
- return true;
- }
- event.preventDefault();
- return false;
- });
- break;
- }
- }
- if( options.validateOnBlur ) {
- input
- .off('blur.xdsoft')
- .on('blur.xdsoft', function() {
- if( options.allowBlank && !$.trim($(this).val()).length ) {
- $(this).val(null);
- datetimepicker.data('xdsoft_datetime').empty();
- }else if( !Date.parseDate( $(this).val(), options.format ) ) {
- $(this).val((_xdsoft_datetime.now()).dateFormat( options.format ));
- datetimepicker.data('xdsoft_datetime').setCurrentTime($(this).val());
- }
- else{
- datetimepicker.data('xdsoft_datetime').setCurrentTime($(this).val());
- }
- datetimepicker.trigger('changedatetime.xdsoft');
- });
- }
- options.dayOfWeekStartPrev = (options.dayOfWeekStart==0)?6:options.dayOfWeekStart-1;
-
- datetimepicker
- .trigger('xchange.xdsoft')
- .trigger('afterOpen.xdsoft')
- };
-
- datetimepicker
- .data('options',options)
- .on('mousedown.xdsoft',function( event ) {
- event.stopPropagation();
- event.preventDefault();
- yearselect.hide();
- monthselect.hide();
- return false;
- });
-
- var scroll_element = timepicker.find('.xdsoft_time_box');
- scroll_element.append(timebox);
- scroll_element.xdsoftScroller();
-
- datetimepicker.on('afterOpen.xdsoft',function() {
- scroll_element.xdsoftScroller();
- });
-
- datetimepicker
- .append(datepicker)
- .append(timepicker);
-
- if( options.withoutCopyright!==true )
- datetimepicker
- .append(xdsoft_copyright);
-
- datepicker
- .append(mounth_picker)
- .append(calendar);
-
- $('body').append(datetimepicker);
-
- var _xdsoft_datetime = new function() {
- var _this = this;
- _this.now = function( norecursion ) {
- var d = new Date();
-
- if( !norecursion && options.defaultDate ){
- var date = _this.strtodate(options.defaultDate);
- d.setFullYear( date.getFullYear() );
- d.setMonth( date.getMonth() );
- d.setDate( date.getDate() );
- }
-
- if( options.yearOffset ){
- d.setFullYear(d.getFullYear()+options.yearOffset);
- }
-
- if( !norecursion && options.defaultTime ){
- var time = _this.strtotime(options.defaultTime);
- d.setHours( time.getHours() );
- d.setMinutes( time.getMinutes() );
- }
-
- return d;
- };
-
-
- _this.isValidDate = function (d) {
- if ( Object.prototype.toString.call(d) !== "[object Date]" )
- return false;
- return !isNaN(d.getTime());
- };
-
- _this.setCurrentTime = function( dTime ) {
- _this.currentTime = (typeof dTime == 'string')? _this.strToDateTime(dTime) : _this.isValidDate(dTime) ? dTime: _this.now();
- datetimepicker.trigger('xchange.xdsoft');
- };
-
- _this.empty = function() {
- _this.currentTime = null;
- };
-
- _this.getCurrentTime = function( dTime) {
- return _this.currentTime;
- };
-
- _this.nextMonth = function() {
- var month = _this.currentTime.getMonth()+1;
- if( month==12 ) {
- _this.currentTime.setFullYear(_this.currentTime.getFullYear()+1);
- month = 0;
- }
- _this.currentTime.setDate(
- Math.min(
- Date.daysInMonth[month],
- _this.currentTime.getDate()
- )
- );
- _this.currentTime.setMonth(month);
- options.onChangeMonth&&options.onChangeMonth.call&&options.onChangeMonth.call(datetimepicker,_xdsoft_datetime.currentTime,datetimepicker.data('input'));
- datetimepicker.trigger('xchange.xdsoft');
- return month;
- };
-
- _this.prevMonth = function() {
- var month = _this.currentTime.getMonth()-1;
- if( month==-1 ) {
- _this.currentTime.setFullYear(_this.currentTime.getFullYear()-1);
- month = 11;
- }
- _this.currentTime.setDate(
- Math.min(
- Date.daysInMonth[month],
- _this.currentTime.getDate()
- )
- );
- _this.currentTime.setMonth(month);
- options.onChangeMonth&&options.onChangeMonth.call&&options.onChangeMonth.call(datetimepicker,_xdsoft_datetime.currentTime,datetimepicker.data('input'));
- datetimepicker.trigger('xchange.xdsoft');
- return month;
- };
-
- _this.strToDateTime = function( sDateTime ) {
- if( sDateTime && sDateTime instanceof Date && _this.isValidDate(sDateTime) )
- return sDateTime;
-
- var tmpDate = [],timeOffset,currentTime;
-
- if( ( tmpDate = /^(\+|\-)(.*)$/.exec(sDateTime) ) && ( tmpDate[2]=Date.parseDate(tmpDate[2], options.formatDate) ) ) {
- timeOffset = tmpDate[2].getTime()-(tmpDate[2].getTimezoneOffset())*60000;
- currentTime = new Date((_xdsoft_datetime.now()).getTime()+parseInt(tmpDate[1]+'1')*timeOffset);
- }else
- currentTime = sDateTime?Date.parseDate(sDateTime, options.format):_this.now();
-
- if( !_this.isValidDate(currentTime) )
- currentTime = _this.now();
-
- return currentTime;
- };
-
- _this.strtodate = function( sDate ) {
- if( sDate && sDate instanceof Date && _this.isValidDate(sDate) )
- return sDate;
-
- var currentTime = sDate?Date.parseDate(sDate, options.formatDate):_this.now(true);
- if( !_this.isValidDate(currentTime) )
- currentTime = _this.now(true);
-
- return currentTime;
- };
-
- _this.strtotime = function( sTime ) {
- if( sTime && sTime instanceof Date && _this.isValidDate(sTime) )
- return sTime;
-
- var currentTime = sTime?Date.parseDate(sTime, options.formatTime):_this.now();
- if( !_this.isValidDate(currentTime) )
- currentTime = _this.now(true);
-
- return currentTime;
- };
-
- _this.str = function() {
- return _this.currentTime.dateFormat(options.format);
- };
-
- _this.currentTime = this.now();
- };
- mounth_picker
- .find('.xdsoft_today_button')
- .on('mousedown.xdsoft',function() {
- datetimepicker.data('changed',true);
- _xdsoft_datetime.setCurrentTime(0);
- datetimepicker.trigger('afterOpen.xdsoft');
- }).on('dblclick.xdsoft',function(){
- input.val( _xdsoft_datetime.str() );
- datetimepicker.trigger('close.xdsoft');
- });
- mounth_picker
- .find('.xdsoft_prev,.xdsoft_next')
- .on('mousedown.xdsoft',function() {
- var $this = $(this),
- timer = 0,
- stop = false;
-
- (function arguments_callee1(v) {
- var month = _xdsoft_datetime.currentTime.getMonth();
- if( $this.hasClass( options.next ) ) {
- _xdsoft_datetime.nextMonth();
- }else if( $this.hasClass( options.prev ) ) {
- _xdsoft_datetime.prevMonth();
- }
- if (options.monthChangeSpinner) {
- !stop&&(timer = setTimeout(arguments_callee1,v?v:100));
- }
- })(500);
-
- $([document.body,window]).on('mouseup.xdsoft',function arguments_callee2() {
- clearTimeout(timer);
- stop = true;
- $([document.body,window]).off('mouseup.xdsoft',arguments_callee2);
- });
- });
-
- timepicker
- .find('.xdsoft_prev,.xdsoft_next')
- .on('mousedown.xdsoft',function() {
- var $this = $(this),
- timer = 0,
- stop = false,
- period = 110;
- (function arguments_callee4(v) {
- var pheight = timeboxparent[0].clientHeight,
- height = timebox[0].offsetHeight,
- top = Math.abs(parseInt(timebox.css('marginTop')));
- if( $this.hasClass(options.next) && (height-pheight)- options.timeHeightInTimePicker>=top ) {
- timebox.css('marginTop','-'+(top+options.timeHeightInTimePicker)+'px')
- }else if( $this.hasClass(options.prev) && top-options.timeHeightInTimePicker>=0 ) {
- timebox.css('marginTop','-'+(top-options.timeHeightInTimePicker)+'px')
- }
- timeboxparent.trigger('scroll_element.xdsoft_scroller',[Math.abs(parseInt(timebox.css('marginTop'))/(height-pheight))]);
- period= ( period>10 )?10:period-10;
- !stop&&(timer = setTimeout(arguments_callee4,v?v:period));
- })(500);
- $([document.body,window]).on('mouseup.xdsoft',function arguments_callee5() {
- clearTimeout(timer);
- stop = true;
- $([document.body,window])
- .off('mouseup.xdsoft',arguments_callee5);
- });
- });
-
- var xchangeTimer = 0;
- // base handler - generating a calendar and timepicker
- datetimepicker
- .on('xchange.xdsoft',function( event ) {
- clearTimeout(xchangeTimer);
- xchangeTimer = setTimeout(function(){
- var table = '',
- start = new Date(_xdsoft_datetime.currentTime.getFullYear(),_xdsoft_datetime.currentTime.getMonth(),1, 12, 0, 0),
- i = 0,
- today = _xdsoft_datetime.now();
-
- while( start.getDay()!=options.dayOfWeekStart )
- start.setDate(start.getDate()-1);
-
- //generate calendar
- table+='';
-
- if(options.weeks) {
- table+=' ';
- }
-
- // days
- for(var j = 0; j<7; j++) {
- table+=''+options.i18n[options.lang].dayOfWeek[(j+options.dayOfWeekStart)%7]+' ';
- }
-
- table+=' ';
- table+='';
- var maxDate = false, minDate = false;
-
- if( options.maxDate!==false ) {
- maxDate = _xdsoft_datetime.strtodate(options.maxDate);
- maxDate = new Date(maxDate.getFullYear(),maxDate.getMonth(),maxDate.getDate(),23,59,59,999);
- }
-
- if( options.minDate!==false ) {
- minDate = _xdsoft_datetime.strtodate(options.minDate);
- minDate = new Date(minDate.getFullYear(),minDate.getMonth(),minDate.getDate());
- }
-
- var d,y,m,w,classes = [],customDateSettings,newRow=true;
-
- while( i<_xdsoft_datetime.currentTime.countDaysInMonth()||start.getDay()!=options.dayOfWeekStart||_xdsoft_datetime.currentTime.getMonth()==start.getMonth() ) {
- classes = [];
- i++;
-
- d = start.getDate(); y = start.getFullYear(); m = start.getMonth(); w = start.getWeekOfYear();
-
- classes.push('xdsoft_date');
-
- if ( options.beforeShowDay && options.beforeShowDay.call ) {
- customDateSettings = options.beforeShowDay.call(datetimepicker, start);
- } else {
- customDateSettings = null;
- }
-
- if( ( maxDate!==false && start > maxDate )||( minDate!==false && start < minDate )||(customDateSettings && customDateSettings[0] === false) ){
- classes.push('xdsoft_disabled');
- }
-
- if ( customDateSettings && customDateSettings[1] != "" ) {
- classes.push(customDateSettings[1]);
- }
-
- if( _xdsoft_datetime.currentTime.getMonth()!=m ) classes.push('xdsoft_other_month');
-
- if( (options.defaultSelect||datetimepicker.data('changed')) && _xdsoft_datetime.currentTime.dateFormat( options.formatDate )==start.dateFormat( options.formatDate ) ) {
- classes.push('xdsoft_current');
- }
-
- if( today.dateFormat( options.formatDate )==start.dateFormat( options.formatDate ) ) {
- classes.push('xdsoft_today');
- }
-
- if( start.getDay()==0||start.getDay()==6||~options.weekends.indexOf(start.dateFormat( options.formatDate )) ) {
- classes.push('xdsoft_weekend');
- }
-
- if(options.beforeShowDay && typeof options.beforeShowDay == 'function') {
- classes.push(options.beforeShowDay(start))
- }
-
- if(newRow) {
- table+='';
- newRow = false;
-
- if(options.weeks) {
- table+=''+w+' ';
- }
- }
-
- table+=''+
- ''+d+'
'+
- ' ';
-
- if( start.getDay()==options.dayOfWeekStartPrev ) {
- table+=' ';
- newRow = true;
- }
-
- start.setDate(d+1);
- }
- table+='
';
-
- calendar.html(table);
-
- mounth_picker.find('.xdsoft_label span').eq(0).text(options.i18n[options.lang].months[_xdsoft_datetime.currentTime.getMonth()]);
- mounth_picker.find('.xdsoft_label span').eq(1).text(_xdsoft_datetime.currentTime.getFullYear());
-
- // generate timebox
- var time = '',
- h = '',
- m ='',
- line_time = function line_time( h,m ) {
- var now = _xdsoft_datetime.now();
- now.setHours(h);
- h = parseInt(now.getHours());
- now.setMinutes(m);
- m = parseInt(now.getMinutes());
-
- classes = [];
- if( (options.maxTime!==false&&_xdsoft_datetime.strtotime(options.maxTime).getTime()now.getTime()))
- classes.push('xdsoft_disabled');
- if( (options.initTime||options.defaultSelect||datetimepicker.data('changed')) && parseInt(_xdsoft_datetime.currentTime.getHours())==parseInt(h)&&(options.step>59||Math[options.roundTime](_xdsoft_datetime.currentTime.getMinutes()/options.step)*options.step==parseInt(m))) {
- if( options.defaultSelect||datetimepicker.data('changed')) {
- classes.push('xdsoft_current');
- } else if( options.initTime ) {
- classes.push('xdsoft_init_time');
- }
- }
- if( parseInt(today.getHours())==parseInt(h)&&parseInt(today.getMinutes())==parseInt(m))
- classes.push('xdsoft_today');
- time+= ''+now.dateFormat(options.formatTime)+'
';
- };
-
- if( !options.allowTimes || !$.isArray(options.allowTimes) || !options.allowTimes.length ) {
- for( var i=0,j=0;i<(options.hours12?12:24);i++ ) {
- for( j=0;j<60;j+=options.step ) {
- h = (i<10?'0':'')+i;
- m = (j<10?'0':'')+j;
- line_time( h,m );
- }
- }
- }else{
- for( var i=0;i'+i+'';
- }
- yearselect.children().eq(0)
- .html(opt);
-
- for( i = 0,opt = '';i<= 11;i++ ) {
- opt+=''+options.i18n[options.lang].months[i]+'
';
- }
- monthselect.children().eq(0).html(opt);
- $(datetimepicker)
- .trigger('generate.xdsoft');
- },10);
- event.stopPropagation();
- })
- .on('afterOpen.xdsoft',function() {
- if( options.timepicker ) {
- var classType;
- if( timebox.find('.xdsoft_current').length ) {
- classType = '.xdsoft_current';
- } else if( timebox.find('.xdsoft_init_time').length ) {
- classType = '.xdsoft_init_time';
- }
-
- if( classType ) {
- var pheight = timeboxparent[0].clientHeight,
- height = timebox[0].offsetHeight,
- top = timebox.find(classType).index()*options.timeHeightInTimePicker+1;
- if( (height-pheight)1||(options.closeOnDateSelect===true||( options.closeOnDateSelect===0&&!options.timepicker )))&&!options.inline ) {
- datetimepicker.trigger('close.xdsoft');
- }
-
- if( options.onSelectDate && options.onSelectDate.call ) {
- options.onSelectDate.call(datetimepicker,_xdsoft_datetime.currentTime,datetimepicker.data('input'));
- }
-
- datetimepicker.data('changed',true);
- datetimepicker.trigger('xchange.xdsoft');
- datetimepicker.trigger('changedatetime.xdsoft');
- setTimeout(function(){
- timerclick = 0;
- },200);
- });
-
- timebox
- .on('click.xdsoft', 'div', function (xdevent) {
- xdevent.stopPropagation(); // NAJ: Prevents closing of Pop-ups, Modals and Flyouts
- var $this = $(this),
- currentTime = _xdsoft_datetime.currentTime;
-
- if( currentTime===undefined||currentTime===null ){
- _xdsoft_datetime.currentTime = _xdsoft_datetime.now();
- currentTime = _xdsoft_datetime.currentTime;
- }
-
- if( $this.hasClass('xdsoft_disabled') )
- return false;
- currentTime.setHours($this.data('hour'));
- currentTime.setMinutes($this.data('minute'));
- datetimepicker.trigger('select.xdsoft',[currentTime]);
-
- datetimepicker.data('input').val( _xdsoft_datetime.str() );
-
- !options.inline&&datetimepicker.trigger('close.xdsoft');
-
- if( options.onSelectTime&&options.onSelectTime.call ) {
- options.onSelectTime.call(datetimepicker,_xdsoft_datetime.currentTime,datetimepicker.data('input'));
- }
- datetimepicker.data('changed',true);
- datetimepicker.trigger('xchange.xdsoft');
- datetimepicker.trigger('changedatetime.xdsoft');
- });
-
- datetimepicker.mousewheel&&datepicker.mousewheel(function(event, delta, deltaX, deltaY) {
- if( !options.scrollMonth )
- return true;
- if( delta<0 )
- _xdsoft_datetime.nextMonth();
- else
- _xdsoft_datetime.prevMonth();
- return false;
- });
-
- datetimepicker.mousewheel&&timeboxparent.unmousewheel().mousewheel(function(event, delta, deltaX, deltaY) {
- if( !options.scrollTime )
- return true;
- var pheight = timeboxparent[0].clientHeight,
- height = timebox[0].offsetHeight,
- top = Math.abs(parseInt(timebox.css('marginTop'))),
- fl = true;
- if( delta<0 && (height-pheight)-options.timeHeightInTimePicker>=top ) {
- timebox.css('marginTop','-'+(top+options.timeHeightInTimePicker)+'px');
- fl = false;
- }else if( delta>0&&top-options.timeHeightInTimePicker>=0 ) {
- timebox.css('marginTop','-'+(top-options.timeHeightInTimePicker)+'px');
- fl = false;
- }
- timeboxparent.trigger('scroll_element.xdsoft_scroller',[Math.abs(parseInt(timebox.css('marginTop'))/(height-pheight))]);
- event.stopPropagation();
- return fl;
- });
-
- var triggerAfterOpen = false;
- datetimepicker
- .on('changedatetime.xdsoft',function() {
- if( options.onChangeDateTime&&options.onChangeDateTime.call ) {
- var $input = datetimepicker.data('input');
- options.onChangeDateTime.call(datetimepicker, _xdsoft_datetime.currentTime, $input);
- delete options.value;
- $input.trigger('change');
- }
- })
- .on('generate.xdsoft',function() {
- if( options.onGenerate&&options.onGenerate.call )
- options.onGenerate.call(datetimepicker,_xdsoft_datetime.currentTime,datetimepicker.data('input'));
- if( triggerAfterOpen ){
- datetimepicker.trigger('afterOpen.xdsoft');
- triggerAfterOpen = false;
- }
- })
- .on( 'click.xdsoft', function( xdevent )
- {
- xdevent.stopPropagation(); // Prevents closing of Pop-ups, Modals and Flyouts in Bootstrap
- });
-
- var current_time_index = 0;
- input.mousewheel&&input.mousewheel(function( event, delta, deltaX, deltaY ) {
- if( !options.scrollInput )
- return true;
- if( !options.datepicker && options.timepicker ) {
- current_time_index = timebox.find('.xdsoft_current').length?timebox.find('.xdsoft_current').eq(0).index():0;
- if( current_time_index+delta>=0&¤t_time_index+delta$(window).height()+$(window).scrollTop() )
- top = offset.top-datetimepicker[0].offsetHeight+1;
- if (top < 0)
- top = 0;
- if( left+datetimepicker[0].offsetWidth>$(window).width() )
- left = offset.left-datetimepicker[0].offsetWidth+datetimepicker.data('input')[0].offsetWidth;
- }
- datetimepicker.css({
- left:left,
- top:top,
- position: position
- });
- };
- datetimepicker
- .on('open.xdsoft', function() {
- var onShow = true;
- if( options.onShow&&options.onShow.call) {
- onShow = options.onShow.call(datetimepicker,_xdsoft_datetime.currentTime,datetimepicker.data('input'));
- }
- if( onShow!==false ) {
- datetimepicker.show();
- setPos();
- $(window)
- .off('resize.xdsoft',setPos)
- .on('resize.xdsoft',setPos);
-
- if( options.closeOnWithoutClick ) {
- $([document.body,window]).on('mousedown.xdsoft',function arguments_callee6() {
- datetimepicker.trigger('close.xdsoft');
- $([document.body,window]).off('mousedown.xdsoft',arguments_callee6);
- });
- }
- }
- })
- .on('close.xdsoft', function( event ) {
- var onClose = true;
- if( options.onClose&&options.onClose.call ) {
- onClose=options.onClose.call(datetimepicker,_xdsoft_datetime.currentTime,datetimepicker.data('input'));
- }
- if( onClose!==false&&!options.opened&&!options.inline ) {
- datetimepicker.hide();
- }
- event.stopPropagation();
- })
- .data('input',input);
-
- var timer = 0,
- timer1 = 0;
-
- datetimepicker.data('xdsoft_datetime',_xdsoft_datetime);
- datetimepicker.setOptions(options);
-
- function getCurrentValue(){
-
- var ct = false;
-
- if ( options.startDate ) {
- ct = _xdsoft_datetime.strToDateTime(options.startDate);
- } else {
- ct = options.value?options.value:(input&&input.val&&input.val())?input.val():'';
- ct = Date.parseDate(ct, options.format);
- }
-
- if ( ct && _xdsoft_datetime.isValidDate(ct) ) {
- datetimepicker.data('changed',true);
- } else {
- ct = '';
- }
-
- return ct?ct:0;
- }
- //debugger
- _xdsoft_datetime.setCurrentTime( getCurrentValue() );
-
- input
- .data( 'xdsoft_datetimepicker',datetimepicker )
- .on('open.xdsoft focusin.xdsoft mousedown.xdsoft',function(event) {
- if( input.is(':disabled')||input.is(':hidden')||!input.is(':visible')||(input.data('xdsoft_datetimepicker').is(':visible') && options.closeOnInputClick) )
- return;
- clearTimeout(timer);
- timer = setTimeout(function() {
- if( input.is(':disabled')||input.is(':hidden')||!input.is(':visible') )
- return;
-
- triggerAfterOpen = true;
- _xdsoft_datetime.setCurrentTime(getCurrentValue());
-
- datetimepicker.trigger('open.xdsoft');
- },100);
- })
- .on('keydown.xdsoft',function( event ) {
- var val = this.value,
- key = event.which;
- switch(true) {
- case !!~([ENTER].indexOf(key)):
- var elementSelector = $("input:visible,textarea:visible");
- datetimepicker.trigger('close.xdsoft');
- elementSelector.eq(elementSelector.index(this) + 1).focus();
- return false;
- case !!~[TAB].indexOf(key):
- datetimepicker.trigger('close.xdsoft');
- return true;
- }
- });
- },
- destroyDateTimePicker = function( input ) {
- var datetimepicker = input.data('xdsoft_datetimepicker');
- if( datetimepicker ) {
- datetimepicker.data('xdsoft_datetime',null);
- datetimepicker.remove();
- input
- .data( 'xdsoft_datetimepicker',null )
- .off( 'open.xdsoft focusin.xdsoft focusout.xdsoft mousedown.xdsoft blur.xdsoft keydown.xdsoft' );
- $(window).off('resize.xdsoft');
- $([window,document.body]).off('mousedown.xdsoft');
- input.unmousewheel&&input.unmousewheel();
- }
- };
- $(document)
- .off('keydown.xdsoftctrl keyup.xdsoftctrl')
- .on('keydown.xdsoftctrl',function(e) {
- if ( e.keyCode == CTRLKEY )
- ctrlDown = true;
- })
- .on('keyup.xdsoftctrl',function(e) {
- if ( e.keyCode == CTRLKEY )
- ctrlDown = false;
- });
- return this.each(function() {
- var datetimepicker;
- if( datetimepicker = $(this).data('xdsoft_datetimepicker') ) {
- if( $.type(opt) === 'string' ) {
- switch(opt) {
- case 'show':
- $(this).select().focus();
- datetimepicker.trigger( 'open.xdsoft' );
- break;
- case 'hide':
- datetimepicker.trigger('close.xdsoft');
- break;
- case 'destroy':
- destroyDateTimePicker($(this));
- break;
- case 'reset':
- this.value = this.defaultValue;
- if(!this.value || !datetimepicker.data('xdsoft_datetime').isValidDate(Date.parseDate(this.value, options.format)))
- datetimepicker.data('changed',false);
- datetimepicker.data('xdsoft_datetime').setCurrentTime(this.value);
- break;
- }
- }else{
- datetimepicker
- .setOptions(opt);
- }
- return 0;
- }else
- if( ($.type(opt) !== 'string') ){
- if( !options.lazyInit||options.open||options.inline ){
- createDateTimePicker($(this));
- }else
- lazyInit($(this));
- }
- });
- };
- $.fn.datetimepicker.defaults = default_options;
-})( jQuery );
-
-/*
- * Copyright (c) 2013 Brandon Aaron (http://brandonaaron.net)
- *
- * Licensed under the MIT License (LICENSE.txt).
- *
- * Thanks to: http://adomas.org/javascript-mouse-wheel/ for some pointers.
- * Thanks to: Mathias Bank(http://www.mathias-bank.de) for a scope bug fix.
- * Thanks to: Seamus Leahy for adding deltaX and deltaY
- *
- * Version: 3.1.3
- *
- * Requires: 1.2.2+
- */
-(function(factory) {if(typeof define==='function'&&define.amd) {define(['jquery'],factory)}else if(typeof exports==='object') {module.exports=factory}else{factory(jQuery)}}(function($) {var toFix=['wheel','mousewheel','DOMMouseScroll','MozMousePixelScroll'];var toBind='onwheel'in document||document.documentMode>=9?['wheel']:['mousewheel','DomMouseScroll','MozMousePixelScroll'];var lowestDelta,lowestDeltaXY;if($.event.fixHooks) {for(var i=toFix.length;i;) {$.event.fixHooks[toFix[--i]]=$.event.mouseHooks}}$.event.special.mousewheel={setup:function() {if(this.addEventListener) {for(var i=toBind.length;i;) {this.addEventListener(toBind[--i],handler,false)}}else{this.onmousewheel=handler}},teardown:function() {if(this.removeEventListener) {for(var i=toBind.length;i;) {this.removeEventListener(toBind[--i],handler,false)}}else{this.onmousewheel=null}}};$.fn.extend({mousewheel:function(fn) {return fn?this.bind("mousewheel",fn):this.trigger("mousewheel")},unmousewheel:function(fn) {return this.unbind("mousewheel",fn)}});function handler(event) {var orgEvent=event||window.event,args=[].slice.call(arguments,1),delta=0,deltaX=0,deltaY=0,absDelta=0,absDeltaXY=0,fn;event=$.event.fix(orgEvent);event.type="mousewheel";if(orgEvent.wheelDelta) {delta=orgEvent.wheelDelta}if(orgEvent.detail) {delta=orgEvent.detail*-1}if(orgEvent.deltaY) {deltaY=orgEvent.deltaY*-1;delta=deltaY}if(orgEvent.deltaX) {deltaX=orgEvent.deltaX;delta=deltaX*-1}if(orgEvent.wheelDeltaY!==undefined) {deltaY=orgEvent.wheelDeltaY}if(orgEvent.wheelDeltaX!==undefined) {deltaX=orgEvent.wheelDeltaX*-1}absDelta=Math.abs(delta);if(!lowestDelta||absDelta0?'floor':'ceil';delta=Math[fn](delta/lowestDelta);deltaX=Math[fn](deltaX/lowestDeltaXY);deltaY=Math[fn](deltaY/lowestDeltaXY);args.unshift(event,delta,deltaX,deltaY);return($.event.dispatch||$.event.handle).apply(this,args)}}));
-
-
-// Parse and Format Library
-//http://www.xaprb.com/blog/2005/12/12/javascript-closures-for-runtime-efficiency/
-/*
- * Copyright (C) 2004 Baron Schwartz
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU Lesser General Public License as published by the
- * Free Software Foundation, version 2.1.
- *
- * This program is distributed in the hope that it will be useful, but WITHOUT
- * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
- * FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License for more
- * details.
- */
-Date.parseFunctions={count:0};Date.parseRegexes=[];Date.formatFunctions={count:0};Date.prototype.dateFormat=function(b){if(b=="unixtime"){return parseInt(this.getTime()/1000);}if(Date.formatFunctions[b]==null){Date.createNewFormat(b);}var a=Date.formatFunctions[b];return this[a]();};Date.createNewFormat=function(format){var funcName="format"+Date.formatFunctions.count++;Date.formatFunctions[format]=funcName;var code="Date.prototype."+funcName+" = function() {return ";var special=false;var ch="";for(var i=0;i 0) {";var regex="";var special=false;var ch="";for(var i=0;i 0 && z > 0){\nvar doyDate = new Date(y,0);\ndoyDate.setDate(z);\nm = doyDate.getMonth();\nd = doyDate.getDate();\n}";code+="if (y > 0 && m >= 0 && d > 0 && h >= 0 && i >= 0 && s >= 0)\n{return new Date(y, m, d, h, i, s);}\nelse if (y > 0 && m >= 0 && d > 0 && h >= 0 && i >= 0)\n{return new Date(y, m, d, h, i);}\nelse if (y > 0 && m >= 0 && d > 0 && h >= 0)\n{return new Date(y, m, d, h);}\nelse if (y > 0 && m >= 0 && d > 0)\n{return new Date(y, m, d);}\nelse if (y > 0 && m >= 0)\n{return new Date(y, m);}\nelse if (y > 0)\n{return new Date(y);}\n}return null;}";Date.parseRegexes[regexNum]=new RegExp("^"+regex+"$");eval(code);};Date.formatCodeToRegex=function(b,a){switch(b){case"D":return{g:0,c:null,s:"(?:Sun|Mon|Tue|Wed|Thu|Fri|Sat)"};case"j":case"d":return{g:1,c:"d = parseInt(results["+a+"], 10);\n",s:"(\\d{1,2})"};case"l":return{g:0,c:null,s:"(?:"+Date.dayNames.join("|")+")"};case"S":return{g:0,c:null,s:"(?:st|nd|rd|th)"};case"w":return{g:0,c:null,s:"\\d"};case"z":return{g:1,c:"z = parseInt(results["+a+"], 10);\n",s:"(\\d{1,3})"};case"W":return{g:0,c:null,s:"(?:\\d{2})"};case"F":return{g:1,c:"m = parseInt(Date.monthNumbers[results["+a+"].substring(0, 3)], 10);\n",s:"("+Date.monthNames.join("|")+")"};case"M":return{g:1,c:"m = parseInt(Date.monthNumbers[results["+a+"]], 10);\n",s:"(Jan|Feb|Mar|Apr|May|Jun|Jul|Aug|Sep|Oct|Nov|Dec)"};case"n":case"m":return{g:1,c:"m = parseInt(results["+a+"], 10) - 1;\n",s:"(\\d{1,2})"};case"t":return{g:0,c:null,s:"\\d{1,2}"};case"L":return{g:0,c:null,s:"(?:1|0)"};case"Y":return{g:1,c:"y = parseInt(results["+a+"], 10);\n",s:"(\\d{4})"};case"y":return{g:1,c:"var ty = parseInt(results["+a+"], 10);\ny = ty > Date.y2kYear ? 1900 + ty : 2000 + ty;\n",s:"(\\d{1,2})"};case"a":return{g:1,c:"if (results["+a+"] == 'am') {\nif (h == 12) { h = 0; }\n} else { if (h < 12) { h += 12; }}",s:"(am|pm)"};case"A":return{g:1,c:"if (results["+a+"] == 'AM') {\nif (h == 12) { h = 0; }\n} else { if (h < 12) { h += 12; }}",s:"(AM|PM)"};case"g":case"G":case"h":case"H":return{g:1,c:"h = parseInt(results["+a+"], 10);\n",s:"(\\d{1,2})"};case"i":return{g:1,c:"i = parseInt(results["+a+"], 10);\n",s:"(\\d{2})"};case"s":return{g:1,c:"s = parseInt(results["+a+"], 10);\n",s:"(\\d{2})"};case"O":return{g:0,c:null,s:"[+-]\\d{4}"};case"T":return{g:0,c:null,s:"[A-Z]{3}"};case"Z":return{g:0,c:null,s:"[+-]\\d{1,5}"};default:return{g:0,c:null,s:String.escape(b)};}};Date.prototype.getTimezone=function(){return this.toString().replace(/^.*? ([A-Z]{3}) [0-9]{4}.*$/,"$1").replace(/^.*?\(([A-Z])[a-z]+ ([A-Z])[a-z]+ ([A-Z])[a-z]+\)$/,"$1$2$3");};Date.prototype.getGMTOffset=function(){return(this.getTimezoneOffset()>0?"-":"+")+String.leftPad(Math.floor(Math.abs(this.getTimezoneOffset())/60),2,"0")+String.leftPad(Math.abs(this.getTimezoneOffset())%60,2,"0");};Date.prototype.getDayOfYear=function(){var a=0;Date.daysInMonth[1]=this.isLeapYear()?29:28;for(var b=0;bdiv >div{
- background: #F5F5F5;
- border-top:1px solid #DDDDDD;
- color: #666666;
- font-size: 12px;
- text-align: center;
- border-collapse:collapse;
- cursor:pointer;
- border-bottom-width:0px;
- height:25px;
- line-height:25px;
-}
-
-.xdsoft_datetimepicker .xdsoft_timepicker .xdsoft_time_box >div > div:first-child{
- border-top-width:0px;
-}
-.xdsoft_datetimepicker .xdsoft_today_button:hover,
-.xdsoft_datetimepicker .xdsoft_next:hover,
-.xdsoft_datetimepicker .xdsoft_prev:hover {
- opacity: 1;
-}
-.xdsoft_datetimepicker .xdsoft_label{
- display: inline;
- position: relative;
- z-index: 9999;
- margin: 0;
- padding: 5px 3px;
- font-size: 14px;
- line-height: 20px;
- font-weight: bold;
- background-color: #fff;
- float:left;
- width:182px;
- text-align:center;
- cursor:pointer;
-}
-.xdsoft_datetimepicker .xdsoft_label:hover{
- text-decoration:underline;
-}
-.xdsoft_datetimepicker .xdsoft_label > .xdsoft_select{
- border:1px solid #ccc;
- position:absolute;
- right:0px;
- top:30px;
- z-index:101;
- display:none;
- background:#fff;
- max-height:160px;
- overflow-y:hidden;
-}
-.xdsoft_datetimepicker .xdsoft_label > .xdsoft_select.xdsoft_monthselect{right:-7px;}
-.xdsoft_datetimepicker .xdsoft_label > .xdsoft_select.xdsoft_yearselect{right:2px;}
-.xdsoft_datetimepicker .xdsoft_label > .xdsoft_select > div > .xdsoft_option:hover{
- color: #fff;
- background: #ff8000;
-}
-.xdsoft_datetimepicker .xdsoft_label > .xdsoft_select > div > .xdsoft_option{
- padding:2px 10px 2px 5px;
-}
-.xdsoft_datetimepicker .xdsoft_label > .xdsoft_select > div > .xdsoft_option.xdsoft_current{
- background: #33AAFF;
- box-shadow: #178FE5 0px 1px 3px 0px inset;
- color:#fff;
- font-weight: 700;
-}
-.xdsoft_datetimepicker .xdsoft_month{
- width:90px;
- text-align:right;
-}
-.xdsoft_datetimepicker .xdsoft_calendar{
- clear:both;
-}
-.xdsoft_datetimepicker .xdsoft_year{
- width:56px;
-}
-.xdsoft_datetimepicker .xdsoft_calendar table{
- border-collapse:collapse;
- width:100%;
-
-}
-.xdsoft_datetimepicker .xdsoft_calendar td > div{
- padding-right:5px;
-}
-.xdsoft_datetimepicker .xdsoft_calendar th{
- height: 25px;
-}
-.xdsoft_datetimepicker .xdsoft_calendar td,.xdsoft_datetimepicker .xdsoft_calendar th{
- width:14.2857142%;
- background: #F5F5F5;
- border:1px solid #DDDDDD;
- color: #666666;
- font-size: 12px;
- text-align: right;
- padding:0px;
- border-collapse:collapse;
- cursor:pointer;
- height: 25px;
-}
-.xdsoft_datetimepicker.xdsoft_showweeks .xdsoft_calendar td,.xdsoft_datetimepicker.xdsoft_showweeks .xdsoft_calendar th{
- width:12.5%;
-}
-.xdsoft_datetimepicker .xdsoft_calendar th{
- background: #F1F1F1;
-}
-.xdsoft_datetimepicker .xdsoft_calendar td.xdsoft_today{
- color:#33AAFF;
-}
-.xdsoft_datetimepicker .xdsoft_calendar td.xdsoft_default,
-.xdsoft_datetimepicker .xdsoft_calendar td.xdsoft_current,
-.xdsoft_datetimepicker .xdsoft_timepicker .xdsoft_time_box >div >div.xdsoft_current{
- background: #33AAFF;
- box-shadow: #178FE5 0px 1px 3px 0px inset;
- color:#fff;
- font-weight: 700;
-}
-.xdsoft_datetimepicker .xdsoft_calendar td.xdsoft_other_month,
-.xdsoft_datetimepicker .xdsoft_calendar td.xdsoft_disabled,
-.xdsoft_datetimepicker .xdsoft_time_box >div >div.xdsoft_disabled{
- opacity:0.5;
-}
-.xdsoft_datetimepicker .xdsoft_calendar td.xdsoft_other_month.xdsoft_disabled{
- opacity:0.2;
-}
-.xdsoft_datetimepicker .xdsoft_calendar td:hover,
-.xdsoft_datetimepicker .xdsoft_timepicker .xdsoft_time_box >div >div:hover{
- color: #fff !important;
- background: #ff8000 !important;
- box-shadow: none !important;
-}
-.xdsoft_datetimepicker .xdsoft_calendar td.xdsoft_disabled:hover,
-.xdsoft_datetimepicker .xdsoft_timepicker .xdsoft_time_box >div >div.xdsoft_disabled:hover{
- color: inherit !important;
- background: inherit !important;
- box-shadow: inherit !important;
-}
-.xdsoft_datetimepicker .xdsoft_calendar th{
- font-weight: 700;
- text-align: center;
- color: #999;
- cursor:default;
-}
-.xdsoft_datetimepicker .xdsoft_copyright{ color:#ccc !important; font-size:10px;clear:both;float:none;margin-left:8px;}
-.xdsoft_datetimepicker .xdsoft_copyright a{ color:#eee !important;}
-.xdsoft_datetimepicker .xdsoft_copyright a:hover{ color:#aaa !important;}
-
-
-.xdsoft_time_box{
- position:relative;
- border:1px solid #ccc;
-}
-.xdsoft_scrollbar >.xdsoft_scroller{
- background:#ccc !important;
- height:20px;
- border-radius:3px;
-}
-.xdsoft_scrollbar{
- position:absolute;
- width:7px;
- right:0px;
- top:0px;
- bottom:0px;
- cursor:pointer;
-}
-.xdsoft_scroller_box{
-position:relative;
-}
diff --git a/app/assets/stylesheets/publify_admin.css.scss b/app/assets/stylesheets/publify_admin.css.scss
index 404b9a4c..1805b54f 100644
--- a/app/assets/stylesheets/publify_admin.css.scss
+++ b/app/assets/stylesheets/publify_admin.css.scss
@@ -3,7 +3,6 @@
*= require jquery-ui
*= require tagmanager
*= require sidebar_admin
- *= require datetimepicker
*/
// "bootstrap-sprockets" must be imported before "bootstrap" and "bootstrap/variables"
@import "bootstrap-sprockets";
diff --git a/app/views/admin/articles/_form.html.erb b/app/views/admin/articles/_form.html.erb
index 09936512..035d183e 100644
--- a/app/views/admin/articles/_form.html.erb
+++ b/app/views/admin/articles/_form.html.erb
@@ -144,7 +144,7 @@
<%= toggle_element('publish') %>
- <%= text_field 'article', 'published_at' %>
+ <%= datetime_field 'article', 'published_at' %>
<%= toggle_element('publish', t('.ok')) %>
diff --git a/app/views/admin/notes/_form.html.erb b/app/views/admin/notes/_form.html.erb
index 30b08cbb..5da27844 100644
--- a/app/views/admin/notes/_form.html.erb
+++ b/app/views/admin/notes/_form.html.erb
@@ -25,11 +25,10 @@
<%= t('.publish_at') %>
- <%= n.text_field :published_at, class: 'form-control datepicker',
- placeholder: t('.now'), data: { locale: I18n.locale } %>
+ <%= n.datetime_field :published_at, class: 'form-control' %>
-
+
<%= link_to(t('.cancel'), action: 'index') %>
<%= t('.or') %>
<%= submit_tag(t('.publish'), class: 'btn btn-success') %>
diff --git a/app/views/admin/notes/_note.html.erb b/app/views/admin/notes/_note.html.erb
index d0b8ee8b..eac0a696 100644
--- a/app/views/admin/notes/_note.html.erb
+++ b/app/views/admin/notes/_note.html.erb
@@ -3,10 +3,10 @@
<%= h(note.body.strip_html.slice(0..140)) %>
- <%= author_link(note) %>
+ <%= author_link(note) %>
- <%= l(note.published_at) %>
+ <%= l(note.published_at) if note.published_at %>
<%= note.text_filter_name %>
diff --git a/config/locales/ar.yml b/config/locales/ar.yml
index 9df2fe62..2cbf57d4 100644
--- a/config/locales/ar.yml
+++ b/config/locales/ar.yml
@@ -284,7 +284,6 @@ ar:
compose_new_note: قم بتكوين ملاحظة جديدة
in_reply_to: في الرد على
no_notes: لا توجد ملاحظات بعد. هل تريد إنشاء واحد؟
- now: الآن
or: أو
permanent_link: رابط ثابت
posse_to_twitter: POSSE to Twitter
diff --git a/config/locales/da.yml b/config/locales/da.yml
index 9ee61ca9..2daaa824 100644
--- a/config/locales/da.yml
+++ b/config/locales/da.yml
@@ -246,7 +246,6 @@ da:
compose_new_note: Compose new note
in_reply_to: In reply to
no_notes: There are no notes yet. Why don't you create one?
- now: Now
or: or
permanent_link: Permanent link
posse_to_twitter: POSSE to Twitter
diff --git a/config/locales/de.yml b/config/locales/de.yml
index bd62d7ac..d1ef17fd 100644
--- a/config/locales/de.yml
+++ b/config/locales/de.yml
@@ -246,7 +246,6 @@ de:
compose_new_note: Compose new note
in_reply_to: In reply to
no_notes: There are no notes yet. Why don't you create one?
- now: Now
or: or
permanent_link: Permanent link
posse_to_twitter: POSSE to Twitter
diff --git a/config/locales/en.yml b/config/locales/en.yml
index 59e4cf89..67cd5c94 100644
--- a/config/locales/en.yml
+++ b/config/locales/en.yml
@@ -246,7 +246,6 @@ en:
compose_new_note: Compose new note
in_reply_to: In reply to
no_notes: There are no notes yet. Why don't you create one?
- now: Now
or: or
permanent_link: Permanent link
posse_to_twitter: POSSE to Twitter
diff --git a/config/locales/es-MX.yml b/config/locales/es-MX.yml
index 63467152..05998e58 100644
--- a/config/locales/es-MX.yml
+++ b/config/locales/es-MX.yml
@@ -246,7 +246,6 @@ es-MX:
compose_new_note: Componer una nueva nota
in_reply_to: In reply to
no_notes: No existen notas aún. Por qué no empieza creando una?
- now: Now
or: or
permanent_link: Permanent link
posse_to_twitter: POSSE to twitter
diff --git a/config/locales/fr.yml b/config/locales/fr.yml
index 181349c8..4f46629b 100644
--- a/config/locales/fr.yml
+++ b/config/locales/fr.yml
@@ -250,7 +250,6 @@ fr:
compose_new_note: Écrire un nouveau billet
in_reply_to: En réponse à
no_notes: 'Il n''y a pas encore de notes, pourquoi ne pas en créer une ? '
- now: Maintenant
or: ou
permanent_link: Lien permanent
posse_to_twitter: POSSE to twitter
diff --git a/config/locales/he.yml b/config/locales/he.yml
index 0f2de19d..78f551e4 100644
--- a/config/locales/he.yml
+++ b/config/locales/he.yml
@@ -245,7 +245,6 @@ he:
compose_new_note: Compose new note
in_reply_to: In reply to
no_notes: There are no notes yet. Why don't you create one?
- now: Now
or: or
permanent_link: Permanent link
posse_to_twitter: POSSE to Twitter
diff --git a/config/locales/it.yml b/config/locales/it.yml
index dd351072..2ef577fa 100644
--- a/config/locales/it.yml
+++ b/config/locales/it.yml
@@ -246,7 +246,6 @@ it:
compose_new_note: Compose new note
in_reply_to: In reply to
no_notes: There are no notes yet. Why don't you create one?
- now: Now
or: or
permanent_link: Permanent link
posse_to_twitter: POSSE to Twitter
diff --git a/config/locales/ja.yml b/config/locales/ja.yml
index 5ccd5817..7efd68d7 100644
--- a/config/locales/ja.yml
+++ b/config/locales/ja.yml
@@ -245,7 +245,6 @@ ja:
compose_new_note: Compose new note
in_reply_to: In reply to
no_notes: There are no notes yet. Why don't you create one?
- now: Now
or: or
permanent_link: Permanent link
posse_to_twitter: POSSE to Twitter
diff --git a/config/locales/lt.yml b/config/locales/lt.yml
index 6e778fa3..23c28fe3 100644
--- a/config/locales/lt.yml
+++ b/config/locales/lt.yml
@@ -258,7 +258,6 @@ lt:
compose_new_note: Compose new note
in_reply_to: In reply to
no_notes: There are no notes yet. Why don't you create one?
- now: Now
or: or
permanent_link: Permanent link
posse_to_twitter: POSSE to Twitter
diff --git a/config/locales/nb.yml b/config/locales/nb.yml
index efc813fa..159a65d5 100644
--- a/config/locales/nb.yml
+++ b/config/locales/nb.yml
@@ -246,7 +246,6 @@ nb:
compose_new_note: Skriv nytt notat
in_reply_to: Som svar på
no_notes: Det er ingen notater enda. Hva med å opprette en?
- now: Nå
or: eller
permanent_link: Permanent lenke
posse_to_twitter: POSSE til Twitter
diff --git a/config/locales/nl.yml b/config/locales/nl.yml
index f3d74a44..70d913d9 100644
--- a/config/locales/nl.yml
+++ b/config/locales/nl.yml
@@ -246,7 +246,6 @@ nl:
compose_new_note: Compose new note
in_reply_to: In reply to
no_notes: Er zijn nog geen notes. Waarom maak je er geen?
- now: Now
or: or
permanent_link: Permanente link
posse_to_twitter: POSSE naar Twitter
diff --git a/config/locales/pl.yml b/config/locales/pl.yml
index 871bb167..ce7623e2 100644
--- a/config/locales/pl.yml
+++ b/config/locales/pl.yml
@@ -270,7 +270,6 @@ pl:
compose_new_note: Utwórz nową notatkę
in_reply_to: W odpowiedzi do
no_notes: Brak notatek
- now: Teraz
or: lub
permanent_link: Link
posse_to_twitter: POSSE to twitter
diff --git a/config/locales/pt-BR.yml b/config/locales/pt-BR.yml
index eb700fb9..e9ae9700 100644
--- a/config/locales/pt-BR.yml
+++ b/config/locales/pt-BR.yml
@@ -246,7 +246,6 @@ pt-BR:
compose_new_note: Compor nova nota
in_reply_to: Em resposta a
no_notes: Não existem notas ainda. Por que você não inicia e cria uma?
- now: Agora
or: ou
permanent_link: link permanente
posse_to_twitter: POSSE para twitter
diff --git a/config/locales/ro.yml b/config/locales/ro.yml
index 0e7085df..d01c946b 100644
--- a/config/locales/ro.yml
+++ b/config/locales/ro.yml
@@ -258,7 +258,6 @@ ro:
compose_new_note: Compose new note
in_reply_to: In reply to
no_notes: There are no notes yet. Why don't you create one?
- now: Now
or: or
permanent_link: Permanent link
posse_to_twitter: POSSE to Twitter
diff --git a/config/locales/ru.yml b/config/locales/ru.yml
index e7c108b7..1afe2339 100644
--- a/config/locales/ru.yml
+++ b/config/locales/ru.yml
@@ -270,7 +270,6 @@ ru:
compose_new_note: Compose new note
in_reply_to: In reply to
no_notes: Ничего нет. Почему бы не начать и не добавить?
- now: Сейчас
or: или
permanent_link: Постоянная ссылка
posse_to_twitter: POSSE to Twitter
diff --git a/config/locales/zh-CN.yml b/config/locales/zh-CN.yml
index 13e527c1..dfd7c8ad 100644
--- a/config/locales/zh-CN.yml
+++ b/config/locales/zh-CN.yml
@@ -242,7 +242,6 @@ zh-CN:
compose_new_note: Compose new note
in_reply_to: In reply to
no_notes: 这儿并不存在Notes。让我们开始创建它。
- now: Now
or: or
permanent_link: Permanent link
posse_to_twitter: POSSE to twitter
diff --git a/config/locales/zh-TW.yml b/config/locales/zh-TW.yml
index bb8d76c9..267cb779 100644
--- a/config/locales/zh-TW.yml
+++ b/config/locales/zh-TW.yml
@@ -243,7 +243,6 @@ zh-TW:
compose_new_note: Compose new note
in_reply_to: In reply to
no_notes: There are no notes yet. Why don't you create one?
- now: Now
or: or
permanent_link: Permanent link
posse_to_twitter: POSSE to Twitter
diff --git a/spec/controllers/admin/notes_controller_spec.rb b/spec/controllers/admin/notes_controller_spec.rb
index 862112e9..c8af997e 100644
--- a/spec/controllers/admin/notes_controller_spec.rb
+++ b/spec/controllers/admin/notes_controller_spec.rb
@@ -6,7 +6,7 @@
render_views
let(:admin) { create(:user, :as_admin, twitter: "@getpublify") }
- let!(:blog) { create(:blog) }
+ let!(:blog) { create(:blog, limit_article_display: 10) }
before do
sign_in admin
@@ -16,13 +16,32 @@
describe "index" do
let!(:notes) { create_list(:note, 2) }
- before { get :index }
+ it "shows the index template" do
+ get :index
+ expect(response).to render_template("index")
+ end
+
+ it "lists existing notes" do
+ get :index
+ expect(assigns(:notes)).to match_array notes
+ end
- it { expect(response).to render_template("index") }
- it { expect(assigns(:notes).sort).to eq(notes.sort) }
- it { expect(assigns(:note)).to be_a(Note) }
- it { expect(assigns(:note).author).to eq(admin.login) }
- it { expect(assigns(:note).user).to eq(admin) }
+ it "assigns a new note for the note form" do
+ get :index
+
+ aggregate_failures do
+ expect(assigns(:note)).to be_a(Note)
+ expect(assigns(:note).author).to eq(admin.login)
+ expect(assigns(:note).user).to eq(admin)
+ end
+ end
+
+ it "lists notes without publication date" do
+ create(:note, published_at: nil)
+
+ get :index
+ expect(response).to be_successful
+ end
end
describe "create" do