Class: BibSonomy::CSL
- Inherits:
-
Object
- Object
- BibSonomy::CSL
- Defined in:
- lib/bibsonomy/csl.rb
Instance Attribute Summary collapse
-
#bibsonomy_link ⇒ Boolean
Whether links to BibSonomy shall be rendered.
-
#bibtex_link ⇒ Boolean
Whether links to the BibTeX data of a post (in BibSonomy) shall be rendered.
-
#css_class ⇒ String
The CSS class used to render the surrounding ‘<ul>` list (default: ’publications’).
-
#doi_link ⇒ Boolean
Whether links for DOIs shall be rendered.
-
#group ⇒ String
Which posts shall be included, based on the groups they are viewable for.
-
#opt_sep ⇒ String
The separator between options.
-
#pdf_dir ⇒ String
The output directory for downloaded PDF files.
-
#public_doc_postfix ⇒ String
When a post has several documents and the filename of one of them ends with ‘public_doc_postfix`, only this document is downloaded and linked, all other are ignored.
-
#style ⇒ String
The / CSL style used for rendering.
-
#url_link ⇒ Boolean
Whether URLs of posts shall be rendered.
-
#year_headings ⇒ Boolean
Whether year headings shall be rendered.
Instance Method Summary collapse
-
#initialize(user_name, api_key) ⇒ CSL
constructor
Create a new BibSonomy instance.
-
#render(user, tags, count) ⇒ String
Download ‘count` posts for the given `user` and `tag(s)` and render them with / CSL.
Constructor Details
#initialize(user_name, api_key) ⇒ CSL
Create a new BibSonomy instance.
84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 |
# File 'lib/bibsonomy/csl.rb', line 84 def initialize(user_name, api_key) super() @bibsonomy = BibSonomy::API.new(user_name, api_key, 'csl') # setting some defaults @style = 'apa.csl' @pdf_dir = nil @css_class = 'publications' @year_headings = true @public_doc_postfix = '_oa.pdf' @group = 'public' # optional parts to be rendered (or not) @doi_link = true @url_link = true @bibtex_link = true @bibsonomy_link = true @opt_sep = ' | ' end |
Instance Attribute Details
#bibsonomy_link ⇒ Boolean
Returns whether links to BibSonomy shall be rendered. (default: ‘true`).
65 66 67 |
# File 'lib/bibsonomy/csl.rb', line 65 def bibsonomy_link @bibsonomy_link end |
#bibtex_link ⇒ Boolean
Returns whether links to the BibTeX data of a post (in BibSonomy) shall be rendered. (default: ‘true`).
62 63 64 |
# File 'lib/bibsonomy/csl.rb', line 62 def bibtex_link @bibtex_link end |
#css_class ⇒ String
Returns the CSS class used to render the surrounding ‘<ul>` list (default: ’publications’).
53 54 55 |
# File 'lib/bibsonomy/csl.rb', line 53 def css_class @css_class end |
#doi_link ⇒ Boolean
Returns whether links for DOIs shall be rendered. (default: ‘true`).
56 57 58 |
# File 'lib/bibsonomy/csl.rb', line 56 def doi_link @doi_link end |
#group ⇒ String
Returns which posts shall be included, based on the groups they are viewable for.
77 78 79 |
# File 'lib/bibsonomy/csl.rb', line 77 def group @group end |
#opt_sep ⇒ String
Returns the separator between options. (default: ‘ | ’).
68 69 70 |
# File 'lib/bibsonomy/csl.rb', line 68 def opt_sep @opt_sep end |
#pdf_dir ⇒ String
Returns the output directory for downloaded PDF files. If set to ‘nil`, no documents are downloaded. (default: `nil`).
44 45 46 |
# File 'lib/bibsonomy/csl.rb', line 44 def pdf_dir @pdf_dir end |
#public_doc_postfix ⇒ String
Returns When a post has several documents and the filename of one of them ends with ‘public_doc_postfix`, only this document is downloaded and linked, all other are ignored. (default: ’_oa.pdf’).
74 75 76 |
# File 'lib/bibsonomy/csl.rb', line 74 def public_doc_postfix @public_doc_postfix end |
#style ⇒ String
Returns the / CSL style used for rendering. (default: ‘apa.csl`).
47 48 49 |
# File 'lib/bibsonomy/csl.rb', line 47 def style @style end |
#url_link ⇒ Boolean
Returns whether URLs of posts shall be rendered. (default: ‘true`).
59 60 61 |
# File 'lib/bibsonomy/csl.rb', line 59 def url_link @url_link end |
#year_headings ⇒ Boolean
Returns whether year headings shall be rendered. (default: ‘true`).
50 51 52 |
# File 'lib/bibsonomy/csl.rb', line 50 def year_headings @year_headings end |
Instance Method Details
#render(user, tags, count) ⇒ String
Download ‘count` posts for the given `user` and `tag(s)` and render them with / CSL.
110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 |
# File 'lib/bibsonomy/csl.rb', line 110 def render(user, , count) # get posts from BibSonomy posts = JSON.parse(@bibsonomy.get_posts_for_user(user, 'publication', , 0, count)) # render them with citeproc cp = CiteProc::Processor.new style: @style, format: 'html' cp.import posts # to check for duplicate file names file_names = [] # filter posts by group # 2017-05-30, rja, disabled until group information is returned by the API # posts.delete_if do |v| # if v["group"] == @group # true # else # print("WARN: " + v["group"]) # false # end # end # sort posts by year sorted_keys = posts.keys.sort { |a,b| get_sort_posts(posts[b], posts[a]) } result = "" # print first heading last_year = 0 if @year_headings and sorted_keys.length > 0 last_year = get_year(posts[sorted_keys[0]]) result += "<h3>" + last_year + "</h3>" end result += "<ul class='#{@css_class}'>\n" for post_id in sorted_keys post = posts[post_id] # print heading if @year_headings year = get_year(post) if year != last_year last_year = year result += "</ul>\n<h3>" + last_year + "</h3>\n<ul class='#{@css_class}'>\n" end end # render metadata csl = cp.render(:bibliography, id: post_id) result += "<li class='" + post["type"] + "'>#{csl[0]}" # extract the post's id intra_hash, user_name = get_intra_hash(post_id) # optional parts = [] # attach documents if @pdf_dir for doc in get_public_docs(post["documents"]) # fileHash, fileName, md5hash, userName file_path = get_document(@bibsonomy, intra_hash, user_name, doc, @pdf_dir, file_names) << "<a href='#{file_path}'>PDF</a>" end end # attach DOI doi = post["DOI"] if @doi_link and doi != "" << "DOI:<a href='http://dx.doi.org/#{doi}'>#{doi}</a>" end # attach URL url = post["URL"] if @url_link and url != "" << "<a href='#{url}'>URL</a>" end # attach BibTeX if @bibtex_link << "<a href='http://www.bibsonomy.org/bib/publication/#{intra_hash}/#{user_name}'>BibTeX</a>" end # attach link to BibSonomy if @bibsonomy_link << "<a href='http://www.bibsonomy.org/publication/#{intra_hash}/#{user_name}'>BibSonomy</a>" end # attach options if .length > 0 result += " <span class='opt'>[" + .join(@opt_sep) + "]</span>" end result += "</li>\n" end result += "</ul>\n" return result end |