@aidc-toolkit/gs1 1.0.43 → 1.0.44-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 (221) hide show
  1. package/dist/abstract-identifier-creator.d.ts +41 -0
  2. package/dist/abstract-identifier-creator.d.ts.map +1 -0
  3. package/dist/abstract-identifier-creator.js +73 -0
  4. package/dist/abstract-identifier-creator.js.map +1 -0
  5. package/dist/abstract-non-gtin-numeric-identifier-creator.d.ts +36 -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 +37 -0
  8. package/dist/abstract-non-gtin-numeric-identifier-creator.js.map +1 -0
  9. package/dist/abstract-numeric-identifier-creator.d.ts +34 -0
  10. package/dist/abstract-numeric-identifier-creator.d.ts.map +1 -0
  11. package/dist/abstract-numeric-identifier-creator.js +154 -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 +83 -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/gcp-length-cache.d.ts +89 -0
  30. package/dist/gcp-length-cache.d.ts.map +1 -0
  31. package/dist/gcp-length-cache.js +240 -0
  32. package/dist/gcp-length-cache.js.map +1 -0
  33. package/dist/gcp-length-data.d.ts +108 -0
  34. package/dist/gcp-length-data.d.ts.map +1 -0
  35. package/dist/gcp-length-data.js +53 -0
  36. package/dist/gcp-length-data.js.map +1 -0
  37. package/dist/gcp-length.d.ts +97 -0
  38. package/dist/gcp-length.d.ts.map +1 -0
  39. package/dist/gcp-length.js +368 -0
  40. package/dist/gcp-length.js.map +1 -0
  41. package/dist/gtin-creator.d.ts +47 -0
  42. package/dist/gtin-creator.d.ts.map +1 -0
  43. package/dist/gtin-creator.js +64 -0
  44. package/dist/gtin-creator.js.map +1 -0
  45. package/dist/gtin-descriptor.d.ts +22 -0
  46. package/dist/gtin-descriptor.d.ts.map +1 -0
  47. package/dist/gtin-descriptor.js +2 -0
  48. package/dist/gtin-descriptor.js.map +1 -0
  49. package/dist/gtin-length.d.ts +64 -0
  50. package/dist/gtin-length.d.ts.map +1 -0
  51. package/dist/gtin-length.js +36 -0
  52. package/dist/gtin-length.js.map +1 -0
  53. package/dist/gtin-type.d.ts +26 -0
  54. package/dist/gtin-type.d.ts.map +1 -0
  55. package/dist/gtin-type.js +7 -0
  56. package/dist/gtin-type.js.map +1 -0
  57. package/dist/gtin-validator.d.ts +132 -0
  58. package/dist/gtin-validator.d.ts.map +1 -0
  59. package/dist/gtin-validator.js +349 -0
  60. package/dist/gtin-validator.js.map +1 -0
  61. package/dist/identifier-creator.d.ts +31 -0
  62. package/dist/identifier-creator.d.ts.map +1 -0
  63. package/dist/identifier-creator.js +2 -0
  64. package/dist/identifier-creator.js.map +1 -0
  65. package/dist/identifier-creators.d.ts +118 -0
  66. package/dist/identifier-creators.d.ts.map +1 -0
  67. package/dist/identifier-creators.js +92 -0
  68. package/dist/identifier-creators.js.map +1 -0
  69. package/dist/identifier-descriptor.d.ts +27 -0
  70. package/dist/identifier-descriptor.d.ts.map +1 -0
  71. package/dist/identifier-descriptor.js +2 -0
  72. package/dist/identifier-descriptor.js.map +1 -0
  73. package/dist/identifier-descriptors.d.ts +106 -0
  74. package/dist/identifier-descriptors.d.ts.map +1 -0
  75. package/dist/identifier-descriptors.js +262 -0
  76. package/dist/identifier-descriptors.js.map +1 -0
  77. package/dist/identifier-extension.d.ts +82 -0
  78. package/dist/identifier-extension.d.ts.map +1 -0
  79. package/dist/identifier-extension.js +79 -0
  80. package/dist/identifier-extension.js.map +1 -0
  81. package/dist/identifier-type.d.ts +62 -0
  82. package/dist/identifier-type.d.ts.map +1 -0
  83. package/dist/identifier-type.js +54 -0
  84. package/dist/identifier-type.js.map +1 -0
  85. package/dist/identifier-validator.d.ts +85 -0
  86. package/dist/identifier-validator.d.ts.map +1 -0
  87. package/dist/identifier-validator.js +107 -0
  88. package/dist/identifier-validator.js.map +1 -0
  89. package/dist/identifier-validators.d.ts +131 -0
  90. package/dist/identifier-validators.d.ts.map +1 -0
  91. package/dist/identifier-validators.js +167 -0
  92. package/dist/identifier-validators.js.map +1 -0
  93. package/dist/index.d.ts +63 -2205
  94. package/dist/index.d.ts.map +1 -0
  95. package/dist/index.js +36 -3
  96. package/dist/index.js.map +1 -0
  97. package/dist/leader-type.d.ts +26 -0
  98. package/dist/leader-type.d.ts.map +1 -0
  99. package/dist/leader-type.js +18 -0
  100. package/dist/leader-type.js.map +1 -0
  101. package/dist/locale/en/locale-resources.d.ts +48 -0
  102. package/dist/locale/en/locale-resources.d.ts.map +1 -0
  103. package/dist/locale/en/locale-resources.js +47 -0
  104. package/dist/locale/en/locale-resources.js.map +1 -0
  105. package/dist/locale/fr/locale-resources.d.ts +48 -0
  106. package/dist/locale/fr/locale-resources.d.ts.map +1 -0
  107. package/dist/locale/fr/locale-resources.js +47 -0
  108. package/dist/locale/fr/locale-resources.js.map +1 -0
  109. package/dist/locale/i18n.d.ts +27 -0
  110. package/dist/locale/i18n.d.ts.map +1 -0
  111. package/dist/locale/i18n.js +35 -0
  112. package/dist/locale/i18n.js.map +1 -0
  113. package/dist/non-gtin-numeric-identifier-creator.d.ts +12 -0
  114. package/dist/non-gtin-numeric-identifier-creator.d.ts.map +1 -0
  115. package/dist/non-gtin-numeric-identifier-creator.js +2 -0
  116. package/dist/non-gtin-numeric-identifier-creator.js.map +1 -0
  117. package/dist/non-gtin-numeric-identifier-descriptor.d.ts +22 -0
  118. package/dist/non-gtin-numeric-identifier-descriptor.d.ts.map +1 -0
  119. package/dist/non-gtin-numeric-identifier-descriptor.js +2 -0
  120. package/dist/non-gtin-numeric-identifier-descriptor.js.map +1 -0
  121. package/dist/non-gtin-numeric-identifier-type.d.ts +26 -0
  122. package/dist/non-gtin-numeric-identifier-type.d.ts.map +1 -0
  123. package/dist/non-gtin-numeric-identifier-type.js +8 -0
  124. package/dist/non-gtin-numeric-identifier-type.js.map +1 -0
  125. package/dist/non-gtin-numeric-identifier-validator.d.ts +12 -0
  126. package/dist/non-gtin-numeric-identifier-validator.d.ts.map +1 -0
  127. package/dist/non-gtin-numeric-identifier-validator.js +10 -0
  128. package/dist/non-gtin-numeric-identifier-validator.js.map +1 -0
  129. package/dist/non-numeric-identifier-creator.d.ts +40 -0
  130. package/dist/non-numeric-identifier-creator.d.ts.map +1 -0
  131. package/dist/non-numeric-identifier-creator.js +82 -0
  132. package/dist/non-numeric-identifier-creator.js.map +1 -0
  133. package/dist/non-numeric-identifier-descriptor.d.ts +26 -0
  134. package/dist/non-numeric-identifier-descriptor.d.ts.map +1 -0
  135. package/dist/non-numeric-identifier-descriptor.js +2 -0
  136. package/dist/non-numeric-identifier-descriptor.js.map +1 -0
  137. package/dist/non-numeric-identifier-type.d.ts +26 -0
  138. package/dist/non-numeric-identifier-type.d.ts.map +1 -0
  139. package/dist/non-numeric-identifier-type.js +8 -0
  140. package/dist/non-numeric-identifier-type.js.map +1 -0
  141. package/dist/non-numeric-identifier-validator.d.ts +41 -0
  142. package/dist/non-numeric-identifier-validator.d.ts.map +1 -0
  143. package/dist/non-numeric-identifier-validator.js +69 -0
  144. package/dist/non-numeric-identifier-validator.js.map +1 -0
  145. package/dist/non-serializable-numeric-identifier-creator.d.ts +10 -0
  146. package/dist/non-serializable-numeric-identifier-creator.d.ts.map +1 -0
  147. package/dist/non-serializable-numeric-identifier-creator.js +8 -0
  148. package/dist/non-serializable-numeric-identifier-creator.js.map +1 -0
  149. package/dist/non-serializable-numeric-identifier-descriptor.d.ts +12 -0
  150. package/dist/non-serializable-numeric-identifier-descriptor.d.ts.map +1 -0
  151. package/dist/non-serializable-numeric-identifier-descriptor.js +2 -0
  152. package/dist/non-serializable-numeric-identifier-descriptor.js.map +1 -0
  153. package/dist/non-serializable-numeric-identifier-type.d.ts +26 -0
  154. package/dist/non-serializable-numeric-identifier-type.d.ts.map +1 -0
  155. package/dist/non-serializable-numeric-identifier-type.js +7 -0
  156. package/dist/non-serializable-numeric-identifier-type.js.map +1 -0
  157. package/dist/non-serializable-numeric-identifier-validator.d.ts +16 -0
  158. package/dist/non-serializable-numeric-identifier-validator.d.ts.map +1 -0
  159. package/dist/non-serializable-numeric-identifier-validator.js +17 -0
  160. package/dist/non-serializable-numeric-identifier-validator.js.map +1 -0
  161. package/dist/numeric-identifier-creator.d.ts +53 -0
  162. package/dist/numeric-identifier-creator.d.ts.map +1 -0
  163. package/dist/numeric-identifier-creator.js +2 -0
  164. package/dist/numeric-identifier-creator.js.map +1 -0
  165. package/dist/numeric-identifier-descriptor.d.ts +22 -0
  166. package/dist/numeric-identifier-descriptor.d.ts.map +1 -0
  167. package/dist/numeric-identifier-descriptor.js +2 -0
  168. package/dist/numeric-identifier-descriptor.js.map +1 -0
  169. package/dist/numeric-identifier-type.d.ts +26 -0
  170. package/dist/numeric-identifier-type.d.ts.map +1 -0
  171. package/dist/numeric-identifier-type.js +7 -0
  172. package/dist/numeric-identifier-type.js.map +1 -0
  173. package/dist/numeric-identifier-validator.d.ts +38 -0
  174. package/dist/numeric-identifier-validator.d.ts.map +1 -0
  175. package/dist/numeric-identifier-validator.js +61 -0
  176. package/dist/numeric-identifier-validator.js.map +1 -0
  177. package/dist/prefix-manager.d.ts +151 -0
  178. package/dist/prefix-manager.d.ts.map +1 -0
  179. package/dist/prefix-manager.js +297 -0
  180. package/dist/prefix-manager.js.map +1 -0
  181. package/dist/prefix-provider.d.ts +27 -0
  182. package/dist/prefix-provider.d.ts.map +1 -0
  183. package/dist/prefix-provider.js +2 -0
  184. package/dist/prefix-provider.js.map +1 -0
  185. package/dist/prefix-type.d.ts +26 -0
  186. package/dist/prefix-type.d.ts.map +1 -0
  187. package/dist/prefix-type.js +18 -0
  188. package/dist/prefix-type.js.map +1 -0
  189. package/dist/prefix-validator.d.ts +71 -0
  190. package/dist/prefix-validator.d.ts.map +1 -0
  191. package/dist/prefix-validator.js +204 -0
  192. package/dist/prefix-validator.js.map +1 -0
  193. package/dist/serializable-numeric-identifier-creator.d.ts +48 -0
  194. package/dist/serializable-numeric-identifier-creator.d.ts.map +1 -0
  195. package/dist/serializable-numeric-identifier-creator.js +93 -0
  196. package/dist/serializable-numeric-identifier-creator.js.map +1 -0
  197. package/dist/serializable-numeric-identifier-descriptor.d.ts +26 -0
  198. package/dist/serializable-numeric-identifier-descriptor.d.ts.map +1 -0
  199. package/dist/serializable-numeric-identifier-descriptor.js +2 -0
  200. package/dist/serializable-numeric-identifier-descriptor.js.map +1 -0
  201. package/dist/serializable-numeric-identifier-type.d.ts +26 -0
  202. package/dist/serializable-numeric-identifier-type.d.ts.map +1 -0
  203. package/dist/serializable-numeric-identifier-type.js +8 -0
  204. package/dist/serializable-numeric-identifier-type.js.map +1 -0
  205. package/dist/serializable-numeric-identifier-validator.d.ts +67 -0
  206. package/dist/serializable-numeric-identifier-validator.d.ts.map +1 -0
  207. package/dist/serializable-numeric-identifier-validator.js +97 -0
  208. package/dist/serializable-numeric-identifier-validator.js.map +1 -0
  209. package/dist/variable-measure.d.ts +68 -0
  210. package/dist/variable-measure.d.ts.map +1 -0
  211. package/dist/variable-measure.js +210 -0
  212. package/dist/variable-measure.js.map +1 -0
  213. package/dist/verified-by-gs1.d.ts +22 -0
  214. package/dist/verified-by-gs1.d.ts.map +1 -0
  215. package/dist/verified-by-gs1.js +46 -0
  216. package/dist/verified-by-gs1.js.map +1 -0
  217. package/package.json +4 -4
  218. package/src/gcp-length-cache.ts +7 -2
  219. package/tsconfig-src.tsbuildinfo +1 -1
  220. package/dist/index.cjs +0 -19
  221. package/dist/index.d.cts +0 -2205
