isEAN.js 2.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172
  1. /**
  2. * The most commonly used EAN standard is
  3. * the thirteen-digit EAN-13, while the
  4. * less commonly used 8-digit EAN-8 barcode was
  5. * introduced for use on small packages.
  6. * Also EAN/UCC-14 is used for Grouping of individual
  7. * trade items above unit level(Intermediate, Carton or Pallet).
  8. * For more info about EAN-14 checkout: https://www.gtin.info/itf-14-barcodes/
  9. * EAN consists of:
  10. * GS1 prefix, manufacturer code, product code and check digit
  11. * Reference: https://en.wikipedia.org/wiki/International_Article_Number
  12. * Reference: https://www.gtin.info/
  13. */
  14. import assertString from './util/assertString';
  15. /**
  16. * Define EAN Lenghts; 8 for EAN-8; 13 for EAN-13; 14 for EAN-14
  17. * and Regular Expression for valid EANs (EAN-8, EAN-13, EAN-14),
  18. * with exact numberic matching of 8 or 13 or 14 digits [0-9]
  19. */
  20. var LENGTH_EAN_8 = 8;
  21. var LENGTH_EAN_14 = 14;
  22. var validEanRegex = /^(\d{8}|\d{13}|\d{14})$/;
  23. /**
  24. * Get position weight given:
  25. * EAN length and digit index/position
  26. *
  27. * @param {number} length
  28. * @param {number} index
  29. * @return {number}
  30. */
  31. function getPositionWeightThroughLengthAndIndex(length, index) {
  32. if (length === LENGTH_EAN_8 || length === LENGTH_EAN_14) {
  33. return index % 2 === 0 ? 3 : 1;
  34. }
  35. return index % 2 === 0 ? 1 : 3;
  36. }
  37. /**
  38. * Calculate EAN Check Digit
  39. * Reference: https://en.wikipedia.org/wiki/International_Article_Number#Calculation_of_checksum_digit
  40. *
  41. * @param {string} ean
  42. * @return {number}
  43. */
  44. function calculateCheckDigit(ean) {
  45. var checksum = ean.slice(0, -1).split('').map(function (_char, index) {
  46. return Number(_char) * getPositionWeightThroughLengthAndIndex(ean.length, index);
  47. }).reduce(function (acc, partialSum) {
  48. return acc + partialSum;
  49. }, 0);
  50. var remainder = 10 - checksum % 10;
  51. return remainder < 10 ? remainder : 0;
  52. }
  53. /**
  54. * Check if string is valid EAN:
  55. * Matches EAN-8/EAN-13/EAN-14 regex
  56. * Has valid check digit.
  57. *
  58. * @param {string} str
  59. * @return {boolean}
  60. */
  61. export default function isEAN(str) {
  62. assertString(str);
  63. var actualCheckDigit = Number(str.slice(-1));
  64. return validEanRegex.test(str) && actualCheckDigit === calculateCheckDigit(str);
  65. }