annotate app/assets/javascripts/init.tabs.js @ 122:a836cfe4092f

Use hash instead of search because IE can't into replaceState. Also probably better cached by browsers.
author Edho Arief <edho@myconan.net>
date Mon, 12 Nov 2012 15:21:01 +0700
parents dd7181c021de
children 5b58b0d6841c
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
59
1833de28583a Turns out the init file is required.
Edho Arief <edho@myconan.net>
parents:
diff changeset
1 $(document).ready(function() {
110
e8c632b0eb80 Check if current location is a show paste before triggering tabs js.
Edho Arief <edho@myconan.net>
parents: 109
diff changeset
2 if ($('#paste-tabs').length == 1) {
e8c632b0eb80 Check if current location is a show paste before triggering tabs js.
Edho Arief <edho@myconan.net>
parents: 109
diff changeset
3 raw = $('#plain pre').text();
104
9825e51ba30f Minor reorganization.
Edho Arief <edho@myconan.net>
parents: 103
diff changeset
4
120
309238f5b7b1 Prettyprint in markdown.
Edho Arief <edho@myconan.net>
parents: 118
diff changeset
5 $('#markdown div').html(marked(raw));
309238f5b7b1 Prettyprint in markdown.
Edho Arief <edho@myconan.net>
parents: 118
diff changeset
6 $('#markdown div pre').addClass('prettyprint');
121
dd7181c021de Add rel=nofollow to links in markdown.
Edho Arief <edho@myconan.net>
parents: 120
diff changeset
7 $('#markdown div a').prop('rel', 'nofollow');
120
309238f5b7b1 Prettyprint in markdown.
Edho Arief <edho@myconan.net>
parents: 118
diff changeset
8
110
e8c632b0eb80 Check if current location is a show paste before triggering tabs js.
Edho Arief <edho@myconan.net>
parents: 109
diff changeset
9 $('#highlight pre').text(raw);
120
309238f5b7b1 Prettyprint in markdown.
Edho Arief <edho@myconan.net>
parents: 118
diff changeset
10
110
e8c632b0eb80 Check if current location is a show paste before triggering tabs js.
Edho Arief <edho@myconan.net>
parents: 109
diff changeset
11 window.prettyPrint && prettyPrint();
104
9825e51ba30f Minor reorganization.
Edho Arief <edho@myconan.net>
parents: 103
diff changeset
12
114
b72f99d7b8cf Dynamic url based on options selected.
Edho Arief <edho@myconan.net>
parents: 112
diff changeset
13 update_state = function() {
b72f99d7b8cf Dynamic url based on options selected.
Edho Arief <edho@myconan.net>
parents: 112
diff changeset
14 var paste = $('#paste'),
b72f99d7b8cf Dynamic url based on options selected.
Edho Arief <edho@myconan.net>
parents: 112
diff changeset
15 mode = paste.data('mode'),
b72f99d7b8cf Dynamic url based on options selected.
Edho Arief <edho@myconan.net>
parents: 112
diff changeset
16 width = paste.data('width'),
122
a836cfe4092f Use hash instead of search because IE can't into replaceState.
Edho Arief <edho@myconan.net>
parents: 121
diff changeset
17 qstring = '#' + mode + '.' + width;
116
9ac24e112ea7 A more compact query string.
Edho Arief <edho@myconan.net>
parents: 115
diff changeset
18 if (width == 'auto') {
122
a836cfe4092f Use hash instead of search because IE can't into replaceState.
Edho Arief <edho@myconan.net>
parents: 121
diff changeset
19 qstring = '#';
116
9ac24e112ea7 A more compact query string.
Edho Arief <edho@myconan.net>
parents: 115
diff changeset
20 if (mode != 'plain') {
9ac24e112ea7 A more compact query string.
Edho Arief <edho@myconan.net>
parents: 115
diff changeset
21 qstring += mode;
9ac24e112ea7 A more compact query string.
Edho Arief <edho@myconan.net>
parents: 115
diff changeset
22 }
114
b72f99d7b8cf Dynamic url based on options selected.
Edho Arief <edho@myconan.net>
parents: 112
diff changeset
23 }
122
a836cfe4092f Use hash instead of search because IE can't into replaceState.
Edho Arief <edho@myconan.net>
parents: 121
diff changeset
24 window.location = qstring;
114
b72f99d7b8cf Dynamic url based on options selected.
Edho Arief <edho@myconan.net>
parents: 112
diff changeset
25 };
b72f99d7b8cf Dynamic url based on options selected.
Edho Arief <edho@myconan.net>
parents: 112
diff changeset
26
112
2b1041e8c35e Allows parameter-based width passing. Requires switching to .search.
Edho Arief <edho@myconan.net>
parents: 111
diff changeset
27 paste_resize = function(size) {
2b1041e8c35e Allows parameter-based width passing. Requires switching to .search.
Edho Arief <edho@myconan.net>
parents: 111
diff changeset
28 var paste = $('#paste'),
2b1041e8c35e Allows parameter-based width passing. Requires switching to .search.
Edho Arief <edho@myconan.net>
parents: 111
diff changeset
29 title = $('#tab-resize a.btn');
115
546381cf83c2 auto sounds better than full.
Edho Arief <edho@myconan.net>
parents: 114
diff changeset
30 title.html(title.html().replace(/(auto|\d+px)/, size));
546381cf83c2 auto sounds better than full.
Edho Arief <edho@myconan.net>
parents: 114
diff changeset
31 if (size == 'auto') {
112
2b1041e8c35e Allows parameter-based width passing. Requires switching to .search.
Edho Arief <edho@myconan.net>
parents: 111
diff changeset
32 paste.css('width', '');
114
b72f99d7b8cf Dynamic url based on options selected.
Edho Arief <edho@myconan.net>
parents: 112
diff changeset
33 paste.data('width', size);
112
2b1041e8c35e Allows parameter-based width passing. Requires switching to .search.
Edho Arief <edho@myconan.net>
parents: 111
diff changeset
34 } else {
2b1041e8c35e Allows parameter-based width passing. Requires switching to .search.
Edho Arief <edho@myconan.net>
parents: 111
diff changeset
35 paste.css('width', size);
2b1041e8c35e Allows parameter-based width passing. Requires switching to .search.
Edho Arief <edho@myconan.net>
parents: 111
diff changeset
36 paste.data('width', size);
2b1041e8c35e Allows parameter-based width passing. Requires switching to .search.
Edho Arief <edho@myconan.net>
parents: 111
diff changeset
37 }
114
b72f99d7b8cf Dynamic url based on options selected.
Edho Arief <edho@myconan.net>
parents: 112
diff changeset
38 update_state();
112
2b1041e8c35e Allows parameter-based width passing. Requires switching to .search.
Edho Arief <edho@myconan.net>
parents: 111
diff changeset
39 }
108
a949b71c9afb Allows paste content width resize.
Edho Arief <edho@myconan.net>
parents: 104
diff changeset
40
114
b72f99d7b8cf Dynamic url based on options selected.
Edho Arief <edho@myconan.net>
parents: 112
diff changeset
41 $('#paste-tabs > li > a').click(function() {
b72f99d7b8cf Dynamic url based on options selected.
Edho Arief <edho@myconan.net>
parents: 112
diff changeset
42 $('#paste').data('mode', $(this).prop('href').split('#')[1]);
b72f99d7b8cf Dynamic url based on options selected.
Edho Arief <edho@myconan.net>
parents: 112
diff changeset
43 update_state();
b72f99d7b8cf Dynamic url based on options selected.
Edho Arief <edho@myconan.net>
parents: 112
diff changeset
44 });
110
e8c632b0eb80 Check if current location is a show paste before triggering tabs js.
Edho Arief <edho@myconan.net>
parents: 109
diff changeset
45 $('#tab-resize ul a').click(function() {
112
2b1041e8c35e Allows parameter-based width passing. Requires switching to .search.
Edho Arief <edho@myconan.net>
parents: 111
diff changeset
46 paste_resize($(this).data('size'));
118
e3f3402da5a1 Takeover handling link clicking on dropdown menu.
Edho Arief <edho@myconan.net>
parents: 116
diff changeset
47 $('.open').removeClass('open');
e3f3402da5a1 Takeover handling link clicking on dropdown menu.
Edho Arief <edho@myconan.net>
parents: 116
diff changeset
48 return false;
110
e8c632b0eb80 Check if current location is a show paste before triggering tabs js.
Edho Arief <edho@myconan.net>
parents: 109
diff changeset
49 });
112
2b1041e8c35e Allows parameter-based width passing. Requires switching to .search.
Edho Arief <edho@myconan.net>
parents: 111
diff changeset
50
122
a836cfe4092f Use hash instead of search because IE can't into replaceState.
Edho Arief <edho@myconan.net>
parents: 121
diff changeset
51 mode = window.location.hash.substr(1).split('.');
114
b72f99d7b8cf Dynamic url based on options selected.
Edho Arief <edho@myconan.net>
parents: 112
diff changeset
52 if (mode[0] == 'highlight') { $('#paste-tabs li:eq(1) a').click(); }
b72f99d7b8cf Dynamic url based on options selected.
Edho Arief <edho@myconan.net>
parents: 112
diff changeset
53 else if (mode[0] == 'markdown') { $('#paste-tabs li:eq(2) a').click(); }
112
2b1041e8c35e Allows parameter-based width passing. Requires switching to .search.
Edho Arief <edho@myconan.net>
parents: 111
diff changeset
54 if (mode[1] && mode[1].match(/^\d+px$/)) { paste_resize(mode[1]); }
114
b72f99d7b8cf Dynamic url based on options selected.
Edho Arief <edho@myconan.net>
parents: 112
diff changeset
55
110
e8c632b0eb80 Check if current location is a show paste before triggering tabs js.
Edho Arief <edho@myconan.net>
parents: 109
diff changeset
56 }
59
1833de28583a Turns out the init file is required.
Edho Arief <edho@myconan.net>
parents:
diff changeset
57 });