mirror of
https://github.com/encode/django-rest-framework.git
synced 2025-06-01 20:23:13 +03:00
Preserve tab preference in cookies.
This commit is contained in:
parent
c7f3b8bebe
commit
1fa2d823cc
|
@ -1,13 +1,56 @@
|
||||||
|
function getCookie(c_name)
|
||||||
|
{
|
||||||
|
// From http://www.w3schools.com/js/js_cookies.asp
|
||||||
|
var c_value = document.cookie;
|
||||||
|
var c_start = c_value.indexOf(" " + c_name + "=");
|
||||||
|
if (c_start == -1) {
|
||||||
|
c_start = c_value.indexOf(c_name + "=");
|
||||||
|
}
|
||||||
|
if (c_start == -1) {
|
||||||
|
c_value = null;
|
||||||
|
} else {
|
||||||
|
c_start = c_value.indexOf("=", c_start) + 1;
|
||||||
|
var c_end = c_value.indexOf(";", c_start);
|
||||||
|
if (c_end == -1) {
|
||||||
|
c_end = c_value.length;
|
||||||
|
}
|
||||||
|
c_value = unescape(c_value.substring(c_start,c_end));
|
||||||
|
}
|
||||||
|
return c_value;
|
||||||
|
}
|
||||||
|
|
||||||
|
// JSON highlighting.
|
||||||
prettyPrint();
|
prettyPrint();
|
||||||
|
|
||||||
|
// Bootstrap tooltips.
|
||||||
$('.js-tooltip').tooltip({
|
$('.js-tooltip').tooltip({
|
||||||
delay: 1000
|
delay: 1000
|
||||||
});
|
});
|
||||||
|
|
||||||
|
// Deal with rounded tab styling after tab clicks.
|
||||||
$('a[data-toggle="tab"]:first').on('shown', function (e) {
|
$('a[data-toggle="tab"]:first').on('shown', function (e) {
|
||||||
$(e.target).parents('.tabbable').addClass('first-tab-active');
|
$(e.target).parents('.tabbable').addClass('first-tab-active');
|
||||||
});
|
});
|
||||||
$('a[data-toggle="tab"]:not(:first)').on('shown', function (e) {
|
$('a[data-toggle="tab"]:not(:first)').on('shown', function (e) {
|
||||||
$(e.target).parents('.tabbable').removeClass('first-tab-active');
|
$(e.target).parents('.tabbable').removeClass('first-tab-active');
|
||||||
});
|
});
|
||||||
|
|
||||||
|
$('a[data-toggle="tab"]').click(function(){
|
||||||
|
document.cookie="tab=" + this.name;
|
||||||
|
});
|
||||||
|
|
||||||
|
// Store tab preference in cookies & display appropriate tab on load.
|
||||||
|
var selectedTab = null;
|
||||||
|
var selectedTabName = getCookie('tab');
|
||||||
|
|
||||||
|
if (selectedTabName) {
|
||||||
|
selectedTab = $('.form-switcher a[name=' + selectedTabName + ']');
|
||||||
|
}
|
||||||
|
|
||||||
|
if (selectedTab && selectedTab.length > 0) {
|
||||||
|
// Display whichever tab is selected.
|
||||||
|
selectedTab.tab('show');
|
||||||
|
} else {
|
||||||
|
// If no tab selected, display rightmost tab.
|
||||||
$('.form-switcher a:first').tab('show');
|
$('.form-switcher a:first').tab('show');
|
||||||
|
}
|
||||||
|
|
|
@ -128,8 +128,8 @@
|
||||||
<div {% if post_form %}class="tabbable"{% endif %}>
|
<div {% if post_form %}class="tabbable"{% endif %}>
|
||||||
{% if post_form %}
|
{% if post_form %}
|
||||||
<ul class="nav nav-tabs form-switcher">
|
<ul class="nav nav-tabs form-switcher">
|
||||||
<li><a href="#object-form" data-toggle="tab">HTML form</a></li>
|
<li><a name='html-tab' href="#object-form" data-toggle="tab">HTML form</a></li>
|
||||||
<li><a href="#generic-content-form" data-toggle="tab">Raw data</a></li>
|
<li><a name='raw-tab' href="#generic-content-form" data-toggle="tab">Raw data</a></li>
|
||||||
</ul>
|
</ul>
|
||||||
{% endif %}
|
{% endif %}
|
||||||
<div class="well tab-content">
|
<div class="well tab-content">
|
||||||
|
|
Loading…
Reference in New Issue
Block a user