@aidc-toolkit/gs1 1.0.25-beta → 1.0.27-beta

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (273) hide show
  1. package/dist/abstract-identifier-creator.d.ts +75 -0
  2. package/dist/abstract-identifier-creator.d.ts.map +1 -0
  3. package/dist/abstract-identifier-creator.js +79 -0
  4. package/dist/abstract-identifier-creator.js.map +1 -0
  5. package/dist/abstract-non-gtin-numeric-identifier-creator.d.ts +42 -0
  6. package/dist/abstract-non-gtin-numeric-identifier-creator.d.ts.map +1 -0
  7. package/dist/abstract-non-gtin-numeric-identifier-creator.js +40 -0
  8. package/dist/abstract-non-gtin-numeric-identifier-creator.js.map +1 -0
  9. package/dist/abstract-numeric-identifier-creator.d.ts +43 -0
  10. package/dist/abstract-numeric-identifier-creator.d.ts.map +1 -0
  11. package/dist/abstract-numeric-identifier-creator.js +160 -0
  12. package/dist/abstract-numeric-identifier-creator.js.map +1 -0
  13. package/dist/character-set.d.ts +27 -0
  14. package/dist/character-set.d.ts.map +1 -0
  15. package/dist/character-set.js +50 -0
  16. package/dist/character-set.js.map +1 -0
  17. package/dist/check.d.ts +81 -0
  18. package/dist/check.d.ts.map +1 -0
  19. package/dist/check.js +218 -0
  20. package/dist/check.js.map +1 -0
  21. package/dist/content-character-set-creators.d.ts +4 -0
  22. package/dist/content-character-set-creators.d.ts.map +1 -0
  23. package/dist/content-character-set-creators.js +9 -0
  24. package/dist/content-character-set-creators.js.map +1 -0
  25. package/dist/content-character-set.d.ts +26 -0
  26. package/dist/content-character-set.d.ts.map +1 -0
  27. package/dist/content-character-set.js +18 -0
  28. package/dist/content-character-set.js.map +1 -0
  29. package/dist/gtin-creator.d.ts +64 -0
  30. package/dist/gtin-creator.d.ts.map +1 -0
  31. package/dist/gtin-creator.js +156 -0
  32. package/dist/gtin-creator.js.map +1 -0
  33. package/dist/gtin-descriptor.d.ts +22 -0
  34. package/dist/gtin-descriptor.d.ts.map +1 -0
  35. package/dist/gtin-descriptor.js +2 -0
  36. package/dist/gtin-descriptor.js.map +1 -0
  37. package/dist/gtin-length.d.ts +64 -0
  38. package/dist/gtin-length.d.ts.map +1 -0
  39. package/dist/gtin-length.js +36 -0
  40. package/dist/gtin-length.js.map +1 -0
  41. package/dist/gtin-type.d.ts +26 -0
  42. package/dist/gtin-type.d.ts.map +1 -0
  43. package/dist/gtin-type.js +7 -0
  44. package/dist/gtin-type.js.map +1 -0
  45. package/dist/gtin-validator.d.ts +177 -0
  46. package/dist/gtin-validator.d.ts.map +1 -0
  47. package/dist/gtin-validator.js +443 -0
  48. package/dist/gtin-validator.js.map +1 -0
  49. package/dist/identifier-creator.d.ts +31 -0
  50. package/dist/identifier-creator.d.ts.map +1 -0
  51. package/dist/identifier-creator.js +2 -0
  52. package/dist/identifier-creator.js.map +1 -0
  53. package/dist/identifier-creators.d.ts +90 -0
  54. package/dist/identifier-creators.d.ts.map +1 -0
  55. package/dist/identifier-creators.js +74 -0
  56. package/dist/identifier-creators.js.map +1 -0
  57. package/dist/identifier-descriptor.d.ts +27 -0
  58. package/dist/identifier-descriptor.d.ts.map +1 -0
  59. package/dist/identifier-descriptor.js +2 -0
  60. package/dist/identifier-descriptor.js.map +1 -0
  61. package/dist/identifier-descriptors.d.ts +106 -0
  62. package/dist/identifier-descriptors.d.ts.map +1 -0
  63. package/dist/identifier-descriptors.js +262 -0
  64. package/dist/identifier-descriptors.js.map +1 -0
  65. package/dist/identifier-extension.d.ts +82 -0
  66. package/dist/identifier-extension.d.ts.map +1 -0
  67. package/dist/identifier-extension.js +79 -0
  68. package/dist/identifier-extension.js.map +1 -0
  69. package/dist/identifier-type.d.ts +62 -0
  70. package/dist/identifier-type.d.ts.map +1 -0
  71. package/dist/identifier-type.js +54 -0
  72. package/dist/identifier-type.js.map +1 -0
  73. package/dist/identifier-validator.d.ts +88 -0
  74. package/dist/identifier-validator.d.ts.map +1 -0
  75. package/dist/identifier-validator.js +110 -0
  76. package/dist/identifier-validator.js.map +1 -0
  77. package/dist/identifier-validators.d.ts +106 -0
  78. package/dist/identifier-validators.d.ts.map +1 -0
  79. package/dist/identifier-validators.js +153 -0
  80. package/dist/identifier-validators.js.map +1 -0
  81. package/dist/index.d.ts +58 -1949
  82. package/dist/index.d.ts.map +1 -0
  83. package/dist/index.js +30 -4727
  84. package/dist/index.js.map +1 -1
  85. package/dist/leader-type.d.ts +26 -0
  86. package/dist/leader-type.d.ts.map +1 -0
  87. package/dist/leader-type.js +18 -0
  88. package/dist/leader-type.js.map +1 -0
  89. package/dist/locale/en/locale-resources.d.ts +42 -0
  90. package/dist/locale/en/locale-resources.d.ts.map +1 -0
  91. package/dist/locale/en/locale-resources.js +41 -0
  92. package/dist/locale/en/locale-resources.js.map +1 -0
  93. package/dist/locale/fr/locale-resources.d.ts +42 -0
  94. package/dist/locale/fr/locale-resources.d.ts.map +1 -0
  95. package/dist/locale/fr/locale-resources.js +41 -0
  96. package/dist/locale/fr/locale-resources.js.map +1 -0
  97. package/dist/locale/i18n.d.ts +27 -0
  98. package/dist/locale/i18n.d.ts.map +1 -0
  99. package/dist/locale/i18n.js +36 -0
  100. package/dist/locale/i18n.js.map +1 -0
  101. package/dist/non-gtin-numeric-identifier-creator.d.ts +12 -0
  102. package/dist/non-gtin-numeric-identifier-creator.d.ts.map +1 -0
  103. package/dist/non-gtin-numeric-identifier-creator.js +2 -0
  104. package/dist/non-gtin-numeric-identifier-creator.js.map +1 -0
  105. package/dist/non-gtin-numeric-identifier-descriptor.d.ts +22 -0
  106. package/dist/non-gtin-numeric-identifier-descriptor.d.ts.map +1 -0
  107. package/dist/non-gtin-numeric-identifier-descriptor.js +2 -0
  108. package/dist/non-gtin-numeric-identifier-descriptor.js.map +1 -0
  109. package/dist/non-gtin-numeric-identifier-type.d.ts +26 -0
  110. package/dist/non-gtin-numeric-identifier-type.d.ts.map +1 -0
  111. package/dist/non-gtin-numeric-identifier-type.js +8 -0
  112. package/dist/non-gtin-numeric-identifier-type.js.map +1 -0
  113. package/dist/non-gtin-numeric-identifier-validator.d.ts +12 -0
  114. package/dist/non-gtin-numeric-identifier-validator.d.ts.map +1 -0
  115. package/dist/non-gtin-numeric-identifier-validator.js +10 -0
  116. package/dist/non-gtin-numeric-identifier-validator.js.map +1 -0
  117. package/dist/non-numeric-identifier-creator.d.ts +40 -0
  118. package/dist/non-numeric-identifier-creator.d.ts.map +1 -0
  119. package/dist/non-numeric-identifier-creator.js +82 -0
  120. package/dist/non-numeric-identifier-creator.js.map +1 -0
  121. package/dist/non-numeric-identifier-descriptor.d.ts +26 -0
  122. package/dist/non-numeric-identifier-descriptor.d.ts.map +1 -0
  123. package/dist/non-numeric-identifier-descriptor.js +2 -0
  124. package/dist/non-numeric-identifier-descriptor.js.map +1 -0
  125. package/dist/non-numeric-identifier-type.d.ts +26 -0
  126. package/dist/non-numeric-identifier-type.d.ts.map +1 -0
  127. package/dist/non-numeric-identifier-type.js +8 -0
  128. package/dist/non-numeric-identifier-type.js.map +1 -0
  129. package/dist/non-numeric-identifier-validator.d.ts +41 -0
  130. package/dist/non-numeric-identifier-validator.d.ts.map +1 -0
  131. package/dist/non-numeric-identifier-validator.js +69 -0
  132. package/dist/non-numeric-identifier-validator.js.map +1 -0
  133. package/dist/non-serializable-numeric-identifier-creator.d.ts +10 -0
  134. package/dist/non-serializable-numeric-identifier-creator.d.ts.map +1 -0
  135. package/dist/non-serializable-numeric-identifier-creator.js +8 -0
  136. package/dist/non-serializable-numeric-identifier-creator.js.map +1 -0
  137. package/dist/non-serializable-numeric-identifier-descriptor.d.ts +7 -0
  138. package/dist/non-serializable-numeric-identifier-descriptor.d.ts.map +1 -0
  139. package/dist/non-serializable-numeric-identifier-descriptor.js +2 -0
  140. package/dist/non-serializable-numeric-identifier-descriptor.js.map +1 -0
  141. package/dist/non-serializable-numeric-identifier-type.d.ts +26 -0
  142. package/dist/non-serializable-numeric-identifier-type.d.ts.map +1 -0
  143. package/dist/non-serializable-numeric-identifier-type.js +7 -0
  144. package/dist/non-serializable-numeric-identifier-type.js.map +1 -0
  145. package/dist/non-serializable-numeric-identifier-validator.d.ts +16 -0
  146. package/dist/non-serializable-numeric-identifier-validator.d.ts.map +1 -0
  147. package/dist/non-serializable-numeric-identifier-validator.js +17 -0
  148. package/dist/non-serializable-numeric-identifier-validator.js.map +1 -0
  149. package/dist/numeric-identifier-creator.d.ts +53 -0
  150. package/dist/numeric-identifier-creator.d.ts.map +1 -0
  151. package/dist/numeric-identifier-creator.js +2 -0
  152. package/dist/numeric-identifier-creator.js.map +1 -0
  153. package/dist/numeric-identifier-descriptor.d.ts +22 -0
  154. package/dist/numeric-identifier-descriptor.d.ts.map +1 -0
  155. package/dist/numeric-identifier-descriptor.js +2 -0
  156. package/dist/numeric-identifier-descriptor.js.map +1 -0
  157. package/dist/numeric-identifier-type.d.ts +26 -0
  158. package/dist/numeric-identifier-type.d.ts.map +1 -0
  159. package/dist/numeric-identifier-type.js +7 -0
  160. package/dist/numeric-identifier-type.js.map +1 -0
  161. package/dist/numeric-identifier-validator.d.ts +38 -0
  162. package/dist/numeric-identifier-validator.d.ts.map +1 -0
  163. package/dist/numeric-identifier-validator.js +61 -0
  164. package/dist/numeric-identifier-validator.js.map +1 -0
  165. package/dist/prefix-manager.d.ts +136 -0
  166. package/dist/prefix-manager.d.ts.map +1 -0
  167. package/dist/prefix-manager.js +339 -0
  168. package/dist/prefix-manager.js.map +1 -0
  169. package/dist/prefix-provider.d.ts +27 -0
  170. package/dist/prefix-provider.d.ts.map +1 -0
  171. package/dist/prefix-provider.js +2 -0
  172. package/dist/prefix-provider.js.map +1 -0
  173. package/dist/prefix-type.d.ts +26 -0
  174. package/dist/prefix-type.d.ts.map +1 -0
  175. package/dist/prefix-type.js +18 -0
  176. package/dist/prefix-type.js.map +1 -0
  177. package/dist/prefix-validator.d.ts +70 -0
  178. package/dist/prefix-validator.d.ts.map +1 -0
  179. package/dist/prefix-validator.js +208 -0
  180. package/dist/prefix-validator.js.map +1 -0
  181. package/dist/serializable-numeric-identifier-creator.d.ts +48 -0
  182. package/dist/serializable-numeric-identifier-creator.d.ts.map +1 -0
  183. package/dist/serializable-numeric-identifier-creator.js +93 -0
  184. package/dist/serializable-numeric-identifier-creator.js.map +1 -0
  185. package/dist/serializable-numeric-identifier-descriptor.d.ts +26 -0
  186. package/dist/serializable-numeric-identifier-descriptor.d.ts.map +1 -0
  187. package/dist/serializable-numeric-identifier-descriptor.js +2 -0
  188. package/dist/serializable-numeric-identifier-descriptor.js.map +1 -0
  189. package/dist/serializable-numeric-identifier-type.d.ts +26 -0
  190. package/dist/serializable-numeric-identifier-type.d.ts.map +1 -0
  191. package/dist/serializable-numeric-identifier-type.js +8 -0
  192. package/dist/serializable-numeric-identifier-type.js.map +1 -0
  193. package/dist/serializable-numeric-identifier-validator.d.ts +41 -0
  194. package/dist/serializable-numeric-identifier-validator.d.ts.map +1 -0
  195. package/dist/serializable-numeric-identifier-validator.js +78 -0
  196. package/dist/serializable-numeric-identifier-validator.js.map +1 -0
  197. package/package.json +11 -8
  198. package/src/abstract-identifier-creator.ts +157 -76
  199. package/src/abstract-non-gtin-numeric-identifier-creator.ts +86 -0
  200. package/src/abstract-numeric-identifier-creator.ts +205 -136
  201. package/src/check.ts +2 -2
  202. package/src/content-character-set-creators.ts +9 -0
  203. package/src/gtin-creator.ts +20 -19
  204. package/src/gtin-descriptor.ts +10 -4
  205. package/src/gtin-length.ts +61 -0
  206. package/src/gtin-type.ts +6 -37
  207. package/src/gtin-validator.ts +39 -46
  208. package/src/identifier-creator.ts +6 -6
  209. package/src/{creators.ts → identifier-creators.ts} +45 -31
  210. package/src/identifier-descriptor.ts +3 -3
  211. package/src/{descriptors.ts → identifier-descriptors.ts} +65 -63
  212. package/src/identifier-extension.ts +155 -0
  213. package/src/identifier-validator.ts +94 -11
  214. package/src/{validators.ts → identifier-validators.ts} +56 -41
  215. package/src/index.ts +50 -43
  216. package/src/leader-type.ts +29 -0
  217. package/src/locale/i18n.ts +3 -3
  218. package/src/locale/i18next.d.ts +1 -1
  219. package/src/non-gtin-numeric-identifier-creator.ts +8 -23
  220. package/src/non-gtin-numeric-identifier-descriptor.ts +4 -4
  221. package/src/non-gtin-numeric-identifier-type.ts +14 -3
  222. package/src/non-gtin-numeric-identifier-validator.ts +7 -15
  223. package/src/non-numeric-identifier-creator.ts +21 -16
  224. package/src/non-numeric-identifier-descriptor.ts +4 -4
  225. package/src/non-numeric-identifier-type.ts +14 -3
  226. package/src/non-numeric-identifier-validator.ts +12 -13
  227. package/src/non-serializable-numeric-identifier-creator.ts +12 -0
  228. package/src/non-serializable-numeric-identifier-descriptor.ts +7 -0
  229. package/src/non-serializable-numeric-identifier-type.ts +22 -0
  230. package/src/non-serializable-numeric-identifier-validator.ts +19 -0
  231. package/src/numeric-identifier-creator.ts +9 -8
  232. package/src/numeric-identifier-descriptor.ts +4 -3
  233. package/src/numeric-identifier-type.ts +17 -35
  234. package/src/numeric-identifier-validator.ts +62 -7
  235. package/src/prefix-manager.ts +79 -76
  236. package/src/prefix-provider.ts +1 -1
  237. package/src/prefix-validator.ts +3 -3
  238. package/src/serializable-numeric-identifier-creator.ts +13 -27
  239. package/src/serializable-numeric-identifier-descriptor.ts +4 -4
  240. package/src/serializable-numeric-identifier-type.ts +14 -5
  241. package/src/serializable-numeric-identifier-validator.ts +22 -21
  242. package/test/check.test.ts +1 -1
  243. package/test/creator.test.ts +5 -5
  244. package/test/gtin-creator.ts +10 -3
  245. package/test/gtin-validator.test.ts +10 -12
  246. package/test/identifier-creator.ts +12 -12
  247. package/test/identifier-validator.ts +1 -1
  248. package/test/non-gtin-numeric-identifier-creator.ts +3 -3
  249. package/test/non-gtin-numeric-identifier-validator.ts +8 -3
  250. package/test/non-numeric-identifier-creator.ts +1 -1
  251. package/test/non-numeric-identifier-validator.ts +3 -3
  252. package/test/non-serializable-numeric-identifier-creator.ts +64 -0
  253. package/test/non-serializable-numeric-identifier-validator.ts +6 -0
  254. package/test/numeric-identifier-creator.ts +9 -4
  255. package/test/numeric-identifier-validator.ts +2 -2
  256. package/test/prefix-manager.test.ts +2 -2
  257. package/test/serializable-numeric-identifier-creator.ts +2 -2
  258. package/test/serializable-numeric-identifier-validator.ts +3 -3
  259. package/test/setup.ts +1 -1
  260. package/test/sparse.test.ts +1 -1
  261. package/test/utility.ts +1 -1
  262. package/test/validator.test.ts +16 -15
  263. package/test/variable-measure-rcn.test.ts +24 -24
  264. package/tsconfig-config.json +4 -0
  265. package/tsconfig-src.json +8 -0
  266. package/tsconfig-test.json +9 -0
  267. package/tsconfig.json +12 -1
  268. package/tsup.config.ts +3 -2
  269. package/dist/index.cjs +0 -4813
  270. package/dist/index.cjs.map +0 -1
  271. package/dist/index.d.cts +0 -1949
  272. package/src/abstract-identifier-validator.ts +0 -140
  273. package/src/abstract-numeric-identifier-validator.ts +0 -69
