[Koha] some jQuery advice please?
Eric Phetteplace
ephetteplace at cca.edu
Wed Sep 2 16:15:38 NZST 2020
Hi Carlos,
You actually need an attribute selector.
.isbn works for class=isbn
#isbn works for I'd=isbn
But the ISBN spans don't have either of those, they have property=isbn. The
way you select that, in both CSS and jQuery, is
[property="isbn"]
Or span[property="isbn"] if you want to add the HTML tag (should work
either way). So try a selector like
$('[property="isbn"]')
(note the mixed single versus double quotes to prevent an error)
Best,
Eric Phetteplace
Systems Librarian
California College of the Arts
On Tue, Sep 1, 2020, 9:02 PM Carlos Lopez <clopez at dml.vic.edu.au> wrote:
> Hi folks
>
> My Javascript/jQuery skills are rudimentary at best and I hope someone
> might be able to help me out.
>
> I'm trying to collapse large blocks of ISBNs on OPAC records (where for
> example we have someone's works catalogued as a set and every volume has a
> different ISBN).
>
> We have a similar bit of jQuery that collapses large contents notes:
>
> ----
> // Collapse contents on OPAC
> if(window.location.href.indexOf("cgi-bin/koha/opac-detail.pl?biblionumber")
> > -1) {
> $(document).ready(function(){
> var countclass = $(".contentblock").length; //counts number of
> contentblocks
> if(countclass > 0){ //if more than one contentblock
> var expander = "<div id='expander' style='font-size:14px;
> color:green;'>Click to Expand +</div>"; //create expansion button
> function tog(){$(document).find('.contentblock').slideToggle("slow")};
> //create slide toggle function
> function typ(){ //change expansion button based on display of
> contentblocks
> if($(".contentblock").css('display') == 'block'){
> $("#expander").text("Click to Expand +");
> }else if($(".contentblock").css('display') == 'none'){
> $("#expander").text("Click to Collapse -");
> };
> };
> $("span:contains('Contents:')").append(expander); //add expansion
> button to page
> $(".contentblock").hide(); //hide contentblocks initially
> $("#expander").click(function(){ //execute the two functions when the
> expansion button is clicked
> typ();
> tog();
> });
> };
> });
> }
> ----
> (from
> https://wiki.koha-community.org/wiki/JQuery_Library#Collapsible_contents_in_bib_record
> )
>
> I thought if I replaced instances of ".contentblock" with ".isbn" this
> might do what I want:
> ----
> // Collapse ISBNs on OPAC
> if(window.location.href.indexOf("cgi-bin/koha/opac-detail.pl?biblionumber")
> > -1) {
> $(document).ready(function(){
> var countisbns = $(".isbn").length; //counts number of isbns
> if(countisbns > 2){ //if more than 3 isbns
> var expander = "<div id='expander' style='font-size:14px;
> color:green;'>Click to Expand +</div>"; //create expansion button
> function tog(){$(document).find('.isbn').slideToggle("slow")};
> //create slide toggle function
> function typ(){ //change expansion button based on display of isbns
> if($(".isbn").css('display') == 'block'){
> $("#expander").text("Click to Expand +");
> }else if($(".isbn").css('display') == 'none'){
> $("#expander").text("Click to Collapse -");
> };
> };
> $("span:contains('ISBN:')").append(expander); //add expansion button
> to page
> $(".isbn").hide(); //hide isbns initially
> $("#expander").click(function(){ //execute the two functions when the
> expansion button is clicked
> typ();
> tog();
> });
> };
> });
> }
> ----
>
> Unfortunately that doesn't work.
>
> I can see that the contents blocks look like <div class="contentblock"
> property="description" style="display: block;"> while ISBNs look like <span
> property="isbn"> (so really I should have used "#isbn" rather than ".isbn"
> but that didn't work either).
>
> How do I select these ISBNs so that I can hide them? Should I be using
> XPath or CSS Selectors instead?
>
>
>
> With kind regards from the Dalton McCaughey Library Team
>
>
>
> Carlos Lopez
>
>
>
> Dalton McCaughey Library | 29 College Crescent, Parkville, VICTORIA 3052
>
> Ph: 03 9340 8888 ext.1 | library at dml.vic.edu.au<mailto:
> library at dml.vic.edu.au> | library.dmlibrary.org.au
>
> _______________________________________________
>
> Koha mailing list http://koha-community.org
> Koha at lists.katipo.co.nz
> Unsubscribe: https://lists.katipo.co.nz/mailman/listinfo/koha
>
More information about the Koha
mailing list