mirror of
https://github.com/wassname/talk.git
synced 2026-06-27 19:17:09 +08:00
c9a0ab8848
* chore: upgrade fluent * chore: upgrade metascraper * chore: upgrade akismet-api * chore: upgrade apollo-server-express * chore: upgrade archiver * chore: upgrade bull * chore: upgrade express, cheerio, content-security-policy-builder * chore: upgrade convict * chore: upgrade cors, cron * chore: upgrade csv-stringify * chore: upgrade dompurify * chore: upgrade dotenv * chore: upgrade express-static-gzip * chore: upgrade fs-extra * chore: upgrade graphql-js * chore: upgrade graphql packages * chore: upgrade html-minifier * chore: upgrade html-to-text * chore: upgrade ioredis * chore: upgrade joi * chore: upgrade jsdom * chore: upgrade jsonwebtoken * chore: upgrade juice * chore: upgrade jwks-rsa ad linkifyjs * chore: upgrade lodash * chore: upgrade luxon * chore: upgrade metascraper * chore: upgrade mongodb * chore: upgrade ms * chore: upgrade node and node-fetch types * chore: upgrade nodemailer nunjucks and typescript-eslint * chore: Upgrade passport * upgrade: prom-client react-helmet source-map-support stack-utils * chore: upgrade uuid * chore: upgrade @babel packages * chore: upgrade types * chore: upgrade autoprefixer * chore: upgrade jest * chore: upgrade ts-jest * chore: remove linkify.d.ts * chore: upgrade bowser * chore: case-sensitive-paths-webpack-plugin * chore: upgrade classnames * chore: upgrade commander * chore: upgrade comment-json * chore: upgrade cross-spawn compression-webpack-plugin del * chore: upgrade build and watch related dependencies * chore: upgrade css-vars-ponyfill * chore: upgrade eslint and css-vars-ponyfill * chore: upgrade enzyme and eventemitter2 * fix: form bug * chore: upgrade farce * chore: upgrade final form * chore: upgrade react-popper * chore: upgrade flat and fork-ts-checker-webpack-plugin * chore: upgrade husky and gulp related, intersection observer * chore: upgrade lint-staged * chore: upgrade marked, loader-utils, mini-css-extract-plugin * chore: upgrade postcss-nested, proxy-polyfill, pstree.remy * chore: upgrade prettier * chore: fix prettier changes, upgrade react * chore: mute createFactory deprecated message * chore: upgrade react-copy-to-clipbard, react-axe, react-dom, react-test-renderer, react-timeago * chore: upgrade react-transistion-group, react-responsive * chore: upgrade types * chore: upgrade react-dev-utils, react-error-overlay regenerator-runtime * chore: upgrade types, sinon, sockjs-client, strip-ansi * chore: upgrade types, fonts * chore: upgrade nunjucks, ts-node, typescript-snapshot-plugin, wait-for-expect * chore: upgrade eslint packages * chore: upgrade fluent, types * chore: upgrade jsdom dep * chore: upgrade mongo * chore: upgrade deps * chore: upgrade typescript, recompose * chore: upgrade prettier * chore: remove obsolete prettier config * chore: upgrade jsdom types * chore: upgrade typescript-eslint * chore: upgrad deps * chore: upgrade deps * chore: upgrade relay related modules * chore: upgrade docz WIP * chore: upgrade docz * chore: add guard * chore: remove obsolete line * chore: comment * chore: refactors * fix: hook count change error
80 lines
2.0 KiB
JavaScript
80 lines
2.0 KiB
JavaScript
const { generateTSTypesAsString } = require("graphql-schema-typescript");
|
|
const { getGraphQLConfig } = require("graphql-config");
|
|
const path = require("path");
|
|
const fs = require("fs");
|
|
|
|
async function main() {
|
|
const config = getGraphQLConfig(__dirname);
|
|
const projects = config.getProjects();
|
|
|
|
const files = [
|
|
{
|
|
name: "tenant",
|
|
fileName: path.join(
|
|
__dirname,
|
|
"../src/core/server/graph/schema/__generated__/types.ts"
|
|
),
|
|
config: {
|
|
contextType: "GraphContext",
|
|
importStatements: [
|
|
'import GraphContext from "coral-server/graph/context";',
|
|
'import { Cursor } from "coral-server/models/helpers";',
|
|
],
|
|
customScalarType: { Cursor: "Cursor", Time: "Date" },
|
|
},
|
|
},
|
|
{
|
|
name: "tenant",
|
|
fileName: path.join(
|
|
__dirname,
|
|
"../src/core/client/framework/schema/__generated__/types.ts"
|
|
),
|
|
config: {
|
|
smartTResult: true,
|
|
smartTParent: true,
|
|
},
|
|
},
|
|
];
|
|
|
|
for (const file of files) {
|
|
// Load the graph schema.
|
|
const schema = projects[file.name].getSchema();
|
|
|
|
// Create the generated directory.
|
|
const dir = path.dirname(file.fileName);
|
|
if (!fs.existsSync(dir)) {
|
|
fs.mkdirSync(dir);
|
|
}
|
|
|
|
// Create the types for this file.
|
|
const types = await generateTSTypesAsString(schema, file.fileName, {
|
|
tabSpaces: 2,
|
|
typePrefix: "GQL",
|
|
strictNulls: false,
|
|
...file.config,
|
|
});
|
|
|
|
fs.writeFileSync(file.fileName, types);
|
|
}
|
|
|
|
return files;
|
|
}
|
|
|
|
module.exports = main;
|
|
|
|
if (require.main === module) {
|
|
// Only run the main module on file load if this is the main module (we're
|
|
// executing this file directly).
|
|
main()
|
|
.then((files) => {
|
|
for (const { fileName } of files) {
|
|
// eslint-disable-next-line no-console
|
|
console.log(`Generated ${fileName}`);
|
|
}
|
|
})
|
|
.catch((err) => {
|
|
// eslint-disable-next-line no-console
|
|
console.error(err);
|
|
});
|
|
}
|