@@ -0,0 +1,136 @@
1
+ import { GTINCreator } from "./gtin-creator.js";
2
+ import { NonNumericIdentifierCreator } from "./non-numeric-identifier-creator.js";
3
+ import { NonSerializableNumericIdentifierCreator } from "./non-serializable-numeric-identifier-creator.js";
4
+ import type { PrefixProvider } from "./prefix-provider.js";
5
+ import { type PrefixType } from "./prefix-type.js";
6
+ import { SerializableNumericIdentifierCreator } from "./serializable-numeric-identifier-creator.js";
7
+ /**
8
+ * Prefix manager. This is the core class for identifier creation.
9
+ *
10
+ * A prefix manager may be constructed for any {@link PrefixType | prefix type}. Construction may be done directly or
11
+ * via the static {@linkcode PrefixManager.get | get()} method, which allows for caching and reuse. As most applications
12
+ * work with a limited number of prefixes for creating identifiers, caching and reuse may be a more efficient option.
13
+ *
14
+ * The prefix type and prefix are normalized before the prefix manager is constructed, so they may not match the input
15
+ * values. For example, the GS1 Company Prefix 0614141 is equivalent to U.P.C. Company Prefix 614141; both result in a
16
+ * prefix manager with prefix type equal to {@linkcode PrefixTypes.UPCCompanyPrefix} and prefix equal to "614141".
17
+ *
18
+ * To support the creation of sparse identifiers, a prefix manager maintains a {@link tweakFactor | tweak factor} which
19
+ * is used, along with a type-specific multiplier, as the tweak when creating numeric identifiers. The default tweak
20
+ * factor is the numeric value of the GS1 Company Prefix representation of the prefix preceded by '1' to ensure
21
+ * uniqueness (i.e., so that prefixes 0 N1 N2 N3... and N1 N2 N3... produce different tweak factors). This is usually
22
+ * sufficient for obfuscation, but as the sparse creation algorithm is reversible and as the GS1 Company Prefix is
23
+ * discoverable via {@link https://www.gs1.org/services/verified-by-gs1 | Verified by GS1}, a user-defined tweak factor
24
+ * should be used if a higher degree of obfuscation is required. When using a tweak factor other than the default, care
25
+ * should be taken to restore it when resuming the application. A tweak factor of 0 creates a straight sequence.
26
+ */
27
+ export declare class PrefixManager implements PrefixProvider {
28
+ #private;
29
+ /**
30
+ * Constructor.
31
+ *
32
+ * @param prefixType
33
+ * Prefix type.
34
+ *
35
+ * @param prefix
36
+ * Prefix.
37
+ */
38
+ constructor(prefixType: PrefixType, prefix: string);
39
+ /**
40
+ * Get the prefix type.
41
+ */
42
+ get prefixType(): PrefixType;
43
+ /**
44
+ * Get the prefix.
45
+ */
46
+ get prefix(): string;
47
+ /**
48
+ * Get the GS1 Company Prefix.
49
+ */
50
+ get gs1CompanyPrefix(): string;
51
+ /**
52
+ * Get the U.P.C. Company Prefix if prefix type is {@linkcode PrefixTypes.UPCCompanyPrefix} or undefined if not.
53
+ */
54
+ get upcCompanyPrefix(): string | undefined;
55
+ /**
56
+ * Get the GS1-8 Prefix if prefix type is {@linkcode PrefixTypes.GS18Prefix} or undefined if not.
57
+ */
58
+ get gs18Prefix(): string | undefined;
59
+ /**
60
+ * Get the tweak factor.
61
+ */
62
+ get tweakFactor(): bigint;
63
+ /**
64
+ * Set the tweak factor.
65
+ *
66
+ * @param value
67
+ * Tweak factor.
68
+ */
69
+ set tweakFactor(value: number | bigint);
70
+ /**
71
+ * Reset the tweak factor to its default (numeric value of the GS1 Company Prefix preceded by '1').
72
+ */
73
+ resetTweakFactor(): void;
74
+ /**
75
+ * Get a prefix manager.
76
+ *
77
+ * @param prefixType
78
+ * Prefix type.
79
+ *
80
+ * @param prefix
81
+ * Prefix.
82
+ *
83
+ * @returns
84
+ * Prefix manager with normalized prefix type and prefix.
85
+ */
86
+ static get(prefixType: PrefixType, prefix: string): PrefixManager;
87
+ /**
88
+ * Get GTIN creator.
89
+ */
90
+ get gtinCreator(): GTINCreator;
91
+ /**
92
+ * Get GLN creator.
93
+ */
94
+ get glnCreator(): NonSerializableNumericIdentifierCreator;
95
+ /**
96
+ * Get SSCC creator.
97
+ */
98
+ get ssccCreator(): NonSerializableNumericIdentifierCreator;
99
+ /**
100
+ * Get GRAI creator.
101
+ */
102
+ get graiCreator(): SerializableNumericIdentifierCreator;
103
+ /**
104
+ * Get GIAI creator.
105
+ */
106
+ get giaiCreator(): NonNumericIdentifierCreator;
107
+ /**
108
+ * Get GSRN creator.
109
+ */
110
+ get gsrnCreator(): NonSerializableNumericIdentifierCreator;
111
+ /**
112
+ * Get GDTI creator.
113
+ */
114
+ get gdtiCreator(): SerializableNumericIdentifierCreator;
115
+ /**
116
+ * Get GINC creator.
117
+ */
118
+ get gincCreator(): NonNumericIdentifierCreator;
119
+ /**
120
+ * Get GSIN creator.
121
+ */
122
+ get gsinCreator(): NonSerializableNumericIdentifierCreator;
123
+ /**
124
+ * Get GCN creator.
125
+ */
126
+ get gcnCreator(): SerializableNumericIdentifierCreator;
127
+ /**
128
+ * Get CPID creator.
129
+ */
130
+ get cpidCreator(): NonNumericIdentifierCreator;
131
+ /**
132
+ * Get GMN creator.
133
+ */
134
+ get gmnCreator(): NonNumericIdentifierCreator;
135
+ }
136
+ //# sourceMappingURL=prefix-manager.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"prefix-manager.d.ts","sourceRoot":"","sources":["../src/prefix-manager.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,MAAM,mBAAmB,CAAC;AAMhD,OAAO,EAAE,2BAA2B,EAAE,MAAM,qCAAqC,CAAC;AAElF,OAAO,EAAE,uCAAuC,EAAE,MAAM,kDAAkD,CAAC;AAG3G,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,sBAAsB,CAAC;AAC3D,OAAO,EAAE,KAAK,UAAU,EAAe,MAAM,kBAAkB,CAAC;AAEhE,OAAO,EAAE,oCAAoC,EAAE,MAAM,8CAA8C,CAAC;AAGpG;;;;;;;;;;;;;;;;;;;GAmBG;AACH,qBAAa,aAAc,YAAW,cAAc;;IA6DhD;;;;;;;;OAQG;gBACS,UAAU,EAAE,UAAU,EAAE,MAAM,EAAE,MAAM;IAelD;;OAEG;IACH,IAAI,UAAU,IAAI,UAAU,CAE3B;IAED;;OAEG;IACH,IAAI,MAAM,IAAI,MAAM,CAEnB;IAED;;OAEG;IACH,IAAI,gBAAgB,IAAI,MAAM,CAE7B;IAED;;OAEG;IACH,IAAI,gBAAgB,IAAI,MAAM,GAAG,SAAS,CAEzC;IAED;;OAEG;IACH,IAAI,UAAU,IAAI,MAAM,GAAG,SAAS,CAEnC;IAeD;;OAEG;IACH,IAAI,WAAW,IAAI,MAAM,CAExB;IAED;;;;;OAKG;IACH,IAAI,WAAW,CAAC,KAAK,EAAE,MAAM,GAAG,MAAM,EAUrC;IAED;;OAEG;IACH,gBAAgB,IAAI,IAAI;IAIxB;;;;;;;;;;;OAWG;IACH,MAAM,CAAC,GAAG,CAAC,UAAU,EAAE,UAAU,EAAE,MAAM,EAAE,MAAM,GAAG,aAAa;IA8FjE;;OAEG;IACH,IAAI,WAAW,IAAI,WAAW,CAE7B;IAED;;OAEG;IACH,IAAI,UAAU,IAAI,uCAAuC,CAExD;IAED;;OAEG;IACH,IAAI,WAAW,IAAI,uCAAuC,CAEzD;IAED;;OAEG;IACH,IAAI,WAAW,IAAI,oCAAoC,CAEtD;IAED;;OAEG;IACH,IAAI,WAAW,IAAI,2BAA2B,CAE7C;IAED;;OAEG;IACH,IAAI,WAAW,IAAI,uCAAuC,CAEzD;IAED;;OAEG;IACH,IAAI,WAAW,IAAI,oCAAoC,CAEtD;IAED;;OAEG;IACH,IAAI,WAAW,IAAI,2BAA2B,CAE7C;IAED;;OAEG;IACH,IAAI,WAAW,IAAI,uCAAuC,CAEzD;IAED;;OAEG;IACH,IAAI,UAAU,IAAI,oCAAoC,CAErD;IAED;;OAEG;IACH,IAAI,WAAW,IAAI,2BAA2B,CAE7C;IAED;;OAEG;IACH,IAAI,UAAU,IAAI,2BAA2B,CAE5C;CACJ"}
@@ -0,0 +1,339 @@
1
+ var _a;
2
+ import { GTINCreator } from "./gtin-creator.js";
3
+ import { GTIN_BASE_TYPES } from "./gtin-length.js";
4
+ import { isNumericIdentifierCreator } from "./identifier-creators.js";
5
+ import { IdentifierTypes } from "./identifier-type.js";
6
+ import { i18nextGS1 } from "./locale/i18n.js";
7
+ import { NonNumericIdentifierCreator } from "./non-numeric-identifier-creator.js";
8
+ import { NonSerializableNumericIdentifierCreator } from "./non-serializable-numeric-identifier-creator.js";
9
+ import { PrefixTypes } from "./prefix-type.js";
10
+ import { PrefixValidator } from "./prefix-validator.js";
11
+ import { SerializableNumericIdentifierCreator } from "./serializable-numeric-identifier-creator.js";
12
+ /**
13
+ * Prefix manager. This is the core class for identifier creation.
14
+ *
15
+ * A prefix manager may be constructed for any {@link PrefixType | prefix type}. Construction may be done directly or
16
+ * via the static {@linkcode PrefixManager.get | get()} method, which allows for caching and reuse. As most applications
17
+ * work with a limited number of prefixes for creating identifiers, caching and reuse may be a more efficient option.
18
+ *
19
+ * The prefix type and prefix are normalized before the prefix manager is constructed, so they may not match the input
20
+ * values. For example, the GS1 Company Prefix 0614141 is equivalent to U.P.C. Company Prefix 614141; both result in a
21
+ * prefix manager with prefix type equal to {@linkcode PrefixTypes.UPCCompanyPrefix} and prefix equal to "614141".
22
+ *
23
+ * To support the creation of sparse identifiers, a prefix manager maintains a {@link tweakFactor | tweak factor} which
24
+ * is used, along with a type-specific multiplier, as the tweak when creating numeric identifiers. The default tweak
25
+ * factor is the numeric value of the GS1 Company Prefix representation of the prefix preceded by '1' to ensure
26
+ * uniqueness (i.e., so that prefixes 0 N1 N2 N3... and N1 N2 N3... produce different tweak factors). This is usually
27
+ * sufficient for obfuscation, but as the sparse creation algorithm is reversible and as the GS1 Company Prefix is
28
+ * discoverable via {@link https://www.gs1.org/services/verified-by-gs1 | Verified by GS1}, a user-defined tweak factor
29
+ * should be used if a higher degree of obfuscation is required. When using a tweak factor other than the default, care
30
+ * should be taken to restore it when resuming the application. A tweak factor of 0 creates a straight sequence.
31
+ */
32
+ export class PrefixManager {
33
+ /**
34
+ * Cached prefix managers, keyed by GS1 Company Prefix.
35
+ */
36
+ static #PREFIX_MANAGERS_MAP = new Map();
37
+ /**
38
+ * Creator tweak factors. Different numeric identifier types have different tweak factors so that sparse creation
39
+ * generates different sequences for each.
40
+ */
41
+ static #CREATOR_TWEAK_FACTORS = {
42
+ GTIN: 1987n,
43
+ GLN: 4241n,
44
+ SSCC: 8087n,
45
+ GRAI: 3221n,
46
+ GSRN: 2341n,
47
+ GDTI: 7333n,
48
+ GSIN: 5623n,
49
+ GCN: 6869n
50
+ };
51
+ /**
52
+ * Normalized prefix type.
53
+ */
54
+ #prefixType;
55
+ /**
56
+ * Normalized prefix.
57
+ */
58
+ #prefix;
59
+ /**
60
+ * Prefix as GS1 Company Prefix.
61
+ */
62
+ #gs1CompanyPrefix;
63
+ /**
64
+ * U.P.C. Company Prefix if prefix type is {@linkcode PrefixTypes.UPCCompanyPrefix}.
65
+ */
66
+ #upcCompanyPrefix;
67
+ /**
68
+ * GS1-8 Prefix if prefix type is {@linkcode PrefixTypes.GS18Prefix}.
69
+ */
70
+ #gs18Prefix;
71
+ /**
72
+ * Default tweak factor.
73
+ */
74
+ #defaultTweakFactor;
75
+ /**
76
+ * Tweak factor.
77
+ */
78
+ #tweakFactor = 0n;
79
+ /**
80
+ * Cached identifier creators.
81
+ */
82
+ #identifierCreators = {};
83
+ /**
84
+ * Constructor.
85
+ *
86
+ * @param prefixType
87
+ * Prefix type.
88
+ *
89
+ * @param prefix
90
+ * Prefix.
91
+ */
92
+ constructor(prefixType, prefix) {
93
+ const normalizedPrefixProvider = PrefixValidator.normalize(prefixType, prefix);
94
+ this.#prefixType = normalizedPrefixProvider.prefixType;
95
+ this.#prefix = normalizedPrefixProvider.prefix;
96
+ this.#gs1CompanyPrefix = normalizedPrefixProvider.gs1CompanyPrefix;
97
+ this.#upcCompanyPrefix = normalizedPrefixProvider.upcCompanyPrefix;
98
+ this.#gs18Prefix = normalizedPrefixProvider.gs18Prefix;
99
+ // Default tweak factor is the numeric value of the GS1 Company Prefix preceded by '1'.
100
+ this.#defaultTweakFactor = BigInt(`1${this.gs1CompanyPrefix}`);
101
+ this.resetTweakFactor();
102
+ }
103
+ /**
104
+ * Get the prefix type.
105
+ */
106
+ get prefixType() {
107
+ return this.#prefixType;
108
+ }
109
+ /**
110
+ * Get the prefix.
111
+ */
112
+ get prefix() {
113
+ return this.#prefix;
114
+ }
115
+ /**
116
+ * Get the GS1 Company Prefix.
117
+ */
118
+ get gs1CompanyPrefix() {
119
+ return this.#gs1CompanyPrefix;
120
+ }
121
+ /**
122
+ * Get the U.P.C. Company Prefix if prefix type is {@linkcode PrefixTypes.UPCCompanyPrefix} or undefined if not.
123
+ */
124
+ get upcCompanyPrefix() {
125
+ return this.#upcCompanyPrefix;
126
+ }
127
+ /**
128
+ * Get the GS1-8 Prefix if prefix type is {@linkcode PrefixTypes.GS18Prefix} or undefined if not.
129
+ */
130
+ get gs18Prefix() {
131
+ return this.#gs18Prefix;
132
+ }
133
+ /**
134
+ * Set the tweak for an identifier creator if it's a numeric identifier creator.
135
+ *
136
+ * @param identifierCreator
137
+ * Identifier creator.
138
+ */
139
+ #setCreatorTweak(identifierCreator) {
140
+ if (isNumericIdentifierCreator(identifierCreator)) {
141
+ // eslint-disable-next-line no-param-reassign -- Method purpose is to set the tweak.
142
+ identifierCreator.tweak = this.tweakFactor * _a.#CREATOR_TWEAK_FACTORS[identifierCreator.identifierType];
143
+ }
144
+ }
145
+ /**
146
+ * Get the tweak factor.
147
+ */
148
+ get tweakFactor() {
149
+ return this.#tweakFactor;
150
+ }
151
+ /**
152
+ * Set the tweak factor.
153
+ *
154
+ * @param value
155
+ * Tweak factor.
156
+ */
157
+ set tweakFactor(value) {
158
+ const tweakFactor = BigInt(value);
159
+ if (this.#tweakFactor !== tweakFactor) {
160
+ this.#tweakFactor = tweakFactor;
161
+ for (const creator of Object.values(this.#identifierCreators)) {
162
+ this.#setCreatorTweak(creator);
163
+ }
164
+ }
165
+ }
166
+ /**
167
+ * Reset the tweak factor to its default (numeric value of the GS1 Company Prefix preceded by '1').
168
+ */
169
+ resetTweakFactor() {
170
+ this.tweakFactor = this.#defaultTweakFactor;
171
+ }
172
+ /**
173
+ * Get a prefix manager.
174
+ *
175
+ * @param prefixType
176
+ * Prefix type.
177
+ *
178
+ * @param prefix
179
+ * Prefix.
180
+ *
181
+ * @returns
182
+ * Prefix manager with normalized prefix type and prefix.
183
+ */
184
+ static get(prefixType, prefix) {
185
+ // Normalization will occur in constructor as well, but it's necessary here for the map.
186
+ const normalizedPrefixProvider = PrefixValidator.normalize(prefixType, prefix);
187
+ let prefixManager = _a.#PREFIX_MANAGERS_MAP.get(normalizedPrefixProvider.gs1CompanyPrefix);
188
+ if (prefixManager === undefined) {
189
+ prefixManager = new _a(normalizedPrefixProvider.prefixType, normalizedPrefixProvider.prefix);
190
+ _a.#PREFIX_MANAGERS_MAP.set(normalizedPrefixProvider.gs1CompanyPrefix, prefixManager);
191
+ }
192
+ return prefixManager;
193
+ }
194
+ /**
195
+ * Get an identifier creator.
196
+ *
197
+ * @template TIdentifierType
198
+ * Identifier type type.
199
+ *
200
+ * @template TConstructorArgument
201
+ * Second constructor argument type.
202
+ *
203
+ * @param identifierType
204
+ * Identifier type used to construct identifier creator.
205
+ *
206
+ * @param constructorArgument
207
+ * Second constructor argument passed to constructor callback alongside this.
208
+ *
209
+ * @param ConstructorCallback
210
+ * Constructor callback.
211
+ *
212
+ * @returns
213
+ * Identifier creator.
214
+ */
215
+ #getIdentifierCreator(identifierType, constructorArgument, ConstructorCallback) {
216
+ let creator = this.#identifierCreators[identifierType];
217
+ if (creator === undefined) {
218
+ if (this.prefixType === PrefixTypes.GS18Prefix && identifierType !== IdentifierTypes.GTIN) {
219
+ throw new RangeError(i18nextGS1.t("Prefix.identifierTypeNotSupportedByGS18Prefix", {
220
+ identifierType
221
+ }));
222
+ }
223
+ creator = new ConstructorCallback(this, constructorArgument);
224
+ this.#setCreatorTweak(creator);
225
+ this.#identifierCreators[identifierType] = creator;
226
+ }
227
+ return creator;
228
+ }
229
+ /**
230
+ * Get non-GTIN numeric identifier creator.
231
+ *
232
+ * @param identifierType
233
+ * Identifier type used to construct identifier creator.
234
+ *
235
+ * @returns
236
+ * Identifier creator.
237
+ */
238
+ #getNonGTINNumericIdentifierCreator(identifierType) {
239
+ return this.#getIdentifierCreator(identifierType, identifierType, NonSerializableNumericIdentifierCreator);
240
+ }
241
+ /**
242
+ * Get serialized numeric identifier creator.
243
+ *
244
+ * @param identifierType
245
+ * Identifier type used to construct identifier creator.
246
+ *
247
+ * @returns
248
+ * Identifier creator.
249
+ */
250
+ #getSerializableNumericIdentifierCreator(identifierType) {
251
+ return this.#getIdentifierCreator(identifierType, identifierType, SerializableNumericIdentifierCreator);
252
+ }
253
+ /**
254
+ * Get non-numeric identifier creator.
255
+ *
256
+ * @param identifierType
257
+ * Identifier type used to construct identifier creator.
258
+ *
259
+ * @returns
260
+ * Identifier creator.
261
+ */
262
+ #getNonNumericIdentifierCreator(identifierType) {
263
+ return this.#getIdentifierCreator(identifierType, identifierType, NonNumericIdentifierCreator);
264
+ }
265
+ /**
266
+ * Get GTIN creator.
267
+ */
268
+ get gtinCreator() {
269
+ return this.#getIdentifierCreator(IdentifierTypes.GTIN, GTIN_BASE_TYPES[this.prefixType], GTINCreator);
270
+ }
271
+ /**
272
+ * Get GLN creator.
273
+ */
274
+ get glnCreator() {
275
+ return this.#getNonGTINNumericIdentifierCreator(IdentifierTypes.GLN);
276
+ }
277
+ /**
278
+ * Get SSCC creator.
279
+ */
280
+ get ssccCreator() {
281
+ return this.#getNonGTINNumericIdentifierCreator(IdentifierTypes.SSCC);
282
+ }
283
+ /**
284
+ * Get GRAI creator.
285
+ */
286
+ get graiCreator() {
287
+ return this.#getSerializableNumericIdentifierCreator(IdentifierTypes.GRAI);
288
+ }
289
+ /**
290
+ * Get GIAI creator.
291
+ */
292
+ get giaiCreator() {
293
+ return this.#getNonNumericIdentifierCreator(IdentifierTypes.GIAI);
294
+ }
295
+ /**
296
+ * Get GSRN creator.
297
+ */
298
+ get gsrnCreator() {
299
+ return this.#getNonGTINNumericIdentifierCreator(IdentifierTypes.GSRN);
300
+ }
301
+ /**
302
+ * Get GDTI creator.
303
+ */
304
+ get gdtiCreator() {
305
+ return this.#getSerializableNumericIdentifierCreator(IdentifierTypes.GDTI);
306
+ }
307
+ /**
308
+ * Get GINC creator.
309
+ */
310
+ get gincCreator() {
311
+ return this.#getNonNumericIdentifierCreator(IdentifierTypes.GINC);
312
+ }
313
+ /**
314
+ * Get GSIN creator.
315
+ */
316
+ get gsinCreator() {
317
+ return this.#getNonGTINNumericIdentifierCreator(IdentifierTypes.GSIN);
318
+ }
319
+ /**
320
+ * Get GCN creator.
321
+ */
322
+ get gcnCreator() {
323
+ return this.#getSerializableNumericIdentifierCreator(IdentifierTypes.GCN);
324
+ }
325
+ /**
326
+ * Get CPID creator.
327
+ */
328
+ get cpidCreator() {
329
+ return this.#getNonNumericIdentifierCreator(IdentifierTypes.CPID);
330
+ }
331
+ /**
332
+ * Get GMN creator.
333
+ */
334
+ get gmnCreator() {
335
+ return this.#getNonNumericIdentifierCreator(IdentifierTypes.GMN);
336
+ }
337
+ }
338
+ _a = PrefixManager;
339
+ //# sourceMappingURL=prefix-manager.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"prefix-manager.js","sourceRoot":"","sources":["../src/prefix-manager.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,27 @@
1
+ import type { PrefixType } from "./prefix-type.js";
2
+ /**
3
+ * Prefix provider.
4
+ */
5
+ export interface PrefixProvider {
6
+ /**
7
+ * Prefix type.
8
+ */
9
+ readonly prefixType: PrefixType;
10
+ /**
11
+ * Prefix appropriate to the prefix type.
12
+ */
13
+ readonly prefix: string;
14
+ /**
15
+ * Prefix as GS1 Company Prefix.
16
+ */
17
+ readonly gs1CompanyPrefix: string;
18
+ /**
19
+ * Prefix as U.P.C. Company Prefix if prefix type is {@linkcode PrefixTypes.UPCCompanyPrefix} or undefined if not.
20
+ */
21
+ readonly upcCompanyPrefix: string | undefined;
22
+ /**
23
+ * Prefix as GS1-8 Prefix if prefix type is {@linkcode PrefixTypes.GS18Prefix} or undefined if not.
24
+ */
25
+ readonly gs18Prefix: string | undefined;
26
+ }
27
+ //# sourceMappingURL=prefix-provider.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"prefix-provider.d.ts","sourceRoot":"","sources":["../src/prefix-provider.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,kBAAkB,CAAC;AAEnD;;GAEG;AACH,MAAM,WAAW,cAAc;IAC3B;;OAEG;IACH,QAAQ,CAAC,UAAU,EAAE,UAAU,CAAC;IAEhC;;OAEG;IACH,QAAQ,CAAC,MAAM,EAAE,MAAM,CAAC;IAExB;;OAEG;IACH,QAAQ,CAAC,gBAAgB,EAAE,MAAM,CAAC;IAElC;;OAEG;IACH,QAAQ,CAAC,gBAAgB,EAAE,MAAM,GAAG,SAAS,CAAC;IAE9C;;OAEG;IACH,QAAQ,CAAC,UAAU,EAAE,MAAM,GAAG,SAAS,CAAC;CAC3C"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=prefix-provider.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"prefix-provider.js","sourceRoot":"","sources":["../src/prefix-provider.ts"],"names":[],"mappings":""}
@@ -0,0 +1,26 @@
1
+ /**
2
+ * Prefix types.
3
+ */
4
+ export declare const PrefixTypes: {
5
+ /**
6
+ * GS1 Company Prefix.
7
+ */
8
+ readonly GS1CompanyPrefix: "GS1 Company Prefix";
9
+ /**
10
+ * U.P.C. Company Prefix.
11
+ */
12
+ readonly UPCCompanyPrefix: "U.P.C. Company Prefix";
13
+ /**
14
+ * GS1-8 Prefix.
15
+ */
16
+ readonly GS18Prefix: "GS1-8 Prefix";
17
+ };
18
+ /**
19
+ * Prefix type key.
20
+ */
21
+ export type PrefixTypeKey = keyof typeof PrefixTypes;
22
+ /**
23
+ * Prefix type.
24
+ */
25
+ export type PrefixType = typeof PrefixTypes[PrefixTypeKey];
26
+ //# sourceMappingURL=prefix-type.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"prefix-type.d.ts","sourceRoot":"","sources":["../src/prefix-type.ts"],"names":[],"mappings":"AAAA;;GAEG;AACH,eAAO,MAAM,WAAW;IACpB;;OAEG;;IAGH;;OAEG;;IAGH;;OAEG;;CAEG,CAAC;AAEX;;GAEG;AACH,MAAM,MAAM,aAAa,GAAG,MAAM,OAAO,WAAW,CAAC;AAErD;;GAEG;AACH,MAAM,MAAM,UAAU,GAAG,OAAO,WAAW,CAAC,aAAa,CAAC,CAAC"}
@@ -0,0 +1,18 @@
1
+ /**
2
+ * Prefix types.
3
+ */
4
+ export const PrefixTypes = {
5
+ /**
6
+ * GS1 Company Prefix.
7
+ */
8
+ GS1CompanyPrefix: "GS1 Company Prefix",
9
+ /**
10
+ * U.P.C. Company Prefix.
11
+ */
12
+ UPCCompanyPrefix: "U.P.C. Company Prefix",
13
+ /**
14
+ * GS1-8 Prefix.
15
+ */
16
+ GS18Prefix: "GS1-8 Prefix"
17
+ };
18
+ //# sourceMappingURL=prefix-type.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"prefix-type.js","sourceRoot":"","sources":["../src/prefix-type.ts"],"names":[],"mappings":"AAAA;;GAEG;AACH,MAAM,CAAC,MAAM,WAAW,GAAG;IACvB;;OAEG;IACH,gBAAgB,EAAE,oBAAoB;IAEtC;;OAEG;IACH,gBAAgB,EAAE,uBAAuB;IAEzC;;OAEG;IACH,UAAU,EAAE,cAAc;CACpB,CAAC"}
@@ -0,0 +1,70 @@
1
+ import { type CharacterSetValidation } from "@aidc-toolkit/utility";
2
+ import type { PrefixProvider } from "./prefix-provider.js";
3
+ import { type PrefixType } from "./prefix-type.js";
4
+ /**
5
+ * Prefix validation parameters.
6
+ */
7
+ export interface PrefixValidation extends CharacterSetValidation {
8
+ /**
9
+ * Minimum length.
10
+ */
11
+ minimumLength: number;
12
+ /**
13
+ * Maximum length.
14
+ */
15
+ maximumLength: number;
16
+ /**
17
+ * Callback to localized prefix type name.
18
+ */
19
+ component: () => string;
20
+ }
21
+ /**
22
+ * Prefix validator.
23
+ */
24
+ export declare const PrefixValidator: {
25
+ readonly GS1_COMPANY_PREFIX_MINIMUM_LENGTH: 4;
26
+ readonly GS1_COMPANY_PREFIX_MAXIMUM_LENGTH: 12;
27
+ readonly UPC_COMPANY_PREFIX_MINIMUM_LENGTH: 6;
28
+ readonly UPC_COMPANY_PREFIX_MAXIMUM_LENGTH: 11;
29
+ readonly GS1_8_PREFIX_MINIMUM_LENGTH: 2;
30
+ readonly GS1_8_PREFIX_MAXIMUM_LENGTH: 7;
31
+ /**
32
+ * Validate a prefix.
33
+ *
34
+ * @param prefixType
35
+ * Prefix type.
36
+ *
37
+ * @param allowUPCCompanyPrefix
38
+ * If true, a U.P.C. Company Prefix expressed as a GS1 Company Prefix is permitted.
39
+ *
40
+ * @param allowGS18Prefix
41
+ * If true, a GS1-8 Prefix expressed as a GS1 Company Prefix is permitted.
42
+ *
43
+ * @param prefix
44
+ * Prefix.
45
+ *
46
+ * @param isFromIdentifier
47
+ * If true, the prefix is from an identifier and should be trimmed before its character set is validated.
48
+ *
49
+ * @param isNumericIdentifier
50
+ * If true, the prefix is from a numeric identifier and its character set will be validated by the caller.
51
+ *
52
+ * @param positionOffset
53
+ * Position offset within a larger string.
54
+ */
55
+ readonly validate: (prefixType: PrefixType, allowUPCCompanyPrefix: boolean, allowGS18Prefix: boolean, prefix: string, isFromIdentifier?: boolean, isNumericIdentifier?: boolean, positionOffset?: number) => void;
56
+ /**
57
+ * Normalize a prefix.
58
+ *
59
+ * @param prefixType
60
+ * Prefix type.
61
+ *
62
+ * @param prefix
63
+ * Prefix.
64
+ *
65
+ * @returns
66
+ * Prefix provider with normalized prefix type and prefix.
67
+ */
68
+ readonly normalize: (prefixType: PrefixType, prefix: string) => PrefixProvider;
69
+ };
70
+ //# sourceMappingURL=prefix-validator.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"prefix-validator.d.ts","sourceRoot":"","sources":["../src/prefix-validator.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,sBAAsB,EAAmB,MAAM,uBAAuB,CAAC;AAErF,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,sBAAsB,CAAC;AAC3D,OAAO,EAAE,KAAK,UAAU,EAAe,MAAM,kBAAkB,CAAC;AAEhE;;GAEG;AACH,MAAM,WAAW,gBAAiB,SAAQ,sBAAsB;IAC5D;;OAEG;IACH,aAAa,EAAE,MAAM,CAAC;IAEtB;;OAEG;IACH,aAAa,EAAE,MAAM,CAAC;IAEtB;;OAEG;IACH,SAAS,EAAE,MAAM,MAAM,CAAC;CAC3B;AA6ED;;GAEG;AACH,eAAO,MAAM,eAAe;;;;;;;IAQxB;;;;;;;;;;;;;;;;;;;;;;;OAuBG;oCACkB,UAAU,yBAAyB,OAAO,mBAAmB,OAAO,UAAU,MAAM,8EAA0E,MAAM,KAAG,IAAI;IAwDhM;;;;;;;;;;;OAWG;qCACmB,UAAU,UAAU,MAAM,KAAG,cAAc;CAiD3D,CAAC"}