machines/product.js
2023-11-12 21:43:05 +01:00

115 lines
15 KiB
JavaScript

"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
exports.productGitSyncTask = exports.productBazarTask = exports.productCADTask = exports.productLaserTask = void 0;
const path = require("path");
const glob_1 = require("@plastichub/osr-cli-commons/glob");
const copy_1 = require("@plastichub/fs/copy");
const remove_1 = require("@plastichub/fs/remove");
const exists_1 = require("@plastichub/fs/exists");
const library_1 = require("./library");
const _1 = require("./");
const PRODUCT_TEMPLATE = './osr/bazar/root.html';
const debug = true;
const verbose = true;
let DEFAULT_CAD_OUTPUTS = '${SRC_DIR}/${SRC_NAME}.+(json|html|step|x_t)';
const HTML_DEFAULT_PATH = 'resources/edrawings.html';
const productLaserTask = (grunt, product, options = {}, product_laser_tasks) => {
const config = {};
const slug = path.parse(product).base;
config[`product-${slug}`] = {
src: [product],
options: {
clear: true,
debug,
verbose
}
};
grunt.extendConfig({
laser: config
});
grunt.registerTask(`product-${slug}`, `laser:product-${slug}`);
product_laser_tasks.push(`laser:product-${slug}`);
grunt.registerTask(`products-laser`, product_laser_tasks);
};
exports.productLaserTask = productLaserTask;
const productCADTask = (grunt, component, options = {}, cad_tasks) => {
const config = {};
const slug = path.parse(component).base;
component = path.resolve(path.join(process.cwd(), component));
const rel = (0, library_1.forward_slash)(path.relative(path.resolve('.'), component));
let glob = `${rel}/cad/*Global*.+(SLDASM)`;
const filesSolidworks = (0, glob_1.files)(path.resolve('.'), glob);
if (!filesSolidworks.length) {
const t = 0;
}
config[`component-${slug}`] = {
src: [`${component}/cad/*Global*.+(SLDASM)`],
output: DEFAULT_CAD_OUTPUTS,
options: {
debug,
verbose,
skip: true,
onNode: (data => {
try {
options.debug && _1.logger.info(`Converted ${data.src} to ${data.target}`);
const parts = path.parse(data.target);
if (parts.ext === '.html' && parts.name.toLowerCase().indexOf('global') !== -1) {
const target = path.join(component, HTML_DEFAULT_PATH);
if ((0, exists_1.sync)(target)) {
(0, remove_1.sync)(target);
}
(0, copy_1.sync)(data.target, target, {});
}
}
catch (error) {
_1.logger.info(`Error copying ${data.src} to ${HTML_DEFAULT_PATH}`, error);
}
})
}
};
grunt.extendConfig({
cad: config
});
grunt.registerTask(`component-${slug}`, `cad:component-${slug}`);
cad_tasks.push(`cad:component-${slug}`);
grunt.registerTask(`components-cad`, cad_tasks);
};
exports.productCADTask = productCADTask;
const productBazarTask = (grunt, product, options = {}, product_bazar_tasks) => {
if (!product) {
_1.logger.error('Invalid product');
}
const config = {};
const slug = path.parse(product).base;
config[`product-${slug}`] = {
src: [PRODUCT_TEMPLATE],
options: (0, library_1.productContentOptions)(product)
};
grunt.extendConfig({
compile: config
});
grunt.registerTask(`product-${slug}`, `compile:product-${slug}`);
product_bazar_tasks.push(`compile:product-${slug}`);
grunt.registerTask(`products-bazar`, product_bazar_tasks);
};
exports.productBazarTask = productBazarTask;
const productGitSyncTask = (grunt, component, options = {}, git_tasks) => {
const config = {};
const opts = {
clean: true,
debug,
verbose,
cwd: '${OSR_ROOT}/osr-machines/',
rel: component.replace('products/', '')
};
const slug = path.parse(component).base;
config[`component-${slug}`] = opts;
grunt.extendConfig({
git: config
});
grunt.registerTask(`git-component-${slug}`, `git:component-${slug}`);
git_tasks.push(`git:component-${slug}`);
grunt.registerTask(`components-git`, git_tasks);
};
exports.productGitSyncTask = productGitSyncTask;
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"product.js","sourceRoot":"","sources":["tasks/product.ts"],"names":[],"mappings":"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","sourcesContent":["import * as path from 'path'\r\n\r\nimport { resolve } from '@plastichub/osr-cli-commons/fs'\r\nimport { files, pathInfo } from '@plastichub/osr-cli-commons/glob'\r\n\r\nimport { sync as cp } from '@plastichub/fs/copy'\r\nimport { sync as rm } from '@plastichub/fs/remove'\r\nimport { sync as exists } from '@plastichub/fs/exists'\r\n\r\nimport {\r\n    productContentOptions,\r\n    forward_slash\r\n} from './library'\r\n\r\n\r\nimport { logger } from './'\r\n\r\nconst PRODUCT_TEMPLATE = './osr/bazar/root.html'\r\n\r\nconst debug = true\r\nconst verbose = true\r\n\r\nlet DEFAULT_CAD_OUTPUTS = '${SRC_DIR}/${SRC_NAME}.+(json|html|step|x_t)'\r\nconst HTML_DEFAULT_PATH = 'resources/edrawings.html'\r\n\r\nexport const productLaserTask = (grunt, product, options: any = {}, product_laser_tasks) => {\r\n    const config = {}\r\n    const slug = path.parse(product).base\r\n\r\n    config[`product-${slug}`] = {\r\n        src: [product],\r\n        options: {\r\n            clear: true,\r\n            debug,\r\n            verbose\r\n        }\r\n    }\r\n    grunt.extendConfig({\r\n        laser: config\r\n    })\r\n    grunt.registerTask(`product-${slug}`, `laser:product-${slug}`)\r\n\r\n    product_laser_tasks.push(`laser:product-${slug}`)\r\n\r\n    grunt.registerTask(`products-laser`, product_laser_tasks)\r\n}\r\n\r\nexport const productCADTask = (grunt, component, options: any = {}, cad_tasks) => {\r\n    const config = {}\r\n    const slug = path.parse(component).base\r\n\r\n    component = path.resolve(path.join(process.cwd(), component))\r\n\r\n    const rel = forward_slash(path.relative(path.resolve('.'), component))\r\n    let glob = `${rel}/cad/*Global*.+(SLDASM)`\r\n    const filesSolidworks = files(path.resolve('.'), glob)\r\n    if (!filesSolidworks.length) {\r\n        const t = 0\r\n    }\r\n\r\n\r\n    config[`component-${slug}`] = {\r\n        src: [`${component}/cad/*Global*.+(SLDASM)`],\r\n        output: DEFAULT_CAD_OUTPUTS,\r\n        options: {\r\n            debug,\r\n            verbose,\r\n            skip:true,\r\n            onNode: (data => {\r\n                try {\r\n                    options.debug && logger.info(`Converted ${data.src} to ${data.target}`)\r\n                    const parts = path.parse(data.target)\r\n                    if (parts.ext === '.html' && parts.name.toLowerCase().indexOf('global') !== -1) {\r\n                        const target = path.join(component, HTML_DEFAULT_PATH)\r\n                        if(exists(target)){\r\n                            rm(target)\r\n                        }\r\n                        cp(data.target, target, {})\r\n                    }\r\n                } catch (error) {\r\n                    logger.info(`Error copying ${data.src} to ${HTML_DEFAULT_PATH}`, error)\r\n                }\r\n            })\r\n        }\r\n    }\r\n    grunt.extendConfig({\r\n        cad: config\r\n    })\r\n    grunt.registerTask(`component-${slug}`, `cad:component-${slug}`)\r\n\r\n    cad_tasks.push(`cad:component-${slug}`)\r\n\r\n    grunt.registerTask(`components-cad`, cad_tasks)\r\n}\r\n\r\nexport const productBazarTask = (grunt, product, options: any = {}, product_bazar_tasks) => {\r\n    if (!product) {\r\n        logger.error('Invalid product')\r\n    }\r\n    const config = {}\r\n    const slug = path.parse(product).base\r\n    config[`product-${slug}`] = {\r\n        src: [PRODUCT_TEMPLATE],\r\n        options: productContentOptions(product)\r\n    }\r\n    grunt.extendConfig({\r\n        compile: config\r\n    })\r\n    grunt.registerTask(`product-${slug}`, `compile:product-${slug}`)\r\n\r\n    product_bazar_tasks.push(`compile:product-${slug}`)\r\n\r\n    grunt.registerTask(`products-bazar`, product_bazar_tasks)\r\n}\r\nexport const productGitSyncTask = (grunt, component, options: any = {}, git_tasks) => {\r\n\r\n    const config = {}\r\n\r\n    const opts = {\r\n        clean: true,\r\n        debug,\r\n        verbose,\r\n        cwd: '${OSR_ROOT}/osr-machines/',\r\n        rel: component.replace('products/', '')\r\n    }\r\n\r\n    const slug = path.parse(component).base\r\n\r\n    config[`component-${slug}`] = opts\r\n\r\n    grunt.extendConfig({\r\n        git: config\r\n    })\r\n\r\n    grunt.registerTask(`git-component-${slug}`, `git:component-${slug}`)\r\n\r\n    git_tasks.push(`git:component-${slug}`)\r\n\r\n    grunt.registerTask(`components-git`, git_tasks)\r\n\r\n}"]}