370 lines
13 KiB
HTML
Executable File
370 lines
13 KiB
HTML
Executable File
<!DOCTYPE html>
|
|
<html dir="ltr" lang="en-US">
|
|
<head>
|
|
<meta charset="UTF-8" />
|
|
<title>A date range picker for Bootstrap</title>
|
|
<link href="http://netdna.bootstrapcdn.com/bootstrap/3.3.2/css/bootstrap.min.css" rel="stylesheet">
|
|
<link rel="stylesheet" type="text/css" media="all" href="daterangepicker.css" />
|
|
<script type="text/javascript" src="https://code.jquery.com/jquery-1.11.3.min.js"></script>
|
|
<script type="text/javascript" src="http://netdna.bootstrapcdn.com/bootstrap/3.3.2/js/bootstrap.min.js"></script>
|
|
<script type="text/javascript" src="moment.js"></script>
|
|
<script type="text/javascript" src="daterangepicker.js"></script>
|
|
|
|
<!-- HTML5 shim and Respond.js IE8 support of HTML5 elements and media queries -->
|
|
<!--[if lt IE 9]>
|
|
<script src="https://oss.maxcdn.com/libs/html5shiv/3.7.0/html5shiv.js"></script>
|
|
<script src="https://oss.maxcdn.com/libs/respond.js/1.4.2/respond.min.js"></script>
|
|
<![endif]-->
|
|
</head>
|
|
<body style="margin: 60px 0">
|
|
|
|
<div class="container">
|
|
|
|
<h1 style="margin: 0 0 20px 0">Configuration Builder</h1>
|
|
|
|
<div class="well configurator">
|
|
|
|
<form>
|
|
<div class="row">
|
|
|
|
<div class="col-md-4">
|
|
|
|
<div class="form-group">
|
|
<label for="parentEl">parentEl</label>
|
|
<input type="text" class="form-control" id="parentEl" value="" placeholder="body">
|
|
</div>
|
|
|
|
<div class="form-group">
|
|
<label for="startDate">startDate</label>
|
|
<input type="text" class="form-control" id="startDate" value="07/01/2015">
|
|
</div>
|
|
|
|
<div class="form-group">
|
|
<label for="endDate">endDate</label>
|
|
<input type="text" class="form-control" id="endDate" value="07/15/2015">
|
|
</div>
|
|
|
|
<div class="form-group">
|
|
<label for="minDate">minDate</label>
|
|
<input type="text" class="form-control" id="minDate" value="" placeholder="MM/DD/YYYY">
|
|
</div>
|
|
|
|
<div class="form-group">
|
|
<label for="maxDate">maxDate</label>
|
|
<input type="text" class="form-control" id="maxDate" value="" placeholder="MM/DD/YYYY">
|
|
</div>
|
|
|
|
</div>
|
|
<div class="col-md-4">
|
|
|
|
<div class="checkbox">
|
|
<label>
|
|
<input type="checkbox" id="autoApply"> autoApply
|
|
</label>
|
|
</div>
|
|
|
|
<div class="checkbox">
|
|
<label>
|
|
<input type="checkbox" id="singleDatePicker"> singleDatePicker
|
|
</label>
|
|
</div>
|
|
|
|
<div class="checkbox">
|
|
<label>
|
|
<input type="checkbox" id="showDropdowns"> showDropdowns
|
|
</label>
|
|
</div>
|
|
|
|
<div class="checkbox">
|
|
<label>
|
|
<input type="checkbox" id="showWeekNumbers"> showWeekNumbers
|
|
</label>
|
|
</div>
|
|
|
|
<div class="checkbox">
|
|
<label>
|
|
<input type="checkbox" id="showISOWeekNumbers"> showISOWeekNumbers
|
|
</label>
|
|
</div>
|
|
|
|
<div class="checkbox">
|
|
<label>
|
|
<input type="checkbox" id="timePicker"> timePicker
|
|
</label>
|
|
</div>
|
|
|
|
<div class="checkbox">
|
|
<label>
|
|
<input type="checkbox" id="timePicker24Hour"> timePicker24Hour
|
|
</label>
|
|
</div>
|
|
|
|
<div class="form-group">
|
|
<label for="timePickerIncrement">timePickerIncrement (in minutes)</label>
|
|
<input type="text" class="form-control" id="timePickerIncrement" value="1">
|
|
</div>
|
|
|
|
<div class="checkbox">
|
|
<label>
|
|
<input type="checkbox" id="timePickerSeconds"> timePickerSeconds
|
|
</label>
|
|
</div>
|
|
|
|
<div class="checkbox">
|
|
<label>
|
|
<input type="checkbox" id="dateLimit"> dateLimit (with example date range span)
|
|
</label>
|
|
</div>
|
|
|
|
<div class="checkbox">
|
|
<label>
|
|
<input type="checkbox" id="ranges"> ranges (with example predefined ranges)
|
|
</label>
|
|
</div>
|
|
|
|
<div class="checkbox">
|
|
<label>
|
|
<input type="checkbox" id="locale"> locale (with example settings)
|
|
</label>
|
|
<label id="rtl-wrap">
|
|
<input type="checkbox" id="rtl"> RTL (right-to-left)
|
|
</label>
|
|
</div>
|
|
|
|
<div class="checkbox">
|
|
<label>
|
|
<input type="checkbox" id="alwaysShowCalendars"> alwaysShowCalendars
|
|
</label>
|
|
</div>
|
|
|
|
</div>
|
|
<div class="col-md-4">
|
|
|
|
<div class="checkbox">
|
|
<label>
|
|
<input type="checkbox" id="linkedCalendars" checked="checked"> linkedCalendars
|
|
</label>
|
|
</div>
|
|
|
|
<div class="checkbox">
|
|
<label>
|
|
<input type="checkbox" id="autoUpdateInput" checked="checked"> autoUpdateInput
|
|
</label>
|
|
</div>
|
|
|
|
<div class="checkbox">
|
|
<label>
|
|
<input type="checkbox" id="showCustomRangeLabel" checked="checked"> showCustomRangeLabel
|
|
</label>
|
|
</div>
|
|
|
|
<div class="form-group">
|
|
<label for="opens">opens</label>
|
|
<select id="opens" class="form-control">
|
|
<option value="right" selected>right</option>
|
|
<option value="left">left</option>
|
|
<option value="center">center</option>
|
|
</select>
|
|
</div>
|
|
|
|
<div class="form-group">
|
|
<label for="drops">drops</label>
|
|
<select id="drops" class="form-control">
|
|
<option value="down" selected>down</option>
|
|
<option value="up">up</option>
|
|
</select>
|
|
</div>
|
|
|
|
<div class="form-group">
|
|
<label for="buttonClasses">buttonClasses</label>
|
|
<input type="text" class="form-control" id="buttonClasses" value="btn btn-sm">
|
|
</div>
|
|
|
|
<div class="form-group">
|
|
<label for="applyClass">applyClass</label>
|
|
<input type="text" class="form-control" id="applyClass" value="btn-success">
|
|
</div>
|
|
|
|
<div class="form-group">
|
|
<label for="cancelClass">cancelClass</label>
|
|
<input type="text" class="form-control" id="cancelClass" value="btn-default">
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
</form>
|
|
|
|
</div>
|
|
|
|
<div class="row">
|
|
|
|
<div class="col-md-4 col-md-offset-2 demo">
|
|
<h4>Your Date Range Picker</h4>
|
|
<input type="text" id="config-demo" class="form-control">
|
|
<i class="glyphicon glyphicon-calendar fa fa-calendar"></i>
|
|
</div>
|
|
|
|
<div class="col-md-6">
|
|
<h4>Configuration</h4>
|
|
|
|
<div class="well">
|
|
<textarea id="config-text" style="height: 300px; width: 100%; padding: 10px"></textarea>
|
|
</div>
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
<style type="text/css">
|
|
.demo { position: relative; }
|
|
.demo i {
|
|
position: absolute; bottom: 10px; right: 24px; top: auto; cursor: pointer;
|
|
}
|
|
</style>
|
|
|
|
<script type="text/javascript">
|
|
$(document).ready(function() {
|
|
|
|
$('#config-text').keyup(function() {
|
|
eval($(this).val());
|
|
});
|
|
|
|
$('.configurator input, .configurator select').change(function() {
|
|
updateConfig();
|
|
});
|
|
|
|
$('.demo i').click(function() {
|
|
$(this).parent().find('input').click();
|
|
});
|
|
|
|
$('#startDate').daterangepicker({
|
|
singleDatePicker: true,
|
|
startDate: moment().subtract(6, 'days')
|
|
});
|
|
|
|
$('#endDate').daterangepicker({
|
|
singleDatePicker: true,
|
|
startDate: moment()
|
|
});
|
|
|
|
updateConfig();
|
|
|
|
function updateConfig() {
|
|
var options = {};
|
|
|
|
if ($('#singleDatePicker').is(':checked'))
|
|
options.singleDatePicker = true;
|
|
|
|
if ($('#showDropdowns').is(':checked'))
|
|
options.showDropdowns = true;
|
|
|
|
if ($('#showWeekNumbers').is(':checked'))
|
|
options.showWeekNumbers = true;
|
|
|
|
if ($('#showISOWeekNumbers').is(':checked'))
|
|
options.showISOWeekNumbers = true;
|
|
|
|
if ($('#timePicker').is(':checked'))
|
|
options.timePicker = true;
|
|
|
|
if ($('#timePicker24Hour').is(':checked'))
|
|
options.timePicker24Hour = true;
|
|
|
|
if ($('#timePickerIncrement').val().length && $('#timePickerIncrement').val() != 1)
|
|
options.timePickerIncrement = parseInt($('#timePickerIncrement').val(), 10);
|
|
|
|
if ($('#timePickerSeconds').is(':checked'))
|
|
options.timePickerSeconds = true;
|
|
|
|
if ($('#autoApply').is(':checked'))
|
|
options.autoApply = true;
|
|
|
|
if ($('#dateLimit').is(':checked'))
|
|
options.dateLimit = { days: 7 };
|
|
|
|
if ($('#ranges').is(':checked')) {
|
|
options.ranges = {
|
|
'Today': [moment(), moment()],
|
|
'Yesterday': [moment().subtract(1, 'days'), moment().subtract(1, 'days')],
|
|
'Last 7 Days': [moment().subtract(6, 'days'), moment()],
|
|
'Last 30 Days': [moment().subtract(29, 'days'), moment()],
|
|
'This Month': [moment().startOf('month'), moment().endOf('month')],
|
|
'Last Month': [moment().subtract(1, 'month').startOf('month'), moment().subtract(1, 'month').endOf('month')]
|
|
};
|
|
}
|
|
|
|
if ($('#locale').is(':checked')) {
|
|
$('#rtl-wrap').show();
|
|
options.locale = {
|
|
direction: $('#rtl').is(':checked') ? 'rtl' : 'ltr',
|
|
format: 'MM/DD/YYYY HH:mm',
|
|
separator: ' - ',
|
|
applyLabel: 'Apply',
|
|
cancelLabel: 'Cancel',
|
|
fromLabel: 'From',
|
|
toLabel: 'To',
|
|
customRangeLabel: 'Custom',
|
|
daysOfWeek: ['Su', 'Mo', 'Tu', 'We', 'Th', 'Fr','Sa'],
|
|
monthNames: ['January', 'February', 'March', 'April', 'May', 'June', 'July', 'August', 'September', 'October', 'November', 'December'],
|
|
firstDay: 1
|
|
};
|
|
} else {
|
|
$('#rtl-wrap').hide();
|
|
}
|
|
|
|
if (!$('#linkedCalendars').is(':checked'))
|
|
options.linkedCalendars = false;
|
|
|
|
if (!$('#autoUpdateInput').is(':checked'))
|
|
options.autoUpdateInput = false;
|
|
|
|
if (!$('#showCustomRangeLabel').is(':checked'))
|
|
options.showCustomRangeLabel = false;
|
|
|
|
if ($('#alwaysShowCalendars').is(':checked'))
|
|
options.alwaysShowCalendars = true;
|
|
|
|
if ($('#parentEl').val().length)
|
|
options.parentEl = $('#parentEl').val();
|
|
|
|
if ($('#startDate').val().length)
|
|
options.startDate = $('#startDate').val();
|
|
|
|
if ($('#endDate').val().length)
|
|
options.endDate = $('#endDate').val();
|
|
|
|
if ($('#minDate').val().length)
|
|
options.minDate = $('#minDate').val();
|
|
|
|
if ($('#maxDate').val().length)
|
|
options.maxDate = $('#maxDate').val();
|
|
|
|
if ($('#opens').val().length && $('#opens').val() != 'right')
|
|
options.opens = $('#opens').val();
|
|
|
|
if ($('#drops').val().length && $('#drops').val() != 'down')
|
|
options.drops = $('#drops').val();
|
|
|
|
if ($('#buttonClasses').val().length && $('#buttonClasses').val() != 'btn btn-sm')
|
|
options.buttonClasses = $('#buttonClasses').val();
|
|
|
|
if ($('#applyClass').val().length && $('#applyClass').val() != 'btn-success')
|
|
options.applyClass = $('#applyClass').val();
|
|
|
|
if ($('#cancelClass').val().length && $('#cancelClass').val() != 'btn-default')
|
|
options.cancelClass = $('#cancelClass').val();
|
|
|
|
$('#config-text').val("$('#demo').daterangepicker(" + JSON.stringify(options, null, ' ') + ", function(start, end, label) {\n console.log(\"New date range selected: ' + start.format('YYYY-MM-DD') + ' to ' + end.format('YYYY-MM-DD') + ' (predefined range: ' + label + ')\");\n});");
|
|
|
|
$('#config-demo').daterangepicker(options, function(start, end, label) { console.log('New date range selected: ' + start.format('YYYY-MM-DD') + ' to ' + end.format('YYYY-MM-DD') + ' (predefined range: ' + label + ')'); });
|
|
|
|
}
|
|
|
|
});
|
|
</script>
|
|
|
|
</body>
|
|
</html>
|