"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports.onProductCompiled = exports.onProduct = exports.unique_by = exports.file_path_with_ext = exports.MainAssembly = exports.files = exports.forward_slash = exports.productContentOptions = exports.md2html = exports.addAssembly = void 0; const path = require("path"); const fg = require('fast-glob'); const read_1 = require("@plastichub/fs/read"); const write_1 = require("@plastichub/fs/write"); const js_beautify_1 = require("js-beautify"); const osr_cli_commons_1 = require("@plastichub/osr-cli-commons"); const cheerio = require('cheerio'); const mysql = require('mysql2'); const _1 = require("./"); const showdown_1 = require("showdown"); const addAssembly = (item) => `${item}/cad/**/Global*.+(SLDASM)`; exports.addAssembly = addAssembly; const md2html = (content) => { let converter = new showdown_1.Converter({ tables: true }); converter.setOption('literalMidWordUnderscores', 'true'); return converter.makeHtml(content); }; exports.md2html = md2html; const productContentOptions = (product) => { console.log('Create product compile options for ', product); product = '' + product; const product_rel = product.replace('products/', ''); return { debug: false, watch: false, root: '.', env: 'bazar-release', profile: '${root}/.osrl.json', output: '${product}/bazar/raw.html', format: 'html', module: 'plastichub-products', cwd: path.resolve('.'), cache: false, onCompiled: exports.onProduct, onCompileDone: exports.onProductCompiled, variables: { product, product_rel, root: path.resolve('.'), product_relative: '' + product_rel } }; }; exports.productContentOptions = productContentOptions; const forward_slash = (path) => { const isExtendedLengthPath = /^\\\\\?\\/.test(path); const hasNonAscii = /[^\u0000-\u0080]+/.test(path); // eslint-disable-line no-control-regex if (isExtendedLengthPath || hasNonAscii) { return path; } return path.replace(/\\/g, '/'); }; exports.forward_slash = forward_slash; const files = (dir, glob) => fg.sync(glob, { dot: true, cwd: dir, absolute: true }); exports.files = files; const MainAssembly = (dir) => { const mains = (0, exports.files)(dir, '**/cad/**/*Global*.+(SLDASM)'); return mains[0]; }; exports.MainAssembly = MainAssembly; const file_path_with_ext = (file, ext) => { const parts = path.parse(file); return path.join(parts.dir, parts.name + '.' + ext); }; exports.file_path_with_ext = file_path_with_ext; const unique_by = (arr, key) => { return [...new Map(arr.map(item => [item[key], item])).values()]; }; exports.unique_by = unique_by; const onProduct = (src, dst, content) => { const $ = cheerio.load(content, { xmlMode: true }); $('a').each(function () { $(this).attr("style", "color:#4C74B9"); }); $('table').each(function () { $(this).attr("style", "display:table;width:auto;margin-left:auto;margin-right:auto"); }); return Promise.resolve($.html()); }; exports.onProduct = onProduct; const update = async (dbconfig, description, id) => { return new Promise((resolve, reject) => { const connection = mysql.createConnection(dbconfig); var sql = mysql.format('UPDATE cscart_product_descriptions SET full_description = ? WHERE cscart_product_descriptions.product_id = ?', [description, id]); connection.query(sql, function (err, results) { if (err) { _1.logger.error('SQL Error', err.message); reject(err); } else { resolve(results); } }); }); }; const onProductCompiled = (src, dst, options, content) => { const config = (0, read_1.sync)(path.resolve(options.variables.product + '/config.json'), 'json'); content = (0, js_beautify_1.html_beautify)((0, exports.md2html)(content)); (0, write_1.sync)(path.resolve(options.variables.product + '/bazar/output.html'), content); const cscartId = config.cscartId; if (!cscartId) { _1.logger.error(`Have no cscart id for ${config.slug}`); return; } const osrConfig = (0, osr_cli_commons_1.CONFIG_DEFAULT)(); if (osrConfig.cscart.mysql) { return new Promise((resolve) => { update(osrConfig.cscart.mysql, content, cscartId).then((result) => { _1.logger.debug('updated cscart ' + config.name); resolve(1); }).catch((e) => { _1.logger.error('Error updating CSCart', e); }); }); } else { _1.logger.error('Have no CSCart Mysql config !'); } return Promise.resolve(); }; exports.onProductCompiled = onProductCompiled; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"library.js","sourceRoot":"","sources":["tasks/library.ts"],"names":[],"mappings":"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","sourcesContent":["import * as path from 'path'\r\n\r\nconst fg = require('fast-glob')\r\n\r\nimport { sync as read } from '@plastichub/fs/read'\r\nimport { sync as write } from '@plastichub/fs/write'\r\nimport { sync as exists } from '@plastichub/fs/exists'\r\nimport { html_beautify } from 'js-beautify'\r\nimport { CONFIG_DEFAULT, IOSRConfig } from '@plastichub/osr-cli-commons'\r\nimport {  } from '@plastichub/osr-cli-commons/fs'\r\n\r\nconst cheerio = require('cheerio')\r\n\r\nconst mysql = require('mysql2')\r\n\r\nimport { logger } from './'\r\n\r\nimport { Converter } from 'showdown'\r\n\r\nexport const addAssembly = (item) => `${item}/cad/**/Global*.+(SLDASM)`\r\n\r\nexport const md2html = (content) => {\r\n    let converter = new Converter({ tables: true });\r\n    converter.setOption('literalMidWordUnderscores', 'true');\r\n    return converter.makeHtml(content);\r\n}\r\n\r\nexport const productContentOptions = (product) => {\r\n    \r\n    console.log('Create product compile options for ', product)\r\n\r\n    product = ''  + product\r\n\r\n    const product_rel = product.replace('products/','')\r\n\r\n    return {\r\n        debug: false,\r\n        watch: false,\r\n        root: '.',\r\n        env: 'bazar-release',\r\n        profile: '${root}/.osrl.json',\r\n        output: '${product}/bazar/raw.html',\r\n        format: 'html',\r\n        module: 'plastichub-products',\r\n        cwd: path.resolve('.'),\r\n        cache: false,\r\n        onCompiled: onProduct,\r\n        onCompileDone: onProductCompiled,\r\n        variables: {\r\n            product,\r\n            product_rel,\r\n            root: path.resolve('.'),\r\n            product_relative: '' + product_rel\r\n        }\r\n    }\r\n}\r\n\r\nexport const forward_slash = (path) => {\r\n    const isExtendedLengthPath = /^\\\\\\\\\\?\\\\/.test(path);\r\n    const hasNonAscii = /[^\\u0000-\\u0080]+/.test(path); // eslint-disable-line no-control-regex\r\n\r\n    if (isExtendedLengthPath || hasNonAscii) {\r\n        return path;\r\n    }\r\n\r\n    return path.replace(/\\\\/g, '/');\r\n};\r\n\r\nexport const files = (dir, glob) => fg.sync(glob, {\r\n    dot: true,\r\n    cwd: dir,\r\n    absolute: true\r\n});\r\n\r\nexport const MainAssembly = (dir) => {\r\n    const mains = files(dir, '**/cad/**/*Global*.+(SLDASM)');\r\n    return mains[0];\r\n}\r\n\r\nexport const file_path_with_ext = (file, ext) => {\r\n    const parts = path.parse(file);\r\n    return path.join(parts.dir, parts.name + '.' + ext);\r\n}\r\n\r\nexport const unique_by = (arr, key) => {\r\n    return [...new Map(arr.map(item => [item[key], item])).values()]\r\n}\r\n\r\nexport const onProduct = (src, dst, content) => {\r\n    const $ = cheerio.load(content, {\r\n        xmlMode: true\r\n    });\r\n\r\n    $('a').each(function () {\r\n        $(this).attr(\"style\", \"color:#4C74B9\");\r\n    })\r\n\r\n    $('table').each(function () {\r\n        $(this).attr(\"style\", \"display:table;width:auto;margin-left:auto;margin-right:auto\");\r\n    })\r\n\r\n    return Promise.resolve($.html())\r\n}\r\n\r\nconst update = async (dbconfig, description, id) => {\r\n    return new Promise((resolve, reject) => {\r\n        const connection = mysql.createConnection(dbconfig);\r\n        var sql = mysql.format('UPDATE cscart_product_descriptions SET full_description = ? WHERE cscart_product_descriptions.product_id = ?',\r\n            [description, id]\r\n        );\r\n        connection.query(\r\n            sql,\r\n            function (err, results) {\r\n                if (err) {\r\n                    logger.error('SQL Error', err.message);\r\n                    reject(err);\r\n                } else {\r\n                    resolve(results)\r\n                }                \r\n            }\r\n        );\r\n    })\r\n}\r\n\r\nexport const onProductCompiled = (src, dst, options, content) => {\r\n    const config: any = read(path.resolve(options.variables.product + '/config.json'), 'json');\r\n\r\n    content = html_beautify(md2html(content))\r\n    write(path.resolve(options.variables.product + '/bazar/output.html'), content)\r\n\r\n    const cscartId = config.cscartId\r\n    if (!cscartId) {\r\n        logger.error(`Have no cscart id for ${config.slug}`)\r\n        return\r\n    }\r\n    const osrConfig = CONFIG_DEFAULT() as IOSRConfig    \r\n\r\n    if (osrConfig.cscart.mysql) {\r\n        return new Promise((resolve) => {\r\n            update(osrConfig.cscart.mysql, content, cscartId).then((result) => {\r\n                logger.debug('updated cscart ' + config.name)\r\n                resolve(1)\r\n            }).catch((e) => {\r\n                logger.error('Error updating CSCart', e)\r\n            })\r\n        })\r\n    }else{\r\n        logger.error('Have no CSCart Mysql config !')\r\n    }\r\n    return Promise.resolve()\r\n}\r\n"]}