- Added comprehensive AI Assistant system (aiassist/ directory): * Vector search and embedding capabilities * Typebot proxy integration * Elastic search functionality * Message classification and chat history * MCP proxy for external integrations - Implemented Court Status API (GetCourtStatus.php): * Real-time court document status checking * Integration with external court systems * Comprehensive error handling and logging - Enhanced S3 integration: * Improved file backup system with metadata * Batch processing capabilities * Enhanced error logging and recovery * Copy operations with URL fixing - Added Telegram contact creation API - Improved error logging across all modules - Enhanced callback system for AI responses - Extensive backup file storage with timestamps - Updated documentation and README files - File storage improvements: * Thousands of backup files with proper metadata * Fix operations for broken file references * Project-specific backup and recovery systems * Comprehensive file integrity checking Total: 26,461+ files added/modified including AWS SDK, vendor dependencies, and extensive backup system.
231 lines
8.8 KiB
JavaScript
231 lines
8.8 KiB
JavaScript
/* http://keith-wood.name/datepick.html
|
|
Datepicker Validation extension for jQuery 4.1.0.
|
|
Requires Jörn Zaefferer's Validation plugin (http://plugins.jquery.com/project/validate).
|
|
Written by Keith Wood (kbwood{at}iinet.com.au).
|
|
Dual licensed under the GPL (http://dev.jquery.com/browser/trunk/jquery/GPL-LICENSE.txt) and
|
|
MIT (http://dev.jquery.com/browser/trunk/jquery/MIT-LICENSE.txt) licenses.
|
|
Please attribute the author if you use it. */
|
|
|
|
(function($) { // Hide the namespace
|
|
|
|
/* Add validation methods if validation plugin available. */
|
|
if ($.fn.validate) {
|
|
|
|
$.datepick.selectDateOrig = $.datepick.selectDate;
|
|
|
|
$.extend($.datepick.regional[''], {
|
|
validateDate: 'Please enter a valid date',
|
|
validateDateMin: 'Please enter a date on or after {0}',
|
|
validateDateMax: 'Please enter a date on or before {0}',
|
|
validateDateMinMax: 'Please enter a date between {0} and {1}',
|
|
validateDateCompare: 'Please enter a date {0} {1}',
|
|
validateDateToday: 'today',
|
|
validateDateOther: 'the other date',
|
|
validateDateEQ: 'equal to',
|
|
validateDateNE: 'not equal to',
|
|
validateDateLT: 'before',
|
|
validateDateGT: 'after',
|
|
validateDateLE: 'not after',
|
|
validateDateGE: 'not before'
|
|
});
|
|
|
|
$.extend($.datepick._defaults, $.datepick.regional['']);
|
|
|
|
$.extend($.datepick, {
|
|
|
|
/* Trigger a validation after updating the input field with the selected date.
|
|
@param target (element) the control to examine
|
|
@param elem (element) the selected datepicker element */
|
|
selectDate: function(target, elem) {
|
|
this.selectDateOrig(target, elem);
|
|
var inst = $.data(target, $.datepick.propertyName);
|
|
if (!inst.inline && $.fn.validate) {
|
|
var validation = $(target).parents('form').validate();
|
|
if (validation) {
|
|
validation.element('#' + target.id);
|
|
}
|
|
}
|
|
},
|
|
|
|
/* Correct error placement for validation errors - after any trigger.
|
|
@param error (jQuery) the error message
|
|
@param element (jQuery) the field in error */
|
|
errorPlacement: function(error, element) {
|
|
var inst = $.data(element[0], $.datepick.propertyName);
|
|
if (inst) {
|
|
error[inst.options.isRTL ? 'insertBefore' : 'insertAfter'](
|
|
inst.trigger.length > 0 ? inst.trigger : element);
|
|
}
|
|
else {
|
|
error.insertAfter(element);
|
|
}
|
|
},
|
|
|
|
/* Format a validation error message involving dates.
|
|
@param source (string) the error message
|
|
@param params (Date[]) the dates
|
|
@return (string) the formatted message */
|
|
errorFormat: function(source, params) {
|
|
var format = ($.datepick.curInst ?
|
|
$.datepick.curInst.options.dateFormat :
|
|
$.datepick._defaults.dateFormat);
|
|
$.each(params, function(index, value) {
|
|
source = source.replace(new RegExp('\\{' + index + '\\}', 'g'),
|
|
$.datepick.formatDate(format, value) || 'nothing');
|
|
});
|
|
return source;
|
|
}
|
|
});
|
|
|
|
var lastElement = null;
|
|
|
|
/* Validate date field. */
|
|
$.validator.addMethod('dpDate', function(value, element) {
|
|
lastElement = element;
|
|
return this.optional(element) || validateEach(value, element);
|
|
},
|
|
function(params) {
|
|
var inst = $.data(lastElement, $.datepick.propertyName);
|
|
var minDate = inst.get('minDate');
|
|
var maxDate = inst.get('maxDate');
|
|
var messages = $.datepick._defaults;
|
|
return (minDate && maxDate ?
|
|
$.datepick.errorFormat(messages.validateDateMinMax, [minDate, maxDate]) :
|
|
(minDate ? $.datepick.errorFormat(messages.validateDateMin, [minDate]) :
|
|
(maxDate ? $.datepick.errorFormat(messages.validateDateMax, [maxDate]) :
|
|
messages.validateDate)));
|
|
});
|
|
|
|
/* Apply a validation test to each date provided.
|
|
@param value (string) the current field value
|
|
@param element (element) the field control
|
|
@return (boolean) true if OK, false if failed validation */
|
|
function validateEach(value, element) {
|
|
var inst = $.data(element, $.datepick.propertyName);
|
|
var dates = (inst.options.multiSelect ? value.split(inst.options.multiSeparator) :
|
|
(inst.options.rangeSelect ? value.split(inst.options.rangeSeparator) : [value]));
|
|
var ok = (inst.options.multiSelect && dates.length <= inst.options.multiSelect) ||
|
|
(!inst.options.multiSelect && inst.options.rangeSelect && dates.length == 2) ||
|
|
(!inst.options.multiSelect && !inst.options.rangeSelect && dates.length == 1);
|
|
if (ok) {
|
|
try {
|
|
var dateFormat = inst.options.dateFormat;
|
|
var minDate = inst.get('minDate');
|
|
var maxDate = inst.get('maxDate');
|
|
var dp = $(element);
|
|
$.each(dates, function(i, v) {
|
|
dates[i] = $.datepick.parseDate(dateFormat, v);
|
|
ok = ok && (!dates[i] || (dp.datepick('isSelectable', dates[i]) &&
|
|
(!minDate || dates[i].getTime() >= minDate.getTime()) &&
|
|
(!maxDate || dates[i].getTime() <= maxDate.getTime())));
|
|
});
|
|
}
|
|
catch (e) {
|
|
ok = false;
|
|
}
|
|
}
|
|
if (ok && inst.options.rangeSelect) {
|
|
ok = (dates[0].getTime() <= dates[1].getTime());
|
|
}
|
|
return ok;
|
|
}
|
|
|
|
/* And allow as a class rule. */
|
|
$.validator.addClassRules('dpDate', {dpDate: true});
|
|
|
|
var comparisons = {equal: 'eq', same: 'eq', notEqual: 'ne', notSame: 'ne',
|
|
lessThan: 'lt', before: 'lt', greaterThan: 'gt', after: 'gt',
|
|
notLessThan: 'ge', notBefore: 'ge', notGreaterThan: 'le', notAfter: 'le'};
|
|
|
|
/* Cross-validate date fields.
|
|
params should be an array with [0] comparison type eq/ne/lt/gt/le/ge or synonyms,
|
|
[1] 'today' or date string or Date or other field selector/element/jQuery OR
|
|
an object with one attribute with name eq/ne/lt/gt/le/ge or synonyms
|
|
and value 'today' or date string or Date or other field selector/element/jQuery OR
|
|
a string with eq/ne/lt/gt/le/ge or synonyms followed by 'today' or date string or jQuery selector */
|
|
$.validator.addMethod('dpCompareDate', function(value, element, params) {
|
|
if (this.optional(element)) {
|
|
return true;
|
|
}
|
|
params = normaliseParams(params);
|
|
var thisDate = $(element).datepick('getDate');
|
|
var thatDate = extractOtherDate(element, params[1]);
|
|
if (thisDate.length == 0 || thatDate.length == 0) {
|
|
return true;
|
|
}
|
|
lastElement = element;
|
|
var finalResult = true;
|
|
for (var i = 0; i < thisDate.length; i++) {
|
|
switch (comparisons[params[0]] || params[0]) {
|
|
case 'eq': finalResult = (thisDate[i].getTime() == thatDate[0].getTime()); break;
|
|
case 'ne': finalResult = (thisDate[i].getTime() != thatDate[0].getTime()); break;
|
|
case 'lt': finalResult = (thisDate[i].getTime() < thatDate[0].getTime()); break;
|
|
case 'gt': finalResult = (thisDate[i].getTime() > thatDate[0].getTime()); break;
|
|
case 'le': finalResult = (thisDate[i].getTime() <= thatDate[0].getTime()); break;
|
|
case 'ge': finalResult = (thisDate[i].getTime() >= thatDate[0].getTime()); break;
|
|
default: finalResult = true;
|
|
}
|
|
if (!finalResult) {
|
|
break;
|
|
}
|
|
}
|
|
return finalResult;
|
|
},
|
|
function(params) {
|
|
var messages = $.datepick._defaults;
|
|
var inst = $.data(lastElement, $.datepick.propertyName);
|
|
params = normaliseParams(params);
|
|
var thatDate = extractOtherDate(lastElement, params[1], true);
|
|
thatDate = (params[1] == 'today' ? messages.validateDateToday : (thatDate.length ?
|
|
$.datepick.formatDate(inst.options.dateFormat, thatDate[0], inst.getConfig()) :
|
|
messages.validateDateOther));
|
|
return messages.validateDateCompare.replace(/\{0\}/,
|
|
messages['validateDate' + (comparisons[params[0]] || params[0]).toUpperCase()]).
|
|
replace(/\{1\}/, thatDate);
|
|
});
|
|
|
|
/* Normalise the comparison parameters to an array.
|
|
@param params (array or object or string) the original parameters
|
|
@return (array) the normalised parameters */
|
|
function normaliseParams(params) {
|
|
if (typeof params == 'string') {
|
|
params = params.split(' ');
|
|
}
|
|
else if (!$.isArray(params)) {
|
|
var opts = [];
|
|
for (var name in params) {
|
|
opts[0] = name;
|
|
opts[1] = params[name];
|
|
}
|
|
params = opts;
|
|
}
|
|
return params;
|
|
}
|
|
|
|
/* Determine the comparison date.
|
|
@param element (element) the current datepicker element
|
|
@param source (string or Date or jQuery or element) the source of the other date
|
|
@param noOther (boolean) true to not get the date from another field
|
|
@return (Date[1]) the date for comparison */
|
|
function extractOtherDate(element, source, noOther) {
|
|
if (source.constructor == Date) {
|
|
return [source];
|
|
}
|
|
var inst = $.data(element, $.datepick.propertyName);
|
|
var thatDate = null;
|
|
try {
|
|
if (typeof source == 'string' && source != 'today') {
|
|
thatDate = $.datepick.parseDate(inst.options.dateFormat, source, inst.getConfig());
|
|
}
|
|
}
|
|
catch (e) {
|
|
// Ignore
|
|
}
|
|
thatDate = (thatDate ? [thatDate] : (source == 'today' ?
|
|
[$.datepick.today()] : (noOther ? [] : $(source).datepick('getDate'))));
|
|
return thatDate;
|
|
}
|
|
}
|
|
|
|
})(jQuery);
|