mirror of
https://github.com/mozilla/gecko-dev.git
synced 2025-01-15 14:30:47 +00:00
Bug 840097: Add clipboard copy for about:telemetry histograms. r=vladan
This commit is contained in:
parent
c94a0e8c44
commit
d5b3283196
@ -78,6 +78,7 @@ h2 {
|
||||
border: 1px solid gray;
|
||||
white-space: nowrap;
|
||||
padding: 10px;
|
||||
position: relative; /* required for position:absolute of the contained .copy-node */
|
||||
}
|
||||
|
||||
body[dir="rtl"] .histogram {
|
||||
@ -128,3 +129,18 @@ caption {
|
||||
body[dir="rtl"] caption {
|
||||
text-align: right;
|
||||
}
|
||||
|
||||
.copy-node {
|
||||
visibility: hidden;
|
||||
position: absolute;
|
||||
bottom: 1px;
|
||||
right: 1px;
|
||||
}
|
||||
|
||||
body[dir="rtl"] .copy-node {
|
||||
left: 1px;
|
||||
}
|
||||
|
||||
.histogram:hover .copy-node {
|
||||
visibility: visible;
|
||||
}
|
||||
|
@ -19,8 +19,9 @@ const brandBundle = Services.strings.createBundle(
|
||||
const TelemetryPing = Cc["@mozilla.org/base/telemetry-ping;1"].
|
||||
getService(Ci.nsITelemetryPing);
|
||||
|
||||
// Maximum height of a histogram bar (in em)
|
||||
// Maximum height of a histogram bar (in em for html, in chars for text)
|
||||
const MAX_BAR_HEIGHT = 18;
|
||||
const MAX_BAR_CHARS = 25;
|
||||
const PREF_TELEMETRY_SERVER_OWNER = "toolkit.telemetry.server_owner";
|
||||
#ifdef MOZ_TELEMETRY_ON_BY_DEFAULT
|
||||
const PREF_TELEMETRY_ENABLED = "toolkit.telemetry.enabledPreRelease";
|
||||
@ -31,6 +32,12 @@ const PREF_DEBUG_SLOW_SQL = "toolkit.telemetry.debugSlowSql";
|
||||
const PREF_SYMBOL_SERVER_URI = "profiler.symbolicationUrl";
|
||||
const DEFAULT_SYMBOL_SERVER_URI = "http://symbolapi.mozilla.org";
|
||||
|
||||
#ifdef XP_WIN
|
||||
const EOL = "\r\n";
|
||||
#else
|
||||
const EOL = "\n";
|
||||
#endif
|
||||
|
||||
// Cached value of document's RTL mode
|
||||
let documentRTLMode = "";
|
||||
|
||||
@ -407,6 +414,8 @@ let Histogram = {
|
||||
|
||||
hgramSumCaption: bundle.GetStringFromName("histogramSum"),
|
||||
|
||||
hgramCopyCaption: bundle.GetStringFromName("histogramCopy"),
|
||||
|
||||
/**
|
||||
* Renders a single Telemetry histogram
|
||||
*
|
||||
@ -437,7 +446,18 @@ let Histogram = {
|
||||
if (isRTL())
|
||||
hgram.values.reverse();
|
||||
|
||||
this.renderValues(outerDiv, hgram.values, hgram.max);
|
||||
let textData = this.renderValues(outerDiv, hgram.values, hgram.max, hgram.sample_count);
|
||||
|
||||
// The 'Copy' button contains the textual data, copied to clipboard on click
|
||||
let copyButton = document.createElement("button");
|
||||
copyButton.className = "copy-node";
|
||||
copyButton.appendChild(document.createTextNode(this.hgramCopyCaption));
|
||||
copyButton.histogramText = aName + EOL + stats + EOL + EOL + textData;
|
||||
copyButton.addEventListener("click", function(){
|
||||
Cc["@mozilla.org/widget/clipboardhelper;1"].getService(Ci.nsIClipboardHelper)
|
||||
.copyString(this.histogramText);
|
||||
});
|
||||
outerDiv.appendChild(copyButton);
|
||||
|
||||
aParent.appendChild(outerDiv);
|
||||
},
|
||||
@ -491,14 +511,28 @@ let Histogram = {
|
||||
},
|
||||
|
||||
/**
|
||||
* Create histogram bars
|
||||
* Create histogram HTML bars, also returns a textual representation
|
||||
* Both aMaxValue and aSumValues must be positive.
|
||||
* Values are assumed to use 0 as baseline.
|
||||
*
|
||||
* @param aDiv Outer parent div
|
||||
* @param aValues Histogram values
|
||||
* @param aMaxValue Largest histogram value in set
|
||||
* @param aMaxValue Value of the longest bar (length, not label)
|
||||
* @param aSumValues Sum of all bar values
|
||||
*/
|
||||
renderValues: function Histogram_renderValues(aDiv, aValues, aMaxValue) {
|
||||
renderValues: function Histogram_renderValues(aDiv, aValues, aMaxValue, aSumValues) {
|
||||
let text = "";
|
||||
// If the last label is not the longest string, alignment will break a little
|
||||
let labelPadTo = String(aValues[aValues.length -1][0]).length;
|
||||
|
||||
for (let [label, value] of aValues) {
|
||||
// Create a text representation: <right-aligned-label> |<bar-of-#><value> <percentage>
|
||||
text += EOL
|
||||
+ " ".repeat(Math.max(0, labelPadTo - String(label).length)) + label // Right-aligned label
|
||||
+ " |" + "#".repeat(Math.round(MAX_BAR_CHARS * value / aMaxValue)) + value // Bars and value
|
||||
+ " " + Math.round(100 * value / aSumValues) + "%"; // Percentage
|
||||
|
||||
// Construct the HTML labels + bars
|
||||
let belowEm = Math.round(MAX_BAR_HEIGHT * (value / aMaxValue) * 10) / 10;
|
||||
let aboveEm = MAX_BAR_HEIGHT - belowEm;
|
||||
|
||||
@ -520,6 +554,8 @@ let Histogram = {
|
||||
|
||||
aDiv.appendChild(barDiv);
|
||||
}
|
||||
|
||||
return text.substr(EOL.length); // Trim the EOL before the first line
|
||||
}
|
||||
};
|
||||
|
||||
|
@ -38,6 +38,8 @@ histogramAverage = average
|
||||
|
||||
histogramSum = sum
|
||||
|
||||
histogramCopy = Copy
|
||||
|
||||
disableTelemetry = Disable Telemetry
|
||||
|
||||
enableTelemetry = Enable Telemetry
|
||||
|
Loading…
x
Reference in New Issue
Block a user