@@ -0,0 +1,297 @@
1
+ var _a;
2
+ import { GTIN_BASE_TYPES } from "./gtin-length.js";
3
+ import { IdentifierCreatorConstructors, isNumericIdentifierCreator } from "./identifier-creators.js";
4
+ import { IdentifierTypes } from "./identifier-type.js";
5
+ import { i18nextGS1 } from "./locale/i18n.js";
6
+ import { PrefixTypes } from "./prefix-type.js";
7
+ import { PrefixValidator } from "./prefix-validator.js";
8
+ /**
9
+ * Prefix manager. This is the core class for identifier creation.
10
+ *
11
+ * A prefix manager may be constructed for any {@link PrefixType | prefix type}. Construction may be done directly or
12
+ * via the static {@linkcode PrefixManager.get | get()} method, which allows for caching and reuse. As most applications
13
+ * work with a limited number of prefixes for creating identifiers, caching and reuse may be a more efficient option.
14
+ *
15
+ * The prefix type and prefix are normalized before the prefix manager is constructed, so they may not match the input
16
+ * values. For example, the GS1 Company Prefix 0614141 is equivalent to U.P.C. Company Prefix 614141; both result in a
17
+ * prefix manager with prefix type equal to {@linkcode PrefixTypes.UPCCompanyPrefix} and prefix equal to "614141".
18
+ *
19
+ * To support the creation of sparse identifiers, a prefix manager maintains a {@link tweakFactor | tweak factor} which
20
+ * is used, along with a type-specific multiplier, as the tweak when creating numeric identifiers. The default tweak
21
+ * factor is the numeric value of the GS1 Company Prefix representation of the prefix preceded by '1' to ensure
22
+ * uniqueness (i.e., so that prefixes 0 N1 N2 N3... and N1 N2 N3... produce different tweak factors). This is usually
23
+ * sufficient for obfuscation, but as the sparse creation algorithm is reversible and as the GS1 Company Prefix is
24
+ * discoverable via {@link https://www.gs1.org/services/verified-by-gs1 | Verified by GS1}, a user-defined tweak factor
25
+ * should be used if a higher degree of obfuscation is required. When using a tweak factor other than the default, care
26
+ * should be taken to restore it when resuming the application. A tweak factor of 0 creates a straight sequence.
27
+ */
28
+ export class PrefixManager {
29
+ /**
30
+ * Cached prefix managers, keyed by GS1 Company Prefix.
31
+ */
32
+ static #PREFIX_MANAGERS_MAP = new Map();
33
+ /**
34
+ * Creator tweak factors. Different numeric identifier types have different tweak factors so that sparse creation
35
+ * generates different sequences for each.
36
+ */
37
+ static #CREATOR_TWEAK_FACTORS = {
38
+ GTIN: 1987n,
39
+ GLN: 4241n,
40
+ SSCC: 8087n,
41
+ GRAI: 3221n,
42
+ GSRN: 2341n,
43
+ GDTI: 7333n,
44
+ GSIN: 5623n,
45
+ GCN: 6869n
46
+ };
47
+ /**
48
+ * Normalized prefix type.
49
+ */
50
+ #prefixType;
51
+ /**
52
+ * Normalized prefix.
53
+ */
54
+ #prefix;
55
+ /**
56
+ * Prefix as GS1 Company Prefix.
57
+ */
58
+ #gs1CompanyPrefix;
59
+ /**
60
+ * U.P.C. Company Prefix if prefix type is {@linkcode PrefixTypes.UPCCompanyPrefix}.
61
+ */
62
+ #upcCompanyPrefix;
63
+ /**
64
+ * GS1-8 Prefix if prefix type is {@linkcode PrefixTypes.GS18Prefix}.
65
+ */
66
+ #gs18Prefix;
67
+ /**
68
+ * Default tweak factor.
69
+ */
70
+ #defaultTweakFactor;
71
+ /**
72
+ * Tweak factor.
73
+ */
74
+ #tweakFactor = 0n;
75
+ /**
76
+ * Cached identifier creators.
77
+ */
78
+ #identifierCreators = {};
79
+ /**
80
+ * Constructor.
81
+ *
82
+ * @param prefixType
83
+ * Prefix type.
84
+ *
85
+ * @param prefix
86
+ * Prefix.
87
+ */
88
+ constructor(prefixType, prefix) {
89
+ const normalizedPrefixProvider = PrefixValidator.normalize(prefixType, prefix);
90
+ this.#prefixType = normalizedPrefixProvider.prefixType;
91
+ this.#prefix = normalizedPrefixProvider.prefix;
92
+ this.#gs1CompanyPrefix = normalizedPrefixProvider.gs1CompanyPrefix;
93
+ this.#upcCompanyPrefix = normalizedPrefixProvider.upcCompanyPrefix;
94
+ this.#gs18Prefix = normalizedPrefixProvider.gs18Prefix;
95
+ // Default tweak factor is the numeric value of the GS1 Company Prefix preceded by '1'.
96
+ this.#defaultTweakFactor = BigInt(`1${this.gs1CompanyPrefix}`);
97
+ this.resetTweakFactor();
98
+ }
99
+ /**
100
+ * Get the prefix type.
101
+ */
102
+ get prefixType() {
103
+ return this.#prefixType;
104
+ }
105
+ /**
106
+ * Get the prefix.
107
+ */
108
+ get prefix() {
109
+ return this.#prefix;
110
+ }
111
+ /**
112
+ * Get the GS1 Company Prefix.
113
+ */
114
+ get gs1CompanyPrefix() {
115
+ return this.#gs1CompanyPrefix;
116
+ }
117
+ /**
118
+ * Get the U.P.C. Company Prefix if prefix type is {@linkcode PrefixTypes.UPCCompanyPrefix} or undefined if not.
119
+ */
120
+ get upcCompanyPrefix() {
121
+ return this.#upcCompanyPrefix;
122
+ }
123
+ /**
124
+ * Get the GS1-8 Prefix if prefix type is {@linkcode PrefixTypes.GS18Prefix} or undefined if not.
125
+ */
126
+ get gs18Prefix() {
127
+ return this.#gs18Prefix;
128
+ }
129
+ /**
130
+ * Set the tweak for an identifier creator if it's a numeric identifier creator.
131
+ *
132
+ * @param identifierCreator
133
+ * Identifier creator.
134
+ */
135
+ #setCreatorTweak(identifierCreator) {
136
+ if (isNumericIdentifierCreator(identifierCreator)) {
137
+ // eslint-disable-next-line no-param-reassign -- Method purpose is to set the tweak.
138
+ identifierCreator.tweak = this.tweakFactor * _a.#CREATOR_TWEAK_FACTORS[identifierCreator.identifierType];
139
+ }
140
+ }
141
+ /**
142
+ * Get the tweak factor.
143
+ */
144
+ get tweakFactor() {
145
+ return this.#tweakFactor;
146
+ }
147
+ /**
148
+ * Set the tweak factor.
149
+ *
150
+ * @param value
151
+ * Tweak factor.
152
+ */
153
+ set tweakFactor(value) {
154
+ const tweakFactor = BigInt(value);
155
+ if (this.#tweakFactor !== tweakFactor) {
156
+ this.#tweakFactor = tweakFactor;
157
+ for (const creator of Object.values(this.#identifierCreators)) {
158
+ this.#setCreatorTweak(creator);
159
+ }
160
+ }
161
+ }
162
+ /**
163
+ * Reset the tweak factor to its default (numeric value of the GS1 Company Prefix preceded by '1').
164
+ */
165
+ resetTweakFactor() {
166
+ this.tweakFactor = this.#defaultTweakFactor;
167
+ }
168
+ /**
169
+ * Get a prefix manager.
170
+ *
171
+ * @param prefixType
172
+ * Prefix type.
173
+ *
174
+ * @param prefix
175
+ * Prefix.
176
+ *
177
+ * @returns
178
+ * Prefix manager with normalized prefix type and prefix.
179
+ */
180
+ static get(prefixType, prefix) {
181
+ // Normalization will occur in constructor as well, but it's necessary here for the map.
182
+ const normalizedPrefixProvider = PrefixValidator.normalize(prefixType, prefix);
183
+ let prefixManager = _a.#PREFIX_MANAGERS_MAP.get(normalizedPrefixProvider.gs1CompanyPrefix);
184
+ if (prefixManager === undefined) {
185
+ prefixManager = new _a(normalizedPrefixProvider.prefixType, normalizedPrefixProvider.prefix);
186
+ _a.#PREFIX_MANAGERS_MAP.set(normalizedPrefixProvider.gs1CompanyPrefix, prefixManager);
187
+ }
188
+ return prefixManager;
189
+ }
190
+ /**
191
+ * Get an identifier creator.
192
+ *
193
+ * @template TIdentifierType
194
+ * Identifier type type.
195
+ *
196
+ * @param identifierType
197
+ * Identifier type for which to retrieve or construct identifier creator.
198
+ *
199
+ * @returns
200
+ * Identifier creator.
201
+ */
202
+ getIdentifierCreator(identifierType) {
203
+ let creator = this.#identifierCreators[identifierType];
204
+ if (creator === undefined) {
205
+ if (identifierType === IdentifierTypes.GTIN) {
206
+ // eslint-disable-next-line @typescript-eslint/no-unsafe-type-assertion -- Types are known to match.
207
+ creator = new IdentifierCreatorConstructors.GTIN(this, GTIN_BASE_TYPES[this.prefixType]);
208
+ }
209
+ else {
210
+ if (this.prefixType === PrefixTypes.GS18Prefix) {
211
+ throw new RangeError(i18nextGS1.t("Prefix.identifierTypeNotSupportedByGS18Prefix", {
212
+ identifierType
213
+ }));
214
+ }
215
+ // eslint-disable-next-line @typescript-eslint/no-unsafe-type-assertion -- Types are known to match.
216
+ creator = new IdentifierCreatorConstructors[identifierType](this, identifierType);
217
+ }
218
+ this.#setCreatorTweak(creator);
219
+ this.#identifierCreators[identifierType] = creator;
220
+ }
221
+ return creator;
222
+ }
223
+ /**
224
+ * Get GTIN creator.
225
+ */
226
+ get gtinCreator() {
227
+ return this.getIdentifierCreator(IdentifierTypes.GTIN);
228
+ }
229
+ /**
230
+ * Get GLN creator.
231
+ */
232
+ get glnCreator() {
233
+ return this.getIdentifierCreator(IdentifierTypes.GLN);
234
+ }
235
+ /**
236
+ * Get SSCC creator.
237
+ */
238
+ get ssccCreator() {
239
+ return this.getIdentifierCreator(IdentifierTypes.SSCC);
240
+ }
241
+ /**
242
+ * Get GRAI creator.
243
+ */
244
+ get graiCreator() {
245
+ return this.getIdentifierCreator(IdentifierTypes.GRAI);
246
+ }
247
+ /**
248
+ * Get GIAI creator.
249
+ */
250
+ get giaiCreator() {
251
+ return this.getIdentifierCreator(IdentifierTypes.GIAI);
252
+ }
253
+ /**
254
+ * Get GSRN creator.
255
+ */
256
+ get gsrnCreator() {
257
+ return this.getIdentifierCreator(IdentifierTypes.GSRN);
258
+ }
259
+ /**
260
+ * Get GDTI creator.
261
+ */
262
+ get gdtiCreator() {
263
+ return this.getIdentifierCreator(IdentifierTypes.GDTI);
264
+ }
265
+ /**
266
+ * Get GINC creator.
267
+ */
268
+ get gincCreator() {
269
+ return this.getIdentifierCreator(IdentifierTypes.GINC);
270
+ }
271
+ /**
272
+ * Get GSIN creator.
273
+ */
274
+ get gsinCreator() {
275
+ return this.getIdentifierCreator(IdentifierTypes.GSIN);
276
+ }
277
+ /**
278
+ * Get GCN creator.
279
+ */
280
+ get gcnCreator() {
281
+ return this.getIdentifierCreator(IdentifierTypes.GCN);
282
+ }
283
+ /**
284
+ * Get CPID creator.
285
+ */
286
+ get cpidCreator() {
287
+ return this.getIdentifierCreator(IdentifierTypes.CPID);
288
+ }
289
+ /**
290
+ * Get GMN creator.
291
+ */
292
+ get gmnCreator() {
293
+ return this.getIdentifierCreator(IdentifierTypes.GMN);
294
+ }
295
+ }
296
+ _a = PrefixManager;
297
+ //# 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,71 @@
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
+ import type { ParseKeys } from "i18next";
5
+ /**
6
+ * Prefix validation parameters.
7
+ */
8
+ export interface PrefixValidation extends CharacterSetValidation {
9
+ /**
10
+ * Minimum length.
11
+ */
12
+ minimumLength: number;
13
+ /**
14
+ * Maximum length.
15
+ */
16
+ maximumLength: number;
17
+ /**
18
+ * Callback to localized prefix type name.
19
+ */
20
+ component: () => string;
21
+ }
22
+ /**
23
+ * Prefix validator.
24
+ */
25
+ export declare const PrefixValidator: {
26
+ readonly GS1_COMPANY_PREFIX_MINIMUM_LENGTH: 4;
27
+ readonly GS1_COMPANY_PREFIX_MAXIMUM_LENGTH: 12;
28
+ readonly UPC_COMPANY_PREFIX_MINIMUM_LENGTH: 5;
29
+ readonly UPC_COMPANY_PREFIX_MAXIMUM_LENGTH: 11;
30
+ readonly GS1_8_PREFIX_MINIMUM_LENGTH: 2;
31
+ readonly GS1_8_PREFIX_MAXIMUM_LENGTH: 7;
32
+ /**
33
+ * Validate a prefix.
34
+ *
35
+ * @param prefixType
36
+ * Prefix type.
37
+ *
38
+ * @param allowUPCCompanyPrefix
39
+ * If true, a U.P.C. Company Prefix expressed as a GS1 Company Prefix is permitted.
40
+ *
41
+ * @param allowGS18Prefix
42
+ * If true, a GS1-8 Prefix expressed as a GS1 Company Prefix is permitted.
43
+ *
44
+ * @param prefix
45
+ * Prefix.
46
+ *
47
+ * @param isFromIdentifier
48
+ * If true, the prefix is from an identifier and should be trimmed before its character set is validated.
49
+ *
50
+ * @param isNumericIdentifier
51
+ * If true, the prefix is from a numeric identifier and its character set will be validated by the caller.
52
+ *
53
+ * @param errorMessageParseKey
54
+ * Parse key for error message when validating GS1 Company Prefix type.
55
+ */
56
+ readonly validate: (prefixType: PrefixType, allowUPCCompanyPrefix: boolean, allowGS18Prefix: boolean, prefix: string, isFromIdentifier?: boolean, isNumericIdentifier?: boolean, errorMessageParseKey?: ParseKeys) => void;
57
+ /**
58
+ * Normalize a prefix.
59
+ *
60
+ * @param prefixType
61
+ * Prefix type.
62
+ *
63
+ * @param prefix
64
+ * Prefix.
65
+ *
66
+ * @returns
67
+ * Prefix provider with normalized prefix type and prefix.
68
+ */
69
+ readonly normalize: (prefixType: PrefixType, prefix: string) => PrefixProvider;
70
+ };
71
+ //# 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;AAChE,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,SAAS,CAAC;AAEzC;;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,oFAAgF,SAAS,KAAG,IAAI;IAmDzM;;;;;;;;;;;OAWG;qCACmB,UAAU,UAAU,MAAM,KAAG,cAAc;CAiD3D,CAAC"}
@@ -0,0 +1,204 @@
1
+ import { NUMERIC_CREATOR } from "@aidc-toolkit/utility";
2
+ import { i18nextGS1 } from "./locale/i18n.js";
3
+ import { PrefixTypes } from "./prefix-type.js";
4
+ /**
5
+ * GS1 Company Prefix minimum length.
6
+ */
7
+ const GS1_COMPANY_PREFIX_MINIMUM_LENGTH = 4;
8
+ /**
9
+ * GS1 Company Prefix maximum length.
10
+ */
11
+ const GS1_COMPANY_PREFIX_MAXIMUM_LENGTH = 12;
12
+ /**
13
+ * U.P.C. Company Prefix minimum length.
14
+ */
15
+ const UPC_COMPANY_PREFIX_MINIMUM_LENGTH = 5;
16
+ /**
17
+ * U.P.C. Company Prefix maximum length.
18
+ */
19
+ const UPC_COMPANY_PREFIX_MAXIMUM_LENGTH = 11;
20
+ /**
21
+ * GS1-8 Prefix minimum length.
22
+ */
23
+ const GS1_8_PREFIX_MINIMUM_LENGTH = 2;
24
+ /**
25
+ * GS1-8 Prefix maximum length.
26
+ */
27
+ const GS1_8_PREFIX_MAXIMUM_LENGTH = 7;
28
+ /**
29
+ * Validation parameters for GS1 Company Prefix.
30
+ */
31
+ const GS1_COMPANY_PREFIX_VALIDATION = {
32
+ minimumLength: GS1_COMPANY_PREFIX_MINIMUM_LENGTH,
33
+ maximumLength: GS1_COMPANY_PREFIX_MAXIMUM_LENGTH,
34
+ component: () => i18nextGS1.t("Prefix.gs1CompanyPrefix")
35
+ };
36
+ /**
37
+ * Validation parameters for U.P.C. Company Prefix expressed as GS1 Company Prefix.
38
+ */
39
+ const UPC_COMPANY_PREFIX_AS_GS1_COMPANY_PREFIX_VALIDATION = {
40
+ minimumLength: UPC_COMPANY_PREFIX_MINIMUM_LENGTH + 1,
41
+ maximumLength: UPC_COMPANY_PREFIX_MAXIMUM_LENGTH + 1,
42
+ component: () => i18nextGS1.t("Prefix.gs1CompanyPrefix")
43
+ };
44
+ /**
45
+ * Validation parameters for GS1-8 Prefix expressed as GS1 Company Prefix.
46
+ */
47
+ const GS1_8_PREFIX_AS_GS1_COMPANY_PREFIX_VALIDATION = {
48
+ minimumLength: GS1_8_PREFIX_MINIMUM_LENGTH + 5,
49
+ maximumLength: GS1_8_PREFIX_MAXIMUM_LENGTH + 5,
50
+ component: () => i18nextGS1.t("Prefix.gs1CompanyPrefix")
51
+ };
52
+ /**
53
+ * Validation parameters for U.P.C. Company Prefix.
54
+ */
55
+ const UPC_COMPANY_PREFIX_VALIDATION = {
56
+ minimumLength: UPC_COMPANY_PREFIX_MINIMUM_LENGTH,
57
+ maximumLength: UPC_COMPANY_PREFIX_MAXIMUM_LENGTH,
58
+ component: () => i18nextGS1.t("Prefix.upcCompanyPrefix")
59
+ };
60
+ /**
61
+ * Validation parameters for GS1-8 Prefix.
62
+ */
63
+ const GS1_8_PREFIX_VALIDATION = {
64
+ minimumLength: GS1_8_PREFIX_MINIMUM_LENGTH,
65
+ maximumLength: GS1_8_PREFIX_MAXIMUM_LENGTH,
66
+ component: () => i18nextGS1.t("Prefix.gs18Prefix")
67
+ };
68
+ /**
69
+ * Prefix validator.
70
+ */
71
+ export const PrefixValidator = {
72
+ GS1_COMPANY_PREFIX_MINIMUM_LENGTH,
73
+ GS1_COMPANY_PREFIX_MAXIMUM_LENGTH,
74
+ UPC_COMPANY_PREFIX_MINIMUM_LENGTH,
75
+ UPC_COMPANY_PREFIX_MAXIMUM_LENGTH,
76
+ GS1_8_PREFIX_MINIMUM_LENGTH,
77
+ GS1_8_PREFIX_MAXIMUM_LENGTH,
78
+ /**
79
+ * Validate a prefix.
80
+ *
81
+ * @param prefixType
82
+ * Prefix type.
83
+ *
84
+ * @param allowUPCCompanyPrefix
85
+ * If true, a U.P.C. Company Prefix expressed as a GS1 Company Prefix is permitted.
86
+ *
87
+ * @param allowGS18Prefix
88
+ * If true, a GS1-8 Prefix expressed as a GS1 Company Prefix is permitted.
89
+ *
90
+ * @param prefix
91
+ * Prefix.
92
+ *
93
+ * @param isFromIdentifier
94
+ * If true, the prefix is from an identifier and should be trimmed before its character set is validated.
95
+ *
96
+ * @param isNumericIdentifier
97
+ * If true, the prefix is from a numeric identifier and its character set will be validated by the caller.
98
+ *
99
+ * @param errorMessageParseKey
100
+ * Parse key for error message when validating GS1 Company Prefix type.
101
+ */
102
+ validate(prefixType, allowUPCCompanyPrefix, allowGS18Prefix, prefix, isFromIdentifier = false, isNumericIdentifier = false, errorMessageParseKey) {
103
+ let validation;
104
+ // Validate the prefix type and determine the prefix validation parameters.
105
+ switch (prefixType) {
106
+ case PrefixTypes.GS1CompanyPrefix:
107
+ if (!prefix.startsWith("0")) {
108
+ validation = GS1_COMPANY_PREFIX_VALIDATION;
109
+ }
110
+ else if (!prefix.startsWith("00000")) {
111
+ if (!allowUPCCompanyPrefix) {
112
+ throw new RangeError(i18nextGS1.t(errorMessageParseKey ?? "Prefix.gs1CompanyPrefixCantStartWith0"));
113
+ }
114
+ validation = UPC_COMPANY_PREFIX_AS_GS1_COMPANY_PREFIX_VALIDATION;
115
+ }
116
+ else if (!prefix.startsWith("000000")) {
117
+ if (!allowGS18Prefix) {
118
+ throw new RangeError(i18nextGS1.t(errorMessageParseKey ?? "Prefix.gs1CompanyPrefixCantStartWith00000"));
119
+ }
120
+ validation = GS1_8_PREFIX_AS_GS1_COMPANY_PREFIX_VALIDATION;
121
+ }
122
+ else {
123
+ throw new RangeError(i18nextGS1.t(errorMessageParseKey ?? "Prefix.gs1CompanyPrefixCantStartWith000000"));
124
+ }
125
+ break;
126
+ case PrefixTypes.UPCCompanyPrefix:
127
+ if (prefix.startsWith("0000")) {
128
+ throw new RangeError(i18nextGS1.t("Prefix.upcCompanyPrefixCantStartWith0000"));
129
+ }
130
+ validation = UPC_COMPANY_PREFIX_VALIDATION;
131
+ break;
132
+ case PrefixTypes.GS18Prefix:
133
+ if (prefix.startsWith("0")) {
134
+ throw new RangeError(i18nextGS1.t("Prefix.gs18PrefixCantStartWith0"));
135
+ }
136
+ validation = GS1_8_PREFIX_VALIDATION;
137
+ break;
138
+ }
139
+ // If from identifier and numeric, identifier validation will take care of character set validation.
140
+ if (!isFromIdentifier) {
141
+ NUMERIC_CREATOR.validate(prefix, validation);
142
+ }
143
+ else if (!isNumericIdentifier) {
144
+ // Validate only the minimum length, allowing at least one character for the (possibly non-numeric) reference.
145
+ NUMERIC_CREATOR.validate(prefix.substring(0, Math.min(validation.minimumLength, prefix.length - 1)), validation);
146
+ }
147
+ },
148
+ /**
149
+ * Normalize a prefix.
150
+ *
151
+ * @param prefixType
152
+ * Prefix type.
153
+ *
154
+ * @param prefix
155
+ * Prefix.
156
+ *
157
+ * @returns
158
+ * Prefix provider with normalized prefix type and prefix.
159
+ */
160
+ normalize(prefixType, prefix) {
161
+ // Validate first.
162
+ this.validate(prefixType, true, true, prefix);
163
+ let gs1CompanyPrefix;
164
+ // First step is to map the prefix to a GS1 Company Prefix.
165
+ switch (prefixType) {
166
+ case PrefixTypes.GS1CompanyPrefix:
167
+ gs1CompanyPrefix = prefix;
168
+ break;
169
+ case PrefixTypes.UPCCompanyPrefix:
170
+ gs1CompanyPrefix = `0${prefix}`;
171
+ break;
172
+ case PrefixTypes.GS18Prefix:
173
+ gs1CompanyPrefix = `00000${prefix}`;
174
+ break;
175
+ }
176
+ let normalizedPrefixType;
177
+ let normalizedPrefix;
178
+ let upcCompanyPrefix = undefined;
179
+ let gs18Prefix = undefined;
180
+ // Determine the prefix type and populate the remaining fields.
181
+ if (!gs1CompanyPrefix.startsWith("0")) {
182
+ normalizedPrefixType = PrefixTypes.GS1CompanyPrefix;
183
+ normalizedPrefix = gs1CompanyPrefix;
184
+ }
185
+ else if (!gs1CompanyPrefix.startsWith("00000")) {
186
+ normalizedPrefixType = PrefixTypes.UPCCompanyPrefix;
187
+ upcCompanyPrefix = gs1CompanyPrefix.substring(1);
188
+ normalizedPrefix = upcCompanyPrefix;
189
+ }
190
+ else {
191
+ normalizedPrefixType = PrefixTypes.GS18Prefix;
192
+ gs18Prefix = gs1CompanyPrefix.substring(5);
193
+ normalizedPrefix = gs18Prefix;
194
+ }
195
+ return {
196
+ prefixType: normalizedPrefixType,
197
+ prefix: normalizedPrefix,
198
+ gs1CompanyPrefix,
199
+ upcCompanyPrefix,
200
+ gs18Prefix
201
+ };
202
+ }
203
+ };
204
+ //# sourceMappingURL=prefix-validator.js.map