Mercurial > zeropaste
annotate app/assets/javascripts/init.tabs.js @ 123:5b58b0d6841c
Use hashbang instead of plain hash.
| author | Edho Arief <edho@myconan.net> |
|---|---|
| date | Mon, 12 Nov 2012 15:27:10 +0700 |
| parents | a836cfe4092f |
| children | 4a8cefa814f1 |
| 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 | 4 |
| 120 | 5 $('#markdown div').html(marked(raw)); |
| 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 | 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 | 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 | 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'), |
|
123
5b58b0d6841c
Use hashbang instead of plain hash.
Edho Arief <edho@myconan.net>
parents:
122
diff
changeset
|
17 qstring = '#!' + mode + '.' + width; |
| 116 | 18 if (width == 'auto') { |
|
123
5b58b0d6841c
Use hashbang instead of plain hash.
Edho Arief <edho@myconan.net>
parents:
122
diff
changeset
|
19 qstring = '#!'; |
| 116 | 20 if (mode != 'plain') { |
| 21 qstring += mode; | |
| 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 |
|
123
5b58b0d6841c
Use hashbang instead of plain hash.
Edho Arief <edho@myconan.net>
parents:
122
diff
changeset
|
51 mode = window.location.hash.substr(2).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 }); |
