goods-exporter 0.3.19 → 0.4.2

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.
package/README.md CHANGED
@@ -13,7 +13,7 @@ export tasks with ease.
13
13
 
14
14
  ## Features
15
15
 
16
- - Export goods data to YML, CSV, and Excel formats.
16
+ - Export goods data to JSON, YML, CSV, and Excel formats.
17
17
  - Easily integrate into your JavaScript projects.
18
18
  - Compatible with Node.js version 16 and above.
19
19
  - Comprehensive TypeScript type definitions included.
@@ -21,6 +21,7 @@ export tasks with ease.
21
21
  ## Supported formats
22
22
 
23
23
  - YML (Yandex Market Language)
24
+ - JSON
24
25
  - CSV
25
26
  - Excel
26
27
  - TgShop
package/dist/bundle.d.ts CHANGED
@@ -562,10 +562,27 @@ interface Category {
562
562
  name: string;
563
563
  }
564
564
 
565
+ interface Brand {
566
+ /**
567
+ * **ID бренда**
568
+ *
569
+ * Целое число
570
+ */
571
+ id: number;
572
+ /**
573
+ * **Название бренда**
574
+ */
575
+ name: string;
576
+ /**
577
+ * **Ссылка на изображение**
578
+ */
579
+ coverURL?: string;
580
+ }
581
+
565
582
  declare abstract class FormatterAbstract {
566
583
  abstract formatterName: string;
567
584
  abstract fileExtension: Extension;
568
- abstract format(products: Product[], categories?: Category[], option?: FormatterOptions): Promise<Buffer | string>;
585
+ abstract format(products: Product[], categories?: Category[], brands?: Brand[], option?: FormatterOptions): Promise<Buffer | string>;
569
586
  }
