Mercurial > agora-palash
diff templates/snippet/snippet_details.js @ 102:f872c643b056
Updates to snippet functionality (see details)
Sorry about the large commit, but it was difficult to break it up as a lot
of new functionality was introduced. Most of it is specific to the snippet
feature but there are some other changes as well.
Commit highlights:
* Added the ability to switch the syntax highlighting colour scheme when
viewing a snippet. This is currently done on a per-snippet basis only,
but eventually it will be possible to set a default in your profile to
have all the snippets you view use that colour scheme. There are currently
8 different colour schemes, all of which were taken from the default
pygments stylesheets (some were modified).
* Added a "num_views" field to the Snippet model, with the field being
incremented any time the snippet view is called (raw or regular view).
* Created a simple "explore" view that lists the recently-posted snippets.
Will implement pagination and sorting by other attributes ("popularity",
for example, based on number of views) as well.
* Added a post-save hook to the User model to ensure that a Profile is created
for every user as soon as the User itself is created. This alleviates the
need for a get_profile method that checks if the user has a profile or not
and creates one if necessary. (The code is currently still there, will be
cleaned up soon).
* Added back the wordwrap toggling feature. Currently, if you want to enable
word-wrapping, the line numbers have to be hidden in order to ensure that
the lines and their numbers don't go out of sync. This will be fixed soon.
* History/diff view is back
* And some other minor cosmetic changes.
Note: since some existing models have been changed, you'll likely need to
delete the existing sqlite database before running syncdb. The alternative
is to determine the necessary column changes/additions and run the SQL
query yourself.
author | dellsystem <ilostwaldo@gmail.com> |
---|---|
date | Fri, 31 Aug 2012 02:53:22 -0400 |
parents | 329a9d17be88 |
children | 7d753658dc0e |
line wrap: on
line diff
--- a/templates/snippet/snippet_details.js Fri Aug 31 02:32:30 2012 -0400 +++ b/templates/snippet/snippet_details.js Fri Aug 31 02:53:22 2012 -0400 @@ -1,18 +1,10 @@ - -jQuery(document).ready(function(){ +jQuery(document).ready(function () { curLine = document.location.hash; if(curLine.substring(0,2) == '#l'){ $('div.snippet div.line'+curLine).addClass('marked'); } - $("div.accordion").accordion({ - autoHeight: false, - header: 'h3', - animation: 'bounceslide', - duration: 2000 - }); - /** * Diff Ajax Call */ @@ -27,18 +19,28 @@ }); /** - * Wordwrap + * Word wrap */ - $('#toggleWordwrap').toggle( - function(){ - $('div.snippet pre.code').css('white-space', 'pre-wrap'); - return false; - }, - function(){ - $('div.snippet pre.code').css('white-space', 'pre'); - return false; - } - ); + $('#toggle-wordwrap').click(function () { + // Hide the line numbers (otherwise they could be wrong) + $('#line-numbers').toggle(); + + // Toggle the wrapping on the highlighted code + $('.highlight').toggleClass('wrap'); + + return false; + }); + + /** + * Changing syntax highlighting colours + */ + var currentStyle = $('#change-highlighting').attr('data-default'); + $('#change-highlighting').change(function () { + var newStyle = $(this).find(':selected').attr('name'); + + $('.highlight').removeClass(currentStyle).addClass(newStyle); + currentStyle = newStyle; + }); /** * Line Highlighting