Improve sorting of collection numbers to be more numeric like, as Human's would expect #2601
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
Problem
Collector numbers are not numbers but strings (an unexpectedly large set of non-numbers) and thus the current sort will sort something like "38" before "4"
Solution
Padding the collector numbers with 0 on the left to normalize them is the main improvement. Other tricks based on the sorts of collector number formats include:
I also tried using a natural sorting library like https://www.npmjs.com/package/natural-orderby but that resulted in some unexpected orders from what I'd expect such as:
In comparison the sort I implemented gives for those cases:
Also the library uses https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/String/localeCompare which has some mobile browser incompatibility with respect to locale which the library does use.
Testing
Tested the sorts with both "Group by Set then Collector number" and "Sort just by Collector number"
Before
Sorting of collector numbers within a set:
data:image/s3,"s3://crabby-images/da69d/da69d50c59e5f5f205967e4961751f952ae628f8" alt="old-sorting-within-set"
data:image/s3,"s3://crabby-images/e7013/e70135b8d98819b37ef5064b62da9ed0ad22c7ca" alt="old-sorting-across-all-sets"
data:image/s3,"s3://crabby-images/7dd6f/7dd6f198b09aa45e3aadb721c779e862a59cc306" alt="old-list-sorting"
Sorting of collector numbers without set grouping:
Sorting of collector numbers with The List cards:
After
Sorting of collector numbers within a set:
data:image/s3,"s3://crabby-images/993a8/993a8e72fe868e6b7d532593cd9b3631701f40de" alt="new-sorting-by-set-then-number"
Sorting of collector numbers without set grouping:
data:image/s3,"s3://crabby-images/45c54/45c54fbacc1efb040b9ecc45db86ffbb53b3c138" alt="new-sorting-numerically-across-all-sets"
Sorting of collector numbers with The List cards:
data:image/s3,"s3://crabby-images/9192d/9192d1b873f4d7d6f9231e9e74d077863f2cd970" alt="new-list-cards-sorting"
Cases this doesn't handle
World championship decks, since those are in format of
data:image/s3,"s3://crabby-images/b07c5/b07c51bce209a1eb0512ea60b9c963e9f13bbd6e" alt="new-sorting-world-champ-not-correct"
<competitor initials>-<number>[sb]
Unknown event cards, since those start with characters then numbers but have different total lengths
data:image/s3,"s3://crabby-images/f54b8/f54b86e4346bc9594e0bf9bab5104c7d9728f794" alt="image"