machines/products/poly-mech/product.js
2024-08-18 21:05:57 +02:00

211 lines
30 KiB
JavaScript

"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
exports.readProducts = exports.productHugoTask = exports.productContentOptions = exports.registerProductTasks = exports.compileProductTask = exports.populateProductDefaults = void 0;
process.env['NODE_TLS_REJECT_UNAUTHORIZED'] = '0';
const path = require("path");
const osr_cli_commons_1 = require("@plastichub/osr-cli-commons");
const fs_1 = require("@plastichub/osr-cli-commons/fs");
const exists_1 = require("@plastichub/fs/exists");
const read_1 = require("@plastichub/fs/read");
const write_1 = require("@plastichub/fs/write");
const debug_1 = require("@plastichub/core/debug");
const _cli_1 = require("@plastichub/osr-i18n/_cli");
const translate_1 = require("@plastichub/osr-i18n/lib/translate");
const media_1 = require("./media");
const log_1 = require("./log");
const config_1 = require("./config");
const logger = (0, debug_1.logger)('ph-site');
/////////////////////////////////////////////////////////////////////
//
// Product Multi Task products[product] -> content/retail/product
const populateProductDefaults = async (grunt, product_root, srcLang, dstLanguage) => {
const _createFile = (file) => {
file = path.resolve(path.join(product_root, file));
if (!(0, exists_1.sync)(file)) {
(0, write_1.sync)(file, '');
}
};
_createFile('templates/shared/product_features.md');
};
exports.populateProductDefaults = populateProductDefaults;
const compileProductTask = async (grunt, product, lang, dstLanguage, target, options = {}) => {
const config = {};
product = '' + product;
const logLevel = grunt.option('logLevel') || 'warn';
const product_rel = product.replace('products/', '');
const root = (0, fs_1.resolve)((0, config_1.PRODUCT_ROOT)());
const slug = path.parse(product).base;
const debug = grunt.option('debug');
const productConfig = (0, read_1.sync)((0, config_1.PRODUCT_CONFIG)(product), "json");
if (!productConfig) {
logger.error('Product config not found !' + product);
return;
}
productConfig.description = productConfig.description || '';
const translateProductAssets = async () => {
logger.info('Translate Product Assets ' + slug + ' ' + dstLanguage + ' ' + product_rel);
const config = (0, osr_cli_commons_1.CONFIG_DEFAULT)();
if (dstLanguage === config_1.I18N_SOURCE_LANGUAGE) {
return;
}
logger.setSettings({ minLevel: config_1.RETAIL_LOG_LEVEL_I18N_PRODUCT_ASSETS });
const i18nOptions = {
srcLang: config_1.I18N_SOURCE_LANGUAGE,
dstLang: dstLanguage,
src: `${(0, config_1.PRODUCT_DIR)(product)}/specs.xlsx`,
store: (0, config_1.I18N_STORE)((0, config_1.OSR_ROOT)(), dstLanguage),
dst: "${SRC_DIR}/${SRC_NAME}-${DST_LANG}${SRC_EXT}",
query: "$[*][0,1]",
cache: true,
api_key: config.deepl.auth_key,
logLevel: config_1.RETAIL_LOG_LEVEL_I18N_PRODUCT_ASSETS
};
return await (0, translate_1.translate)((0, _cli_1.sanitize)(i18nOptions));
};
const onCompiled = async (src, dst, options, content) => {
if (config_1.TranslateProductAssets || grunt.option('translateProductAssets')) {
await translateProductAssets();
}
if (config_1.ConvertProductMedia || grunt.option('convertProductMedia')) {
await (0, media_1.compileProductAssets)(grunt, (0, config_1.PRODUCT_DIR)(product), lang, dstLanguage);
}
if (config_1.PopulateProductDefaults) {
await (0, exports.populateProductDefaults)(grunt, (0, config_1.PRODUCT_DIR)(product), lang, dstLanguage);
}
// logger.warn('On Compiled Product ' + product + ' ' + dstLanguage)
};
let defaultOptions = {
src: [path.resolve(path.join(root, config_1.PRODUCT_HUGO_TEMPLATE))],
options: {
cache: config_1.RETAIL_COMPILE_CACHE,
debug,
env: config_1.OSRL_ENVIRONMENT,
format: 'html',
language: config_1.OSRL_LANG_FLAVOR,
module: config_1.OSRL_MODULE_NAME,
output: `${target}/${product_rel}/_index.md`,
profile: config_1.OSRL_PRODUCT_PROFILE,
root,
cwd: root,
watchContent: false,
logLevel,
store: (0, config_1.I18N_STORE)((0, config_1.OSR_ROOT)(), dstLanguage),
sourceLanguage: config_1.I18N_SOURCE_LANGUAGE,
targetLanguage: dstLanguage,
variables: {
root,
product,
product_rel,
product_relative: '' + product_rel,
sourceLanguage: config_1.I18N_SOURCE_LANGUAGE,
targetLanguage: dstLanguage,
language: dstLanguage,
i18n: (0, config_1.I18N_STORE)((0, config_1.OSR_ROOT)(), dstLanguage),
...productConfig,
fm: {
keywords: (productConfig.keywords || "").split(',').map((k) => k.trim())
}
},
...options,
onCompileDone: onCompiled,
onCompile: async (options) => {
const gallery = await (0, media_1.productGallery)(grunt, 'media/gallery', product, lang, dstLanguage);
const galleryRenderings = await (0, media_1.productGallery)(grunt, 'renderings', product, lang, dstLanguage);
options.variables.fm.rGallery = gallery;
options.variables.fm.rGalleryRenderings = galleryRenderings;
return options;
}
}
};
debug && logger.debug('Create product compile options for ' + product, defaultOptions.options);
config[`content-${dstLanguage}-${slug}`] = {
...defaultOptions,
};
grunt.extendConfig({ compile: config });
grunt.registerTask(`content-${dstLanguage}-${slug}`, `compile:content-${dstLanguage}-${slug}`);
};
exports.compileProductTask = compileProductTask;
const registerProductTasks = (grunt) => {
const logLevel = grunt.option('logLevel') || 'warn';
logger.setSettings({ minLevel: logLevel });
const product_compile_tasks = [];
const productTasks = (items) => {
items.forEach((product) => {
const slug = path.parse(product).base;
(0, exports.compileProductTask)(grunt, product, config_1.I18N_SOURCE_LANGUAGE, config_1.I18N_SOURCE_LANGUAGE, "./content/en/retail");
product_compile_tasks.push(`compile:content-en-${slug}`);
config_1.LANGUAGES.forEach((lang) => {
product_compile_tasks.push(`compile:content-${lang}-${slug}`);
(0, exports.compileProductTask)(grunt, product, config_1.I18N_SOURCE_LANGUAGE, lang, `./content/${lang}/retail`);
});
});
};
productTasks((0, exports.readProducts)(grunt.option('branch') || 'test'));
grunt.registerTask(`content-all`, product_compile_tasks);
};
exports.registerProductTasks = registerProductTasks;
/////////////////////////////////////////////////////////////////////
//
// Product Single Test Task products[product] -> src/retail/product
const productContentOptions = (target, product) => {
product = '' + product;
const product_rel = product.replace('products/', '');
const root = (0, fs_1.resolve)((0, config_1.PRODUCT_ROOT)());
const productConfig = (0, read_1.sync)((0, config_1.PRODUCT_CONFIG)(product), "json");
if (!productConfig) {
logger.error('Product config not found !' + product);
}
return {
debug: false,
watch: false,
root,
cwd: root,
env: config_1.OSRL_ENV,
profile: '${root}/.osrl.json',
output: `${target}/${product_rel}/_index.md`,
// format: 'html',
module: config_1.OSRL_MODULE_NAME,
cache: true,
variables: {
product,
product_rel,
root,
product_relative: '' + product_rel,
...productConfig
}
};
};
exports.productContentOptions = productContentOptions;
const productHugoTask = (grunt, product, options = {}, product_item_tasks) => {
if (!product) {
logger.error('Invalid product');
}
const config = {};
const slug = path.parse(product).base;
const target = path.resolve(config_1.PRODUCTS_TARGET_SRC);
const productOptions = (0, exports.productContentOptions)(target, product);
config[`product-${slug}`] = {
src: [config_1.PRODUCT_HUGO_TEMPLATE],
options: productOptions
};
grunt.extendConfig({
compile: config
});
grunt.registerTask(`product-${slug}`, `compile:product-${slug}`);
product_item_tasks.push(`compile:product-${slug}`);
grunt.registerTask(`products-hugo`, product_item_tasks);
(0, log_1.writeTaskConfig)(`compile_product-${slug}`, config);
};
exports.productHugoTask = productHugoTask;
const readProducts = (branch = 'test') => {
const conf = (0, read_1.sync)(config_1.ENABLED_PRODUCTS, "json") || {};
if (branch) {
conf['all'] = [...conf["sheetpress"], ...conf["injectors"], ...conf["extruders"], ...conf["shredders"]];
return conf[branch] || [];
}
else {
return Object.values(conf).flat();
}
};
exports.readProducts = readProducts;
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"product.js","sourceRoot":"","sources":["tasks/product.ts"],"names":[],"mappings":"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","sourcesContent":["process.env['NODE_TLS_REJECT_UNAUTHORIZED'] = '0'\nimport * as path from 'path'\nimport { CONFIG_DEFAULT } from '@plastichub/osr-cli-commons'\nimport { resolve } from '@plastichub/osr-cli-commons/fs'\n\nimport { sync as exists } from '@plastichub/fs/exists'\nimport { sync as read } from '@plastichub/fs/read'\nimport { sync as write } from '@plastichub/fs/write'\n\nimport { logger as _logger } from '@plastichub/core/debug'\n\nimport { sanitize } from '@plastichub/osr-i18n/_cli'\nimport { IOptions as IOptionsI18n } from '@plastichub/osr-i18n/types'\nimport { translate } from '@plastichub/osr-i18n/lib/translate'\n\nimport { compileProductAssets, productGallery } from './media'\nimport { writeTaskConfig } from './log'\n\nimport {\n  ENABLED_PRODUCTS, I18N_SOURCE_LANGUAGE, I18N_STORE,\n  LANGUAGES,\n  OSRL_ENV, OSRL_LANG_FLAVOR,\n  OSRL_MODULE_NAME, OSR_ROOT, PRODUCTS_TARGET_SRC, PRODUCT_CONFIG, PRODUCT_HUGO_TEMPLATE, OSRL_PRODUCT_PROFILE, PRODUCT_ROOT, PRODUCT_DIR,\n  OSRL_ENVIRONMENT,\n  RETAIL_LOG_LEVEL_I18N_PRODUCT_ASSETS,\n  TranslateProductAssets,\n  ConvertProductMedia,\n  PopulateProductDefaults,\n  RETAIL_COMPILE_CACHE\n} from './config'\nimport { ICompileTaskOptions } from '@plastichub/osr-tasks/tasks/compile'\n\nconst logger = _logger('ph-site')\n\n/////////////////////////////////////////////////////////////////////\n//\n//  Product Multi Task products[product] -> content/retail/product\nexport const populateProductDefaults = async (grunt, product_root, srcLang, dstLanguage) => {\n  const _createFile = (file: string) => {\n    file = path.resolve(path.join(product_root, file))\n    if (!exists(file)) {\n      write(file, '')\n    }\n  }\n  _createFile('templates/shared/product_features.md')\n}\nexport const compileProductTask = async (grunt, product, lang, dstLanguage, target, options: any = {}) => {\n  const config = {}\n  product = '' + product\n  const logLevel = grunt.option('logLevel') || 'warn'\n  const product_rel = product.replace('products/', '')\n  const root = resolve(PRODUCT_ROOT())\n  const slug = path.parse(product).base\n  const debug = grunt.option('debug')\n  const productConfig: any = read(PRODUCT_CONFIG(product), \"json\")\n  if (!productConfig) {\n    logger.error('Product config not found !' + product)\n    return\n  }\n  productConfig.description = productConfig.description || ''\n  const translateProductAssets = async () => {\n    logger.info('Translate Product Assets ' + slug + ' ' + dstLanguage + ' ' + product_rel)\n    const config: any = CONFIG_DEFAULT()\n    if (dstLanguage === I18N_SOURCE_LANGUAGE) {\n      return\n    }\n    logger.setSettings({ minLevel: RETAIL_LOG_LEVEL_I18N_PRODUCT_ASSETS })\n    const i18nOptions: IOptionsI18n = {\n      srcLang: I18N_SOURCE_LANGUAGE,\n      dstLang: dstLanguage,\n      src: `${PRODUCT_DIR(product)}/specs.xlsx`,\n      store: I18N_STORE(OSR_ROOT(), dstLanguage),\n      dst: \"${SRC_DIR}/${SRC_NAME}-${DST_LANG}${SRC_EXT}\",\n      query: \"$[*][0,1]\",\n      cache: true,\n      api_key: config.deepl.auth_key,\n      logLevel: RETAIL_LOG_LEVEL_I18N_PRODUCT_ASSETS\n    }\n    return await translate(sanitize(i18nOptions) as any)\n  }\n\n  const onCompiled = async (src, dst, options, content) => {\n    if (TranslateProductAssets || grunt.option('translateProductAssets')) {\n      await translateProductAssets()\n    }\n    if (ConvertProductMedia || grunt.option('convertProductMedia')) {\n      await compileProductAssets(grunt, PRODUCT_DIR(product), lang, dstLanguage)\n    }\n    if (PopulateProductDefaults) {\n      await populateProductDefaults(grunt, PRODUCT_DIR(product), lang, dstLanguage)\n    }\n    // logger.warn('On Compiled Product ' + product + ' ' + dstLanguage)\n  }\n\n  let defaultOptions: any = {\n    src: [path.resolve(path.join(root, PRODUCT_HUGO_TEMPLATE))],\n    options: {\n      cache: RETAIL_COMPILE_CACHE,\n      debug,\n      env: OSRL_ENVIRONMENT,\n      format: 'html',\n      language: OSRL_LANG_FLAVOR,\n      module: OSRL_MODULE_NAME,\n      output: `${target}/${product_rel}/_index.md`,\n      profile: OSRL_PRODUCT_PROFILE,\n      root,\n      cwd: root,\n      watchContent: false,\n      logLevel,\n      store: I18N_STORE(OSR_ROOT(), dstLanguage),\n      sourceLanguage: I18N_SOURCE_LANGUAGE,\n      targetLanguage: dstLanguage,\n      variables: {\n        root,\n        product,\n        product_rel,\n        product_relative: '' + product_rel,\n        sourceLanguage: I18N_SOURCE_LANGUAGE,\n        targetLanguage: dstLanguage,\n        language: dstLanguage,\n        i18n: I18N_STORE(OSR_ROOT(), dstLanguage),\n        ...productConfig,\n        fm: {\n          keywords: (productConfig.keywords || \"\").split(',').map((k) => k.trim())\n        }\n      },\n      ...options,\n      onCompileDone: onCompiled,\n      onCompile: async (options) => {\n        const gallery = await productGallery(grunt, 'media/gallery', product, lang, dstLanguage)\n        const galleryRenderings = await productGallery(grunt, 'renderings', product, lang, dstLanguage)\n        options.variables.fm.rGallery = gallery\n        options.variables.fm.rGalleryRenderings = galleryRenderings\n        return options\n      }\n    } as ICompileTaskOptions\n  }\n  debug && logger.debug('Create product compile options for ' + product, defaultOptions.options)\n  config[`content-${dstLanguage}-${slug}`] = {\n    ...defaultOptions,\n  }\n  grunt.extendConfig({ compile: config })\n  grunt.registerTask(`content-${dstLanguage}-${slug}`, `compile:content-${dstLanguage}-${slug}`)\n}\nexport const registerProductTasks = (grunt) => {\n  const logLevel = grunt.option('logLevel') || 'warn'\n  logger.setSettings({ minLevel: logLevel })\n  const product_compile_tasks = []\n  const productTasks = (items) => {\n    items.forEach((product) => {\n      const slug = path.parse(product).base\n      compileProductTask(grunt, product, I18N_SOURCE_LANGUAGE, I18N_SOURCE_LANGUAGE, \"./content/en/retail\")\n      product_compile_tasks.push(`compile:content-en-${slug}`)\n      LANGUAGES.forEach((lang) => {\n        product_compile_tasks.push(`compile:content-${lang}-${slug}`)\n        compileProductTask(grunt, product, I18N_SOURCE_LANGUAGE, lang, `./content/${lang}/retail`)\n      })\n    })\n  }\n  productTasks(readProducts(grunt.option('branch') || 'test'))\n  grunt.registerTask(`content-all`, product_compile_tasks)\n}\n\n/////////////////////////////////////////////////////////////////////\n//\n//  Product Single Test Task products[product] -> src/retail/product\nexport const productContentOptions = (target, product) => {\n  product = '' + product\n  const product_rel = product.replace('products/', '')\n  const root = resolve(PRODUCT_ROOT())\n  const productConfig: any = read(PRODUCT_CONFIG(product), \"json\")\n  if (!productConfig) {\n    logger.error('Product config not found !' + product)\n  }\n  return {\n    debug: false,\n    watch: false,\n    root,\n    cwd: root,\n    env: OSRL_ENV,\n    profile: '${root}/.osrl.json',\n    output: `${target}/${product_rel}/_index.md`,\n    // format: 'html',\n    module: OSRL_MODULE_NAME,\n    cache: true,\n    variables: {\n      product,\n      product_rel,\n      root,\n      product_relative: '' + product_rel,\n      ...productConfig\n    }\n  }\n}\nexport const productHugoTask = (grunt, product, options: any = {}, product_item_tasks) => {\n  if (!product) {\n    logger.error('Invalid product')\n  }\n  const config = {}\n  const slug = path.parse(product).base\n  const target = path.resolve(PRODUCTS_TARGET_SRC)\n  const productOptions = productContentOptions(target, product)\n  config[`product-${slug}`] = {\n    src: [PRODUCT_HUGO_TEMPLATE],\n    options: productOptions\n  }\n  grunt.extendConfig({\n    compile: config\n  })\n  grunt.registerTask(`product-${slug}`, `compile:product-${slug}`)\n  product_item_tasks.push(`compile:product-${slug}`)\n  grunt.registerTask(`products-hugo`, product_item_tasks)\n  writeTaskConfig(`compile_product-${slug}`, config)\n}\nexport const readProducts = (branch: string = 'test') => {\n  const conf = read(ENABLED_PRODUCTS, \"json\") || {}\n  if (branch) {\n    conf['all'] = [...conf[\"sheetpress\"], ...conf[\"injectors\"], ...conf[\"extruders\"], ...conf[\"shredders\"]]\n    return conf[branch] || []\n  } else {\n    return Object.values(conf).flat()\n  }\n}\n"]}