UNPKG

gen-jhipster

Version:

VHipster - Spring Boot + Angular/React/Vue in one handy generator

302 lines (301 loc) 12.8 kB
/** * Copyright 2013-2026 the original author or authors from the JHipster project. * * This file is part of the JHipster project, see https://www.jhipster.tech/ * for more information. * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * https://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ import { asWriteFilesSection, asWritingEntitiesTask, asWritingTask } from "../base-application/support/index.js"; import { clientApplicationTemplatesBlock, clientRootTemplatesBlock, clientSrcTemplatesBlock } from "../client/support/files.js"; export const vueFiles = asWriteFilesSection({ common: [ clientRootTemplatesBlock({ templates: [ 'eslint.config.ts.jhi.vue', 'package.json', 'tsconfig.json', 'tsconfig.app.json', 'tsconfig.node.json', 'tsconfig.vitest.json', 'vite.config.ts', 'vitest.config.ts', ], }), ], microfrontend: [ clientRootTemplatesBlock({ condition: generator => generator.microfrontend, templates: ['module-federation.config.cjs'], }), clientRootTemplatesBlock({ condition: ctx => ctx.clientBundlerWebpack, templates: [ // webpack config files are commonjs, add a package.json in the webpack folder to set "type": "commonjs" 'webpack/package.json', 'webpack/config.js', 'webpack/webpack.common.js', 'webpack/webpack.dev.js', 'webpack/webpack.prod.js', 'webpack/vue.utils.js', ], }), { condition: generator => generator.microfrontend, ...clientApplicationTemplatesBlock(), templates: ['index.ts', 'core/error/error-loading.vue'], }, { condition: generator => generator.applicationTypeMicroservice, ...clientApplicationTemplatesBlock(), templates: ['entities/entities-menu.spec.ts'], }, ], sass: [ { ...clientSrcTemplatesBlock(), templates: ['content/scss/_bootstrap-variables.scss', 'content/scss/global.scss', 'content/scss/vendor.scss'], }, ], vueApp: [ { ...clientApplicationTemplatesBlock(), templates: [ 'app.vue', 'app.component.ts', 'shims-vue.d.ts', 'declarations.d.ts', 'main.ts', 'shared/alert/alert.service.ts', 'shared/alert/alert.service.spec.ts', 'shared/config/axios-interceptor.ts', 'shared/config/axios-interceptor.spec.ts', 'shared/config/config.ts', 'shared/config/config-bootstrap-vue.ts', 'shared/config/dayjs.ts', 'shared/config/store/account-store.ts', 'store.ts', 'router/index.ts', 'router/admin.ts', 'router/pages.ts', 'test-setup.ts', ], }, ], i18n: [ { condition: generator => generator.enableTranslation, ...clientApplicationTemplatesBlock(), templates: ['locale/translation.service.ts', 'shared/config/store/translation-store.ts', 'shared/config/languages.ts'], }, clientRootTemplatesBlock({ condition: ctx => ctx.enableTranslation && ctx.enableI18nRTL, templates: ['postcss.config.ts'], }), ], sharedVueApp: [ { ...clientApplicationTemplatesBlock(), templates: [ 'core/home/home.vue', 'core/home/home.component.ts', 'core/home/home.component.spec.ts', 'core/error/error.vue', 'core/error/error.component.ts', 'core/error/error.component.spec.ts', 'core/jhi-footer/jhi-footer.vue', 'core/jhi-footer/jhi-footer.component.ts', 'core/jhi-navbar/jhi-navbar.vue', 'core/jhi-navbar/jhi-navbar.component.ts', 'core/jhi-navbar/jhi-navbar.component.spec.ts', 'core/ribbon/ribbon.vue', 'core/ribbon/ribbon.component.ts', 'core/ribbon/ribbon.component.spec.ts', 'shared/composables/date-format.ts', 'shared/composables/index.ts', 'shared/composables/validation.ts', 'shared/computables/arrays.ts', 'shared/computables/index.ts', 'shared/sort/jhi-sort-indicator.component.ts', 'shared/sort/jhi-sort-indicator.vue', 'shared/sort/sorts.ts', 'shared/sort/sorts.spec.ts', 'shared/data/data-utils.service.ts', 'shared/data/data-utils.service.spec.ts', 'shared/jhi-item-count.component.ts', 'shared/jhi-item-count.vue', 'shared/model/user.model.ts', ], }, ], accountModule: [ { ...clientApplicationTemplatesBlock(), templates: ['account/account.service.ts', 'account/account.service.spec.ts'], }, { condition: generator => !generator.authenticationTypeOauth2, ...clientApplicationTemplatesBlock(), templates: [ 'account/login-form/login-form.vue', 'account/login-form/login-form.component.ts', 'account/login-form/login-form.component.spec.ts', 'account/login-modal.ts', 'router/account.ts', ], }, { condition: generator => generator.generateUserManagement, ...clientApplicationTemplatesBlock(), templates: [ 'account/change-password/change-password.vue', 'account/change-password/change-password.component.ts', 'account/change-password/change-password.component.spec.ts', 'account/register/register.vue', 'account/register/register.component.ts', 'account/register/register.component.spec.ts', 'account/register/register.service.ts', 'account/reset-password/init/reset-password-init.vue', 'account/reset-password/init/reset-password-init.component.ts', 'account/reset-password/init/reset-password-init.component.spec.ts', 'account/reset-password/finish/reset-password-finish.vue', 'account/reset-password/finish/reset-password-finish.component.ts', 'account/reset-password/finish/reset-password-finish.component.spec.ts', 'account/settings/settings.vue', 'account/settings/settings.component.ts', 'account/settings/settings.component.spec.ts', 'account/activate/activate.component.ts', 'account/activate/activate.component.spec.ts', 'account/activate/activate.service.ts', 'account/activate/activate.vue', ], }, { condition: generator => generator.authenticationTypeSession && generator.generateUserManagement, ...clientApplicationTemplatesBlock(), templates: ['account/sessions/sessions.vue', 'account/sessions/sessions.component.ts', 'account/sessions/sessions.component.spec.ts'], }, { condition: generator => generator.authenticationUsesCsrf, ...clientApplicationTemplatesBlock(), templates: ['account/login.service.ts', 'account/login.service.spec.ts'], }, ], adminModule: [ { ...clientApplicationTemplatesBlock(), templates: ['admin/docs/docs.vue', 'admin/docs/docs.component.ts'], }, { ...clientApplicationTemplatesBlock(), condition: generator => generator.withAdminUi, templates: [ 'admin/configuration/configuration.vue', 'admin/configuration/configuration.component.ts', 'admin/configuration/configuration.component.spec.ts', 'admin/configuration/configuration.service.ts', 'admin/health/health.vue', 'admin/health/health.component.ts', 'admin/health/health.component.spec.ts', 'admin/health/health-modal.vue', 'admin/health/health-modal.component.ts', 'admin/health/health-modal.component.spec.ts', 'admin/health/health.service.ts', 'admin/health/health.service.spec.ts', 'admin/logs/logs.vue', 'admin/logs/logs.component.ts', 'admin/logs/logs.component.spec.ts', 'admin/logs/logs.service.ts', 'admin/metrics/metrics.vue', 'admin/metrics/metrics.component.ts', 'admin/metrics/metrics.component.spec.ts', 'admin/metrics/metrics.service.ts', 'admin/metrics/metrics-modal.vue', 'admin/metrics/metrics-modal.component.ts', 'admin/metrics/metrics-modal.component.spec.ts', ], }, { condition: generator => generator.communicationSpringWebsocket, ...clientApplicationTemplatesBlock(), templates: [ 'admin/tracker/tracker.vue', 'admin/tracker/tracker.component.ts', 'admin/tracker/tracker.component.spec.ts', 'admin/tracker/tracker.service.ts', 'admin/tracker/tracker.service.spec.ts', ], }, { condition: generator => generator.generateUserManagement, ...clientApplicationTemplatesBlock(), templates: [ 'admin/user-management/user-management.vue', 'admin/user-management/user-management.component.ts', 'admin/user-management/user-management.component.spec.ts', 'admin/user-management/user-management-view.vue', 'admin/user-management/user-management-view.component.ts', 'admin/user-management/user-management-view.component.spec.ts', 'admin/user-management/user-management-edit.vue', 'admin/user-management/user-management-edit.component.ts', 'admin/user-management/user-management-edit.component.spec.ts', 'admin/user-management/user-management.service.ts', ], }, { condition: ctx => ctx.applicationTypeGateway && ctx.gatewayServicesApiAvailable, ...clientApplicationTemplatesBlock(), templates: [ 'admin/gateway/gateway.vue', 'admin/gateway/gateway.component.ts', 'admin/gateway/gateway.component.spec.ts', 'admin/gateway/gateway.service.ts', ], }, { condition: generator => generator.generateBuiltInUserEntity, ...clientApplicationTemplatesBlock(), templates: ['entities/user/user.service.ts'], }, ], }); export const entitiesFiles = { entities: [ { ...clientApplicationTemplatesBlock(), templates: [ 'entities/entities.component.ts', 'entities/entities.vue', 'entities/entities-menu.component.ts', 'entities/entities-menu.vue', 'router/entities.ts', ], }, ], }; export const writeFiles = asWritingTask(async function writeFiles({ application }) { await this.writeFiles({ sections: vueFiles, context: application, }); }); export const writeEntitiesFiles = asWritingEntitiesTask(async function writeEntitiesFiles({ application, entities, }) { entities = entities.filter(entity => !entity.skipClient && !entity.builtInUser); await this.writeFiles({ sections: entitiesFiles, context: { ...application, entities, }, }); });