570
587
  interface FormatterOptions {
571
588
  shopName?: string;
@@ -582,44 +599,46 @@ declare enum Extension {
582
599
  declare class CSVFormatter implements FormatterAbstract {
583
600
  formatterName: string;
584
601
  fileExtension: Extension;
585
- format(products: Product[], categories?: Category[], options?: FormatterOptions): Promise<string>;
602
+ format(products: Product[], categories?: Category[], _?: Brand[], options?: FormatterOptions): Promise<string>;
586
603
  }
587
604
 
588
605
  declare class ExcelFormatter implements FormatterAbstract {
589
606
  formatterName: string;
590
607
  fileExtension: Extension;
591
- format(products: Product[], categories?: Category[], options?: FormatterOptions): Promise<Buffer>;
608
+ format(products: Product[], categories?: Category[], _?: Brand[], options?: FormatterOptions): Promise<Buffer>;
592
609
  }
593
610
 
594
611
  declare class InsalesFormatter implements FormatterAbstract {
595
612
  formatterName: string;
596
613
  fileExtension: Extension;
597
- format(products: Product[], categories?: Category[], _?: FormatterOptions): Promise<Buffer>;
614
+ format(products: Product[], categories?: Category[], _?: Brand[], __?: FormatterOptions): Promise<Buffer>;
598
615
  }
599
616
 
600
617
  declare class JSONFormatter implements FormatterAbstract {
601
618
  formatterName: string;
602
619
  fileExtension: Extension;
603
- format(products: Product[], categories?: Category[], _?: FormatterOptions): Promise<string>;
620
+ format(products: Product[], categories?: Category[], brands?: Brand[], _?: FormatterOptions): Promise<string>;
604
621
  }
605
622
 
606
623
  declare class TgShopFormatter implements FormatterAbstract {
607
624
  formatterName: string;
608
625
  fileExtension: Extension;
609
- format(products: Product[], categories?: Category[], _?: FormatterOptions): Promise<Buffer>;
626
+ format(products: Product[], categories?: Category[], _?: Brand[], __?: FormatterOptions): Promise<Buffer>;
610
627
  }
611
628
 
612
629
  declare class TildaFormatter implements FormatterAbstract {
613
630
  formatterName: string;
614
631
  fileExtension: Extension;
615
- format(products: Product[], categories?: Category[], _?: FormatterOptions): Promise<string>;
632
+ format(products: Product[], categories?: Category[], _?: Brand[], __?: FormatterOptions): Promise<string>;
616
633
  }
617
634
 
618
635
  declare class YMLFormatter implements FormatterAbstract {
619
636
  formatterName: string;
620
637
  fileExtension: Extension;
621
638
  private readonly builder;
622
- format(products: Product[], categories?: Category[], options?: FormatterOptions): Promise<string>;
639
+ format(products: Product[], categories?: Category[], brands?: Brand[], options?: FormatterOptions): Promise<string>;
640
+ private getBrands;
641
+ private getCategories;
623
642
  private getOffers;
624
643
  }
625
644
 
@@ -643,7 +662,7 @@ declare class GoodsExporter {
643
662
  setTransformers(transformers: Transformer[]): void;
644
663
  setFormatter(formatter: FormatterAbstract): void;
645
664
  setExporter(exporter: Exporter): void;
646
- export(products: Product[], categories?: Category[], option?: FormatterOptions): Promise<Buffer>;
665
+ export(products: Product[], categories?: Category[], brands?: Brand[], option?: FormatterOptions): Promise<Buffer>;
647
666
  }
648
667
 
649
- export { type Category, Currency, type Exporter, Extension, FormatterAbstract, type FormatterOptions, Formatters, GoodsExporter, type IParam, type ISize, type Product, type Transformer, Vat };
668
+ export { type Brand, type Category, Currency, type Exporter, Extension, FormatterAbstract, type FormatterOptions, Formatters, GoodsExporter, type IParam, type ISize, type Product, type Transformer, Vat };
@@ -79,7 +79,7 @@ class CSVFormatter {
79
79
  __publicField$7(this, "formatterName", "CSV");
80
80
  __publicField$7(this, "fileExtension", Extension.CSV);
81
81
  }
82
- async format(products, categories, options) {
82
+ async format(products, categories, _, options) {
83
83
  const mappedCategories = {};
84
84
  categories?.forEach(({ id, name }) => mappedCategories[id] = name);
85
85
  const data = products.map((product) => ({
@@ -113,7 +113,7 @@ class ExcelFormatter {
113
113
  __publicField$6(this, "formatterName", "Excel");
114
114
  __publicField$6(this, "fileExtension", Extension.XLSX);
115
115
  }
116
- async format(products, categories, options) {
116
+ async format(products, categories, _, options) {
117
117
  const mappedCategories = {};
118
118
  categories?.forEach(({ id, name }) => mappedCategories[id] = name);
119
119
  const data = products.map((product) => ({
@@ -149,7 +149,7 @@ class InsalesFormatter {
149
149
  __publicField$5(this, "formatterName", "Insales");
150
150
  __publicField$5(this, "fileExtension", Extension.XLSX);
151
151
  }
152
- async format(products, categories, _) {
152
+ async format(products, categories, _, __) {
153
153
  const mappedCategories = {};
154
154
  categories?.forEach(
155
155
  (category) => mappedCategories[category.id] = category
@@ -197,6 +197,7 @@ class InsalesFormatter {
197
197
  };
198
198
  const data = products.map((product) => ({
199
199
  "\u0412\u043D\u0435\u0448\u043D\u0438\u0439 ID": product.productId,
200
+ "\u0421\u0441\u044B\u043B\u043A\u0430 \u043D\u0430 \u0442\u043E\u0432\u0430\u0440": product.url,
200
201
  \u0410\u0440\u0442\u0438\u043A\u0443\u043B: product.vendorCode,
201
202
  "\u041D\u0430\u0437\u0432\u0430\u043D\u0438\u0435 \u0442\u043E\u0432\u0430\u0440\u0430 \u0438\u043B\u0438 \u0443\u0441\u043B\u0443\u0433\u0438": product.title,
202
203
  "\u0421\u0442\u0430\u0440\u0430\u044F \u0446\u0435\u043D\u0430": product.oldPrice,
@@ -242,9 +243,10 @@ class JSONFormatter {
242
243
  __publicField$4(this, "formatterName", "JSON");
243
244
  __publicField$4(this, "fileExtension", Extension.JSON);
244
245
  }
245
- async format(products, categories, _) {
246
+ async format(products, categories, brands, _) {
246
247
  const result = {
247
248
  categories,
249
+ brands,
248
250
  products
249
251
  };
250
252
  return JSON.stringify(result);
@@ -262,7 +264,7 @@ class TgShopFormatter {
262
264
  __publicField$3(this, "formatterName", "TgShop");
263
265
  __publicField$3(this, "fileExtension", Extension.XLSX);
264
266
  }
265
- async format(products, categories, _) {
267
+ async format(products, categories, _, __) {
266
268
  const getParameter = (product, key) => product.params?.find((value) => value.key === key);
267
269
  const productsData = products.map((product) => ({
268
270
  "category id": product.categoryId,
@@ -300,7 +302,7 @@ class TildaFormatter {
300
302
  __publicField$2(this, "formatterName", "Tilda");
301
303
  __publicField$2(this, "fileExtension", Extension.CSV);
302
304
  }
303
- async format(products, categories, _) {
305
+ async format(products, categories, _, __) {
304
306
  const mappedCategories = {};
305
307
  categories?.forEach(({ id, name }) => mappedCategories[id] = name);
306
308
  const data = products.map((product) => ({
@@ -337,16 +339,7 @@ class YMLFormatter {
337
339
  cdataPropName: "__cdata"
338
340
  }));
339
341
  }
340
- async format(products, categories, options) {
341
- const mappedCategories = {
342
- category: categories?.map((cat) => ({
343
- "@_id": cat.id,
344
- "@_parentId": cat.parentId,
345
- "#text": cat.name
346
- }))
347
- };
348
- const shopName = options?.shopName ?? "ShopName";
349
- const companyName = options?.companyName ?? "CompanyName";
342
+ async format(products, categories, brands, options) {
350
343
  const offers = { offer: products.map(this.getOffers) };
351
344
  const result = {
352
345
  "?xml": {
@@ -357,15 +350,34 @@ class YMLFormatter {
357
350
  yml_catalog: {
358
351
  "@_date": (/* @__PURE__ */ new Date()).toISOString().replace(/.\d+Z/, ""),
359
352
  shop: {
360
- name: shopName,
361
- company: companyName,
362
- categories: mappedCategories,
353
+ name: options?.shopName,
354
+ company: options?.companyName,
355
+ categories: this.getCategories(categories),
356
+ brands: this.getBrands(brands),
363
357
  offers
364
358
  }
365
359
  }
366
360
  };
367
361
  return this.builder.build(result);
368
362
  }
363
+ getBrands(brands) {
364
+ return {
365
+ brand: brands?.map((brand) => ({
366
+ "@_id": brand.id,
367
+ "@_url": brand.coverURL,
368
+ "#text": brand.name
369
+ }))
370
+ };
371
+ }
372
+ getCategories(categories) {
373
+ return {
374
+ category: categories?.map((cat) => ({
375
+ "@_id": cat.id,
376
+ "@_parentId": cat.parentId,
377
+ "#text": cat.name
378
+ }))
379
+ };
380
+ }
369
381
  getOffers(product) {
370
382
  const result = {
371
383
  "@_id": product.variantId,
@@ -478,7 +490,7 @@ class GoodsExporter {
478
490
  setExporter(exporter) {
479
491
  this.exporter = exporter;
480
492
  }
481
- async export(products, categories, option) {
493
+ async export(products, categories, brands, option) {
482
494
  const copyProducts = deepcopy(products);
483
495
  const transformedProducts = await Promise.all(
484
496
  copyProducts.map(async (product) => {
@@ -491,6 +503,7 @@ class GoodsExporter {
491
503
  const data = await this.formatter.format(
492
504
  transformedProducts,
493
505
  categories,
506
+ brands,
494
507
  option
495
508
  );
496
509
  if (typeof data === "string") {
@@ -1 +1 @@
1
- {"version":3,"file":"index.cjs","sources":["../../src/util/formatter.util.ts","../../src/formatter/formater.types.ts","../../src/formatter/CSV.formatter.ts","../../src/formatter/Excel.formatter.ts","../../src/formatter/Insales.formatter.ts","../../src/formatter/JSON.formatter.ts","../../src/formatter/TgShop.formatter.ts","../../src/formatter/Tilda.formatter.ts","../../src/formatter/YML.formatter.ts","../../src/formatter/index.ts","../../src/exporter/goodsExporter.ts","../../src/types/Product.types.ts"],"sourcesContent":["import { type FormatterOptions } from \"../formatter\";\nimport { type Product } from \"../types\";\n\nconst getParams = (\n product: Product,\n option?: FormatterOptions,\n): Record<string, string> => {\n const params: Record<string, string> = {};\n\n if (option?.splitParams === false) {\n return params;\n }\n\n product.params?.forEach(\n ({ key, value }) => (params[`Param [${key}]`] = value),\n );\n return params;\n};\n\nconst getProperties = (\n product: Product,\n option?: FormatterOptions,\n): Record<string, string> => {\n const properties: Record<string, string> = {};\n\n if (option?.splitParams === false) {\n return properties;\n }\n\n product.properties?.forEach(\n ({ key, value }) => (properties[`Property [${key}]`] = value),\n );\n return properties;\n};\n\nconst getSizes = (\n product: Product,\n _?: FormatterOptions,\n): Record<string, string> => {\n const sizes: Record<string, string> = {};\n product.sizes?.forEach(\n ({ name, value }) => (sizes[`Size [${name}]`] = value),\n );\n return sizes;\n};\n\nexport const UTILS = {\n getSizes,\n getParams,\n getProperties,\n};\n","import { type Category, type Product } from \"../types\";\n\nexport abstract class FormatterAbstract {\n public abstract formatterName: string;\n public abstract fileExtension: Extension;\n\n public abstract format(\n products: Product[],\n categories?: Category[],\n option?: FormatterOptions,\n ): Promise<Buffer | string>;\n}\n\nexport interface FormatterOptions {\n shopName?: string;\n\n companyName?: string;\n\n splitParams?: boolean;\n}\n\nexport enum Extension {\n CSV = \"csv\",\n YML = \"yml\",\n XLSX = \"xlsx\",\n JSON = \"json\",\n}\n","import { json2csv } from \"json-2-csv\";\n\nimport { type Category, type Product } from \"../types\";\nimport { UTILS } from \"../util/formatter.util\";\nimport {\n Extension,\n type FormatterAbstract,\n type FormatterOptions,\n} from \"./formater.types\";\n\nexport class CSVFormatter implements FormatterAbstract {\n public formatterName = \"CSV\";\n public fileExtension = Extension.CSV;\n\n public async format(\n products: Product[],\n categories?: Category[],\n options?: FormatterOptions,\n ): Promise<string> {\n const mappedCategories: Record<number, string> = {};\n categories?.forEach(({ id, name }) => (mappedCategories[id] = name));\n\n const data = products.map((product) => ({\n ...product,\n category: mappedCategories[product.categoryId],\n images: product.images?.join(\",\"),\n videos: product.videos?.join(\",\"),\n tags: product.tags?.join(\",\"),\n codesTN: product.codesTN?.join(\", \"),\n params: product.params\n ?.map(({ key, value }) => `${key}=${value}`)\n .join(\",\"),\n ...UTILS.getParams(product, options),\n ...UTILS.getProperties(product, options),\n ...UTILS.getSizes(product, options),\n sizes: undefined,\n keywords: product.keywords?.join(\",\"),\n relatedProducts: product.relatedProducts?.join(\",\"),\n }));\n return json2csv(data, { emptyFieldValue: \"\" });\n }\n}\n","import xlsx from \"xlsx\";\n\nimport { type Category, type Product } from \"../types\";\nimport { UTILS } from \"../util/formatter.util\";\nimport {\n Extension,\n type FormatterAbstract,\n type FormatterOptions,\n} from \"./formater.types\";\nconst { writeXLSX, utils } = xlsx;\n\nexport class ExcelFormatter implements FormatterAbstract {\n public formatterName = \"Excel\";\n public fileExtension = Extension.XLSX;\n\n public async format(\n products: Product[],\n categories?: Category[],\n options?: FormatterOptions,\n ): Promise<Buffer> {\n const mappedCategories: Record<number, string> = {};\n categories?.forEach(({ id, name }) => (mappedCategories[id] = name));\n\n const data = products.map((product) => ({\n ...product,\n category: mappedCategories[product.categoryId],\n images: product.images?.join(\",\"),\n videos: product.videos?.join(\",\"),\n tags: product.tags?.join(\",\"),\n keywords: product.keywords?.join(\",\"),\n relatedProducts: product.relatedProducts?.join(\",\"),\n codesTN: product.codesTN?.join(\", \"),\n params: product.params\n ?.map(({ key, value }) => `${key}=${value}`)\n .join(\",\"),\n sizes: undefined,\n ...UTILS.getParams(product, options),\n ...UTILS.getProperties(product, options),\n ...UTILS.getSizes(product, options),\n }));\n const workBook = utils.book_new();\n const productsWorkSheet = utils.json_to_sheet(data);\n\n utils.book_append_sheet(workBook, productsWorkSheet, \"products\");\n return writeXLSX(workBook, { type: \"buffer\" });\n }\n}\n","import xlsx from \"xlsx\";\n\nimport { type Category, type Product } from \"../types\";\nimport {\n Extension,\n type FormatterAbstract,\n type FormatterOptions,\n} from \"./formater.types\";\n\nexport class InsalesFormatter implements FormatterAbstract {\n public formatterName = \"Insales\";\n public fileExtension = Extension.XLSX;\n\n public async format(\n products: Product[],\n categories?: Category[],\n _?: FormatterOptions,\n ): Promise<Buffer> {\n const mappedCategories: Record<number, Category> = {};\n categories?.forEach(\n (category) => (mappedCategories[category.id] = category),\n );\n\n const getParams = (product: Product): Record<string, string> => {\n const properties: Record<string, string> = {};\n\n product.params?.forEach(\n (p) => (properties[`Свойство: ${p.key}`] = p.value),\n );\n\n return properties;\n };\n const getProperties = (product: Product): Record<string, string> => {\n const properties: Record<string, string> = {};\n\n product.properties?.forEach(\n (p) => (properties[`Параметр: ${p.key}`] = p.value),\n );\n\n return properties;\n };\n\n const getSizes = (product: Product): Record<string, string> => {\n const sizes: Record<string, string> = {};\n\n product.sizes?.forEach(\n ({ name, value }) => (sizes[`Размеры [${name}]:`] = value),\n );\n\n return sizes;\n };\n\n const getCategories = (product: Product) => {\n const categories: Record<string, string> = {};\n const categoryList = new Array<string>();\n\n function addCategory(categoryId: number | undefined) {\n if (categoryId === undefined) return;\n\n const category = mappedCategories[categoryId];\n if (category) {\n categoryList.push(category.name);\n addCategory(category.parentId);\n }\n }\n\n addCategory(product.categoryId);\n\n categoryList.forEach((name, i) => {\n const index = categoryList.length - 1 - i;\n const key = index === 0 ? \"Корневая\" : `Подкатегория ${index}`;\n categories[key] = name;\n });\n\n return categories;\n };\n\n const data = products.map((product) => ({\n \"Внешний ID\": product.productId,\n Артикул: product.vendorCode,\n \"Название товара или услуги\": product.title,\n \"Старая цена\": product.oldPrice,\n \"Цена продажи\": product.price,\n \"Цена закупки\": product.purchasePrice,\n ...getCategories(product),\n Остаток: product.count,\n \"Штрих-код\": product.barcode,\n \"Краткое описание\": undefined,\n \"Полное описание\": product.description,\n \"Габариты варианта\": product.dimensions,\n Вес: product.weight,\n \"Размещение на сайте\": product.available,\n НДС: product.vat.toString(),\n \"Валюта склада\": product.currency.toString(),\n \"Изображения варианта\": product.images?.join(\" \"),\n Изображения: product.images?.join(\" \"),\n \"Ссылка на видео\": product.videos ? product.videos[0] : undefined,\n ...getParams(product),\n ...getProperties(product),\n \"Параметр: Бренд\": product.vendor,\n \"Параметр: Коллекция\": product.seriesName,\n \"Параметр: Пол\": product.gender,\n \"Параметр: Дата выхода\": product.saleDate,\n ...getSizes(product),\n \"Связанные товары\": product.relatedProducts?.join(\",\"),\n }));\n const workBook = xlsx.utils.book_new();\n const productsWorkSheet = xlsx.utils.json_to_sheet(data);\n\n xlsx.utils.book_append_sheet(workBook, productsWorkSheet, \"products\");\n\n return xlsx.write(workBook, { bookType: \"xlsx\", type: \"buffer\" });\n }\n}\n","import { type Product, type Category } from \"../types\";\nimport {\n Extension,\n type FormatterAbstract,\n type FormatterOptions,\n} from \"./formater.types\";\n\nexport class JSONFormatter implements FormatterAbstract {\n public formatterName = \"JSON\";\n public fileExtension = Extension.JSON;\n\n public async format(\n products: Product[],\n categories?: Category[],\n _?: FormatterOptions,\n ): Promise<string> {\n const result = {\n categories,\n products,\n };\n\n return JSON.stringify(result);\n }\n}\n","import xlsx from \"xlsx\";\n\nimport { type Category, type IParam, type Product } from \"../types\";\nimport {\n Extension,\n type FormatterAbstract,\n type FormatterOptions,\n} from \"./formater.types\";\n\nexport class TgShopFormatter implements FormatterAbstract {\n public formatterName = \"TgShop\";\n public fileExtension = Extension.XLSX;\n\n public async format(\n products: Product[],\n categories?: Category[],\n _?: FormatterOptions,\n ): Promise<Buffer> {\n const getParameter = (product: Product, key: string): IParam | undefined =>\n product.params?.find((value) => value.key === key);\n const productsData = products.map((product) => ({\n \"category id\": product.categoryId,\n \"group id\": product.parentId,\n \"id product\": product.variantId,\n \"name product\": product.title,\n price: product.price,\n picture: product.images?.join(\", \"),\n vendorCode: product.vendorCode,\n oldprice: product.oldPrice,\n description: product.description,\n shortDescription: product.description,\n quantityInStock: product.count,\n color: getParameter(product, \"color\")?.value,\n size: getParameter(product, \"size\")?.value,\n priority: undefined,\n }));\n\n const workBook = xlsx.utils.book_new();\n const productsWorkSheet = xlsx.utils.json_to_sheet(productsData);\n const categoriesWorkSheet = xlsx.utils.json_to_sheet(categories ?? []);\n\n xlsx.utils.book_append_sheet(workBook, categoriesWorkSheet, \"categories\");\n xlsx.utils.book_append_sheet(workBook, productsWorkSheet, \"offers\");\n\n return xlsx.write(workBook, { bookType: \"xlsx\", type: \"buffer\" });\n }\n}\n","import { json2csv } from \"json-2-csv\";\n\nimport { type Category, type Product } from \"../types\";\nimport {\n Extension,\n type FormatterAbstract,\n type FormatterOptions,\n} from \"./formater.types\";\n\nexport class TildaFormatter implements FormatterAbstract {\n public formatterName = \"Tilda\";\n public fileExtension = Extension.CSV;\n\n public async format(\n products: Product[],\n categories?: Category[],\n _?: FormatterOptions,\n ): Promise<string> {\n const mappedCategories: Record<number, string> = {};\n categories?.forEach(({ id, name }) => (mappedCategories[id] = name));\n\n const data = products.map((product) => ({\n SKU: product.vendorCode,\n Brand: product.vendor,\n Category: mappedCategories[product.categoryId],\n Title: product.title,\n Text: product.description,\n Photo: product.images?.join(\";\"),\n Price: product.price,\n \"Price Old\": product.oldPrice,\n Quantity: product.count,\n Editions: product.params\n ?.map(({ key, value }) => `${key}:${value}`)\n .join(\";\"),\n \"External ID\": product.variantId,\n \"Parent UID\": product.parentId,\n }));\n\n return json2csv(data, { emptyFieldValue: \"\", delimiter: { field: \";\" } });\n }\n}\n","import { XMLBuilder } from \"fast-xml-parser\";\n\nimport { type Product, type Category } from \"../types\";\nimport {\n Extension,\n type FormatterAbstract,\n type FormatterOptions,\n} from \"./formater.types\";\n\nexport class YMLFormatter implements FormatterAbstract {\n public formatterName = \"YMl\";\n public fileExtension = Extension.YML;\n private readonly builder = new XMLBuilder({\n ignoreAttributes: false,\n format: true,\n cdataPropName: \"__cdata\",\n });\n\n public async format(\n products: Product[],\n categories?: Category[],\n options?: FormatterOptions,\n ): Promise<string> {\n const mappedCategories = {\n category: categories?.map((cat) => ({\n \"@_id\": cat.id,\n \"@_parentId\": cat.parentId,\n \"#text\": cat.name,\n })),\n };\n const shopName = options?.shopName ?? \"ShopName\";\n const companyName = options?.companyName ?? \"CompanyName\";\n const offers = { offer: products.map(this.getOffers) };\n const result = {\n \"?xml\": {\n \"@_version\": \"1.0\",\n \"@_encoding\": \"UTF-8\",\n \"@_standalone\": \"yes\",\n },\n yml_catalog: {\n \"@_date\": new Date().toISOString().replace(/.\\d+Z/, \"\"),\n shop: {\n name: shopName,\n company: companyName,\n categories: mappedCategories,\n offers,\n },\n },\n };\n\n return this.builder.build(result);\n }\n\n private getOffers(product: Product): any {\n const result = {\n \"@_id\": product.variantId,\n name: product.title,\n price: product.price,\n oldprice: product.oldPrice,\n purchase_price: product.purchasePrice,\n additional_expenses: product.additionalExpenses,\n cofinance_price: product.cofinancePrice,\n currencyId: product.currency,\n categoryId: product.categoryId,\n vendor: product.vendor,\n vendorCode: product.vendorCode,\n picture: product.images,\n video: product.videos,\n available: product.available,\n series: product.seriesName,\n \"min-quantity\": product.minQuantity,\n \"step-quantity\": product.stepQuantity,\n size: product.sizes?.map((size) => ({\n \"#text\": size.value,\n \"@_name\": size.name,\n \"@_delimiter\": size.delimiter,\n })),\n keyword: product.keywords,\n saleDate: product.saleDate,\n property: product.properties?.map((property) => ({\n \"#text\": property.value,\n \"@_name\": property.key,\n })),\n param: product.params?.map((param) => ({\n \"#text\": param.value,\n \"@_name\": param.key,\n })),\n description: {\n __cdata: product.description,\n },\n country_of_origin: product.countryOfOrigin,\n barcode: product.barcode,\n vat: product.vat,\n count: product.count,\n \"set-ids\": product.tags?.join(\", \"),\n adult: product.adult,\n downloadable: product.downloadable,\n \"period-of-validity-days\": product.validityPeriod,\n \"comment-validity-days\": product.validityComment,\n \"service-life-days\": product.serviceLifePeriod,\n \"comment-life-days\": product.serviceLifeComment,\n \"warranty-days\": product.warrantyPeriod,\n \"comment-warranty\": product.warrantyComment,\n manufacturer_warranty: product.manufacturerWarranty,\n certificate: product.certificate,\n url: product.url,\n weight: product.weight,\n dimensions: product.dimensions,\n boxCount: product.boxCount,\n disabled: product.disabled,\n age: product.age != null && {\n \"@_unit\": product.age.unit,\n \"#text\": product.age.value,\n },\n \"tn-ved-codes\": product.codesTN?.length != null && {\n \"tn-ved-code\": product.codesTN,\n },\n relatedProduct: product.relatedProducts,\n gender: product.gender,\n };\n if (product.parentId !== undefined) {\n return {\n ...result,\n \"@_group_id\": product.parentId,\n };\n }\n return result;\n }\n}\n","import { CSVFormatter } from \"./CSV.formatter\";\nimport { ExcelFormatter } from \"./Excel.formatter\";\nimport { InsalesFormatter } from \"./Insales.formatter\";\nimport { JSONFormatter } from \"./JSON.formatter\";\nimport { TgShopFormatter } from \"./TgShop.formatter\";\nimport { TildaFormatter } from \"./Tilda.formatter\";\nimport { YMLFormatter } from \"./YML.formatter\";\n\nexport * from \"./formater.types\";\n\nexport const Formatters = {\n TildaFormatter,\n CSVFormatter,\n InsalesFormatter,\n YMLFormatter,\n TgShopFormatter,\n ExcelFormatter,\n JSONFormatter,\n};\n","import deepcopy from \"deepcopy\";\n\nimport {\n type FormatterAbstract,\n type FormatterOptions,\n Formatters,\n} from \"../formatter\";\nimport { type Category, type Product } from \"../types\";\nimport { type Exporter, type Transformer } from \"./exporter.types\";\n\nimport * as fs from \"fs\";\n\nexport class GoodsExporter {\n private formatter: FormatterAbstract = new Formatters.YMLFormatter();\n private exporter: Exporter = (data: Buffer) => {\n const filename = `${this.formatter.formatterName}.output.${this.formatter.fileExtension}`;\n fs.writeFileSync(filename, data);\n return data;\n };\n\n private transformers = new Array<Transformer>();\n\n public setTransformers(transformers: Transformer[]): void {\n this.transformers = transformers;\n }\n\n public setFormatter(formatter: FormatterAbstract): void {\n this.formatter = formatter;\n }\n\n public setExporter(exporter: Exporter): void {\n this.exporter = exporter;\n }\n\n async export(\n products: Product[],\n categories?: Category[],\n option?: FormatterOptions,\n ): Promise<Buffer> {\n const copyProducts = deepcopy(products);\n const transformedProducts = await Promise.all(\n copyProducts.map(async (product) => {\n let transformedProduct: Product = product;\n for (const transformer of this.transformers)\n transformedProduct = await transformer(transformedProduct);\n return transformedProduct;\n }),\n );\n const data = await this.formatter.format(\n transformedProducts,\n categories,\n option,\n );\n\n if (typeof data === \"string\") {\n return await this.exporter(Buffer.from(data, \"utf-8\"));\n }\n return await this.exporter(data);\n }\n}\n","export interface Product {\n /**\n * **ID товара**\n *\n * Любая последовательность длиной до 80 знаков. В нее могут входить английские и русские (кроме ё) буквы, цифры и символы . , / \\ ( ) [ ] - = _\n *\n * Пример: belaya-kofta-12345\n */\n productId: number;\n /**\n * **Родительскй SKU**\n *\n * Любая последовательность длиной до 80 знаков. В нее могут входить английские и русские (кроме ё) буквы, цифры и символы . , / \\ ( ) [ ] - = _\n *\n * Пример: belaya-kofta-12345\n */\n parentId?: number;\n /**\n * **SKU**\n *\n * Любая последовательность длиной до 80 знаков. В нее могут входить английские и русские (кроме ё) буквы, цифры и символы . , / \\ ( ) [ ] - = _\n *\n * Пример: belaya-kofta-12345\n */\n variantId: number;\n /**\n * **Название**\n *\n * Составляйте название по схеме: тип + бренд или производитель + модель + особенности, если есть (например, цвет, размер или вес) и количество в упаковке.\n *\n * Не включайте в название условия продажи (например, «скидка», «бесплатная доставка» и т. д.), эмоциональные характеристики («хит», «супер» и т. д.). Не пишите слова большими буквами — кроме устоявшихся названий брендов и моделей.\n *\n * Оптимальная длина — 50–60 символов, максимальная — 150.\n *\n * Составлять хорошие названия помогут [рекомендации](https://yandex.ru/support/marketplace/assortment/fields/title.html).\n *\n * Пример: Ударная дрель Makita HP1630, 710 Вт\n */\n title: string;\n /**\n * **Описание**\n *\n * Подробное описание товара: например, его преимущества и особенности.\n *\n * Не давайте в описании инструкций по установке и сборке. Не используйте слова «скидка», «распродажа», «дешевый», «подарок» (кроме подарочных категорий), «бесплатно», «акция», «специальная цена», «новинка», «new», «аналог», «заказ», «хит». Не указывайте никакой контактной информации и не давайте ссылок.\n *\n * Можно использовать теги:\n *\n ** &lt;h&gt;, &lt;h1&gt;, &lt;h2&gt; и так далее — для заголовков;\n ** &lt;br&gt; и &lt;p&gt; — для переноса строки;\n ** &lt;ol&gt; — для нумерованного списка;\n ** &lt;ul&gt; — для маркированного списка;\n ** &lt;li&gt; — для создания элементов списка (должен находиться внутри &lt;ol&gt; или &lt;ul&gt;);\n ** &lt;div&gt; — поддерживается, но не влияет на отображение текста.\n * Оптимальная длина — 400–600 символов, максимальная — 6000.\n *\n * Составить хорошее описание помогут рекомендации.\n *\n * Пример: В комплекте с детским микроскопом есть все, что нужно вашему ребенку для изучения микромира\n */\n description: string;\n /**\n * **Бренд**\n *\n * Название бренда или производителя.\n *\n * Записывайте название так, как его пишет сам бренд.\n *\n * Пример: LEVENHUK\n */\n vendor?: string;\n /**\n * **Артикул производителя**\n *\n * Код товара, который ему присвоил производитель.\n *\n * Если артикулов несколько, укажите их через запятую.\n *\n * Пример: VNDR-0005A, VNDR-0005B\n */\n vendorCode?: string;\n /**\n * **Дата выхода**\n *\n * Пример: 01.01.2000\n */\n saleDate?: string;\n /**\n * **Категория в магазине**\n *\n * Категория, к которой вы относите товар. Она помогает точнее определить для товара категорию на Маркете.\n *\n * Указывайте конкретные категории — например, набор ножей лучше отнести к категории Столовые приборы, а не просто Посуда.\n *\n * Выбирайте категории, которые описывают товар, а не абстрактный признак — например, лучше указать Духи, а не Подарки.\n *\n * Содержит номер категории, а не ее название.\n */\n categoryId: number;\n /**\n * **Страна производства**\n *\n * Страна, где был произведен товар.\n *\n * Записывайте названия стран так, как они записаны в [списке](https://yastatic.net/s3/doc-binary/src/support/market/ru/countries.xlsx).\n *\n * Пример: Россия\n */\n countryOfOrigin?: string;\n /**\n * **Изображение**\n *\n * До двадцати изображений, которые показываются на карточке товара.\n *\n * Принимаются jpg- или png-изображения товара, соответствующие [требованиям](https://yandex.ru/support/marketplace/assortment/fields/images.html).\n *\n * В кабинете изображения добавляются в виде файлов. В Excel-файле — в виде ссылок через запятую. Первое фото становится основным.\n *\n * Чтобы изменить изображение, выложите новое по новой ссылке, иначе картинка не обновится.\n */\n images?: string[];\n /**\n * **Видео**\n *\n * Видеоиллюстрации для карточки товара.\n *\n * Видео должно соответствовать [требованиям](https://yandex.ru/support/marketplace/assortment/fields/video.html).\n *\n * Можно добавить не больше 6 видео.\n *\n * В кабинете можно загрузить видеофайлы. В Excel-шаблоне укажите ссылки на файлы.\n */\n videos?: string[];\n /**\n * **Базовая цена**\n *\n * Цена указывается в рублях. Число должно быть целым.\n *\n * Пример:\n *\n * 240\n */\n price: number;\n /**\n * **Цена до скидки**\n *\n * Цена указывается в рублях. Число должно быть целым.\n *\n * Вы можете указать цену со скидкой от 5 до 75 %.\n *\n * Пример:\n *\n * 250\n */\n oldPrice?: number;\n /**\n * **Себестоимость**\n *\n * Цена указывается в рублях. Число должно быть целым.\n *\n * Пример:\n *\n * 200\n */\n purchasePrice?: number;\n /**\n * **Дополнительные расходы**\n *\n * Дополнительные расходы на товар. Например, на доставку или упаковку.\n *\n * После заполнения этого поля в калькуляторе и на странице управления ценами рассчитается потенциальная маржинальность товара.\n *\n * Цена указывается в рублях. Число должно быть целым.\n *\n * Пример:\n *\n * 75\n */\n additionalExpenses?: number;\n /**\n * **Порог для скидок с Маркетом**\n *\n * Цена указывается в рублях. Число должно быть целым.\n *\n * Пример:\n *\n * 300\n */\n cofinancePrice?: number;\n /**\n * **Валюта (DBS)**\n *\n * Валюта, в которой указана цена товара. Покупателям Маркет показывает цену в рублях, пересчитывая ее по курсу Центробанка.\n *\n * Поле используется, если для кабинета еще не включена работа с базовыми ценами.\n *\n * Поддерживаются российские и белорусские рубли, евро, доллары, украинские гривны и казахстанские тенге.\n *\n * В кабинете валюту можно просто выбрать из списка. В Excel-файле указывается код валюты: RUR, BYN, EUR, USD, UAN, KZT.\n */\n currency: Currency;\n /**\n * **Ссылка на страницу товара**\n *\n * Адрес страницы на вашем сайте с фотографиями и описанием товара.\n *\n * Максимальная длина URL — 512 символов. Записывайте его согласно стандарту RFC 3986.\n *\n * Пример: http://best.seller.ru/product_page.asp?pid=12346\n */\n url?: string;\n /**\n * **Убрать из продажи**\n *\n * Поле позволяет приостановить продажу товара.\n *\n * Укажите значение true, если нужно приостановить продажу.\n */\n disabled?: boolean;\n /**\n * **Доступное количество товара**\n *\n * Общее количество товара, доступное для продажи\n *\n * Укажите 0, если товара нет в наличии.\n *\n * Пример: 7\n */\n count?: number;\n /**\n * **Товар в наличии (DBS)**\n *\n * Поле указывает, есть ли товар в наличии.\n */\n available?: boolean;\n /**\n * **Минимальное количество товара**\n *\n * Если значение задано, покупатель не сможет заказать меньше единиц товара. Ограничение не работает, когда товара на складе осталось меньше этого количества — тогда покупатель сможет сделать заказ на остаток.\n *\n * Целое число.\n */\n minQuantity?: number;\n /**\n * **Квант продажи**\n *\n * Если значение задано, покупатель сможет добавить к заказу только кратное количество товара. Ограничение не работает, когда на складе осталось меньше этого количества — тогда покупатель сможет сделать заказ на остаток.\n *\n * Целое число.\n */\n stepQuantity?: number;\n /**\n * **Штрихкод**\n *\n * Указывайте в виде последовательности символов. Подойдут коды EAN-13, EAN-8, UPC-A, UPC-E или Code 128.\n *\n * Для книг указывайте ISBN.\n *\n * Для товаров [определенных категорий и торговых марок](https://yastatic.net/s3/doc-binary/src/support/market/ru/yandex-market-list-for-gtin.xlsx) штрихкод должен быть действительным кодом GTIN. Обратите внимание: внутренние штрихкоды, начинающиеся на 2 или 02, и коды формата Code 128 не являются GTIN.\n *\n * Если штрихкодов несколько, напишите все через запятую.\n *\n * Пример: 46012300000000\n */\n barcode?: string;\n /**\n * **Код ТН ВЭД**\n *\n * Для некоторых категорий товаров код ТН ВЭД обязателен. Если это касается ваших товаров, вы получите уведомление в каталоге.\n *\n * 10 или 14 цифр без пробелов.\n *\n * Пример: 8517610008\n */\n codesTN?: string[];\n /**\n * **С какого возраста пользоваться**\n *\n * Если товар не предназначен для детей младше определенного возраста, укажите это.\n *\n * Возрастные ограничения можно задавать в годах (с нуля, с 6, 12, 16 или 18) или в месяцах (любое число от 0 до 12).\n */\n age?: { unit: \"year\" | \"month\"; value: number };\n /**\n * **Вес с упаковкой**\n *\n * Вес товара с упаковкой.\n *\n * Единица измерения — килограммы. Можно дроби: разделитель — точка или запятая, не больше трех цифр после него.\n *\n * Пример: 3.1\n */\n weight?: number;\n /**\n * **Габариты с упаковкой**\n *\n * Длина, ширина, высота в упаковке.\n *\n * Единица измерения — сантиметры. Можно дроби: разделитель — точка или запятая, не больше трех цифр после него.\n *\n * Пример: 20.1/20.551/22.5\n */\n dimensions?: string;\n /**\n * **Товар занимает больше одного места**\n *\n * Если товар занимает одно место (представляет собой одну коробку, упаковку и так далее), оставьте поле пустым. Если товар занимает несколько мест — укажите их количество. Например, кондиционер занимает два места — внешний и внутренний блоки в двух коробках.\n *\n * Укажите количество мест.\n *\n * Пример: 2\n */\n boxCount?: number;\n /**\n * **Ставка НДС**\n *\n * Значение ставки НДС для товара.\n *\n * Выберите одно из значений:\n *\n ** НДС не облагается — 6 или NO_VAT\n *\n ** 0 % — 5 или VAT_0\n *\n ** 10 % — 2 или VAT_10\n *\n ** 20 % — 7 или VAT_20\n *\n * Если не заполнено, Маркет устанавливает ставку, соответствующую схеме налогообложения.\n *\n * Пример: VAT_20\n */\n vat: Vat;\n /**\n * **Характеристики, которые есть только у товаров конкретной категории**\n *\n * Кроме общих свойств, у товара есть характеристики, присущие конкретной категории, к которой он относится. Например, у велосипеда есть размер рамы, а детское пюре бывает овощное, мясное или фруктовое.\n */\n params?: IParam[];\n /**\n * **Свойства товара**\n *\n * *не YML поле\n */\n properties?: IParam[];\n /**\n * **Теги**\n *\n * Придумайте любое название — его можно будет изменить после.\n *\n * Максимальная длина тега — 20 символов.\n *\n * У одного товара — максимум 10 тегов.\n *\n * Всего можно создать не больше 50 разных тегов.\n *\n * Пример: apple, до 500 рублей\n */\n tags?: string[];\n /**\n * **Товар для взрослых**\n *\n * Параметр включает для товара пометку 18+. Устанавливайте ее только для товаров, которые относятся к удовлетворению сексуальных потребностей.\n */\n adult?: boolean;\n /**\n * **Цифровой товар**\n *\n * Параметр, устанавливаемый для цифровых товаров, которые просто скачиваются.\n */\n downloadable?: boolean;\n /**\n * **Срок годности**\n *\n * Период с момента изготовления, по прошествии которого товар становится непригоден.\n *\n * Указывайте срок, указанный на банке или упаковке. Текущая дата, дата поставки или дата отгрузки значения не имеет.\n *\n * Срок можно указывать в годах, месяцах, днях, неделях и часах.\n *\n * Обязательно указывайте срок, если он есть.\n *\n * Продолжительность указывается согласно ISO 8601, то есть в виде строчки, начинающейся буквой P:\n *\n ** P1Y — 1 год;\n ** P1Y6M — 1 год и 6 месяцев;\n ** P15D — 15 дней.\n */\n validityPeriod?: string;\n /**\n * **Комментарий к сроку годности**\n *\n * Поле предназначено для описаний условий хранения.\n *\n * Не длиннее 250 знаков и без спецсимволов.\n *\n * Пример: Хранить в сухом помещении\n */\n validityComment?: string;\n /**\n * **Срок службы**\n *\n * В течение срока службы товар должен исправно выполнять свою функцию.\n *\n * Обязательно указывайте срок, если он есть.\n *\n * Срок можно указывать в годах, месяцах и днях.\n * Продолжительность указывается согласно ISO 8601, то есть в виде строчки, начинающейся буквой P:\n *\n ** P1Y — 1 год;\n ** P1Y2M — 1 год и 2 месяца;\n ** P15D — 15 дней;\n ** P2Y10D — 2 года, 10 дней;\n ** P2Y6M10D — 2 года, 6 месяцев и 10 дней.\n */\n serviceLifePeriod?: string;\n /**\n * **Комментарий к сроку службы**\n *\n * Поле предназначено для описаний условий использования.\n *\n * Не длиннее 250 знаков и без спецсимволов.\n *\n * Пример: Использовать при температуре не ниже −10 градусов\n */\n serviceLifeComment?: string;\n /**\n * **Гарантийный срок**\n *\n * В течение какого времени можно бесплатно заменить или починить товар.\n *\n * Срок можно указывать в годах, месяцах или днях.\n *\n * Продолжительность указывается согласно ISO 8601, то есть в виде строчки, начинающейся буквой P:\n *\n ** P1Y — 1 год;\n ** P1Y2M — 1 год и 2 месяца;\n ** P15D — 15 дней;\n ** P2Y10D — 2 года, 10 дней;\n ** P2Y6M10D — 2 года, 6 месяцев и 10 дней.\n */\n warrantyPeriod?: string;\n /**\n * **Комментарий к гарантийному сроку**\n *\n * Поле предназначено для описания особенностей гарантийных условий.\n *\n * Указывайте только то, что относится к гарантии изготовителя.\n *\n * Не длиннее 250 знаков и без спецсимволов.\n *\n * Пример: Гарантия на аккумулятор — 6 месяцев\n */\n warrantyComment?: string;\n /**\n * **Официальная гарантия производителя**\n */\n manufacturerWarranty?: boolean;\n /**\n * **Номер документа**\n *\n * Номер документа на товар: сертификата, декларации соответствия и т. п.\n *\n * Прежде чем указывать номер документа, загрузите скан документа через кабинет.\n *\n * Укажите номер документа.\n *\n * Пример: 6241421\n */\n certificate?: string;\n /**\n * **Ключевые слова**\n *\n * Пример: Кроссовки, высокая подошва\n */\n keywords?: string[];\n /**\n * **Размерная сетка**\n */\n sizes?: ISize[];\n /**\n * **Связанные товары**\n *\n * Указываются id товаров\n *\n * Пример: 1234\n */\n relatedProducts?: number[];\n /**\n * **Название коллекции, ряда или серии товара**\n *\n * Пример: Jordan 4\n */\n seriesName?: string;\n /**\n * **Пол или название группы потребителей**\n *\n * Пример: Дети, Женское, Унисекс\n */\n gender?: string;\n}\n\nexport enum Vat {\n NO_VAT = \"NO_VAT\",\n VAT_0 = \"VAT_0\",\n VAT_10 = \"VAT_10\",\n VAT_20 = \"VAT_20\",\n}\n\nexport enum Currency {\n RUR = \"RUR\",\n BYN = \"BYN\",\n EUR = \"EUR\",\n USD = \"USD\",\n UAN = \"UAN\",\n KZT = \"KZT\",\n}\n\nexport interface IParam {\n /**\n * **Название характеристики**\n */\n key: string;\n /**\n * **Значение**\n */\n value: string;\n}\n\nexport interface ISize {\n /**\n * **Название единицы измерения**\n */\n name: string;\n /**\n * **Разделитель**\n */\n delimiter: string;\n /**\n * **Значения размерного ряда**\n *\n * Размеры указываются через разделитель\n */\n value: string;\n}\n"],"names":["Extension","__publicField","json2csv","categories","XMLBuilder","fs","Vat","Currency"],"mappings":"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"}
1
+ {"version":3,"file":"index.cjs","sources":["../../src/util/formatter.util.ts","../../src/formatter/formater.types.ts","../../src/formatter/CSV.formatter.ts","../../src/formatter/Excel.formatter.ts","../../src/formatter/Insales.formatter.ts","../../src/formatter/JSON.formatter.ts","../../src/formatter/TgShop.formatter.ts","../../src/formatter/Tilda.formatter.ts","../../src/formatter/YML.formatter.ts","../../src/formatter/index.ts","../../src/exporter/goodsExporter.ts","../../src/types/Product.types.ts"],"sourcesContent":["import { type FormatterOptions } from \"../formatter\";\nimport { type Product } from \"../types\";\n\nconst getParams = (\n product: Product,\n option?: FormatterOptions,\n): Record<string, string> => {\n const params: Record<string, string> = {};\n\n if (option?.splitParams === false) {\n return params;\n }\n\n product.params?.forEach(\n ({ key, value }) => (params[`Param [${key}]`] = value),\n );\n return params;\n};\n\nconst getProperties = (\n product: Product,\n option?: FormatterOptions,\n): Record<string, string> => {\n const properties: Record<string, string> = {};\n\n if (option?.splitParams === false) {\n return properties;\n }\n\n product.properties?.forEach(\n ({ key, value }) => (properties[`Property [${key}]`] = value),\n );\n return properties;\n};\n\nconst getSizes = (\n product: Product,\n _?: FormatterOptions,\n): Record<string, string> => {\n const sizes: Record<string, string> = {};\n product.sizes?.forEach(\n ({ name, value }) => (sizes[`Size [${name}]`] = value),\n );\n return sizes;\n};\n\nexport const UTILS = {\n getSizes,\n getParams,\n getProperties,\n};\n","import { type Brand, type Category, type Product } from \"../types\";\n\nexport abstract class FormatterAbstract {\n public abstract formatterName: string;\n public abstract fileExtension: Extension;\n\n public abstract format(\n products: Product[],\n categories?: Category[],\n brands?: Brand[],\n option?: FormatterOptions,\n ): Promise<Buffer | string>;\n}\n\nexport interface FormatterOptions {\n shopName?: string;\n\n companyName?: string;\n\n splitParams?: boolean;\n}\n\nexport enum Extension {\n CSV = \"csv\",\n YML = \"yml\",\n XLSX = \"xlsx\",\n JSON = \"json\",\n}\n","import { json2csv } from \"json-2-csv\";\n\nimport { type Brand, type Category, type Product } from \"../types\";\nimport { UTILS } from \"../util/formatter.util\";\nimport {\n Extension,\n type FormatterAbstract,\n type FormatterOptions,\n} from \"./formater.types\";\n\nexport class CSVFormatter implements FormatterAbstract {\n public formatterName = \"CSV\";\n public fileExtension = Extension.CSV;\n\n public async format(\n products: Product[],\n categories?: Category[],\n _?: Brand[],\n options?: FormatterOptions,\n ): Promise<string> {\n const mappedCategories: Record<number, string> = {};\n categories?.forEach(({ id, name }) => (mappedCategories[id] = name));\n\n const data = products.map((product) => ({\n ...product,\n category: mappedCategories[product.categoryId],\n images: product.images?.join(\",\"),\n videos: product.videos?.join(\",\"),\n tags: product.tags?.join(\",\"),\n codesTN: product.codesTN?.join(\", \"),\n params: product.params\n ?.map(({ key, value }) => `${key}=${value}`)\n .join(\",\"),\n ...UTILS.getParams(product, options),\n ...UTILS.getProperties(product, options),\n ...UTILS.getSizes(product, options),\n sizes: undefined,\n keywords: product.keywords?.join(\",\"),\n relatedProducts: product.relatedProducts?.join(\",\"),\n }));\n return json2csv(data, { emptyFieldValue: \"\" });\n }\n}\n","import xlsx from \"xlsx\";\n\nimport { type Brand, type Category, type Product } from \"../types\";\nimport { UTILS } from \"../util/formatter.util\";\nimport {\n Extension,\n type FormatterAbstract,\n type FormatterOptions,\n} from \"./formater.types\";\nconst { writeXLSX, utils } = xlsx;\n\nexport class ExcelFormatter implements FormatterAbstract {\n public formatterName = \"Excel\";\n public fileExtension = Extension.XLSX;\n\n public async format(\n products: Product[],\n categories?: Category[],\n _?: Brand[],\n options?: FormatterOptions,\n ): Promise<Buffer> {\n const mappedCategories: Record<number, string> = {};\n categories?.forEach(({ id, name }) => (mappedCategories[id] = name));\n\n const data = products.map((product) => ({\n ...product,\n category: mappedCategories[product.categoryId],\n images: product.images?.join(\",\"),\n videos: product.videos?.join(\",\"),\n tags: product.tags?.join(\",\"),\n keywords: product.keywords?.join(\",\"),\n relatedProducts: product.relatedProducts?.join(\",\"),\n codesTN: product.codesTN?.join(\", \"),\n params: product.params\n ?.map(({ key, value }) => `${key}=${value}`)\n .join(\",\"),\n sizes: undefined,\n ...UTILS.getParams(product, options),\n ...UTILS.getProperties(product, options),\n ...UTILS.getSizes(product, options),\n }));\n const workBook = utils.book_new();\n const productsWorkSheet = utils.json_to_sheet(data);\n\n utils.book_append_sheet(workBook, productsWorkSheet, \"products\");\n return writeXLSX(workBook, { type: \"buffer\" });\n }\n}\n","import xlsx from \"xlsx\";\n\nimport { type Brand, type Category, type Product } from \"../types\";\nimport {\n Extension,\n type FormatterAbstract,\n type FormatterOptions,\n} from \"./formater.types\";\n\nexport class InsalesFormatter implements FormatterAbstract {\n public formatterName = \"Insales\";\n public fileExtension = Extension.XLSX;\n\n public async format(\n products: Product[],\n categories?: Category[],\n _?: Brand[],\n __?: FormatterOptions,\n ): Promise<Buffer> {\n const mappedCategories: Record<number, Category> = {};\n categories?.forEach(\n (category) => (mappedCategories[category.id] = category),\n );\n\n const getParams = (product: Product): Record<string, string> => {\n const properties: Record<string, string> = {};\n\n product.params?.forEach(\n (p) => (properties[`Свойство: ${p.key}`] = p.value),\n );\n\n return properties;\n };\n const getProperties = (product: Product): Record<string, string> => {\n const properties: Record<string, string> = {};\n\n product.properties?.forEach(\n (p) => (properties[`Параметр: ${p.key}`] = p.value),\n );\n\n return properties;\n };\n\n const getSizes = (product: Product): Record<string, string> => {\n const sizes: Record<string, string> = {};\n\n product.sizes?.forEach(\n ({ name, value }) => (sizes[`Размеры [${name}]:`] = value),\n );\n\n return sizes;\n };\n\n const getCategories = (product: Product) => {\n const categories: Record<string, string> = {};\n const categoryList = new Array<string>();\n\n function addCategory(categoryId: number | undefined) {\n if (categoryId === undefined) return;\n\n const category = mappedCategories[categoryId];\n if (category) {\n categoryList.push(category.name);\n addCategory(category.parentId);\n }\n }\n\n addCategory(product.categoryId);\n\n categoryList.forEach((name, i) => {\n const index = categoryList.length - 1 - i;\n const key = index === 0 ? \"Корневая\" : `Подкатегория ${index}`;\n categories[key] = name;\n });\n\n return categories;\n };\n\n const data = products.map((product) => ({\n \"Внешний ID\": product.productId,\n \"Ссылка на товар\": product.url,\n Артикул: product.vendorCode,\n \"Название товара или услуги\": product.title,\n \"Старая цена\": product.oldPrice,\n \"Цена продажи\": product.price,\n \"Цена закупки\": product.purchasePrice,\n ...getCategories(product),\n Остаток: product.count,\n \"Штрих-код\": product.barcode,\n \"Краткое описание\": undefined,\n \"Полное описание\": product.description,\n \"Габариты варианта\": product.dimensions,\n Вес: product.weight,\n \"Размещение на сайте\": product.available,\n НДС: product.vat.toString(),\n \"Валюта склада\": product.currency.toString(),\n \"Изображения варианта\": product.images?.join(\" \"),\n Изображения: product.images?.join(\" \"),\n \"Ссылка на видео\": product.videos ? product.videos[0] : undefined,\n ...getParams(product),\n ...getProperties(product),\n \"Параметр: Бренд\": product.vendor,\n \"Параметр: Коллекция\": product.seriesName,\n \"Параметр: Пол\": product.gender,\n \"Параметр: Дата выхода\": product.saleDate,\n ...getSizes(product),\n \"Связанные товары\": product.relatedProducts?.join(\",\"),\n }));\n const workBook = xlsx.utils.book_new();\n const productsWorkSheet = xlsx.utils.json_to_sheet(data);\n\n xlsx.utils.book_append_sheet(workBook, productsWorkSheet, \"products\");\n\n return xlsx.write(workBook, { bookType: \"xlsx\", type: \"buffer\" });\n }\n}\n","import { type Product, type Category, type Brand } from \"../types\";\nimport {\n Extension,\n type FormatterAbstract,\n type FormatterOptions,\n} from \"./formater.types\";\n\nexport class JSONFormatter implements FormatterAbstract {\n public formatterName = \"JSON\";\n public fileExtension = Extension.JSON;\n\n public async format(\n products: Product[],\n categories?: Category[],\n brands?: Brand[],\n _?: FormatterOptions,\n ): Promise<string> {\n const result = {\n categories,\n brands,\n products,\n };\n\n return JSON.stringify(result);\n }\n}\n","import xlsx from \"xlsx\";\n\nimport { type Brand, type Category, type IParam, type Product } from \"../types\";\nimport {\n Extension,\n type FormatterAbstract,\n type FormatterOptions,\n} from \"./formater.types\";\n\nexport class TgShopFormatter implements FormatterAbstract {\n public formatterName = \"TgShop\";\n public fileExtension = Extension.XLSX;\n\n public async format(\n products: Product[],\n categories?: Category[],\n _?: Brand[],\n __?: FormatterOptions,\n ): Promise<Buffer> {\n const getParameter = (product: Product, key: string): IParam | undefined =>\n product.params?.find((value) => value.key === key);\n const productsData = products.map((product) => ({\n \"category id\": product.categoryId,\n \"group id\": product.parentId,\n \"id product\": product.variantId,\n \"name product\": product.title,\n price: product.price,\n picture: product.images?.join(\", \"),\n vendorCode: product.vendorCode,\n oldprice: product.oldPrice,\n description: product.description,\n shortDescription: product.description,\n quantityInStock: product.count,\n color: getParameter(product, \"color\")?.value,\n size: getParameter(product, \"size\")?.value,\n priority: undefined,\n }));\n\n const workBook = xlsx.utils.book_new();\n const productsWorkSheet = xlsx.utils.json_to_sheet(productsData);\n const categoriesWorkSheet = xlsx.utils.json_to_sheet(categories ?? []);\n\n xlsx.utils.book_append_sheet(workBook, categoriesWorkSheet, \"categories\");\n xlsx.utils.book_append_sheet(workBook, productsWorkSheet, \"offers\");\n\n return xlsx.write(workBook, { bookType: \"xlsx\", type: \"buffer\" });\n }\n}\n","import { json2csv } from \"json-2-csv\";\n\nimport { type Brand, type Category, type Product } from \"../types\";\nimport {\n Extension,\n type FormatterAbstract,\n type FormatterOptions,\n} from \"./formater.types\";\n\nexport class TildaFormatter implements FormatterAbstract {\n public formatterName = \"Tilda\";\n public fileExtension = Extension.CSV;\n\n public async format(\n products: Product[],\n categories?: Category[],\n _?: Brand[],\n __?: FormatterOptions,\n ): Promise<string> {\n const mappedCategories: Record<number, string> = {};\n categories?.forEach(({ id, name }) => (mappedCategories[id] = name));\n\n const data = products.map((product) => ({\n SKU: product.vendorCode,\n Brand: product.vendor,\n Category: mappedCategories[product.categoryId],\n Title: product.title,\n Text: product.description,\n Photo: product.images?.join(\";\"),\n Price: product.price,\n \"Price Old\": product.oldPrice,\n Quantity: product.count,\n Editions: product.params\n ?.map(({ key, value }) => `${key}:${value}`)\n .join(\";\"),\n \"External ID\": product.variantId,\n \"Parent UID\": product.parentId,\n }));\n\n return json2csv(data, { emptyFieldValue: \"\", delimiter: { field: \";\" } });\n }\n}\n","import { XMLBuilder } from \"fast-xml-parser\";\n\nimport { type Product, type Category, type Brand } from \"../types\";\nimport {\n Extension,\n type FormatterAbstract,\n type FormatterOptions,\n} from \"./formater.types\";\n\nexport class YMLFormatter implements FormatterAbstract {\n public formatterName = \"YMl\";\n public fileExtension = Extension.YML;\n private readonly builder = new XMLBuilder({\n ignoreAttributes: false,\n format: true,\n cdataPropName: \"__cdata\",\n });\n\n public async format(\n products: Product[],\n categories?: Category[],\n brands?: Brand[],\n options?: FormatterOptions,\n ): Promise<string> {\n const offers = { offer: products.map(this.getOffers) };\n const result = {\n \"?xml\": {\n \"@_version\": \"1.0\",\n \"@_encoding\": \"UTF-8\",\n \"@_standalone\": \"yes\",\n },\n yml_catalog: {\n \"@_date\": new Date().toISOString().replace(/.\\d+Z/, \"\"),\n shop: {\n name: options?.shopName,\n company: options?.companyName,\n categories: this.getCategories(categories),\n brands: this.getBrands(brands),\n offers,\n },\n },\n };\n\n return this.builder.build(result);\n }\n\n private getBrands(brands?: Brand[]) {\n return {\n brand: brands?.map((brand) => ({\n \"@_id\": brand.id,\n \"@_url\": brand.coverURL,\n \"#text\": brand.name,\n })),\n };\n }\n\n private getCategories(categories?: Category[]) {\n return {\n category: categories?.map((cat) => ({\n \"@_id\": cat.id,\n \"@_parentId\": cat.parentId,\n \"#text\": cat.name,\n })),\n };\n }\n\n private getOffers(product: Product): any {\n const result = {\n \"@_id\": product.variantId,\n name: product.title,\n price: product.price,\n oldprice: product.oldPrice,\n purchase_price: product.purchasePrice,\n additional_expenses: product.additionalExpenses,\n cofinance_price: product.cofinancePrice,\n currencyId: product.currency,\n categoryId: product.categoryId,\n vendor: product.vendor,\n vendorCode: product.vendorCode,\n picture: product.images,\n video: product.videos,\n available: product.available,\n series: product.seriesName,\n \"min-quantity\": product.minQuantity,\n \"step-quantity\": product.stepQuantity,\n size: product.sizes?.map((size) => ({\n \"#text\": size.value,\n \"@_name\": size.name,\n \"@_delimiter\": size.delimiter,\n })),\n keyword: product.keywords,\n saleDate: product.saleDate,\n property: product.properties?.map((property) => ({\n \"#text\": property.value,\n \"@_name\": property.key,\n })),\n param: product.params?.map((param) => ({\n \"#text\": param.value,\n \"@_name\": param.key,\n })),\n description: {\n __cdata: product.description,\n },\n country_of_origin: product.countryOfOrigin,\n barcode: product.barcode,\n vat: product.vat,\n count: product.count,\n \"set-ids\": product.tags?.join(\", \"),\n adult: product.adult,\n downloadable: product.downloadable,\n \"period-of-validity-days\": product.validityPeriod,\n \"comment-validity-days\": product.validityComment,\n \"service-life-days\": product.serviceLifePeriod,\n \"comment-life-days\": product.serviceLifeComment,\n \"warranty-days\": product.warrantyPeriod,\n \"comment-warranty\": product.warrantyComment,\n manufacturer_warranty: product.manufacturerWarranty,\n certificate: product.certificate,\n url: product.url,\n weight: product.weight,\n dimensions: product.dimensions,\n boxCount: product.boxCount,\n disabled: product.disabled,\n age: product.age != null && {\n \"@_unit\": product.age.unit,\n \"#text\": product.age.value,\n },\n \"tn-ved-codes\": product.codesTN?.length != null && {\n \"tn-ved-code\": product.codesTN,\n },\n relatedProduct: product.relatedProducts,\n gender: product.gender,\n };\n if (product.parentId !== undefined) {\n return {\n ...result,\n \"@_group_id\": product.parentId,\n };\n }\n return result;\n }\n}\n","import { CSVFormatter } from \"./CSV.formatter\";\nimport { ExcelFormatter } from \"./Excel.formatter\";\nimport { InsalesFormatter } from \"./Insales.formatter\";\nimport { JSONFormatter } from \"./JSON.formatter\";\nimport { TgShopFormatter } from \"./TgShop.formatter\";\nimport { TildaFormatter } from \"./Tilda.formatter\";\nimport { YMLFormatter } from \"./YML.formatter\";\n\nexport * from \"./formater.types\";\n\nexport const Formatters = {\n TildaFormatter,\n CSVFormatter,\n InsalesFormatter,\n YMLFormatter,\n TgShopFormatter,\n ExcelFormatter,\n JSONFormatter,\n};\n","import deepcopy from \"deepcopy\";\n\nimport {\n type FormatterAbstract,\n type FormatterOptions,\n Formatters,\n} from \"../formatter\";\nimport { type Brand, type Category, type Product } from \"../types\";\nimport { type Exporter, type Transformer } from \"./exporter.types\";\n\nimport * as fs from \"fs\";\n\nexport class GoodsExporter {\n private formatter: FormatterAbstract = new Formatters.YMLFormatter();\n private exporter: Exporter = (data: Buffer) => {\n const filename = `${this.formatter.formatterName}.output.${this.formatter.fileExtension}`;\n fs.writeFileSync(filename, data);\n return data;\n };\n\n private transformers = new Array<Transformer>();\n\n public setTransformers(transformers: Transformer[]): void {\n this.transformers = transformers;\n }\n\n public setFormatter(formatter: FormatterAbstract): void {\n this.formatter = formatter;\n }\n\n public setExporter(exporter: Exporter): void {\n this.exporter = exporter;\n }\n\n async export(\n products: Product[],\n categories?: Category[],\n brands?: Brand[],\n option?: FormatterOptions,\n ): Promise<Buffer> {\n const copyProducts = deepcopy(products);\n const transformedProducts = await Promise.all(\n copyProducts.map(async (product) => {\n let transformedProduct: Product = product;\n for (const transformer of this.transformers)\n transformedProduct = await transformer(transformedProduct);\n return transformedProduct;\n }),\n );\n const data = await this.formatter.format(\n transformedProducts,\n categories,\n brands,\n option,\n );\n\n if (typeof data === \"string\") {\n return await this.exporter(Buffer.from(data, \"utf-8\"));\n }\n return await this.exporter(data);\n }\n}\n","export interface Product {\n /**\n * **ID товара**\n *\n * Любая последовательность длиной до 80 знаков. В нее могут входить английские и русские (кроме ё) буквы, цифры и символы . , / \\ ( ) [ ] - = _\n *\n * Пример: belaya-kofta-12345\n */\n productId: number;\n /**\n * **Родительскй SKU**\n *\n * Любая последовательность длиной до 80 знаков. В нее могут входить английские и русские (кроме ё) буквы, цифры и символы . , / \\ ( ) [ ] - = _\n *\n * Пример: belaya-kofta-12345\n */\n parentId?: number;\n /**\n * **SKU**\n *\n * Любая последовательность длиной до 80 знаков. В нее могут входить английские и русские (кроме ё) буквы, цифры и символы . , / \\ ( ) [ ] - = _\n *\n * Пример: belaya-kofta-12345\n */\n variantId: number;\n /**\n * **Название**\n *\n * Составляйте название по схеме: тип + бренд или производитель + модель + особенности, если есть (например, цвет, размер или вес) и количество в упаковке.\n *\n * Не включайте в название условия продажи (например, «скидка», «бесплатная доставка» и т. д.), эмоциональные характеристики («хит», «супер» и т. д.). Не пишите слова большими буквами — кроме устоявшихся названий брендов и моделей.\n *\n * Оптимальная длина — 50–60 символов, максимальная — 150.\n *\n * Составлять хорошие названия помогут [рекомендации](https://yandex.ru/support/marketplace/assortment/fields/title.html).\n *\n * Пример: Ударная дрель Makita HP1630, 710 Вт\n */\n title: string;\n /**\n * **Описание**\n *\n * Подробное описание товара: например, его преимущества и особенности.\n *\n * Не давайте в описании инструкций по установке и сборке. Не используйте слова «скидка», «распродажа», «дешевый», «подарок» (кроме подарочных категорий), «бесплатно», «акция», «специальная цена», «новинка», «new», «аналог», «заказ», «хит». Не указывайте никакой контактной информации и не давайте ссылок.\n *\n * Можно использовать теги:\n *\n ** &lt;h&gt;, &lt;h1&gt;, &lt;h2&gt; и так далее — для заголовков;\n ** &lt;br&gt; и &lt;p&gt; — для переноса строки;\n ** &lt;ol&gt; — для нумерованного списка;\n ** &lt;ul&gt; — для маркированного списка;\n ** &lt;li&gt; — для создания элементов списка (должен находиться внутри &lt;ol&gt; или &lt;ul&gt;);\n ** &lt;div&gt; — поддерживается, но не влияет на отображение текста.\n * Оптимальная длина — 400–600 символов, максимальная — 6000.\n *\n * Составить хорошее описание помогут рекомендации.\n *\n * Пример: В комплекте с детским микроскопом есть все, что нужно вашему ребенку для изучения микромира\n */\n description: string;\n /**\n * **Бренд**\n *\n * Название бренда или производителя.\n *\n * Записывайте название так, как его пишет сам бренд.\n *\n * Пример: LEVENHUK\n */\n vendor?: string;\n /**\n * **Артикул производителя**\n *\n * Код товара, который ему присвоил производитель.\n *\n * Если артикулов несколько, укажите их через запятую.\n *\n * Пример: VNDR-0005A, VNDR-0005B\n */\n vendorCode?: string;\n /**\n * **Дата выхода**\n *\n * Пример: 01.01.2000\n */\n saleDate?: string;\n /**\n * **Категория в магазине**\n *\n * Категория, к которой вы относите товар. Она помогает точнее определить для товара категорию на Маркете.\n *\n * Указывайте конкретные категории — например, набор ножей лучше отнести к категории Столовые приборы, а не просто Посуда.\n *\n * Выбирайте категории, которые описывают товар, а не абстрактный признак — например, лучше указать Духи, а не Подарки.\n *\n * Содержит номер категории, а не ее название.\n */\n categoryId: number;\n /**\n * **Страна производства**\n *\n * Страна, где был произведен товар.\n *\n * Записывайте названия стран так, как они записаны в [списке](https://yastatic.net/s3/doc-binary/src/support/market/ru/countries.xlsx).\n *\n * Пример: Россия\n */\n countryOfOrigin?: string;\n /**\n * **Изображение**\n *\n * До двадцати изображений, которые показываются на карточке товара.\n *\n * Принимаются jpg- или png-изображения товара, соответствующие [требованиям](https://yandex.ru/support/marketplace/assortment/fields/images.html).\n *\n * В кабинете изображения добавляются в виде файлов. В Excel-файле — в виде ссылок через запятую. Первое фото становится основным.\n *\n * Чтобы изменить изображение, выложите новое по новой ссылке, иначе картинка не обновится.\n */\n images?: string[];\n /**\n * **Видео**\n *\n * Видеоиллюстрации для карточки товара.\n *\n * Видео должно соответствовать [требованиям](https://yandex.ru/support/marketplace/assortment/fields/video.html).\n *\n * Можно добавить не больше 6 видео.\n *\n * В кабинете можно загрузить видеофайлы. В Excel-шаблоне укажите ссылки на файлы.\n */\n videos?: string[];\n /**\n * **Базовая цена**\n *\n * Цена указывается в рублях. Число должно быть целым.\n *\n * Пример:\n *\n * 240\n */\n price: number;\n /**\n * **Цена до скидки**\n *\n * Цена указывается в рублях. Число должно быть целым.\n *\n * Вы можете указать цену со скидкой от 5 до 75 %.\n *\n * Пример:\n *\n * 250\n */\n oldPrice?: number;\n /**\n * **Себестоимость**\n *\n * Цена указывается в рублях. Число должно быть целым.\n *\n * Пример:\n *\n * 200\n */\n purchasePrice?: number;\n /**\n * **Дополнительные расходы**\n *\n * Дополнительные расходы на товар. Например, на доставку или упаковку.\n *\n * После заполнения этого поля в калькуляторе и на странице управления ценами рассчитается потенциальная маржинальность товара.\n *\n * Цена указывается в рублях. Число должно быть целым.\n *\n * Пример:\n *\n * 75\n */\n additionalExpenses?: number;\n /**\n * **Порог для скидок с Маркетом**\n *\n * Цена указывается в рублях. Число должно быть целым.\n *\n * Пример:\n *\n * 300\n */\n cofinancePrice?: number;\n /**\n * **Валюта (DBS)**\n *\n * Валюта, в которой указана цена товара. Покупателям Маркет показывает цену в рублях, пересчитывая ее по курсу Центробанка.\n *\n * Поле используется, если для кабинета еще не включена работа с базовыми ценами.\n *\n * Поддерживаются российские и белорусские рубли, евро, доллары, украинские гривны и казахстанские тенге.\n *\n * В кабинете валюту можно просто выбрать из списка. В Excel-файле указывается код валюты: RUR, BYN, EUR, USD, UAN, KZT.\n */\n currency: Currency;\n /**\n * **Ссылка на страницу товара**\n *\n * Адрес страницы на вашем сайте с фотографиями и описанием товара.\n *\n * Максимальная длина URL — 512 символов. Записывайте его согласно стандарту RFC 3986.\n *\n * Пример: http://best.seller.ru/product_page.asp?pid=12346\n */\n url?: string;\n /**\n * **Убрать из продажи**\n *\n * Поле позволяет приостановить продажу товара.\n *\n * Укажите значение true, если нужно приостановить продажу.\n */\n disabled?: boolean;\n /**\n * **Доступное количество товара**\n *\n * Общее количество товара, доступное для продажи\n *\n * Укажите 0, если товара нет в наличии.\n *\n * Пример: 7\n */\n count?: number;\n /**\n * **Товар в наличии (DBS)**\n *\n * Поле указывает, есть ли товар в наличии.\n */\n available?: boolean;\n /**\n * **Минимальное количество товара**\n *\n * Если значение задано, покупатель не сможет заказать меньше единиц товара. Ограничение не работает, когда товара на складе осталось меньше этого количества — тогда покупатель сможет сделать заказ на остаток.\n *\n * Целое число.\n */\n minQuantity?: number;\n /**\n * **Квант продажи**\n *\n * Если значение задано, покупатель сможет добавить к заказу только кратное количество товара. Ограничение не работает, когда на складе осталось меньше этого количества — тогда покупатель сможет сделать заказ на остаток.\n *\n * Целое число.\n */\n stepQuantity?: number;\n /**\n * **Штрихкод**\n *\n * Указывайте в виде последовательности символов. Подойдут коды EAN-13, EAN-8, UPC-A, UPC-E или Code 128.\n *\n * Для книг указывайте ISBN.\n *\n * Для товаров [определенных категорий и торговых марок](https://yastatic.net/s3/doc-binary/src/support/market/ru/yandex-market-list-for-gtin.xlsx) штрихкод должен быть действительным кодом GTIN. Обратите внимание: внутренние штрихкоды, начинающиеся на 2 или 02, и коды формата Code 128 не являются GTIN.\n *\n * Если штрихкодов несколько, напишите все через запятую.\n *\n * Пример: 46012300000000\n */\n barcode?: string;\n /**\n * **Код ТН ВЭД**\n *\n * Для некоторых категорий товаров код ТН ВЭД обязателен. Если это касается ваших товаров, вы получите уведомление в каталоге.\n *\n * 10 или 14 цифр без пробелов.\n *\n * Пример: 8517610008\n */\n codesTN?: string[];\n /**\n * **С какого возраста пользоваться**\n *\n * Если товар не предназначен для детей младше определенного возраста, укажите это.\n *\n * Возрастные ограничения можно задавать в годах (с нуля, с 6, 12, 16 или 18) или в месяцах (любое число от 0 до 12).\n */\n age?: { unit: \"year\" | \"month\"; value: number };\n /**\n * **Вес с упаковкой**\n *\n * Вес товара с упаковкой.\n *\n * Единица измерения — килограммы. Можно дроби: разделитель — точка или запятая, не больше трех цифр после него.\n *\n * Пример: 3.1\n */\n weight?: number;\n /**\n * **Габариты с упаковкой**\n *\n * Длина, ширина, высота в упаковке.\n *\n * Единица измерения — сантиметры. Можно дроби: разделитель — точка или запятая, не больше трех цифр после него.\n *\n * Пример: 20.1/20.551/22.5\n */\n dimensions?: string;\n /**\n * **Товар занимает больше одного места**\n *\n * Если товар занимает одно место (представляет собой одну коробку, упаковку и так далее), оставьте поле пустым. Если товар занимает несколько мест — укажите их количество. Например, кондиционер занимает два места — внешний и внутренний блоки в двух коробках.\n *\n * Укажите количество мест.\n *\n * Пример: 2\n */\n boxCount?: number;\n /**\n * **Ставка НДС**\n *\n * Значение ставки НДС для товара.\n *\n * Выберите одно из значений:\n *\n ** НДС не облагается — 6 или NO_VAT\n *\n ** 0 % — 5 или VAT_0\n *\n ** 10 % — 2 или VAT_10\n *\n ** 20 % — 7 или VAT_20\n *\n * Если не заполнено, Маркет устанавливает ставку, соответствующую схеме налогообложения.\n *\n * Пример: VAT_20\n */\n vat: Vat;\n /**\n * **Характеристики, которые есть только у товаров конкретной категории**\n *\n * Кроме общих свойств, у товара есть характеристики, присущие конкретной категории, к которой он относится. Например, у велосипеда есть размер рамы, а детское пюре бывает овощное, мясное или фруктовое.\n */\n params?: IParam[];\n /**\n * **Свойства товара**\n *\n * *не YML поле\n */\n properties?: IParam[];\n /**\n * **Теги**\n *\n * Придумайте любое название — его можно будет изменить после.\n *\n * Максимальная длина тега — 20 символов.\n *\n * У одного товара — максимум 10 тегов.\n *\n * Всего можно создать не больше 50 разных тегов.\n *\n * Пример: apple, до 500 рублей\n */\n tags?: string[];\n /**\n * **Товар для взрослых**\n *\n * Параметр включает для товара пометку 18+. Устанавливайте ее только для товаров, которые относятся к удовлетворению сексуальных потребностей.\n */\n adult?: boolean;\n /**\n * **Цифровой товар**\n *\n * Параметр, устанавливаемый для цифровых товаров, которые просто скачиваются.\n */\n downloadable?: boolean;\n /**\n * **Срок годности**\n *\n * Период с момента изготовления, по прошествии которого товар становится непригоден.\n *\n * Указывайте срок, указанный на банке или упаковке. Текущая дата, дата поставки или дата отгрузки значения не имеет.\n *\n * Срок можно указывать в годах, месяцах, днях, неделях и часах.\n *\n * Обязательно указывайте срок, если он есть.\n *\n * Продолжительность указывается согласно ISO 8601, то есть в виде строчки, начинающейся буквой P:\n *\n ** P1Y — 1 год;\n ** P1Y6M — 1 год и 6 месяцев;\n ** P15D — 15 дней.\n */\n validityPeriod?: string;\n /**\n * **Комментарий к сроку годности**\n *\n * Поле предназначено для описаний условий хранения.\n *\n * Не длиннее 250 знаков и без спецсимволов.\n *\n * Пример: Хранить в сухом помещении\n */\n validityComment?: string;\n /**\n * **Срок службы**\n *\n * В течение срока службы товар должен исправно выполнять свою функцию.\n *\n * Обязательно указывайте срок, если он есть.\n *\n * Срок можно указывать в годах, месяцах и днях.\n * Продолжительность указывается согласно ISO 8601, то есть в виде строчки, начинающейся буквой P:\n *\n ** P1Y — 1 год;\n ** P1Y2M — 1 год и 2 месяца;\n ** P15D — 15 дней;\n ** P2Y10D — 2 года, 10 дней;\n ** P2Y6M10D — 2 года, 6 месяцев и 10 дней.\n */\n serviceLifePeriod?: string;\n /**\n * **Комментарий к сроку службы**\n *\n * Поле предназначено для описаний условий использования.\n *\n * Не длиннее 250 знаков и без спецсимволов.\n *\n * Пример: Использовать при температуре не ниже −10 градусов\n */\n serviceLifeComment?: string;\n /**\n * **Гарантийный срок**\n *\n * В течение какого времени можно бесплатно заменить или починить товар.\n *\n * Срок можно указывать в годах, месяцах или днях.\n *\n * Продолжительность указывается согласно ISO 8601, то есть в виде строчки, начинающейся буквой P:\n *\n ** P1Y — 1 год;\n ** P1Y2M — 1 год и 2 месяца;\n ** P15D — 15 дней;\n ** P2Y10D — 2 года, 10 дней;\n ** P2Y6M10D — 2 года, 6 месяцев и 10 дней.\n */\n warrantyPeriod?: string;\n /**\n * **Комментарий к гарантийному сроку**\n *\n * Поле предназначено для описания особенностей гарантийных условий.\n *\n * Указывайте только то, что относится к гарантии изготовителя.\n *\n * Не длиннее 250 знаков и без спецсимволов.\n *\n * Пример: Гарантия на аккумулятор — 6 месяцев\n */\n warrantyComment?: string;\n /**\n * **Официальная гарантия производителя**\n */\n manufacturerWarranty?: boolean;\n /**\n * **Номер документа**\n *\n * Номер документа на товар: сертификата, декларации соответствия и т. п.\n *\n * Прежде чем указывать номер документа, загрузите скан документа через кабинет.\n *\n * Укажите номер документа.\n *\n * Пример: 6241421\n */\n certificate?: string;\n /**\n * **Ключевые слова**\n *\n * Пример: Кроссовки, высокая подошва\n */\n keywords?: string[];\n /**\n * **Размерная сетка**\n */\n sizes?: ISize[];\n /**\n * **Связанные товары**\n *\n * Указываются id товаров\n *\n * Пример: 1234\n */\n relatedProducts?: number[];\n /**\n * **Название коллекции, ряда или серии товара**\n *\n * Пример: Jordan 4\n */\n seriesName?: string;\n /**\n * **Пол или название группы потребителей**\n *\n * Пример: Дети, Женское, Унисекс\n */\n gender?: string;\n}\n\nexport enum Vat {\n NO_VAT = \"NO_VAT\",\n VAT_0 = \"VAT_0\",\n VAT_10 = \"VAT_10\",\n VAT_20 = \"VAT_20\",\n}\n\nexport enum Currency {\n RUR = \"RUR\",\n BYN = \"BYN\",\n EUR = \"EUR\",\n USD = \"USD\",\n UAN = \"UAN\",\n KZT = \"KZT\",\n}\n\nexport interface IParam {\n /**\n * **Название характеристики**\n */\n key: string;\n /**\n * **Значение**\n */\n value: string;\n}\n\nexport interface ISize {\n /**\n * **Название единицы измерения**\n */\n name: string;\n /**\n * **Разделитель**\n */\n delimiter: string;\n /**\n * **Значения размерного ряда**\n *\n * Размеры указываются через разделитель\n */\n value: string;\n}\n"],"names":["Extension","__publicField","json2csv","categories","XMLBuilder","fs","Vat","Currency"],"mappings":"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"}
@@ -58,7 +58,7 @@ class CSVFormatter {
58
58
  __publicField$7(this, "formatterName", "CSV");
59
59
  __publicField$7(this, "fileExtension", Extension.CSV);
60
60
  }
61
- async format(products, categories, options) {
61
+ async format(products, categories, _, options) {
62
62
  const mappedCategories = {};
63
63
  categories?.forEach(({ id, name }) => mappedCategories[id] = name);
64
64
  const data = products.map((product) => ({
@@ -92,7 +92,7 @@ class ExcelFormatter {
92
92
  __publicField$6(this, "formatterName", "Excel");
93
93
  __publicField$6(this, "fileExtension", Extension.XLSX);
94
94
  }
95
- async format(products, categories, options) {
95
+ async format(products, categories, _, options) {
96
96
  const mappedCategories = {};
97
97
  categories?.forEach(({ id, name }) => mappedCategories[id] = name);
98
98
  const data = products.map((product) => ({
@@ -128,7 +128,7 @@ class InsalesFormatter {
128
128
  __publicField$5(this, "formatterName", "Insales");
129
129
  __publicField$5(this, "fileExtension", Extension.XLSX);
130
130
  }
131
- async format(products, categories, _) {
131
+ async format(products, categories, _, __) {
132
132
  const mappedCategories = {};
133
133
  categories?.forEach(
134
134
  (category) => mappedCategories[category.id] = category
@@ -176,6 +176,7 @@ class InsalesFormatter {
176
176
  };
177
177
  const data = products.map((product) => ({
178
178
  "\u0412\u043D\u0435\u0448\u043D\u0438\u0439 ID": product.productId,
179
+ "\u0421\u0441\u044B\u043B\u043A\u0430 \u043D\u0430 \u0442\u043E\u0432\u0430\u0440": product.url,
179
180
  \u0410\u0440\u0442\u0438\u043A\u0443\u043B: product.vendorCode,
180
181
  "\u041D\u0430\u0437\u0432\u0430\u043D\u0438\u0435 \u0442\u043E\u0432\u0430\u0440\u0430 \u0438\u043B\u0438 \u0443\u0441\u043B\u0443\u0433\u0438": product.title,
181
182
  "\u0421\u0442\u0430\u0440\u0430\u044F \u0446\u0435\u043D\u0430": product.oldPrice,
@@ -221,9 +222,10 @@ class JSONFormatter {
221
222
  __publicField$4(this, "formatterName", "JSON");
222
223
  __publicField$4(this, "fileExtension", Extension.JSON);
223
224
  }
224
- async format(products, categories, _) {
225
+ async format(products, categories, brands, _) {
225
226
  const result = {
226
227
  categories,
228
+ brands,
227
229
  products
228
230
  };
229
231
  return JSON.stringify(result);
@@ -241,7 +243,7 @@ class TgShopFormatter {
241
243
  __publicField$3(this, "formatterName", "TgShop");
242
244
  __publicField$3(this, "fileExtension", Extension.XLSX);
243
245
  }
244
- async format(products, categories, _) {
246
+ async format(products, categories, _, __) {
245
247
  const getParameter = (product, key) => product.params?.find((value) => value.key === key);
246
248
  const productsData = products.map((product) => ({
247
249
  "category id": product.categoryId,
@@ -279,7 +281,7 @@ class TildaFormatter {
279
281
  __publicField$2(this, "formatterName", "Tilda");
280
282
  __publicField$2(this, "fileExtension", Extension.CSV);
281
283
  }
282
- async format(products, categories, _) {
284
+ async format(products, categories, _, __) {
283
285
  const mappedCategories = {};
284
286
  categories?.forEach(({ id, name }) => mappedCategories[id] = name);
285
287
  const data = products.map((product) => ({
@@ -316,16 +318,7 @@ class YMLFormatter {
316
318
  cdataPropName: "__cdata"
317
319
  }));
318
320
  }
319
- async format(products, categories, options) {
320
- const mappedCategories = {
321
- category: categories?.map((cat) => ({
322
- "@_id": cat.id,
323
- "@_parentId": cat.parentId,
324
- "#text": cat.name
325
- }))
326
- };
327
- const shopName = options?.shopName ?? "ShopName";
328
- const companyName = options?.companyName ?? "CompanyName";
321
+ async format(products, categories, brands, options) {
329
322
  const offers = { offer: products.map(this.getOffers) };
330
323
  const result = {
331
324
  "?xml": {
@@ -336,15 +329,34 @@ class YMLFormatter {
336
329
  yml_catalog: {
337
330
  "@_date": (/* @__PURE__ */ new Date()).toISOString().replace(/.\d+Z/, ""),
338
331
  shop: {
339
- name: shopName,
340
- company: companyName,
341
- categories: mappedCategories,
332
+ name: options?.shopName,
333
+ company: options?.companyName,
334
+ categories: this.getCategories(categories),
335
+ brands: this.getBrands(brands),
342
336
  offers
343
337
  }
344
338
  }
345
339
  };
346
340
  return this.builder.build(result);
347
341
  }
342
+ getBrands(brands) {
343
+ return {
344
+ brand: brands?.map((brand) => ({
345
+ "@_id": brand.id,
346
+ "@_url": brand.coverURL,
347
+ "#text": brand.name
348
+ }))
349
+ };
350
+ }
351
+ getCategories(categories) {
352
+ return {
353
+ category: categories?.map((cat) => ({
354
+ "@_id": cat.id,
355
+ "@_parentId": cat.parentId,
356
+ "#text": cat.name
357
+ }))
358
+ };
359
+ }
348
360
  getOffers(product) {
349
361
  const result = {
350
362
  "@_id": product.variantId,
@@ -457,7 +469,7 @@ class GoodsExporter {
457
469
  setExporter(exporter) {
458
470
  this.exporter = exporter;
459
471
  }
460
- async export(products, categories, option) {
472
+ async export(products, categories, brands, option) {
461
473
  const copyProducts = deepcopy(products);
462
474
  const transformedProducts = await Promise.all(
463
475
  copyProducts.map(async (product) => {
@@ -470,6 +482,7 @@ class GoodsExporter {
470
482
  const data = await this.formatter.format(
471
483
  transformedProducts,
472
484
  categories,
485
+ brands,
473
486
  option
474
487
  );
475
488
  if (typeof data === "string") {
@@ -1 +1 @@
1
- {"version":3,"file":"index.mjs","sources":["../../src/util/formatter.util.ts","../../src/formatter/formater.types.ts","../../src/formatter/CSV.formatter.ts","../../src/formatter/Excel.formatter.ts","../../src/formatter/Insales.formatter.ts","../../src/formatter/JSON.formatter.ts","../../src/formatter/TgShop.formatter.ts","../../src/formatter/Tilda.formatter.ts","../../src/formatter/YML.formatter.ts","../../src/formatter/index.ts","../../src/exporter/goodsExporter.ts","../../src/types/Product.types.ts"],"sourcesContent":["import { type FormatterOptions } from \"../formatter\";\nimport { type Product } from \"../types\";\n\nconst getParams = (\n product: Product,\n option?: FormatterOptions,\n): Record<string, string> => {\n const params: Record<string, string> = {};\n\n if (option?.splitParams === false) {\n return params;\n }\n\n product.params?.forEach(\n ({ key, value }) => (params[`Param [${key}]`] = value),\n );\n return params;\n};\n\nconst getProperties = (\n product: Product,\n option?: FormatterOptions,\n): Record<string, string> => {\n const properties: Record<string, string> = {};\n\n if (option?.splitParams === false) {\n return properties;\n }\n\n product.properties?.forEach(\n ({ key, value }) => (properties[`Property [${key}]`] = value),\n );\n return properties;\n};\n\nconst getSizes = (\n product: Product,\n _?: FormatterOptions,\n): Record<string, string> => {\n const sizes: Record<string, string> = {};\n product.sizes?.forEach(\n ({ name, value }) => (sizes[`Size [${name}]`] = value),\n );\n return sizes;\n};\n\nexport const UTILS = {\n getSizes,\n getParams,\n getProperties,\n};\n","import { type Category, type Product } from \"../types\";\n\nexport abstract class FormatterAbstract {\n public abstract formatterName: string;\n public abstract fileExtension: Extension;\n\n public abstract format(\n products: Product[],\n categories?: Category[],\n option?: FormatterOptions,\n ): Promise<Buffer | string>;\n}\n\nexport interface FormatterOptions {\n shopName?: string;\n\n companyName?: string;\n\n splitParams?: boolean;\n}\n\nexport enum Extension {\n CSV = \"csv\",\n YML = \"yml\",\n XLSX = \"xlsx\",\n JSON = \"json\",\n}\n","import { json2csv } from \"json-2-csv\";\n\nimport { type Category, type Product } from \"../types\";\nimport { UTILS } from \"../util/formatter.util\";\nimport {\n Extension,\n type FormatterAbstract,\n type FormatterOptions,\n} from \"./formater.types\";\n\nexport class CSVFormatter implements FormatterAbstract {\n public formatterName = \"CSV\";\n public fileExtension = Extension.CSV;\n\n public async format(\n products: Product[],\n categories?: Category[],\n options?: FormatterOptions,\n ): Promise<string> {\n const mappedCategories: Record<number, string> = {};\n categories?.forEach(({ id, name }) => (mappedCategories[id] = name));\n\n const data = products.map((product) => ({\n ...product,\n category: mappedCategories[product.categoryId],\n images: product.images?.join(\",\"),\n videos: product.videos?.join(\",\"),\n tags: product.tags?.join(\",\"),\n codesTN: product.codesTN?.join(\", \"),\n params: product.params\n ?.map(({ key, value }) => `${key}=${value}`)\n .join(\",\"),\n ...UTILS.getParams(product, options),\n ...UTILS.getProperties(product, options),\n ...UTILS.getSizes(product, options),\n sizes: undefined,\n keywords: product.keywords?.join(\",\"),\n relatedProducts: product.relatedProducts?.join(\",\"),\n }));\n return json2csv(data, { emptyFieldValue: \"\" });\n }\n}\n","import xlsx from \"xlsx\";\n\nimport { type Category, type Product } from \"../types\";\nimport { UTILS } from \"../util/formatter.util\";\nimport {\n Extension,\n type FormatterAbstract,\n type FormatterOptions,\n} from \"./formater.types\";\nconst { writeXLSX, utils } = xlsx;\n\nexport class ExcelFormatter implements FormatterAbstract {\n public formatterName = \"Excel\";\n public fileExtension = Extension.XLSX;\n\n public async format(\n products: Product[],\n categories?: Category[],\n options?: FormatterOptions,\n ): Promise<Buffer> {\n const mappedCategories: Record<number, string> = {};\n categories?.forEach(({ id, name }) => (mappedCategories[id] = name));\n\n const data = products.map((product) => ({\n ...product,\n category: mappedCategories[product.categoryId],\n images: product.images?.join(\",\"),\n videos: product.videos?.join(\",\"),\n tags: product.tags?.join(\",\"),\n keywords: product.keywords?.join(\",\"),\n relatedProducts: product.relatedProducts?.join(\",\"),\n codesTN: product.codesTN?.join(\", \"),\n params: product.params\n ?.map(({ key, value }) => `${key}=${value}`)\n .join(\",\"),\n sizes: undefined,\n ...UTILS.getParams(product, options),\n ...UTILS.getProperties(product, options),\n ...UTILS.getSizes(product, options),\n }));\n const workBook = utils.book_new();\n const productsWorkSheet = utils.json_to_sheet(data);\n\n utils.book_append_sheet(workBook, productsWorkSheet, \"products\");\n return writeXLSX(workBook, { type: \"buffer\" });\n }\n}\n","import xlsx from \"xlsx\";\n\nimport { type Category, type Product } from \"../types\";\nimport {\n Extension,\n type FormatterAbstract,\n type FormatterOptions,\n} from \"./formater.types\";\n\nexport class InsalesFormatter implements FormatterAbstract {\n public formatterName = \"Insales\";\n public fileExtension = Extension.XLSX;\n\n public async format(\n products: Product[],\n categories?: Category[],\n _?: FormatterOptions,\n ): Promise<Buffer> {\n const mappedCategories: Record<number, Category> = {};\n categories?.forEach(\n (category) => (mappedCategories[category.id] = category),\n );\n\n const getParams = (product: Product): Record<string, string> => {\n const properties: Record<string, string> = {};\n\n product.params?.forEach(\n (p) => (properties[`Свойство: ${p.key}`] = p.value),\n );\n\n return properties;\n };\n const getProperties = (product: Product): Record<string, string> => {\n const properties: Record<string, string> = {};\n\n product.properties?.forEach(\n (p) => (properties[`Параметр: ${p.key}`] = p.value),\n );\n\n return properties;\n };\n\n const getSizes = (product: Product): Record<string, string> => {\n const sizes: Record<string, string> = {};\n\n product.sizes?.forEach(\n ({ name, value }) => (sizes[`Размеры [${name}]:`] = value),\n );\n\n return sizes;\n };\n\n const getCategories = (product: Product) => {\n const categories: Record<string, string> = {};\n const categoryList = new Array<string>();\n\n function addCategory(categoryId: number | undefined) {\n if (categoryId === undefined) return;\n\n const category = mappedCategories[categoryId];\n if (category) {\n categoryList.push(category.name);\n addCategory(category.parentId);\n }\n }\n\n addCategory(product.categoryId);\n\n categoryList.forEach((name, i) => {\n const index = categoryList.length - 1 - i;\n const key = index === 0 ? \"Корневая\" : `Подкатегория ${index}`;\n categories[key] = name;\n });\n\n return categories;\n };\n\n const data = products.map((product) => ({\n \"Внешний ID\": product.productId,\n Артикул: product.vendorCode,\n \"Название товара или услуги\": product.title,\n \"Старая цена\": product.oldPrice,\n \"Цена продажи\": product.price,\n \"Цена закупки\": product.purchasePrice,\n ...getCategories(product),\n Остаток: product.count,\n \"Штрих-код\": product.barcode,\n \"Краткое описание\": undefined,\n \"Полное описание\": product.description,\n \"Габариты варианта\": product.dimensions,\n Вес: product.weight,\n \"Размещение на сайте\": product.available,\n НДС: product.vat.toString(),\n \"Валюта склада\": product.currency.toString(),\n \"Изображения варианта\": product.images?.join(\" \"),\n Изображения: product.images?.join(\" \"),\n \"Ссылка на видео\": product.videos ? product.videos[0] : undefined,\n ...getParams(product),\n ...getProperties(product),\n \"Параметр: Бренд\": product.vendor,\n \"Параметр: Коллекция\": product.seriesName,\n \"Параметр: Пол\": product.gender,\n \"Параметр: Дата выхода\": product.saleDate,\n ...getSizes(product),\n \"Связанные товары\": product.relatedProducts?.join(\",\"),\n }));\n const workBook = xlsx.utils.book_new();\n const productsWorkSheet = xlsx.utils.json_to_sheet(data);\n\n xlsx.utils.book_append_sheet(workBook, productsWorkSheet, \"products\");\n\n return xlsx.write(workBook, { bookType: \"xlsx\", type: \"buffer\" });\n }\n}\n","import { type Product, type Category } from \"../types\";\nimport {\n Extension,\n type FormatterAbstract,\n type FormatterOptions,\n} from \"./formater.types\";\n\nexport class JSONFormatter implements FormatterAbstract {\n public formatterName = \"JSON\";\n public fileExtension = Extension.JSON;\n\n public async format(\n products: Product[],\n categories?: Category[],\n _?: FormatterOptions,\n ): Promise<string> {\n const result = {\n categories,\n products,\n };\n\n return JSON.stringify(result);\n }\n}\n","import xlsx from \"xlsx\";\n\nimport { type Category, type IParam, type Product } from \"../types\";\nimport {\n Extension,\n type FormatterAbstract,\n type FormatterOptions,\n} from \"./formater.types\";\n\nexport class TgShopFormatter implements FormatterAbstract {\n public formatterName = \"TgShop\";\n public fileExtension = Extension.XLSX;\n\n public async format(\n products: Product[],\n categories?: Category[],\n _?: FormatterOptions,\n ): Promise<Buffer> {\n const getParameter = (product: Product, key: string): IParam | undefined =>\n product.params?.find((value) => value.key === key);\n const productsData = products.map((product) => ({\n \"category id\": product.categoryId,\n \"group id\": product.parentId,\n \"id product\": product.variantId,\n \"name product\": product.title,\n price: product.price,\n picture: product.images?.join(\", \"),\n vendorCode: product.vendorCode,\n oldprice: product.oldPrice,\n description: product.description,\n shortDescription: product.description,\n quantityInStock: product.count,\n color: getParameter(product, \"color\")?.value,\n size: getParameter(product, \"size\")?.value,\n priority: undefined,\n }));\n\n const workBook = xlsx.utils.book_new();\n const productsWorkSheet = xlsx.utils.json_to_sheet(productsData);\n const categoriesWorkSheet = xlsx.utils.json_to_sheet(categories ?? []);\n\n xlsx.utils.book_append_sheet(workBook, categoriesWorkSheet, \"categories\");\n xlsx.utils.book_append_sheet(workBook, productsWorkSheet, \"offers\");\n\n return xlsx.write(workBook, { bookType: \"xlsx\", type: \"buffer\" });\n }\n}\n","import { json2csv } from \"json-2-csv\";\n\nimport { type Category, type Product } from \"../types\";\nimport {\n Extension,\n type FormatterAbstract,\n type FormatterOptions,\n} from \"./formater.types\";\n\nexport class TildaFormatter implements FormatterAbstract {\n public formatterName = \"Tilda\";\n public fileExtension = Extension.CSV;\n\n public async format(\n products: Product[],\n categories?: Category[],\n _?: FormatterOptions,\n ): Promise<string> {\n const mappedCategories: Record<number, string> = {};\n categories?.forEach(({ id, name }) => (mappedCategories[id] = name));\n\n const data = products.map((product) => ({\n SKU: product.vendorCode,\n Brand: product.vendor,\n Category: mappedCategories[product.categoryId],\n Title: product.title,\n Text: product.description,\n Photo: product.images?.join(\";\"),\n Price: product.price,\n \"Price Old\": product.oldPrice,\n Quantity: product.count,\n Editions: product.params\n ?.map(({ key, value }) => `${key}:${value}`)\n .join(\";\"),\n \"External ID\": product.variantId,\n \"Parent UID\": product.parentId,\n }));\n\n return json2csv(data, { emptyFieldValue: \"\", delimiter: { field: \";\" } });\n }\n}\n","import { XMLBuilder } from \"fast-xml-parser\";\n\nimport { type Product, type Category } from \"../types\";\nimport {\n Extension,\n type FormatterAbstract,\n type FormatterOptions,\n} from \"./formater.types\";\n\nexport class YMLFormatter implements FormatterAbstract {\n public formatterName = \"YMl\";\n public fileExtension = Extension.YML;\n private readonly builder = new XMLBuilder({\n ignoreAttributes: false,\n format: true,\n cdataPropName: \"__cdata\",\n });\n\n public async format(\n products: Product[],\n categories?: Category[],\n options?: FormatterOptions,\n ): Promise<string> {\n const mappedCategories = {\n category: categories?.map((cat) => ({\n \"@_id\": cat.id,\n \"@_parentId\": cat.parentId,\n \"#text\": cat.name,\n })),\n };\n const shopName = options?.shopName ?? \"ShopName\";\n const companyName = options?.companyName ?? \"CompanyName\";\n const offers = { offer: products.map(this.getOffers) };\n const result = {\n \"?xml\": {\n \"@_version\": \"1.0\",\n \"@_encoding\": \"UTF-8\",\n \"@_standalone\": \"yes\",\n },\n yml_catalog: {\n \"@_date\": new Date().toISOString().replace(/.\\d+Z/, \"\"),\n shop: {\n name: shopName,\n company: companyName,\n categories: mappedCategories,\n offers,\n },\n },\n };\n\n return this.builder.build(result);\n }\n\n private getOffers(product: Product): any {\n const result = {\n \"@_id\": product.variantId,\n name: product.title,\n price: product.price,\n oldprice: product.oldPrice,\n purchase_price: product.purchasePrice,\n additional_expenses: product.additionalExpenses,\n cofinance_price: product.cofinancePrice,\n currencyId: product.currency,\n categoryId: product.categoryId,\n vendor: product.vendor,\n vendorCode: product.vendorCode,\n picture: product.images,\n video: product.videos,\n available: product.available,\n series: product.seriesName,\n \"min-quantity\": product.minQuantity,\n \"step-quantity\": product.stepQuantity,\n size: product.sizes?.map((size) => ({\n \"#text\": size.value,\n \"@_name\": size.name,\n \"@_delimiter\": size.delimiter,\n })),\n keyword: product.keywords,\n saleDate: product.saleDate,\n property: product.properties?.map((property) => ({\n \"#text\": property.value,\n \"@_name\": property.key,\n })),\n param: product.params?.map((param) => ({\n \"#text\": param.value,\n \"@_name\": param.key,\n })),\n description: {\n __cdata: product.description,\n },\n country_of_origin: product.countryOfOrigin,\n barcode: product.barcode,\n vat: product.vat,\n count: product.count,\n \"set-ids\": product.tags?.join(\", \"),\n adult: product.adult,\n downloadable: product.downloadable,\n \"period-of-validity-days\": product.validityPeriod,\n \"comment-validity-days\": product.validityComment,\n \"service-life-days\": product.serviceLifePeriod,\n \"comment-life-days\": product.serviceLifeComment,\n \"warranty-days\": product.warrantyPeriod,\n \"comment-warranty\": product.warrantyComment,\n manufacturer_warranty: product.manufacturerWarranty,\n certificate: product.certificate,\n url: product.url,\n weight: product.weight,\n dimensions: product.dimensions,\n boxCount: product.boxCount,\n disabled: product.disabled,\n age: product.age != null && {\n \"@_unit\": product.age.unit,\n \"#text\": product.age.value,\n },\n \"tn-ved-codes\": product.codesTN?.length != null && {\n \"tn-ved-code\": product.codesTN,\n },\n relatedProduct: product.relatedProducts,\n gender: product.gender,\n };\n if (product.parentId !== undefined) {\n return {\n ...result,\n \"@_group_id\": product.parentId,\n };\n }\n return result;\n }\n}\n","import { CSVFormatter } from \"./CSV.formatter\";\nimport { ExcelFormatter } from \"./Excel.formatter\";\nimport { InsalesFormatter } from \"./Insales.formatter\";\nimport { JSONFormatter } from \"./JSON.formatter\";\nimport { TgShopFormatter } from \"./TgShop.formatter\";\nimport { TildaFormatter } from \"./Tilda.formatter\";\nimport { YMLFormatter } from \"./YML.formatter\";\n\nexport * from \"./formater.types\";\n\nexport const Formatters = {\n TildaFormatter,\n CSVFormatter,\n InsalesFormatter,\n YMLFormatter,\n TgShopFormatter,\n ExcelFormatter,\n JSONFormatter,\n};\n","import deepcopy from \"deepcopy\";\n\nimport {\n type FormatterAbstract,\n type FormatterOptions,\n Formatters,\n} from \"../formatter\";\nimport { type Category, type Product } from \"../types\";\nimport { type Exporter, type Transformer } from \"./exporter.types\";\n\nimport * as fs from \"fs\";\n\nexport class GoodsExporter {\n private formatter: FormatterAbstract = new Formatters.YMLFormatter();\n private exporter: Exporter = (data: Buffer) => {\n const filename = `${this.formatter.formatterName}.output.${this.formatter.fileExtension}`;\n fs.writeFileSync(filename, data);\n return data;\n };\n\n private transformers = new Array<Transformer>();\n\n public setTransformers(transformers: Transformer[]): void {\n this.transformers = transformers;\n }\n\n public setFormatter(formatter: FormatterAbstract): void {\n this.formatter = formatter;\n }\n\n public setExporter(exporter: Exporter): void {\n this.exporter = exporter;\n }\n\n async export(\n products: Product[],\n categories?: Category[],\n option?: FormatterOptions,\n ): Promise<Buffer> {\n const copyProducts = deepcopy(products);\n const transformedProducts = await Promise.all(\n copyProducts.map(async (product) => {\n let transformedProduct: Product = product;\n for (const transformer of this.transformers)\n transformedProduct = await transformer(transformedProduct);\n return transformedProduct;\n }),\n );\n const data = await this.formatter.format(\n transformedProducts,\n categories,\n option,\n );\n\n if (typeof data === \"string\") {\n return await this.exporter(Buffer.from(data, \"utf-8\"));\n }\n return await this.exporter(data);\n }\n}\n","export interface Product {\n /**\n * **ID товара**\n *\n * Любая последовательность длиной до 80 знаков. В нее могут входить английские и русские (кроме ё) буквы, цифры и символы . , / \\ ( ) [ ] - = _\n *\n * Пример: belaya-kofta-12345\n */\n productId: number;\n /**\n * **Родительскй SKU**\n *\n * Любая последовательность длиной до 80 знаков. В нее могут входить английские и русские (кроме ё) буквы, цифры и символы . , / \\ ( ) [ ] - = _\n *\n * Пример: belaya-kofta-12345\n */\n parentId?: number;\n /**\n * **SKU**\n *\n * Любая последовательность длиной до 80 знаков. В нее могут входить английские и русские (кроме ё) буквы, цифры и символы . , / \\ ( ) [ ] - = _\n *\n * Пример: belaya-kofta-12345\n */\n variantId: number;\n /**\n * **Название**\n *\n * Составляйте название по схеме: тип + бренд или производитель + модель + особенности, если есть (например, цвет, размер или вес) и количество в упаковке.\n *\n * Не включайте в название условия продажи (например, «скидка», «бесплатная доставка» и т. д.), эмоциональные характеристики («хит», «супер» и т. д.). Не пишите слова большими буквами — кроме устоявшихся названий брендов и моделей.\n *\n * Оптимальная длина — 50–60 символов, максимальная — 150.\n *\n * Составлять хорошие названия помогут [рекомендации](https://yandex.ru/support/marketplace/assortment/fields/title.html).\n *\n * Пример: Ударная дрель Makita HP1630, 710 Вт\n */\n title: string;\n /**\n * **Описание**\n *\n * Подробное описание товара: например, его преимущества и особенности.\n *\n * Не давайте в описании инструкций по установке и сборке. Не используйте слова «скидка», «распродажа», «дешевый», «подарок» (кроме подарочных категорий), «бесплатно», «акция», «специальная цена», «новинка», «new», «аналог», «заказ», «хит». Не указывайте никакой контактной информации и не давайте ссылок.\n *\n * Можно использовать теги:\n *\n ** &lt;h&gt;, &lt;h1&gt;, &lt;h2&gt; и так далее — для заголовков;\n ** &lt;br&gt; и &lt;p&gt; — для переноса строки;\n ** &lt;ol&gt; — для нумерованного списка;\n ** &lt;ul&gt; — для маркированного списка;\n ** &lt;li&gt; — для создания элементов списка (должен находиться внутри &lt;ol&gt; или &lt;ul&gt;);\n ** &lt;div&gt; — поддерживается, но не влияет на отображение текста.\n * Оптимальная длина — 400–600 символов, максимальная — 6000.\n *\n * Составить хорошее описание помогут рекомендации.\n *\n * Пример: В комплекте с детским микроскопом есть все, что нужно вашему ребенку для изучения микромира\n */\n description: string;\n /**\n * **Бренд**\n *\n * Название бренда или производителя.\n *\n * Записывайте название так, как его пишет сам бренд.\n *\n * Пример: LEVENHUK\n */\n vendor?: string;\n /**\n * **Артикул производителя**\n *\n * Код товара, который ему присвоил производитель.\n *\n * Если артикулов несколько, укажите их через запятую.\n *\n * Пример: VNDR-0005A, VNDR-0005B\n */\n vendorCode?: string;\n /**\n * **Дата выхода**\n *\n * Пример: 01.01.2000\n */\n saleDate?: string;\n /**\n * **Категория в магазине**\n *\n * Категория, к которой вы относите товар. Она помогает точнее определить для товара категорию на Маркете.\n *\n * Указывайте конкретные категории — например, набор ножей лучше отнести к категории Столовые приборы, а не просто Посуда.\n *\n * Выбирайте категории, которые описывают товар, а не абстрактный признак — например, лучше указать Духи, а не Подарки.\n *\n * Содержит номер категории, а не ее название.\n */\n categoryId: number;\n /**\n * **Страна производства**\n *\n * Страна, где был произведен товар.\n *\n * Записывайте названия стран так, как они записаны в [списке](https://yastatic.net/s3/doc-binary/src/support/market/ru/countries.xlsx).\n *\n * Пример: Россия\n */\n countryOfOrigin?: string;\n /**\n * **Изображение**\n *\n * До двадцати изображений, которые показываются на карточке товара.\n *\n * Принимаются jpg- или png-изображения товара, соответствующие [требованиям](https://yandex.ru/support/marketplace/assortment/fields/images.html).\n *\n * В кабинете изображения добавляются в виде файлов. В Excel-файле — в виде ссылок через запятую. Первое фото становится основным.\n *\n * Чтобы изменить изображение, выложите новое по новой ссылке, иначе картинка не обновится.\n */\n images?: string[];\n /**\n * **Видео**\n *\n * Видеоиллюстрации для карточки товара.\n *\n * Видео должно соответствовать [требованиям](https://yandex.ru/support/marketplace/assortment/fields/video.html).\n *\n * Можно добавить не больше 6 видео.\n *\n * В кабинете можно загрузить видеофайлы. В Excel-шаблоне укажите ссылки на файлы.\n */\n videos?: string[];\n /**\n * **Базовая цена**\n *\n * Цена указывается в рублях. Число должно быть целым.\n *\n * Пример:\n *\n * 240\n */\n price: number;\n /**\n * **Цена до скидки**\n *\n * Цена указывается в рублях. Число должно быть целым.\n *\n * Вы можете указать цену со скидкой от 5 до 75 %.\n *\n * Пример:\n *\n * 250\n */\n oldPrice?: number;\n /**\n * **Себестоимость**\n *\n * Цена указывается в рублях. Число должно быть целым.\n *\n * Пример:\n *\n * 200\n */\n purchasePrice?: number;\n /**\n * **Дополнительные расходы**\n *\n * Дополнительные расходы на товар. Например, на доставку или упаковку.\n *\n * После заполнения этого поля в калькуляторе и на странице управления ценами рассчитается потенциальная маржинальность товара.\n *\n * Цена указывается в рублях. Число должно быть целым.\n *\n * Пример:\n *\n * 75\n */\n additionalExpenses?: number;\n /**\n * **Порог для скидок с Маркетом**\n *\n * Цена указывается в рублях. Число должно быть целым.\n *\n * Пример:\n *\n * 300\n */\n cofinancePrice?: number;\n /**\n * **Валюта (DBS)**\n *\n * Валюта, в которой указана цена товара. Покупателям Маркет показывает цену в рублях, пересчитывая ее по курсу Центробанка.\n *\n * Поле используется, если для кабинета еще не включена работа с базовыми ценами.\n *\n * Поддерживаются российские и белорусские рубли, евро, доллары, украинские гривны и казахстанские тенге.\n *\n * В кабинете валюту можно просто выбрать из списка. В Excel-файле указывается код валюты: RUR, BYN, EUR, USD, UAN, KZT.\n */\n currency: Currency;\n /**\n * **Ссылка на страницу товара**\n *\n * Адрес страницы на вашем сайте с фотографиями и описанием товара.\n *\n * Максимальная длина URL — 512 символов. Записывайте его согласно стандарту RFC 3986.\n *\n * Пример: http://best.seller.ru/product_page.asp?pid=12346\n */\n url?: string;\n /**\n * **Убрать из продажи**\n *\n * Поле позволяет приостановить продажу товара.\n *\n * Укажите значение true, если нужно приостановить продажу.\n */\n disabled?: boolean;\n /**\n * **Доступное количество товара**\n *\n * Общее количество товара, доступное для продажи\n *\n * Укажите 0, если товара нет в наличии.\n *\n * Пример: 7\n */\n count?: number;\n /**\n * **Товар в наличии (DBS)**\n *\n * Поле указывает, есть ли товар в наличии.\n */\n available?: boolean;\n /**\n * **Минимальное количество товара**\n *\n * Если значение задано, покупатель не сможет заказать меньше единиц товара. Ограничение не работает, когда товара на складе осталось меньше этого количества — тогда покупатель сможет сделать заказ на остаток.\n *\n * Целое число.\n */\n minQuantity?: number;\n /**\n * **Квант продажи**\n *\n * Если значение задано, покупатель сможет добавить к заказу только кратное количество товара. Ограничение не работает, когда на складе осталось меньше этого количества — тогда покупатель сможет сделать заказ на остаток.\n *\n * Целое число.\n */\n stepQuantity?: number;\n /**\n * **Штрихкод**\n *\n * Указывайте в виде последовательности символов. Подойдут коды EAN-13, EAN-8, UPC-A, UPC-E или Code 128.\n *\n * Для книг указывайте ISBN.\n *\n * Для товаров [определенных категорий и торговых марок](https://yastatic.net/s3/doc-binary/src/support/market/ru/yandex-market-list-for-gtin.xlsx) штрихкод должен быть действительным кодом GTIN. Обратите внимание: внутренние штрихкоды, начинающиеся на 2 или 02, и коды формата Code 128 не являются GTIN.\n *\n * Если штрихкодов несколько, напишите все через запятую.\n *\n * Пример: 46012300000000\n */\n barcode?: string;\n /**\n * **Код ТН ВЭД**\n *\n * Для некоторых категорий товаров код ТН ВЭД обязателен. Если это касается ваших товаров, вы получите уведомление в каталоге.\n *\n * 10 или 14 цифр без пробелов.\n *\n * Пример: 8517610008\n */\n codesTN?: string[];\n /**\n * **С какого возраста пользоваться**\n *\n * Если товар не предназначен для детей младше определенного возраста, укажите это.\n *\n * Возрастные ограничения можно задавать в годах (с нуля, с 6, 12, 16 или 18) или в месяцах (любое число от 0 до 12).\n */\n age?: { unit: \"year\" | \"month\"; value: number };\n /**\n * **Вес с упаковкой**\n *\n * Вес товара с упаковкой.\n *\n * Единица измерения — килограммы. Можно дроби: разделитель — точка или запятая, не больше трех цифр после него.\n *\n * Пример: 3.1\n */\n weight?: number;\n /**\n * **Габариты с упаковкой**\n *\n * Длина, ширина, высота в упаковке.\n *\n * Единица измерения — сантиметры. Можно дроби: разделитель — точка или запятая, не больше трех цифр после него.\n *\n * Пример: 20.1/20.551/22.5\n */\n dimensions?: string;\n /**\n * **Товар занимает больше одного места**\n *\n * Если товар занимает одно место (представляет собой одну коробку, упаковку и так далее), оставьте поле пустым. Если товар занимает несколько мест — укажите их количество. Например, кондиционер занимает два места — внешний и внутренний блоки в двух коробках.\n *\n * Укажите количество мест.\n *\n * Пример: 2\n */\n boxCount?: number;\n /**\n * **Ставка НДС**\n *\n * Значение ставки НДС для товара.\n *\n * Выберите одно из значений:\n *\n ** НДС не облагается — 6 или NO_VAT\n *\n ** 0 % — 5 или VAT_0\n *\n ** 10 % — 2 или VAT_10\n *\n ** 20 % — 7 или VAT_20\n *\n * Если не заполнено, Маркет устанавливает ставку, соответствующую схеме налогообложения.\n *\n * Пример: VAT_20\n */\n vat: Vat;\n /**\n * **Характеристики, которые есть только у товаров конкретной категории**\n *\n * Кроме общих свойств, у товара есть характеристики, присущие конкретной категории, к которой он относится. Например, у велосипеда есть размер рамы, а детское пюре бывает овощное, мясное или фруктовое.\n */\n params?: IParam[];\n /**\n * **Свойства товара**\n *\n * *не YML поле\n */\n properties?: IParam[];\n /**\n * **Теги**\n *\n * Придумайте любое название — его можно будет изменить после.\n *\n * Максимальная длина тега — 20 символов.\n *\n * У одного товара — максимум 10 тегов.\n *\n * Всего можно создать не больше 50 разных тегов.\n *\n * Пример: apple, до 500 рублей\n */\n tags?: string[];\n /**\n * **Товар для взрослых**\n *\n * Параметр включает для товара пометку 18+. Устанавливайте ее только для товаров, которые относятся к удовлетворению сексуальных потребностей.\n */\n adult?: boolean;\n /**\n * **Цифровой товар**\n *\n * Параметр, устанавливаемый для цифровых товаров, которые просто скачиваются.\n */\n downloadable?: boolean;\n /**\n * **Срок годности**\n *\n * Период с момента изготовления, по прошествии которого товар становится непригоден.\n *\n * Указывайте срок, указанный на банке или упаковке. Текущая дата, дата поставки или дата отгрузки значения не имеет.\n *\n * Срок можно указывать в годах, месяцах, днях, неделях и часах.\n *\n * Обязательно указывайте срок, если он есть.\n *\n * Продолжительность указывается согласно ISO 8601, то есть в виде строчки, начинающейся буквой P:\n *\n ** P1Y — 1 год;\n ** P1Y6M — 1 год и 6 месяцев;\n ** P15D — 15 дней.\n */\n validityPeriod?: string;\n /**\n * **Комментарий к сроку годности**\n *\n * Поле предназначено для описаний условий хранения.\n *\n * Не длиннее 250 знаков и без спецсимволов.\n *\n * Пример: Хранить в сухом помещении\n */\n validityComment?: string;\n /**\n * **Срок службы**\n *\n * В течение срока службы товар должен исправно выполнять свою функцию.\n *\n * Обязательно указывайте срок, если он есть.\n *\n * Срок можно указывать в годах, месяцах и днях.\n * Продолжительность указывается согласно ISO 8601, то есть в виде строчки, начинающейся буквой P:\n *\n ** P1Y — 1 год;\n ** P1Y2M — 1 год и 2 месяца;\n ** P15D — 15 дней;\n ** P2Y10D — 2 года, 10 дней;\n ** P2Y6M10D — 2 года, 6 месяцев и 10 дней.\n */\n serviceLifePeriod?: string;\n /**\n * **Комментарий к сроку службы**\n *\n * Поле предназначено для описаний условий использования.\n *\n * Не длиннее 250 знаков и без спецсимволов.\n *\n * Пример: Использовать при температуре не ниже −10 градусов\n */\n serviceLifeComment?: string;\n /**\n * **Гарантийный срок**\n *\n * В течение какого времени можно бесплатно заменить или починить товар.\n *\n * Срок можно указывать в годах, месяцах или днях.\n *\n * Продолжительность указывается согласно ISO 8601, то есть в виде строчки, начинающейся буквой P:\n *\n ** P1Y — 1 год;\n ** P1Y2M — 1 год и 2 месяца;\n ** P15D — 15 дней;\n ** P2Y10D — 2 года, 10 дней;\n ** P2Y6M10D — 2 года, 6 месяцев и 10 дней.\n */\n warrantyPeriod?: string;\n /**\n * **Комментарий к гарантийному сроку**\n *\n * Поле предназначено для описания особенностей гарантийных условий.\n *\n * Указывайте только то, что относится к гарантии изготовителя.\n *\n * Не длиннее 250 знаков и без спецсимволов.\n *\n * Пример: Гарантия на аккумулятор — 6 месяцев\n */\n warrantyComment?: string;\n /**\n * **Официальная гарантия производителя**\n */\n manufacturerWarranty?: boolean;\n /**\n * **Номер документа**\n *\n * Номер документа на товар: сертификата, декларации соответствия и т. п.\n *\n * Прежде чем указывать номер документа, загрузите скан документа через кабинет.\n *\n * Укажите номер документа.\n *\n * Пример: 6241421\n */\n certificate?: string;\n /**\n * **Ключевые слова**\n *\n * Пример: Кроссовки, высокая подошва\n */\n keywords?: string[];\n /**\n * **Размерная сетка**\n */\n sizes?: ISize[];\n /**\n * **Связанные товары**\n *\n * Указываются id товаров\n *\n * Пример: 1234\n */\n relatedProducts?: number[];\n /**\n * **Название коллекции, ряда или серии товара**\n *\n * Пример: Jordan 4\n */\n seriesName?: string;\n /**\n * **Пол или название группы потребителей**\n *\n * Пример: Дети, Женское, Унисекс\n */\n gender?: string;\n}\n\nexport enum Vat {\n NO_VAT = \"NO_VAT\",\n VAT_0 = \"VAT_0\",\n VAT_10 = \"VAT_10\",\n VAT_20 = \"VAT_20\",\n}\n\nexport enum Currency {\n RUR = \"RUR\",\n BYN = \"BYN\",\n EUR = \"EUR\",\n USD = \"USD\",\n UAN = \"UAN\",\n KZT = \"KZT\",\n}\n\nexport interface IParam {\n /**\n * **Название характеристики**\n */\n key: string;\n /**\n * **Значение**\n */\n value: string;\n}\n\nexport interface ISize {\n /**\n * **Название единицы измерения**\n */\n name: string;\n /**\n * **Разделитель**\n */\n delimiter: string;\n /**\n * **Значения размерного ряда**\n *\n * Размеры указываются через разделитель\n */\n value: string;\n}\n"],"names":["Extension","__publicField","categories","Vat","Currency"],"mappings":"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"}
1
+ {"version":3,"file":"index.mjs","sources":["../../src/util/formatter.util.ts","../../src/formatter/formater.types.ts","../../src/formatter/CSV.formatter.ts","../../src/formatter/Excel.formatter.ts","../../src/formatter/Insales.formatter.ts","../../src/formatter/JSON.formatter.ts","../../src/formatter/TgShop.formatter.ts","../../src/formatter/Tilda.formatter.ts","../../src/formatter/YML.formatter.ts","../../src/formatter/index.ts","../../src/exporter/goodsExporter.ts","../../src/types/Product.types.ts"],"sourcesContent":["import { type FormatterOptions } from \"../formatter\";\nimport { type Product } from \"../types\";\n\nconst getParams = (\n product: Product,\n option?: FormatterOptions,\n): Record<string, string> => {\n const params: Record<string, string> = {};\n\n if (option?.splitParams === false) {\n return params;\n }\n\n product.params?.forEach(\n ({ key, value }) => (params[`Param [${key}]`] = value),\n );\n return params;\n};\n\nconst getProperties = (\n product: Product,\n option?: FormatterOptions,\n): Record<string, string> => {\n const properties: Record<string, string> = {};\n\n if (option?.splitParams === false) {\n return properties;\n }\n\n product.properties?.forEach(\n ({ key, value }) => (properties[`Property [${key}]`] = value),\n );\n return properties;\n};\n\nconst getSizes = (\n product: Product,\n _?: FormatterOptions,\n): Record<string, string> => {\n const sizes: Record<string, string> = {};\n product.sizes?.forEach(\n ({ name, value }) => (sizes[`Size [${name}]`] = value),\n );\n return sizes;\n};\n\nexport const UTILS = {\n getSizes,\n getParams,\n getProperties,\n};\n","import { type Brand, type Category, type Product } from \"../types\";\n\nexport abstract class FormatterAbstract {\n public abstract formatterName: string;\n public abstract fileExtension: Extension;\n\n public abstract format(\n products: Product[],\n categories?: Category[],\n brands?: Brand[],\n option?: FormatterOptions,\n ): Promise<Buffer | string>;\n}\n\nexport interface FormatterOptions {\n shopName?: string;\n\n companyName?: string;\n\n splitParams?: boolean;\n}\n\nexport enum Extension {\n CSV = \"csv\",\n YML = \"yml\",\n XLSX = \"xlsx\",\n JSON = \"json\",\n}\n","import { json2csv } from \"json-2-csv\";\n\nimport { type Brand, type Category, type Product } from \"../types\";\nimport { UTILS } from \"../util/formatter.util\";\nimport {\n Extension,\n type FormatterAbstract,\n type FormatterOptions,\n} from \"./formater.types\";\n\nexport class CSVFormatter implements FormatterAbstract {\n public formatterName = \"CSV\";\n public fileExtension = Extension.CSV;\n\n public async format(\n products: Product[],\n categories?: Category[],\n _?: Brand[],\n options?: FormatterOptions,\n ): Promise<string> {\n const mappedCategories: Record<number, string> = {};\n categories?.forEach(({ id, name }) => (mappedCategories[id] = name));\n\n const data = products.map((product) => ({\n ...product,\n category: mappedCategories[product.categoryId],\n images: product.images?.join(\",\"),\n videos: product.videos?.join(\",\"),\n tags: product.tags?.join(\",\"),\n codesTN: product.codesTN?.join(\", \"),\n params: product.params\n ?.map(({ key, value }) => `${key}=${value}`)\n .join(\",\"),\n ...UTILS.getParams(product, options),\n ...UTILS.getProperties(product, options),\n ...UTILS.getSizes(product, options),\n sizes: undefined,\n keywords: product.keywords?.join(\",\"),\n relatedProducts: product.relatedProducts?.join(\",\"),\n }));\n return json2csv(data, { emptyFieldValue: \"\" });\n }\n}\n","import xlsx from \"xlsx\";\n\nimport { type Brand, type Category, type Product } from \"../types\";\nimport { UTILS } from \"../util/formatter.util\";\nimport {\n Extension,\n type FormatterAbstract,\n type FormatterOptions,\n} from \"./formater.types\";\nconst { writeXLSX, utils } = xlsx;\n\nexport class ExcelFormatter implements FormatterAbstract {\n public formatterName = \"Excel\";\n public fileExtension = Extension.XLSX;\n\n public async format(\n products: Product[],\n categories?: Category[],\n _?: Brand[],\n options?: FormatterOptions,\n ): Promise<Buffer> {\n const mappedCategories: Record<number, string> = {};\n categories?.forEach(({ id, name }) => (mappedCategories[id] = name));\n\n const data = products.map((product) => ({\n ...product,\n category: mappedCategories[product.categoryId],\n images: product.images?.join(\",\"),\n videos: product.videos?.join(\",\"),\n tags: product.tags?.join(\",\"),\n keywords: product.keywords?.join(\",\"),\n relatedProducts: product.relatedProducts?.join(\",\"),\n codesTN: product.codesTN?.join(\", \"),\n params: product.params\n ?.map(({ key, value }) => `${key}=${value}`)\n .join(\",\"),\n sizes: undefined,\n ...UTILS.getParams(product, options),\n ...UTILS.getProperties(product, options),\n ...UTILS.getSizes(product, options),\n }));\n const workBook = utils.book_new();\n const productsWorkSheet = utils.json_to_sheet(data);\n\n utils.book_append_sheet(workBook, productsWorkSheet, \"products\");\n return writeXLSX(workBook, { type: \"buffer\" });\n }\n}\n","import xlsx from \"xlsx\";\n\nimport { type Brand, type Category, type Product } from \"../types\";\nimport {\n Extension,\n type FormatterAbstract,\n type FormatterOptions,\n} from \"./formater.types\";\n\nexport class InsalesFormatter implements FormatterAbstract {\n public formatterName = \"Insales\";\n public fileExtension = Extension.XLSX;\n\n public async format(\n products: Product[],\n categories?: Category[],\n _?: Brand[],\n __?: FormatterOptions,\n ): Promise<Buffer> {\n const mappedCategories: Record<number, Category> = {};\n categories?.forEach(\n (category) => (mappedCategories[category.id] = category),\n );\n\n const getParams = (product: Product): Record<string, string> => {\n const properties: Record<string, string> = {};\n\n product.params?.forEach(\n (p) => (properties[`Свойство: ${p.key}`] = p.value),\n );\n\n return properties;\n };\n const getProperties = (product: Product): Record<string, string> => {\n const properties: Record<string, string> = {};\n\n product.properties?.forEach(\n (p) => (properties[`Параметр: ${p.key}`] = p.value),\n );\n\n return properties;\n };\n\n const getSizes = (product: Product): Record<string, string> => {\n const sizes: Record<string, string> = {};\n\n product.sizes?.forEach(\n ({ name, value }) => (sizes[`Размеры [${name}]:`] = value),\n );\n\n return sizes;\n };\n\n const getCategories = (product: Product) => {\n const categories: Record<string, string> = {};\n const categoryList = new Array<string>();\n\n function addCategory(categoryId: number | undefined) {\n if (categoryId === undefined) return;\n\n const category = mappedCategories[categoryId];\n if (category) {\n categoryList.push(category.name);\n addCategory(category.parentId);\n }\n }\n\n addCategory(product.categoryId);\n\n categoryList.forEach((name, i) => {\n const index = categoryList.length - 1 - i;\n const key = index === 0 ? \"Корневая\" : `Подкатегория ${index}`;\n categories[key] = name;\n });\n\n return categories;\n };\n\n const data = products.map((product) => ({\n \"Внешний ID\": product.productId,\n \"Ссылка на товар\": product.url,\n Артикул: product.vendorCode,\n \"Название товара или услуги\": product.title,\n \"Старая цена\": product.oldPrice,\n \"Цена продажи\": product.price,\n \"Цена закупки\": product.purchasePrice,\n ...getCategories(product),\n Остаток: product.count,\n \"Штрих-код\": product.barcode,\n \"Краткое описание\": undefined,\n \"Полное описание\": product.description,\n \"Габариты варианта\": product.dimensions,\n Вес: product.weight,\n \"Размещение на сайте\": product.available,\n НДС: product.vat.toString(),\n \"Валюта склада\": product.currency.toString(),\n \"Изображения варианта\": product.images?.join(\" \"),\n Изображения: product.images?.join(\" \"),\n \"Ссылка на видео\": product.videos ? product.videos[0] : undefined,\n ...getParams(product),\n ...getProperties(product),\n \"Параметр: Бренд\": product.vendor,\n \"Параметр: Коллекция\": product.seriesName,\n \"Параметр: Пол\": product.gender,\n \"Параметр: Дата выхода\": product.saleDate,\n ...getSizes(product),\n \"Связанные товары\": product.relatedProducts?.join(\",\"),\n }));\n const workBook = xlsx.utils.book_new();\n const productsWorkSheet = xlsx.utils.json_to_sheet(data);\n\n xlsx.utils.book_append_sheet(workBook, productsWorkSheet, \"products\");\n\n return xlsx.write(workBook, { bookType: \"xlsx\", type: \"buffer\" });\n }\n}\n","import { type Product, type Category, type Brand } from \"../types\";\nimport {\n Extension,\n type FormatterAbstract,\n type FormatterOptions,\n} from \"./formater.types\";\n\nexport class JSONFormatter implements FormatterAbstract {\n public formatterName = \"JSON\";\n public fileExtension = Extension.JSON;\n\n public async format(\n products: Product[],\n categories?: Category[],\n brands?: Brand[],\n _?: FormatterOptions,\n ): Promise<string> {\n const result = {\n categories,\n brands,\n products,\n };\n\n return JSON.stringify(result);\n }\n}\n","import xlsx from \"xlsx\";\n\nimport { type Brand, type Category, type IParam, type Product } from \"../types\";\nimport {\n Extension,\n type FormatterAbstract,\n type FormatterOptions,\n} from \"./formater.types\";\n\nexport class TgShopFormatter implements FormatterAbstract {\n public formatterName = \"TgShop\";\n public fileExtension = Extension.XLSX;\n\n public async format(\n products: Product[],\n categories?: Category[],\n _?: Brand[],\n __?: FormatterOptions,\n ): Promise<Buffer> {\n const getParameter = (product: Product, key: string): IParam | undefined =>\n product.params?.find((value) => value.key === key);\n const productsData = products.map((product) => ({\n \"category id\": product.categoryId,\n \"group id\": product.parentId,\n \"id product\": product.variantId,\n \"name product\": product.title,\n price: product.price,\n picture: product.images?.join(\", \"),\n vendorCode: product.vendorCode,\n oldprice: product.oldPrice,\n description: product.description,\n shortDescription: product.description,\n quantityInStock: product.count,\n color: getParameter(product, \"color\")?.value,\n size: getParameter(product, \"size\")?.value,\n priority: undefined,\n }));\n\n const workBook = xlsx.utils.book_new();\n const productsWorkSheet = xlsx.utils.json_to_sheet(productsData);\n const categoriesWorkSheet = xlsx.utils.json_to_sheet(categories ?? []);\n\n xlsx.utils.book_append_sheet(workBook, categoriesWorkSheet, \"categories\");\n xlsx.utils.book_append_sheet(workBook, productsWorkSheet, \"offers\");\n\n return xlsx.write(workBook, { bookType: \"xlsx\", type: \"buffer\" });\n }\n}\n","import { json2csv } from \"json-2-csv\";\n\nimport { type Brand, type Category, type Product } from \"../types\";\nimport {\n Extension,\n type FormatterAbstract,\n type FormatterOptions,\n} from \"./formater.types\";\n\nexport class TildaFormatter implements FormatterAbstract {\n public formatterName = \"Tilda\";\n public fileExtension = Extension.CSV;\n\n public async format(\n products: Product[],\n categories?: Category[],\n _?: Brand[],\n __?: FormatterOptions,\n ): Promise<string> {\n const mappedCategories: Record<number, string> = {};\n categories?.forEach(({ id, name }) => (mappedCategories[id] = name));\n\n const data = products.map((product) => ({\n SKU: product.vendorCode,\n Brand: product.vendor,\n Category: mappedCategories[product.categoryId],\n Title: product.title,\n Text: product.description,\n Photo: product.images?.join(\";\"),\n Price: product.price,\n \"Price Old\": product.oldPrice,\n Quantity: product.count,\n Editions: product.params\n ?.map(({ key, value }) => `${key}:${value}`)\n .join(\";\"),\n \"External ID\": product.variantId,\n \"Parent UID\": product.parentId,\n }));\n\n return json2csv(data, { emptyFieldValue: \"\", delimiter: { field: \";\" } });\n }\n}\n","import { XMLBuilder } from \"fast-xml-parser\";\n\nimport { type Product, type Category, type Brand } from \"../types\";\nimport {\n Extension,\n type FormatterAbstract,\n type FormatterOptions,\n} from \"./formater.types\";\n\nexport class YMLFormatter implements FormatterAbstract {\n public formatterName = \"YMl\";\n public fileExtension = Extension.YML;\n private readonly builder = new XMLBuilder({\n ignoreAttributes: false,\n format: true,\n cdataPropName: \"__cdata\",\n });\n\n public async format(\n products: Product[],\n categories?: Category[],\n brands?: Brand[],\n options?: FormatterOptions,\n ): Promise<string> {\n const offers = { offer: products.map(this.getOffers) };\n const result = {\n \"?xml\": {\n \"@_version\": \"1.0\",\n \"@_encoding\": \"UTF-8\",\n \"@_standalone\": \"yes\",\n },\n yml_catalog: {\n \"@_date\": new Date().toISOString().replace(/.\\d+Z/, \"\"),\n shop: {\n name: options?.shopName,\n company: options?.companyName,\n categories: this.getCategories(categories),\n brands: this.getBrands(brands),\n offers,\n },\n },\n };\n\n return this.builder.build(result);\n }\n\n private getBrands(brands?: Brand[]) {\n return {\n brand: brands?.map((brand) => ({\n \"@_id\": brand.id,\n \"@_url\": brand.coverURL,\n \"#text\": brand.name,\n })),\n };\n }\n\n private getCategories(categories?: Category[]) {\n return {\n category: categories?.map((cat) => ({\n \"@_id\": cat.id,\n \"@_parentId\": cat.parentId,\n \"#text\": cat.name,\n })),\n };\n }\n\n private getOffers(product: Product): any {\n const result = {\n \"@_id\": product.variantId,\n name: product.title,\n price: product.price,\n oldprice: product.oldPrice,\n purchase_price: product.purchasePrice,\n additional_expenses: product.additionalExpenses,\n cofinance_price: product.cofinancePrice,\n currencyId: product.currency,\n categoryId: product.categoryId,\n vendor: product.vendor,\n vendorCode: product.vendorCode,\n picture: product.images,\n video: product.videos,\n available: product.available,\n series: product.seriesName,\n \"min-quantity\": product.minQuantity,\n \"step-quantity\": product.stepQuantity,\n size: product.sizes?.map((size) => ({\n \"#text\": size.value,\n \"@_name\": size.name,\n \"@_delimiter\": size.delimiter,\n })),\n keyword: product.keywords,\n saleDate: product.saleDate,\n property: product.properties?.map((property) => ({\n \"#text\": property.value,\n \"@_name\": property.key,\n })),\n param: product.params?.map((param) => ({\n \"#text\": param.value,\n \"@_name\": param.key,\n })),\n description: {\n __cdata: product.description,\n },\n country_of_origin: product.countryOfOrigin,\n barcode: product.barcode,\n vat: product.vat,\n count: product.count,\n \"set-ids\": product.tags?.join(\", \"),\n adult: product.adult,\n downloadable: product.downloadable,\n \"period-of-validity-days\": product.validityPeriod,\n \"comment-validity-days\": product.validityComment,\n \"service-life-days\": product.serviceLifePeriod,\n \"comment-life-days\": product.serviceLifeComment,\n \"warranty-days\": product.warrantyPeriod,\n \"comment-warranty\": product.warrantyComment,\n manufacturer_warranty: product.manufacturerWarranty,\n certificate: product.certificate,\n url: product.url,\n weight: product.weight,\n dimensions: product.dimensions,\n boxCount: product.boxCount,\n disabled: product.disabled,\n age: product.age != null && {\n \"@_unit\": product.age.unit,\n \"#text\": product.age.value,\n },\n \"tn-ved-codes\": product.codesTN?.length != null && {\n \"tn-ved-code\": product.codesTN,\n },\n relatedProduct: product.relatedProducts,\n gender: product.gender,\n };\n if (product.parentId !== undefined) {\n return {\n ...result,\n \"@_group_id\": product.parentId,\n };\n }\n return result;\n }\n}\n","import { CSVFormatter } from \"./CSV.formatter\";\nimport { ExcelFormatter } from \"./Excel.formatter\";\nimport { InsalesFormatter } from \"./Insales.formatter\";\nimport { JSONFormatter } from \"./JSON.formatter\";\nimport { TgShopFormatter } from \"./TgShop.formatter\";\nimport { TildaFormatter } from \"./Tilda.formatter\";\nimport { YMLFormatter } from \"./YML.formatter\";\n\nexport * from \"./formater.types\";\n\nexport const Formatters = {\n TildaFormatter,\n CSVFormatter,\n InsalesFormatter,\n YMLFormatter,\n TgShopFormatter,\n ExcelFormatter,\n JSONFormatter,\n};\n","import deepcopy from \"deepcopy\";\n\nimport {\n type FormatterAbstract,\n type FormatterOptions,\n Formatters,\n} from \"../formatter\";\nimport { type Brand, type Category, type Product } from \"../types\";\nimport { type Exporter, type Transformer } from \"./exporter.types\";\n\nimport * as fs from \"fs\";\n\nexport class GoodsExporter {\n private formatter: FormatterAbstract = new Formatters.YMLFormatter();\n private exporter: Exporter = (data: Buffer) => {\n const filename = `${this.formatter.formatterName}.output.${this.formatter.fileExtension}`;\n fs.writeFileSync(filename, data);\n return data;\n };\n\n private transformers = new Array<Transformer>();\n\n public setTransformers(transformers: Transformer[]): void {\n this.transformers = transformers;\n }\n\n public setFormatter(formatter: FormatterAbstract): void {\n this.formatter = formatter;\n }\n\n public setExporter(exporter: Exporter): void {\n this.exporter = exporter;\n }\n\n async export(\n products: Product[],\n categories?: Category[],\n brands?: Brand[],\n option?: FormatterOptions,\n ): Promise<Buffer> {\n const copyProducts = deepcopy(products);\n const transformedProducts = await Promise.all(\n copyProducts.map(async (product) => {\n let transformedProduct: Product = product;\n for (const transformer of this.transformers)\n transformedProduct = await transformer(transformedProduct);\n return transformedProduct;\n }),\n );\n const data = await this.formatter.format(\n transformedProducts,\n categories,\n brands,\n option,\n );\n\n if (typeof data === \"string\") {\n return await this.exporter(Buffer.from(data, \"utf-8\"));\n }\n return await this.exporter(data);\n }\n}\n","export interface Product {\n /**\n * **ID товара**\n *\n * Любая последовательность длиной до 80 знаков. В нее могут входить английские и русские (кроме ё) буквы, цифры и символы . , / \\ ( ) [ ] - = _\n *\n * Пример: belaya-kofta-12345\n */\n productId: number;\n /**\n * **Родительскй SKU**\n *\n * Любая последовательность длиной до 80 знаков. В нее могут входить английские и русские (кроме ё) буквы, цифры и символы . , / \\ ( ) [ ] - = _\n *\n * Пример: belaya-kofta-12345\n */\n parentId?: number;\n /**\n * **SKU**\n *\n * Любая последовательность длиной до 80 знаков. В нее могут входить английские и русские (кроме ё) буквы, цифры и символы . , / \\ ( ) [ ] - = _\n *\n * Пример: belaya-kofta-12345\n */\n variantId: number;\n /**\n * **Название**\n *\n * Составляйте название по схеме: тип + бренд или производитель + модель + особенности, если есть (например, цвет, размер или вес) и количество в упаковке.\n *\n * Не включайте в название условия продажи (например, «скидка», «бесплатная доставка» и т. д.), эмоциональные характеристики («хит», «супер» и т. д.). Не пишите слова большими буквами — кроме устоявшихся названий брендов и моделей.\n *\n * Оптимальная длина — 50–60 символов, максимальная — 150.\n *\n * Составлять хорошие названия помогут [рекомендации](https://yandex.ru/support/marketplace/assortment/fields/title.html).\n *\n * Пример: Ударная дрель Makita HP1630, 710 Вт\n */\n title: string;\n /**\n * **Описание**\n *\n * Подробное описание товара: например, его преимущества и особенности.\n *\n * Не давайте в описании инструкций по установке и сборке. Не используйте слова «скидка», «распродажа», «дешевый», «подарок» (кроме подарочных категорий), «бесплатно», «акция», «специальная цена», «новинка», «new», «аналог», «заказ», «хит». Не указывайте никакой контактной информации и не давайте ссылок.\n *\n * Можно использовать теги:\n *\n ** &lt;h&gt;, &lt;h1&gt;, &lt;h2&gt; и так далее — для заголовков;\n ** &lt;br&gt; и &lt;p&gt; — для переноса строки;\n ** &lt;ol&gt; — для нумерованного списка;\n ** &lt;ul&gt; — для маркированного списка;\n ** &lt;li&gt; — для создания элементов списка (должен находиться внутри &lt;ol&gt; или &lt;ul&gt;);\n ** &lt;div&gt; — поддерживается, но не влияет на отображение текста.\n * Оптимальная длина — 400–600 символов, максимальная — 6000.\n *\n * Составить хорошее описание помогут рекомендации.\n *\n * Пример: В комплекте с детским микроскопом есть все, что нужно вашему ребенку для изучения микромира\n */\n description: string;\n /**\n * **Бренд**\n *\n * Название бренда или производителя.\n *\n * Записывайте название так, как его пишет сам бренд.\n *\n * Пример: LEVENHUK\n */\n vendor?: string;\n /**\n * **Артикул производителя**\n *\n * Код товара, который ему присвоил производитель.\n *\n * Если артикулов несколько, укажите их через запятую.\n *\n * Пример: VNDR-0005A, VNDR-0005B\n */\n vendorCode?: string;\n /**\n * **Дата выхода**\n *\n * Пример: 01.01.2000\n */\n saleDate?: string;\n /**\n * **Категория в магазине**\n *\n * Категория, к которой вы относите товар. Она помогает точнее определить для товара категорию на Маркете.\n *\n * Указывайте конкретные категории — например, набор ножей лучше отнести к категории Столовые приборы, а не просто Посуда.\n *\n * Выбирайте категории, которые описывают товар, а не абстрактный признак — например, лучше указать Духи, а не Подарки.\n *\n * Содержит номер категории, а не ее название.\n */\n categoryId: number;\n /**\n * **Страна производства**\n *\n * Страна, где был произведен товар.\n *\n * Записывайте названия стран так, как они записаны в [списке](https://yastatic.net/s3/doc-binary/src/support/market/ru/countries.xlsx).\n *\n * Пример: Россия\n */\n countryOfOrigin?: string;\n /**\n * **Изображение**\n *\n * До двадцати изображений, которые показываются на карточке товара.\n *\n * Принимаются jpg- или png-изображения товара, соответствующие [требованиям](https://yandex.ru/support/marketplace/assortment/fields/images.html).\n *\n * В кабинете изображения добавляются в виде файлов. В Excel-файле — в виде ссылок через запятую. Первое фото становится основным.\n *\n * Чтобы изменить изображение, выложите новое по новой ссылке, иначе картинка не обновится.\n */\n images?: string[];\n /**\n * **Видео**\n *\n * Видеоиллюстрации для карточки товара.\n *\n * Видео должно соответствовать [требованиям](https://yandex.ru/support/marketplace/assortment/fields/video.html).\n *\n * Можно добавить не больше 6 видео.\n *\n * В кабинете можно загрузить видеофайлы. В Excel-шаблоне укажите ссылки на файлы.\n */\n videos?: string[];\n /**\n * **Базовая цена**\n *\n * Цена указывается в рублях. Число должно быть целым.\n *\n * Пример:\n *\n * 240\n */\n price: number;\n /**\n * **Цена до скидки**\n *\n * Цена указывается в рублях. Число должно быть целым.\n *\n * Вы можете указать цену со скидкой от 5 до 75 %.\n *\n * Пример:\n *\n * 250\n */\n oldPrice?: number;\n /**\n * **Себестоимость**\n *\n * Цена указывается в рублях. Число должно быть целым.\n *\n * Пример:\n *\n * 200\n */\n purchasePrice?: number;\n /**\n * **Дополнительные расходы**\n *\n * Дополнительные расходы на товар. Например, на доставку или упаковку.\n *\n * После заполнения этого поля в калькуляторе и на странице управления ценами рассчитается потенциальная маржинальность товара.\n *\n * Цена указывается в рублях. Число должно быть целым.\n *\n * Пример:\n *\n * 75\n */\n additionalExpenses?: number;\n /**\n * **Порог для скидок с Маркетом**\n *\n * Цена указывается в рублях. Число должно быть целым.\n *\n * Пример:\n *\n * 300\n */\n cofinancePrice?: number;\n /**\n * **Валюта (DBS)**\n *\n * Валюта, в которой указана цена товара. Покупателям Маркет показывает цену в рублях, пересчитывая ее по курсу Центробанка.\n *\n * Поле используется, если для кабинета еще не включена работа с базовыми ценами.\n *\n * Поддерживаются российские и белорусские рубли, евро, доллары, украинские гривны и казахстанские тенге.\n *\n * В кабинете валюту можно просто выбрать из списка. В Excel-файле указывается код валюты: RUR, BYN, EUR, USD, UAN, KZT.\n */\n currency: Currency;\n /**\n * **Ссылка на страницу товара**\n *\n * Адрес страницы на вашем сайте с фотографиями и описанием товара.\n *\n * Максимальная длина URL — 512 символов. Записывайте его согласно стандарту RFC 3986.\n *\n * Пример: http://best.seller.ru/product_page.asp?pid=12346\n */\n url?: string;\n /**\n * **Убрать из продажи**\n *\n * Поле позволяет приостановить продажу товара.\n *\n * Укажите значение true, если нужно приостановить продажу.\n */\n disabled?: boolean;\n /**\n * **Доступное количество товара**\n *\n * Общее количество товара, доступное для продажи\n *\n * Укажите 0, если товара нет в наличии.\n *\n * Пример: 7\n */\n count?: number;\n /**\n * **Товар в наличии (DBS)**\n *\n * Поле указывает, есть ли товар в наличии.\n */\n available?: boolean;\n /**\n * **Минимальное количество товара**\n *\n * Если значение задано, покупатель не сможет заказать меньше единиц товара. Ограничение не работает, когда товара на складе осталось меньше этого количества — тогда покупатель сможет сделать заказ на остаток.\n *\n * Целое число.\n */\n minQuantity?: number;\n /**\n * **Квант продажи**\n *\n * Если значение задано, покупатель сможет добавить к заказу только кратное количество товара. Ограничение не работает, когда на складе осталось меньше этого количества — тогда покупатель сможет сделать заказ на остаток.\n *\n * Целое число.\n */\n stepQuantity?: number;\n /**\n * **Штрихкод**\n *\n * Указывайте в виде последовательности символов. Подойдут коды EAN-13, EAN-8, UPC-A, UPC-E или Code 128.\n *\n * Для книг указывайте ISBN.\n *\n * Для товаров [определенных категорий и торговых марок](https://yastatic.net/s3/doc-binary/src/support/market/ru/yandex-market-list-for-gtin.xlsx) штрихкод должен быть действительным кодом GTIN. Обратите внимание: внутренние штрихкоды, начинающиеся на 2 или 02, и коды формата Code 128 не являются GTIN.\n *\n * Если штрихкодов несколько, напишите все через запятую.\n *\n * Пример: 46012300000000\n */\n barcode?: string;\n /**\n * **Код ТН ВЭД**\n *\n * Для некоторых категорий товаров код ТН ВЭД обязателен. Если это касается ваших товаров, вы получите уведомление в каталоге.\n *\n * 10 или 14 цифр без пробелов.\n *\n * Пример: 8517610008\n */\n codesTN?: string[];\n /**\n * **С какого возраста пользоваться**\n *\n * Если товар не предназначен для детей младше определенного возраста, укажите это.\n *\n * Возрастные ограничения можно задавать в годах (с нуля, с 6, 12, 16 или 18) или в месяцах (любое число от 0 до 12).\n */\n age?: { unit: \"year\" | \"month\"; value: number };\n /**\n * **Вес с упаковкой**\n *\n * Вес товара с упаковкой.\n *\n * Единица измерения — килограммы. Можно дроби: разделитель — точка или запятая, не больше трех цифр после него.\n *\n * Пример: 3.1\n */\n weight?: number;\n /**\n * **Габариты с упаковкой**\n *\n * Длина, ширина, высота в упаковке.\n *\n * Единица измерения — сантиметры. Можно дроби: разделитель — точка или запятая, не больше трех цифр после него.\n *\n * Пример: 20.1/20.551/22.5\n */\n dimensions?: string;\n /**\n * **Товар занимает больше одного места**\n *\n * Если товар занимает одно место (представляет собой одну коробку, упаковку и так далее), оставьте поле пустым. Если товар занимает несколько мест — укажите их количество. Например, кондиционер занимает два места — внешний и внутренний блоки в двух коробках.\n *\n * Укажите количество мест.\n *\n * Пример: 2\n */\n boxCount?: number;\n /**\n * **Ставка НДС**\n *\n * Значение ставки НДС для товара.\n *\n * Выберите одно из значений:\n *\n ** НДС не облагается — 6 или NO_VAT\n *\n ** 0 % — 5 или VAT_0\n *\n ** 10 % — 2 или VAT_10\n *\n ** 20 % — 7 или VAT_20\n *\n * Если не заполнено, Маркет устанавливает ставку, соответствующую схеме налогообложения.\n *\n * Пример: VAT_20\n */\n vat: Vat;\n /**\n * **Характеристики, которые есть только у товаров конкретной категории**\n *\n * Кроме общих свойств, у товара есть характеристики, присущие конкретной категории, к которой он относится. Например, у велосипеда есть размер рамы, а детское пюре бывает овощное, мясное или фруктовое.\n */\n params?: IParam[];\n /**\n * **Свойства товара**\n *\n * *не YML поле\n */\n properties?: IParam[];\n /**\n * **Теги**\n *\n * Придумайте любое название — его можно будет изменить после.\n *\n * Максимальная длина тега — 20 символов.\n *\n * У одного товара — максимум 10 тегов.\n *\n * Всего можно создать не больше 50 разных тегов.\n *\n * Пример: apple, до 500 рублей\n */\n tags?: string[];\n /**\n * **Товар для взрослых**\n *\n * Параметр включает для товара пометку 18+. Устанавливайте ее только для товаров, которые относятся к удовлетворению сексуальных потребностей.\n */\n adult?: boolean;\n /**\n * **Цифровой товар**\n *\n * Параметр, устанавливаемый для цифровых товаров, которые просто скачиваются.\n */\n downloadable?: boolean;\n /**\n * **Срок годности**\n *\n * Период с момента изготовления, по прошествии которого товар становится непригоден.\n *\n * Указывайте срок, указанный на банке или упаковке. Текущая дата, дата поставки или дата отгрузки значения не имеет.\n *\n * Срок можно указывать в годах, месяцах, днях, неделях и часах.\n *\n * Обязательно указывайте срок, если он есть.\n *\n * Продолжительность указывается согласно ISO 8601, то есть в виде строчки, начинающейся буквой P:\n *\n ** P1Y — 1 год;\n ** P1Y6M — 1 год и 6 месяцев;\n ** P15D — 15 дней.\n */\n validityPeriod?: string;\n /**\n * **Комментарий к сроку годности**\n *\n * Поле предназначено для описаний условий хранения.\n *\n * Не длиннее 250 знаков и без спецсимволов.\n *\n * Пример: Хранить в сухом помещении\n */\n validityComment?: string;\n /**\n * **Срок службы**\n *\n * В течение срока службы товар должен исправно выполнять свою функцию.\n *\n * Обязательно указывайте срок, если он есть.\n *\n * Срок можно указывать в годах, месяцах и днях.\n * Продолжительность указывается согласно ISO 8601, то есть в виде строчки, начинающейся буквой P:\n *\n ** P1Y — 1 год;\n ** P1Y2M — 1 год и 2 месяца;\n ** P15D — 15 дней;\n ** P2Y10D — 2 года, 10 дней;\n ** P2Y6M10D — 2 года, 6 месяцев и 10 дней.\n */\n serviceLifePeriod?: string;\n /**\n * **Комментарий к сроку службы**\n *\n * Поле предназначено для описаний условий использования.\n *\n * Не длиннее 250 знаков и без спецсимволов.\n *\n * Пример: Использовать при температуре не ниже −10 градусов\n */\n serviceLifeComment?: string;\n /**\n * **Гарантийный срок**\n *\n * В течение какого времени можно бесплатно заменить или починить товар.\n *\n * Срок можно указывать в годах, месяцах или днях.\n *\n * Продолжительность указывается согласно ISO 8601, то есть в виде строчки, начинающейся буквой P:\n *\n ** P1Y — 1 год;\n ** P1Y2M — 1 год и 2 месяца;\n ** P15D — 15 дней;\n ** P2Y10D — 2 года, 10 дней;\n ** P2Y6M10D — 2 года, 6 месяцев и 10 дней.\n */\n warrantyPeriod?: string;\n /**\n * **Комментарий к гарантийному сроку**\n *\n * Поле предназначено для описания особенностей гарантийных условий.\n *\n * Указывайте только то, что относится к гарантии изготовителя.\n *\n * Не длиннее 250 знаков и без спецсимволов.\n *\n * Пример: Гарантия на аккумулятор — 6 месяцев\n */\n warrantyComment?: string;\n /**\n * **Официальная гарантия производителя**\n */\n manufacturerWarranty?: boolean;\n /**\n * **Номер документа**\n *\n * Номер документа на товар: сертификата, декларации соответствия и т. п.\n *\n * Прежде чем указывать номер документа, загрузите скан документа через кабинет.\n *\n * Укажите номер документа.\n *\n * Пример: 6241421\n */\n certificate?: string;\n /**\n * **Ключевые слова**\n *\n * Пример: Кроссовки, высокая подошва\n */\n keywords?: string[];\n /**\n * **Размерная сетка**\n */\n sizes?: ISize[];\n /**\n * **Связанные товары**\n *\n * Указываются id товаров\n *\n * Пример: 1234\n */\n relatedProducts?: number[];\n /**\n * **Название коллекции, ряда или серии товара**\n *\n * Пример: Jordan 4\n */\n seriesName?: string;\n /**\n * **Пол или название группы потребителей**\n *\n * Пример: Дети, Женское, Унисекс\n */\n gender?: string;\n}\n\nexport enum Vat {\n NO_VAT = \"NO_VAT\",\n VAT_0 = \"VAT_0\",\n VAT_10 = \"VAT_10\",\n VAT_20 = \"VAT_20\",\n}\n\nexport enum Currency {\n RUR = \"RUR\",\n BYN = \"BYN\",\n EUR = \"EUR\",\n USD = \"USD\",\n UAN = \"UAN\",\n KZT = \"KZT\",\n}\n\nexport interface IParam {\n /**\n * **Название характеристики**\n */\n key: string;\n /**\n * **Значение**\n */\n value: string;\n}\n\nexport interface ISize {\n /**\n * **Название единицы измерения**\n */\n name: string;\n /**\n * **Разделитель**\n */\n delimiter: string;\n /**\n * **Значения размерного ряда**\n *\n * Размеры указываются через разделитель\n */\n value: string;\n}\n"],"names":["Extension","__publicField","categories","Vat","Currency"],"mappings":"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"}
package/package.json CHANGED
@@ -11,7 +11,7 @@
11
11
  "url": "https://github.com/Bagi4-source/goods-converter/issues"
12
12
  },
13
13
  "name": "goods-exporter",
14
- "version": "0.3.19",
14
+ "version": "0.4.2",
15
15
  "description": "A versatile JavaScript library for exporting goods data to various formats such as YML, CSV, and Excel. Simplify data export tasks with ease.",
16
16
  "main": "./dist/cjs/index.cjs",
17
17
  "exports": {
@@ -32,6 +32,7 @@
32
32
  },
33
33
  "keywords": [
34
34
  "yml",
35
+ "json",
35
36
  "csv",
36
37
  "excel",
37
38
  "tilda",