Output: allow empty string data-attributes. See #923

This commit is contained in:
Mottie 2015-06-01 16:29:59 -05:00
parent 18a97ed4d9
commit 7f9258f1e1
3 changed files with 10 additions and 7 deletions

File diff suppressed because one or more lines are too long

View File

@ -223,6 +223,7 @@
<h4>Changes</h4> <h4>Changes</h4>
<ul> <ul>
<li>In <span class="version">v2.22.2</span>, the data-attribute used by the <code>output_dataAttrib</code> can now be an empty string.</li>
<li>In <span class="version">v2.22.0</span>, <li>In <span class="version">v2.22.0</span>,
<ul> <ul>
<li>Added the BOM back to the UTF-8 csv downloadable file to support unicode characters in Excel.</li> <li>Added the BOM back to the UTF-8 csv downloadable file to support unicode characters in Excel.</li>
@ -478,10 +479,11 @@ line,value1,value2,value3
<td><a href="#" class="permalink">output_dataAttrib</a></td> <td><a href="#" class="permalink">output_dataAttrib</a></td>
<td><code>'data-name'</code></td> <td><code>'data-name'</code></td>
<td> <td>
This option allows you to override any table cell (<code>thead</code> or <code>tbody</code>) text with the contents of this data-attribute This option allows you to override any table cell (<code>thead</code> or <code>tbody</code>) text with the contents of this data-attribute (<span class="version updated">v2.22.2</span>)
<div class="collapsible"> <div class="collapsible">
<br> <br>
In the below example, the header text is obtained from this set data-attribute. If the data-attribute doesn't exist, then the header name is obtained from the actual header text.<br> <p>In the below example, the header text is obtained from this set data-attribute. If the data-attribute doesn't exist, then the header name is obtained from the actual header text.</p>
<p>The data-attribute can be an empty string (<span class="version updated">v2.22.2</span>).</p>
<pre class="prettyprint lang-html">&lt;thead&gt; <pre class="prettyprint lang-html">&lt;thead&gt;
&lt;tr&gt; &lt;tr&gt;
&lt;th&gt;Rank&lt;/th&gt; &lt;th&gt;Rank&lt;/th&gt;
@ -493,8 +495,7 @@ line,value1,value2,value3
&lt;th&gt;Date&lt;/th&gt; &lt;th&gt;Date&lt;/th&gt;
&lt;/tr&gt; &lt;/tr&gt;
&lt;/thead&gt;</pre> &lt;/thead&gt;</pre>
<br> <p>Notice in this output that the "First" and "Last" columns match the contents of the <code>data-name</code> attribute and not the header text:</p>
Notice in this output that the "First" and "Last" columns match the contents of the <code>data-name</code> attribute and not the header text:
<pre class="prettyprint lang-js">Rank,First,Last,Age,Total,Discount,Date</pre> <pre class="prettyprint lang-js">Rank,First,Last,Age,Total,Discount,Date</pre>
<span class="label warning">* NOTE *</span> The core plugin uses the <code>data-text</code> attribute for text extraction. If you want to use the same data for both, make the data-attributes match! <span class="label warning">* NOTE *</span> The core plugin uses the <code>data-text</code> attribute for text extraction. If you want to use the same data for both, make the data-attributes match!
</div> </div>

View File

@ -39,7 +39,7 @@ output = ts.output = {
}, },
processRow: function(c, $rows, isHeader, isJSON) { processRow: function(c, $rows, isHeader, isJSON) {
var $this, row, col, rowlen, collen, txt, var $this, row, col, rowlen, collen, txt, attr,
wo = c.widgetOptions, wo = c.widgetOptions,
tmpRow = [], tmpRow = [],
dupe = wo.output_duplicateSpans, dupe = wo.output_duplicateSpans,
@ -62,7 +62,9 @@ output = ts.output = {
// process colspans // process colspans
if ($this.filter('[colspan]').length) { if ($this.filter('[colspan]').length) {
collen = parseInt( $this.attr('colspan'), 10) - 1; collen = parseInt( $this.attr('colspan'), 10) - 1;
txt = output.formatData( wo, $this.attr(wo.output_dataAttrib) || $this.html(), isHeader ); attr = $this.attr(wo.output_dataAttrib);
// allow data-attribute to be an empty string
txt = output.formatData( wo, typeof attr !== 'undefined' ? attr : $this.html(), isHeader );
for (col = 1; col <= collen; col++) { for (col = 1; col <= collen; col++) {
// if we're processing the header & making JSON, the header names need to be unique // if we're processing the header & making JSON, the header names need to be unique
if ($this.filter('[rowspan]').length) { if ($this.filter('[rowspan]').length) {