forked from mirrors/gecko-dev
		
	Bug 1554399 - sort media files by size in page info by comparing the raw sizes rather than the localized strings, r=cmkm.
Differential Revision: https://phabricator.services.mozilla.com/D210637
This commit is contained in:
		
							parent
							
								
									72a21fd33f
								
							
						
					
					
						commit
						cf730e7457
					
				
					 1 changed files with 18 additions and 3 deletions
				
			
		|  | @ -174,6 +174,7 @@ const COL_IMAGE_ALT = 3; | |||
| const COL_IMAGE_COUNT = 4; | ||||
| const COL_IMAGE_NODE = 5; | ||||
| const COL_IMAGE_BG = 6; | ||||
| const COL_IMAGE_RAWSIZE = 7; | ||||
| 
 | ||||
| // column number to copy from, second argument to pageInfoTreeView's constructor
 | ||||
| const COPYCOL_NONE = -1; | ||||
|  | @ -213,6 +214,11 @@ gImageView.onPageMediaSort = function (columnname) { | |||
|     comparator = function numComparator(a, b) { | ||||
|       return a - b; | ||||
|     }; | ||||
| 
 | ||||
|     // COL_IMAGE_SIZE contains the localized string, compare raw numbers.
 | ||||
|     if (index == COL_IMAGE_SIZE) { | ||||
|       index = COL_IMAGE_RAWSIZE; | ||||
|     } | ||||
|   } else { | ||||
|     comparator = function textComparator(a, b) { | ||||
|       return (a || "").toLowerCase().localeCompare((b || "").toLowerCase()); | ||||
|  | @ -580,21 +586,30 @@ async function addImage({ url, type, alt, altNotProvided, element, isBg }) { | |||
|   } | ||||
|   if (!gImageHash[url][type].hasOwnProperty(alt)) { | ||||
|     gImageHash[url][type][alt] = gImageView.data.length; | ||||
|     var row = [url, MEDIA_STRINGS[type], SIZE_UNKNOWN, alt, 1, element, isBg]; | ||||
|     var row = [ | ||||
|       url, | ||||
|       MEDIA_STRINGS[type], | ||||
|       SIZE_UNKNOWN, | ||||
|       alt, | ||||
|       1, | ||||
|       element, | ||||
|       isBg, | ||||
|       -1, | ||||
|     ]; | ||||
|     gImageView.addRow(row); | ||||
| 
 | ||||
|     // Fill in cache data asynchronously
 | ||||
|     openCacheEntry(url, function (cacheEntry) { | ||||
|       // The data at row[2] corresponds to the data size.
 | ||||
|       if (cacheEntry) { | ||||
|         let value = cacheEntry.dataSize; | ||||
|         // If value is not -1 then replace with actual value, else keep as "unknown"
 | ||||
|         if (value != -1) { | ||||
|           row[COL_IMAGE_RAWSIZE] = value; | ||||
|           let kbSize = Number(Math.round((value / 1024) * 100) / 100); | ||||
|           document.l10n | ||||
|             .formatValue("media-file-size", { size: kbSize }) | ||||
|             .then(function (response) { | ||||
|               row[2] = response; | ||||
|               row[COL_IMAGE_SIZE] = response; | ||||
|               // Invalidate the row to trigger a repaint.
 | ||||
|               gImageView.tree.invalidateRow(gImageView.data.indexOf(row)); | ||||
|             }); | ||||
|  |  | |||
		Loading…
	
		Reference in a new issue
	
	 Florian Quèze
						Florian Quèze