generator-jhipster 7.2.0 → 7.4.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (313) hide show
  1. package/cli/environment-builder.js +1 -0
  2. package/cli/import-jdl.js +3 -2
  3. package/cli/jdl.js +1 -0
  4. package/cli/jhipster-command.js +2 -2
  5. package/cli/program.js +32 -29
  6. package/generators/app/index.js +35 -26
  7. package/generators/aws/index.js +8 -8
  8. package/generators/aws/lib/eb.js +1 -1
  9. package/generators/azure-app-service/index.js +16 -9
  10. package/generators/azure-app-service/templates/github/workflows/azure-app-service.yml.ejs +2 -2
  11. package/generators/azure-spring-cloud/index.js +16 -9
  12. package/generators/azure-spring-cloud/templates/github/workflows/azure-spring-cloud.yml.ejs +2 -2
  13. package/generators/bootstrap/index.js +57 -61
  14. package/generators/ci-cd/index.js +11 -8
  15. package/generators/ci-cd/templates/github-actions.yml.ejs +1 -1
  16. package/generators/ci-cd/templates/travis.yml.ejs +9 -4
  17. package/generators/client/__workflow/devserver-angular.json +1 -1
  18. package/generators/client/__workflow/devserver-react.json +1 -1
  19. package/generators/client/__workflow/devserver-vue.json +1 -1
  20. package/generators/client/files-angular.js +6 -0
  21. package/generators/client/files-common.js +6 -2
  22. package/generators/client/files-react.js +13 -2
  23. package/generators/client/files-vue.js +56 -6
  24. package/generators/client/index.js +114 -32
  25. package/generators/client/needle-api/needle-client-angular.js +1 -1
  26. package/generators/client/needle-api/needle-client-vue.js +57 -7
  27. package/generators/client/templates/angular/.eslintrc.json.ejs +1 -0
  28. package/generators/client/templates/angular/package.json +19 -19
  29. package/generators/client/templates/angular/package.json.ejs +2 -1
  30. package/generators/client/templates/angular/src/main/webapp/app/account/activate/activate.component.spec.ts.ejs +52 -54
  31. package/generators/client/templates/angular/src/main/webapp/app/account/activate/activate.service.spec.ts.ejs +65 -0
  32. package/generators/client/templates/angular/src/main/webapp/app/account/password/password-strength-bar/password-strength-bar.component.spec.ts.ejs +35 -37
  33. package/generators/client/templates/angular/src/main/webapp/app/account/password/password.component.spec.ts.ejs +78 -80
  34. package/generators/client/templates/angular/src/main/webapp/app/account/password/password.service.spec.ts.ejs +41 -0
  35. package/generators/client/templates/angular/src/main/webapp/app/account/password-reset/finish/password-reset-finish.component.spec.ts.ejs +73 -75
  36. package/generators/client/templates/angular/src/main/webapp/app/account/password-reset/finish/password-reset-finish.service.spec.ts.ejs +62 -0
  37. package/generators/client/templates/angular/src/main/webapp/app/account/password-reset/init/password-reset-init.component.spec.ts.ejs +44 -46
  38. package/generators/client/templates/angular/src/main/webapp/app/account/password-reset/init/password-reset-init.service.spec.ts.ejs +61 -0
  39. package/generators/client/templates/angular/src/main/webapp/app/account/register/register.component.spec.ts.ejs +116 -118
  40. package/generators/client/templates/angular/src/main/webapp/app/account/register/register.service.spec.ts.ejs +66 -0
  41. package/generators/client/templates/angular/src/main/webapp/app/account/sessions/sessions.component.spec.ts.ejs +75 -77
  42. package/generators/client/templates/angular/src/main/webapp/app/account/settings/settings.component.spec.ts.ejs +74 -76
  43. package/generators/client/templates/angular/src/main/webapp/app/admin/configuration/configuration.component.spec.ts.ejs +48 -50
  44. package/generators/client/templates/angular/src/main/webapp/app/admin/configuration/configuration.service.spec.ts.ejs +50 -52
  45. package/generators/client/templates/angular/src/main/webapp/app/admin/health/health.component.spec.ts.ejs +45 -47
  46. package/generators/client/templates/angular/src/main/webapp/app/admin/health/health.service.spec.ts.ejs +66 -0
  47. package/generators/client/templates/angular/src/main/webapp/app/admin/health/modal/health-modal.component.spec.ts.ejs +99 -101
  48. package/generators/client/templates/angular/src/main/webapp/app/admin/logs/logs.component.spec.ts.ejs +61 -63
  49. package/generators/client/templates/angular/src/main/webapp/app/admin/logs/logs.service.spec.ts.ejs +19 -21
  50. package/generators/client/templates/angular/src/main/webapp/app/admin/metrics/blocks/jvm-memory/jvm-memory.component.html.ejs +2 -2
  51. package/generators/client/templates/angular/src/main/webapp/app/admin/metrics/metrics.component.spec.ts.ejs +28 -30
  52. package/generators/client/templates/angular/src/main/webapp/app/admin/metrics/metrics.service.spec.ts.ejs +62 -64
  53. package/generators/client/templates/angular/src/main/webapp/app/admin/user-management/delete/user-management-delete-dialog.component.spec.ts.ejs +35 -37
  54. package/generators/client/templates/angular/src/main/webapp/app/admin/user-management/detail/user-management-detail.component.spec.ts.ejs +40 -42
  55. package/generators/client/templates/angular/src/main/webapp/app/admin/user-management/list/user-management.component.spec.ts.ejs +87 -89
  56. package/generators/client/templates/angular/src/main/webapp/app/admin/user-management/service/user-management.service.spec.ts.ejs +41 -43
  57. package/generators/client/templates/angular/src/main/webapp/app/admin/user-management/update/user-management-update.component.spec.ts.ejs +81 -83
  58. package/generators/client/templates/angular/src/main/webapp/app/app.module.ts.ejs +3 -0
  59. package/generators/client/templates/angular/src/main/webapp/app/core/auth/account.service.spec.ts.ejs +178 -180
  60. package/generators/client/templates/angular/src/main/webapp/app/core/config/application-config.service.ts.ejs +9 -0
  61. package/generators/client/templates/angular/src/main/webapp/app/entities/user/user.service.spec.ts.ejs +87 -89
  62. package/generators/client/templates/angular/src/main/webapp/app/home/home.component.spec.ts.ejs +93 -95
  63. package/generators/client/templates/angular/src/main/webapp/app/layouts/main/main.component.spec.ts.ejs +166 -168
  64. package/generators/client/templates/angular/src/main/webapp/app/layouts/navbar/navbar.component.spec.ts.ejs +66 -68
  65. package/generators/client/templates/angular/src/main/webapp/app/layouts/profiles/page-ribbon.component.spec.ts.ejs +27 -29
  66. package/generators/client/templates/angular/src/main/webapp/app/login/login.component.spec.ts.ejs +112 -114
  67. package/generators/client/templates/angular/src/main/webapp/app/shared/alert/alert-error.component.spec.ts.ejs +132 -134
  68. package/generators/client/templates/angular/src/main/webapp/app/shared/alert/alert.component.spec.ts.ejs +29 -31
  69. package/generators/client/templates/angular/webpack/webpack.custom.js.ejs +2 -3
  70. package/generators/client/templates/common/README.md.jhi.client.ejs +34 -0
  71. package/generators/client/templates/common/package.json +7 -7
  72. package/generators/client/templates/common/webpack/webpack.microfrontend.js.jhi.ejs +56 -0
  73. package/generators/client/templates/react/.eslintrc.json.ejs +1 -0
  74. package/generators/client/templates/react/package.json +57 -56
  75. package/generators/client/templates/react/package.json.ejs +5 -2
  76. package/generators/client/templates/react/src/main/webapp/app/app.scss.ejs +0 -3
  77. package/generators/client/templates/react/src/main/webapp/app/modules/account/password/password.tsx.ejs +2 -2
  78. package/generators/client/templates/react/src/main/webapp/app/modules/administration/configuration/configuration.tsx.ejs +2 -2
  79. package/generators/client/templates/react/src/main/webapp/app/modules/administration/gateway/gateway.tsx.ejs +2 -2
  80. package/generators/client/templates/react/src/main/webapp/app/modules/administration/metrics/metrics.tsx.ejs +6 -6
  81. package/generators/client/templates/react/src/main/webapp/app/modules/administration/user-management/user-management.tsx.ejs +8 -8
  82. package/generators/client/templates/react/src/main/webapp/app/modules/home/home.tsx.ejs +1 -1
  83. package/generators/client/templates/react/src/main/webapp/app/shared/layout/header/header.tsx.ejs +1 -1
  84. package/generators/client/templates/react/src/main/webapp/app/shared/layout/menus/account.tsx.ejs +3 -3
  85. package/generators/client/templates/react/src/main/webapp/app/shared/layout/menus/admin.tsx.ejs +7 -7
  86. package/generators/client/templates/react/src/main/webapp/app/shared/layout/menus/menu-components.tsx.ejs +1 -1
  87. package/generators/client/templates/react/webpack/webpack.dev.js.ejs +17 -1
  88. package/generators/client/templates/react/webpack/webpack.prod.js.ejs +13 -1
  89. package/generators/client/templates/vue/.eslintrc.js.ejs +8 -5
  90. package/generators/client/templates/vue/package.json +40 -49
  91. package/generators/client/templates/vue/package.json.ejs +14 -18
  92. package/generators/client/templates/vue/src/main/webapp/app/account/account.service.ts.ejs +6 -5
  93. package/generators/client/templates/vue/src/main/webapp/app/account/settings/settings.vue.ejs +7 -1
  94. package/generators/client/templates/vue/src/main/webapp/app/admin/configuration/configuration.service.ts.ejs +1 -1
  95. package/generators/client/templates/vue/src/main/webapp/app/admin/configuration/configuration.vue.ejs +1 -1
  96. package/generators/client/templates/vue/src/main/webapp/app/admin/metrics/metrics.component.ts.ejs +1 -1
  97. package/generators/client/templates/vue/src/main/webapp/app/admin/tracker/tracker.service.ts.ejs +5 -4
  98. package/generators/client/templates/vue/src/main/webapp/app/admin/user-management/user-management-edit.component.ts.ejs +9 -0
  99. package/generators/client/templates/vue/src/main/webapp/app/admin/user-management/user-management-view.component.ts.ejs +5 -0
  100. package/generators/client/templates/vue/src/main/webapp/app/admin/user-management/user-management.component.ts.ejs +5 -0
  101. package/generators/client/templates/vue/src/main/webapp/app/constants.ts.ejs +16 -6
  102. package/generators/client/templates/vue/src/main/webapp/app/core/jhi-navbar/jhi-navbar.component.ts.ejs +27 -8
  103. package/generators/client/templates/vue/src/main/webapp/app/core/jhi-navbar/jhi-navbar.vue.ejs +6 -0
  104. package/generators/client/templates/vue/src/main/webapp/app/declarations.d.ts.ejs +41 -0
  105. package/generators/client/templates/vue/src/main/webapp/app/entities/entities-menu.component.ts.ejs +34 -0
  106. package/generators/client/templates/vue/src/main/webapp/app/entities/entities-menu.vue.ejs +13 -0
  107. package/generators/client/templates/vue/src/main/webapp/app/entities/entities.component.ts.ejs +14 -0
  108. package/generators/client/templates/vue/src/main/webapp/app/entities/entities.vue.ejs +5 -0
  109. package/generators/client/templates/vue/{webpack/utils.js.ejs → src/main/webapp/app/index.ts.ejs} +1 -12
  110. package/generators/client/templates/vue/src/main/webapp/app/locale/translation.service.ts.ejs +26 -9
  111. package/generators/client/templates/vue/src/main/webapp/app/main.ts.ejs +23 -11
  112. package/generators/client/templates/vue/src/main/webapp/app/router/admin.ts.ejs +4 -4
  113. package/generators/client/templates/vue/src/main/webapp/app/router/entities.ts.ejs +45 -3
  114. package/generators/client/templates/vue/src/main/webapp/app/router/index.ts.ejs +19 -3
  115. package/generators/client/templates/vue/src/main/webapp/app/shared/alert/alert.service.ts.ejs +61 -0
  116. package/generators/client/templates/vue/src/main/webapp/app/shared/config/axios-interceptor.ts.ejs +0 -2
  117. package/generators/client/templates/vue/src/main/webapp/app/shared/data/data-utils.service.ts.ejs +3 -1
  118. package/generators/client/templates/vue/src/main/webapp/app/shims-vue.d.ts.ejs +17 -3
  119. package/generators/client/templates/vue/src/test/javascript/jest.conf.js.ejs +25 -10
  120. package/generators/client/templates/vue/src/test/javascript/spec/app/account/account.service.spec.ts.ejs +2 -2
  121. package/generators/client/templates/vue/src/test/javascript/spec/app/account/login-form/login-form.component.spec.ts.ejs +2 -2
  122. package/generators/client/templates/vue/src/test/javascript/spec/app/admin/tracker/tracker.component.spec.ts.ejs +12 -12
  123. package/generators/client/templates/vue/src/test/javascript/spec/app/admin/tracker/tracker.service.spec.ts.ejs +2 -1
  124. package/generators/client/templates/vue/src/test/javascript/spec/app/admin/user-management/user-management-edit.component.spec.ts.ejs +5 -1
  125. package/generators/client/templates/vue/src/test/javascript/spec/app/admin/user-management/user-management-view.component.spec.ts.ejs +2 -1
  126. package/generators/client/templates/vue/src/test/javascript/spec/app/admin/user-management/user-management.component.spec.ts.ejs +5 -1
  127. package/generators/client/templates/vue/src/test/javascript/spec/app/core/jhi-navbar/jhi-navbar.component.spec.ts.ejs +10 -4
  128. package/generators/client/templates/vue/src/test/javascript/spec/app/entities/entities-menu.spec.ts.ejs +52 -0
  129. package/generators/client/templates/vue/src/test/javascript/spec/app/microfrontends/entities-menu.component.ts.ejs +4 -0
  130. package/generators/client/templates/vue/src/test/javascript/spec/app/microfrontends/entities-menu.vue.ejs +7 -0
  131. package/generators/client/templates/vue/src/test/javascript/spec/app/microfrontends/entities-router.ts.ejs +1 -0
  132. package/generators/client/templates/vue/src/test/javascript/spec/app/shared/alert/alert.service.spec.ts.ejs +124 -0
  133. package/generators/client/templates/vue/src/test/javascript/spec/app/shared/config/axios-interceptor.spec.ts.ejs +0 -1
  134. package/generators/client/templates/vue/tsconfig.json.ejs +6 -10
  135. package/generators/client/templates/vue/tsconfig.spec.json.ejs +37 -0
  136. package/generators/client/templates/vue/webpack/config.js.ejs +50 -0
  137. package/generators/client/templates/vue/webpack/vue.utils.js.ejs +33 -32
  138. package/generators/client/templates/vue/webpack/webpack.common.js.ejs +152 -126
  139. package/generators/client/templates/vue/webpack/webpack.dev.js.ejs +19 -76
  140. package/generators/client/templates/vue/webpack/webpack.microfrontend.js.jhi.vue.ejs +77 -0
  141. package/generators/client/templates/vue/webpack/webpack.prod.js.ejs +5 -41
  142. package/generators/cloudfoundry/index.js +9 -9
  143. package/generators/common/index.js +12 -10
  144. package/generators/common/templates/.husky/pre-commit +1 -1
  145. package/generators/common/templates/.prettierrc.ejs +1 -1
  146. package/generators/common/templates/README.md.jhi.ejs +21 -0
  147. package/generators/common/templates/package.json +4 -4
  148. package/generators/cypress/index.js +12 -9
  149. package/generators/cypress/templates/cypress.json.ejs +9 -2
  150. package/generators/cypress/templates/src/test/javascript/cypress/plugins/index.ts.ejs +4 -4
  151. package/generators/cypress/templates/src/test/javascript/cypress/support/commands.ts.ejs +30 -2
  152. package/generators/cypress/templates/src/test/javascript/cypress/support/entity.ts.ejs +4 -4
  153. package/generators/cypress/templates/src/test/javascript/cypress/support/index.ts.ejs +1 -1
  154. package/generators/cypress/templates/src/test/javascript/cypress/support/management.ts.ejs +1 -1
  155. package/generators/cypress/templates/src/test/javascript/cypress/support/navbar.ts.ejs +1 -1
  156. package/generators/database-changelog/index.js +33 -22
  157. package/generators/database-changelog-liquibase/index.js +12 -8
  158. package/generators/database-changelog-liquibase/templates/src/main/resources/config/liquibase/changelog/updated_entity_constraints.xml.ejs +1 -1
  159. package/generators/docker-compose/index.js +11 -12
  160. package/generators/docker-compose/templates/realm-config/jhipster-realm.json.ejs +13 -12
  161. package/generators/entities/index.js +35 -26
  162. package/generators/entities-client/index.js +10 -7
  163. package/generators/entity/index.js +49 -29
  164. package/generators/entity-client/files.js +7 -16
  165. package/generators/entity-client/index.js +74 -11
  166. package/generators/entity-client/templates/angular/src/main/webapp/app/entities/delete/entity-management-delete-dialog.component.spec.ts.ejs +42 -44
  167. package/generators/entity-client/templates/angular/src/main/webapp/app/entities/detail/entity-management-detail.component.spec.ts.ejs +58 -60
  168. package/generators/entity-client/templates/angular/src/main/webapp/app/entities/entity-management.module.ts.ejs +1 -1
  169. package/generators/entity-client/templates/angular/src/main/webapp/app/entities/list/entity-management.component.spec.ts.ejs +105 -107
  170. package/generators/entity-client/templates/angular/src/main/webapp/app/entities/list/entity-management.component.ts.ejs +8 -1
  171. package/generators/entity-client/templates/angular/src/main/webapp/app/entities/route/entity-management-routing-resolve.service.spec.ts.ejs +52 -54
  172. package/generators/entity-client/templates/angular/src/main/webapp/app/entities/route/entity-management-routing.module.ts.ejs +1 -1
  173. package/generators/entity-client/templates/angular/src/main/webapp/app/entities/service/entity.service.spec.ts.ejs +173 -175
  174. package/generators/entity-client/templates/angular/src/main/webapp/app/entities/update/entity-management-update.component.html.ejs +2 -4
  175. package/generators/entity-client/templates/angular/src/main/webapp/app/entities/update/entity-management-update.component.spec.ts.ejs +193 -195
  176. package/generators/entity-client/templates/angular/src/main/webapp/app/entities/update/entity-management-update.component.ts.ejs +7 -0
  177. package/generators/entity-client/templates/common/src/test/javascript/cypress/integration/entity/entity.spec.ts.ejs +269 -109
  178. package/generators/entity-client/templates/react/src/main/webapp/app/entities/entity-delete-dialog.tsx.ejs +5 -2
  179. package/generators/entity-client/templates/react/src/main/webapp/app/entities/entity-update.tsx.ejs +17 -14
  180. package/generators/entity-client/templates/react/src/main/webapp/app/entities/entity.tsx.ejs +11 -13
  181. package/generators/entity-client/templates/vue/src/main/webapp/app/entities/entity-details.component.ts.ejs +5 -0
  182. package/generators/entity-client/templates/vue/src/main/webapp/app/entities/entity-update.component.ts.ejs +23 -8
  183. package/generators/entity-client/templates/vue/src/main/webapp/app/entities/entity-update.vue.ejs +6 -9
  184. package/generators/entity-client/templates/vue/src/main/webapp/app/entities/entity.component.ts.ejs +9 -1
  185. package/generators/entity-client/templates/vue/src/main/webapp/app/entities/entity.model.ts.ejs +1 -1
  186. package/generators/entity-client/templates/vue/src/main/webapp/app/entities/entity.service.ts.ejs +2 -6
  187. package/generators/entity-client/templates/vue/src/test/javascript/spec/app/entities/entity-details.component.spec.ts.ejs +2 -1
  188. package/generators/entity-client/templates/vue/src/test/javascript/spec/app/entities/entity-update.component.spec.ts.ejs +8 -1
  189. package/generators/entity-client/templates/vue/src/test/javascript/spec/app/entities/entity.component.spec.ts.ejs +8 -2
  190. package/generators/entity-client/templates/vue/src/test/javascript/spec/app/entities/entity.service.spec.ts.ejs +1 -1
  191. package/generators/entity-i18n/index.js +7 -4
  192. package/generators/entity-server/files-couchbase.js +2 -2
  193. package/generators/entity-server/files.js +35 -30
  194. package/generators/entity-server/index.js +12 -8
  195. package/generators/entity-server/templates/couchbase/src/main/java/package/repository/EntityRepository.java.ejs +2 -2
  196. package/generators/entity-server/templates/couchbase/src/main/resources/config/couchmove/changelog/entity.fts.ejs +1 -1
  197. package/generators/entity-server/templates/src/main/java/package/domain/Entity.java.jhi.ejs +6 -2
  198. package/generators/entity-server/templates/src/main/java/package/domain/enumeration/Enum.java.ejs +1 -1
  199. package/generators/entity-server/templates/src/main/java/package/repository/EntityRepository.java.ejs +2 -2
  200. package/generators/entity-server/templates/src/main/java/package/repository/EntityRepositoryInternalImpl_reactive.java.ejs +17 -30
  201. package/generators/entity-server/templates/src/main/java/package/repository/EntityRepository_reactive.java.ejs +5 -5
  202. package/generators/entity-server/templates/src/main/java/package/repository/EntitySqlHelper_reactive.java.ejs +46 -0
  203. package/generators/entity-server/templates/src/main/java/package/repository/rowmapper/EntityRowMapper.java.ejs +3 -3
  204. package/generators/entity-server/templates/src/main/java/package/repository/search/EntitySearchRepository.java.ejs +2 -2
  205. package/generators/entity-server/templates/src/main/java/package/service/EntityQueryService.java.ejs +8 -8
  206. package/generators/entity-server/templates/src/main/java/package/service/EntityService.java.ejs +4 -4
  207. package/generators/entity-server/templates/src/main/java/package/service/criteria/EntityCriteria.java.ejs +4 -4
  208. package/generators/entity-server/templates/src/main/java/package/service/dto/EntityDTO.java.ejs +7 -3
  209. package/generators/entity-server/templates/src/main/java/package/service/impl/EntityServiceImpl.java.ejs +8 -8
  210. package/generators/entity-server/templates/src/main/java/package/service/mapper/BaseEntityMapper.java.ejs +1 -1
  211. package/generators/entity-server/templates/src/main/java/package/service/mapper/EntityMapper.java.ejs +7 -3
  212. package/generators/entity-server/templates/src/main/java/package/web/rest/EntityResource.java.ejs +51 -53
  213. package/generators/entity-server/templates/src/test/java/package/domain/EntityTest.java.ejs +1 -1
  214. package/generators/entity-server/templates/src/test/java/package/repository/search/EntitySearchRepositoryMockConfiguration.java.ejs +1 -1
  215. package/generators/entity-server/templates/src/test/java/package/service/dto/EntityDTOTest.java.ejs +1 -1
  216. package/generators/entity-server/templates/src/test/java/package/service/mapper/EntityMapperTest.java.ejs +1 -1
  217. package/generators/entity-server/templates/src/test/java/package/web/rest/EntityResourceIT.java.ejs +17 -14
  218. package/generators/gae/index.js +10 -10
  219. package/generators/generator-base-blueprint.js +14 -46
  220. package/generators/generator-base-private.js +42 -22
  221. package/generators/generator-base.js +57 -20
  222. package/generators/generator-constants.js +29 -21
  223. package/generators/generator-transforms.js +39 -27
  224. package/generators/heroku/index.js +27 -48
  225. package/generators/init/constants.cjs +1 -1
  226. package/generators/init/templates/.husky/pre-commit +1 -1
  227. package/generators/java/constants.cjs +1 -1
  228. package/generators/kubernetes/files.js +3 -0
  229. package/generators/kubernetes/index.js +10 -10
  230. package/generators/kubernetes/templates/db/couchbase.yml.ejs +1 -1
  231. package/generators/kubernetes/templates/deployment.yml.ejs +8 -3
  232. package/generators/kubernetes/templates/istio/destination-rule.yml.ejs +1 -1
  233. package/generators/kubernetes/templates/istio/gateway/grafana-gateway.yml.ejs +5 -2
  234. package/generators/kubernetes/templates/istio/gateway/jhipster-grafana-gateway.yml.ejs +5 -2
  235. package/generators/kubernetes/templates/istio/gateway/kiali-gateway.yml.ejs +10 -8
  236. package/generators/kubernetes/templates/istio/gateway/zipkin-gateway.yml.ejs +5 -2
  237. package/generators/kubernetes/templates/istio/gateway.yml.ejs +7 -5
  238. package/generators/kubernetes/templates/secret/couchbase-secret.yml.ejs +9 -0
  239. package/generators/kubernetes-base.js +1 -0
  240. package/generators/kubernetes-helm/files.js +3 -8
  241. package/generators/kubernetes-helm/index.js +10 -10
  242. package/generators/kubernetes-helm/templates/README-KUBERNETES-HELM.md.ejs +0 -1
  243. package/generators/kubernetes-helm/templates/app/Chart.yml.ejs +27 -0
  244. package/generators/kubernetes-helm/templates/app/helpers.tpl.ejs +0 -11
  245. package/generators/kubernetes-helm/templates/app/requirements.yml.ejs +7 -2
  246. package/generators/kubernetes-helm/templates/app/values.yml.ejs +68 -5
  247. package/generators/kubernetes-helm/templates/csvc/Chart.yml.ejs +17 -0
  248. package/generators/kubernetes-helm/templates/csvc/requirements.yml.ejs +2 -2
  249. package/generators/kubernetes-knative/index.js +10 -10
  250. package/generators/kubernetes-knative/templates/istio/gateway.yml.ejs +6 -4
  251. package/generators/kubernetes-knative/templates/service.yml.ejs +1 -1
  252. package/generators/languages/index.js +13 -13
  253. package/generators/languages/templates/src/main/webapp/i18n/hr/reset.json.ejs +1 -2
  254. package/generators/languages/templates/src/main/webapp/i18n/vi/login.json +1 -1
  255. package/generators/maven/templates/.mvn/wrapper/maven-wrapper.properties +1 -1
  256. package/generators/openapi-client/index.js +13 -10
  257. package/generators/openshift/index.js +10 -11
  258. package/generators/openshift/templates/deployment.yml.ejs +1 -1
  259. package/generators/page/index.js +12 -10
  260. package/generators/server/__snapshots__/generator.spec.mjs.snap +12 -0
  261. package/generators/server/files-sql.js +52 -0
  262. package/generators/server/files.js +15 -0
  263. package/generators/server/index.js +100 -33
  264. package/generators/server/needle-api/needle-server-cache.js +4 -6
  265. package/generators/server/templates/.mvn/wrapper/maven-wrapper.properties +1 -1
  266. package/generators/server/templates/build.gradle.ejs +17 -1
  267. package/generators/server/templates/gradle.properties.ejs +11 -11
  268. package/generators/server/templates/npmw +1 -1
  269. package/generators/server/templates/npmw.cmd +1 -1
  270. package/generators/server/templates/pom.xml.ejs +128 -9
  271. package/generators/server/templates/settings.gradle.ejs +9 -0
  272. package/generators/server/templates/sql/reactive/src/main/java/package/repository/UserSqlHelper.java.ejs +48 -0
  273. package/generators/server/templates/src/main/docker/app.yml.ejs +2 -1
  274. package/generators/server/templates/src/main/docker/config/realm-config/jhipster-realm.json.ejs +13 -12
  275. package/generators/server/templates/src/main/java/package/aop/logging/LoggingAspect.java.ejs +1 -1
  276. package/generators/server/templates/src/main/java/package/config/DatabaseConfiguration_cassandra.java.ejs +0 -6
  277. package/generators/server/templates/src/main/java/package/config/DatabaseConfiguration_sql.java.ejs +2 -2
  278. package/generators/server/templates/src/main/java/package/config/JacksonConfiguration.java.ejs +1 -1
  279. package/generators/server/templates/src/main/java/package/config/LocaleConfiguration.java.ejs +0 -2
  280. package/generators/server/templates/src/main/java/package/config/SecurityConfiguration.java.ejs +2 -5
  281. package/generators/server/templates/src/main/java/package/config/SecurityConfiguration_reactive.java.ejs +9 -1
  282. package/generators/server/templates/src/main/java/package/config/WebConfigurer.java.ejs +0 -1
  283. package/generators/server/templates/src/main/java/package/management/SecurityMetersService.java.ejs +68 -0
  284. package/generators/server/templates/src/main/java/package/repository/UserRepository.java.ejs +0 -23
  285. package/generators/server/templates/src/main/java/package/security/PersistentTokenRememberMeServices.java.ejs +0 -2
  286. package/generators/server/templates/src/main/java/package/security/jwt/TokenProvider.java.ejs +29 -4
  287. package/generators/server/templates/src/main/java/package/security/oauth2/CustomClaimConverter.java.ejs +21 -9
  288. package/generators/server/templates/src/main/java/package/service/UserService.java.ejs +13 -5
  289. package/generators/server/templates/src/main/resources/config/application-dev.yml.ejs +1 -1
  290. package/generators/server/templates/src/main/resources/config/application-prod.yml.ejs +1 -1
  291. package/generators/server/templates/src/main/resources/config/application.yml.ejs +7 -7
  292. package/generators/server/templates/src/main/resources/static/microservices_index.html.ejs +1 -1
  293. package/generators/server/templates/src/test/java/package/management/SecurityMetersServiceTests.java.ejs +113 -0
  294. package/generators/server/templates/src/test/java/package/security/jwt/JWTFilterTest.java.ejs +6 -1
  295. package/generators/server/templates/src/test/java/package/security/jwt/TokenProviderSecurityMetersTests.java.ejs +198 -0
  296. package/generators/server/templates/src/test/java/package/security/jwt/TokenProviderTest.java.ejs +13 -3
  297. package/generators/server/templates/src/test/java/package/security/oauth2/AuthorizationHeaderUtilTest.java.ejs +16 -2
  298. package/generators/server/templates/src/test/java/package/security/oauth2/CustomClaimConverterIT.java.ejs +63 -0
  299. package/generators/spring-controller/index.js +9 -7
  300. package/generators/spring-service/index.js +10 -7
  301. package/generators/upgrade/index.js +4 -5
  302. package/generators/utils.js +2 -2
  303. package/generators/workspaces/index.js +16 -7
  304. package/jdl/jhipster/default-application-options.js +9 -7
  305. package/package.json +23 -23
  306. package/utils/entity.js +21 -4
  307. package/utils/field.js +12 -2
  308. package/utils/multi-step-transform/index.js +8 -8
  309. package/generators/client/templates/react/.npmrc.ejs +0 -1
  310. package/generators/client/templates/vue/webpack/dev.env.js.ejs +0 -17
  311. package/generators/client/templates/vue/webpack/env.js.ejs +0 -67
  312. package/generators/client/templates/vue/webpack/loader.conf.js.ejs +0 -20
  313. package/generators/client/templates/vue/webpack/prod.env.js.ejs +0 -15
@@ -51,6 +51,8 @@ import { DATE_TIME_LONG_FORMAT } from '@/shared/date/filters';
51
51
  <%_ } _%>
52
52
  <%_ } _%>
53
53
 
54
+ import AlertService from '@/shared/alert/alert.service';
55
+
54
56
  <%_ const importEntitiesSeen = [entityAngularName];
55
57
  let hasManyToMany = false;
56
58
  for (relationship of relationships) { _%>
@@ -76,6 +78,10 @@ import { I<%= otherEntityAngularName %> } from '@/shared/model/<%= otherEntityMo
76
78
  <%_ importEntitiesSeen.push(otherEntityAngularName); } } _%>
77
79
  import { I<%= entityAngularName %>, <%= entityAngularName %> } from '@/shared/model/<%= entityModelFileName %>.model';
78
80
  import <%= entityAngularName %>Service from './<%= entityFileName %>.service';
81
+ <%_ const enumImports = generateEntityClientEnumImports(fields); _%>
82
+ <%_ enumImports.forEach( (importedPath, importedType) => { _%>
83
+ import { <%- importedType %> } from '<%- importedPath %>';
84
+ <%_ }); _%>
79
85
 
80
86
  const validations: any = {
81
87
  <%= entityInstance %>: {
@@ -111,7 +117,7 @@ _%>
111
117
  <%_ } _%>
112
118
  <%_ for (relationship of relationships) { _%>
113
119
  <%_ if (relationship.relationshipValidate && relationship.relationshipRequired) { _%>
114
- <%= relationship.relationshipFieldName %>: {
120
+ <%= relationship.collection ? relationship.relationshipFieldNamePlural : relationship.relationshipFieldName %>: {
115
121
  required
116
122
  },
117
123
  <%_ } _%>
@@ -124,6 +130,8 @@ _%>
124
130
  })
125
131
  export default class <%= entityAngularName %>Update extends <% if (fieldsContainBlob) { %>mixins(JhiDataUtils)<% } else { %>Vue<% } %> {
126
132
  @Inject('<%= entityInstance %>Service') private <%= entityInstance %>Service: () => <%= entityAngularName %>Service;
133
+ @Inject('alertService') private alertService: () => AlertService;
134
+
127
135
  public <%= entityInstance %>: I<%= entityAngularName %> = new <%= entityAngularName %>();
128
136
  <%_
129
137
  const entitiesSeen = [entityAngularName];
@@ -144,6 +152,9 @@ export default class <%= entityAngularName %>Update extends <% if (fieldsContain
144
152
  public <%= otherEntityNamePlural %> : <% if (otherEntityAngularName === 'User') { %>Array<any><%_ } else { _%>I<%= otherEntityAngularName %>[]<%_ } _%> = [];
145
153
  <%_ } _%>
146
154
  <%_ entitiesSeen.push(otherEntityAngularName);entitiesSeen.push(otherEntityNamePlural); } } _%>
155
+ <%_ enumImports.forEach( (importedPath, importedType) => { _%>
156
+ public <%- _.lowerFirst(importedType) %>Values : string[] = Object.keys(<%- importedType %>);
157
+ <%_ }); _%>
147
158
  public isSaving = false;
148
159
  public currentLanguage = '';
149
160
 
@@ -199,7 +210,10 @@ export default class <%= entityAngularName %>Update extends <% if (fieldsContain
199
210
  variant: 'info',
200
211
  solid: true,
201
212
  autoHideDelay: 5000,
202
- });
213
+ })
214
+ }).catch(error => {
215
+ this.isSaving = false;
216
+ this.alertService().showHttpError(this,error.response);
203
217
  });
204
218
  } else {
205
219
  this.<%= entityInstance %>Service().create(this.<%= entityInstance %>).then((param) => {
@@ -217,7 +231,10 @@ export default class <%= entityAngularName %>Update extends <% if (fieldsContain
217
231
  solid: true,
218
232
  autoHideDelay: 5000,
219
233
  });
220
- });
234
+ }).catch(error => {
235
+ this.isSaving = false;
236
+ this.alertService().showHttpError(this,error.response);
237
+ });;
221
238
  }
222
239
  }
223
240
 
@@ -264,6 +281,8 @@ _%>
264
281
  res.<%= fieldName %> = new Date(res.<%= fieldName %>);
265
282
  <%_ } } _%>
266
283
  this.<%= entityInstance %> = res;
284
+ }).catch(error => {
285
+ this.alertService().showHttpError(this,error.response);
267
286
  });
268
287
  }
269
288
 
@@ -311,11 +330,7 @@ _%>
311
330
  <%_ if (hasManyToMany) { _%>
312
331
  public getSelected(selectedVals, option) : any {
313
332
  if (selectedVals) {
314
- for (let i = 0; i < selectedVals.length; i++) {
315
- if (option.id === selectedVals[i].id) {
316
- return selectedVals[i];
317
- }
318
- }
333
+ return selectedVals.find(value => option.id === value.id) ?? option;
319
334
  }
320
335
  return option;
321
336
  }
@@ -34,12 +34,9 @@ _%>
34
34
  <label class="form-control-label" v-text="$t('<%= translationKey %>')" for="<%= entityFileName %>-<%= fieldName %>"><%= fieldNameHumanized %></label>
35
35
  <%_ if (field.fieldIsEnum) { _%>
36
36
  <select class="form-control" name="<%= fieldName %>" :class="{'valid': !$v.<%= entityInstance %>.<%= fieldName %>.$invalid, 'invalid': $v.<%= entityInstance %>.<%= fieldName %>.$invalid }" v-model="$v.<%= entityInstance %>.<%= fieldName %>.$model" id="<%= entityFileName %>-<%= fieldName %>" data-cy="<%= fieldName %>" <% if (field.fieldValidate === true && field.fieldValidateRules.includes('required')) { %> required<% } %>>
37
- <%_ const enumPrefix = frontendAppName + '.'+ fieldType;
38
- const values = field.enumValues;
39
- for (key in values) {
40
- const enumValue = values[key]; _%>
41
- <option value="<%= enumValue.name %>" v-bind:label="$t('<%=enumPrefix%>.<%= enumValue.name %>')"><%= enumValue.value %></option>
42
- <%_ } _%>
37
+ <%_ const enumPrefix = frontendAppName + '.'+ fieldType; _%>
38
+ <option v-for="<%= _.lowerFirst(fieldType) %> in <%= _.lowerFirst(fieldType)%>Values" :key="<%= _.lowerFirst(fieldType) %>" v-bind:value="<%= _.lowerFirst(fieldType) %>" v-bind:label="$t('<%= enumPrefix %>.'+<%= _.lowerFirst(fieldType) %>)">{{ <%= _.lowerFirst(fieldType) %> }}</option>
39
+
43
40
  </select>
44
41
  <%_ } else { _%>
45
42
  <%_ if (field.fieldTypeBinary && !field.blobContentTypeText) { _%>
@@ -195,15 +192,15 @@ _%>
195
192
  <%_ } else if (relationship.relationshipManyToMany && ownerSide) { _%>
196
193
  <div class="form-group">
197
194
  <label v-text="$t('<%= translationKey %>')" for="<%= entityFileName %>-<%= relationshipName %>"><%= relationshipNameHumanized %></label>
198
- <select class="form-control" id="<%= entityFileName %>-<%= relationshipName %>" data-cy="<%= relationshipFieldName %>" multiple name="<%= relationshipName %>" v-if="<%=entityInstance %>.<%=relationshipFieldNamePlural %> !== undefined" v-model="<%=entityInstance %>.<%=relationshipFieldNamePlural %>"<% if (relationshipRequired) { %> required<% } %>>
195
+ <select class="form-control" id="<%= entityFileName %>-<%= relationshipFieldNamePlural %>" data-cy="<%= relationshipFieldName %>" multiple name="<%= relationshipName %>" v-if="<%=entityInstance %>.<%=relationshipFieldNamePlural %> !== undefined" v-model="<%=entityInstance %>.<%=relationshipFieldNamePlural %>"<% if (relationshipRequired) { %> required<% } %>>
199
196
  <option v-bind:value="getSelected(<%=entityInstance %>.<%=relationshipFieldNamePlural %>, <%=otherEntityName %>Option)" v-for="<%=otherEntityName %>Option in <%=otherEntityNamePlural %>" :key="<%=otherEntityName %>Option.id">{{<%=otherEntityName %>Option.<%=otherEntityField %>}}</option>
200
197
  </select>
201
198
  </div>
202
199
  <%_ } _%>
203
200
  <%_ if (relationship.relationshipValidate) { _%>
204
- <div v-if="$v.<%= entityInstance %>.<%= relationshipName %>.$anyDirty && $v.<%= entityInstance %>.<%= relationshipName %>.$invalid">
201
+ <div v-if="$v.<%= entityInstance %>.<%= relationship.collection ? relationshipFieldNamePlural : relationshipFieldName %>.$anyDirty && $v.<%= entityInstance %>.<%= relationship.collection ? relationshipFieldNamePlural : relationshipFieldName %>.$invalid">
205
202
  <%_ if (relationshipRequired) { _%>
206
- <small class="form-text text-danger" v-if="!$v.<%= entityInstance %>.<%= relationshipName %>.required" v-text="$t('entity.validation.required')">
203
+ <small class="form-text text-danger" v-if="!$v.<%= entityInstance %>.<%= relationship.collection ? relationshipFieldNamePlural : relationshipFieldName %>.required" v-text="$t('entity.validation.required')">
207
204
  This field is required.
208
205
  </small>
209
206
  <%_ } _%>
@@ -1,5 +1,6 @@
1
+ <%_ if (fieldsContainBlob || paginationInfiniteScroll) { -%>
1
2
  import { mixins } from 'vue-class-component';
2
-
3
+ <%_ } -%>
3
4
  import { Component, Vue, Inject } from 'vue-property-decorator';
4
5
  import Vue2Filters from 'vue2-filters';
5
6
  import { I<%= entityAngularName %> } from '@/shared/model/<%= entityModelFileName %>.model';
@@ -7,12 +8,15 @@ import { I<%= entityAngularName %> } from '@/shared/model/<%= entityModelFileNam
7
8
  import JhiDataUtils from '@/shared/data/data-utils.service';
8
9
  <% } %>
9
10
  import <%= entityAngularName %>Service from './<%= entityFileName %>.service';
11
+ import AlertService from '@/shared/alert/alert.service';
10
12
 
11
13
  @Component({
12
14
  mixins: [Vue2Filters.mixin]
13
15
  })
14
16
  export default class <%= entityAngularName %> extends <% if (fieldsContainBlob || paginationInfiniteScroll) { %>mixins(JhiDataUtils)<% } else { %>Vue<% } %> {
15
17
  @Inject('<%= entityInstance %>Service') private <%= entityInstance %>Service: () => <%= entityAngularName %>Service;
18
+ @Inject('alertService') private alertService: () => AlertService;
19
+
16
20
  <%_ if (searchEngine) { _%>
17
21
  public currentSearch = '';
18
22
  <%_ } _%>
@@ -114,6 +118,7 @@ export default class <%= entityAngularName %> extends <% if (fieldsContainBlob |
114
118
  <%_ } _%>
115
119
  }, err => {
116
120
  this.isFetching = false;
121
+ this.alertService().showHttpError(this,err.response);
117
122
  });
118
123
  return;
119
124
  }
@@ -146,6 +151,7 @@ export default class <%= entityAngularName %> extends <% if (fieldsContainBlob |
146
151
  <%_ } _%>
147
152
  }, err => {
148
153
  this.isFetching = false;
154
+ this.alertService().showHttpError(this,err.response);
149
155
  });
150
156
  }
151
157
 
@@ -182,6 +188,8 @@ export default class <%= entityAngularName %> extends <% if (fieldsContainBlob |
182
188
  this.retrieveAll<%= entityAngularName %>s();
183
189
  <%_ } _%>
184
190
  this.closeDialog();
191
+ }).catch(error => {
192
+ this.alertService().showHttpError(this,error.response);
185
193
  });
186
194
  }
187
195
 
@@ -32,7 +32,7 @@ import { <%- importedType %> } from '<%- importedPath %>';
32
32
  <%_ }); _%>
33
33
 
34
34
  <%_ enumImports.forEach( (importedPath, importedType) => { _%>
35
- import { <%- importedType %> } from '<%- importedPath.replace('app/', '@/'); %>';
35
+ import { <%- importedType %> } from '<%- importedPath %>';
36
36
  <%_ }); _%>
37
37
  export interface I<%= entityAngularName %> {
38
38
  <%_ variablesWithTypes.forEach(variablesWithType => { _%>
@@ -4,13 +4,9 @@ import buildPaginationQueryOpts from '@/shared/sort/sorts';
4
4
  <% } %>
5
5
  import { I<%= entityAngularName %> } from '@/shared/model/<%= entityModelFileName %>.model';
6
6
 
7
- <%_
8
- const baseApi = (applicationTypeGateway && locals.microserviceName) ? 'services/' + microserviceName.toLowerCase() + '/api/' : 'api/';
9
- _%>
10
-
11
- const baseApiUrl = '<%= baseApi + entityApiUrl %>';
7
+ const baseApiUrl = '<%= entityApi %>api/<%= entityApiUrl %>';
12
8
  <%_ if (searchEngine) { _%>
13
- const baseSearchApiUrl = '<%= baseApi %>_search/<%= entityApiUrl %>?query=';
9
+ const baseSearchApiUrl = '<%= entityApi %>api/_search/<%= entityApiUrl %>?query=';
14
10
  <%_ } _%>
15
11
 
16
12
  export default class <%= entityAngularName %>Service {
@@ -29,6 +29,7 @@ import <%= entityAngularName %>DetailComponent from '@/entities/<%= entityFolder
29
29
  import <%= entityAngularName %>Class from '@/entities/<%= entityFolderName %>/<%= entityFileName %>-details.component';
30
30
  import <%= entityAngularName %>Service from '@/entities/<%= entityFolderName %>/<%= entityFileName %>.service';
31
31
  import router from '@/router';
32
+ import AlertService from '@/shared/alert/alert.service';
32
33
 
33
34
  const localVue = createLocalVue();
34
35
  localVue.use(VueRouter);
@@ -51,7 +52,7 @@ describe('Component Tests', () => {
51
52
  beforeEach(() => {
52
53
  <%= entityInstance %>ServiceStub = sinon.createStubInstance<<%= entityAngularName %>Service>(<%= entityAngularName %>Service);
53
54
 
54
- wrapper = shallowMount<<%= entityAngularName %>Class>(<%= entityAngularName %>DetailComponent, { store, <% if (enableTranslation) { %>i18n, <% } %>localVue, router, provide: { <%= entityInstance %>Service: () => <%= entityInstance %>ServiceStub } });
55
+ wrapper = shallowMount<<%= entityAngularName %>Class>(<%= entityAngularName %>DetailComponent, { store, <% if (enableTranslation) { %>i18n, <% } %>localVue, router, provide: { <%= entityInstance %>Service: () => <%= entityInstance %>ServiceStub, alertService: () => new AlertService(), } });
55
56
  comp = wrapper.vm;
56
57
  });
57
58
 
@@ -21,6 +21,7 @@
21
21
  import { shallowMount, createLocalVue, Wrapper } from '@vue/test-utils';
22
22
  import sinon, { SinonStubbedInstance } from 'sinon';
23
23
  import Router from 'vue-router';
24
+ import { ToastPlugin } from 'bootstrap-vue';
24
25
 
25
26
  <%_ let dayJsIncluded = false;
26
27
  for (field of fields.filter(field => !field.id)) { _%>
@@ -55,6 +56,7 @@ import <%= otherEntityAngularName %>Service from '@/entities/<%= otherEntityClie
55
56
  <%_ importEntitiesSeen.push(otherEntityAngularName); _%>
56
57
  <%_ } _%>
57
58
  <%_ } _%>
59
+ import AlertService from '@/shared/alert/alert.service';
58
60
 
59
61
  const localVue = createLocalVue();
60
62
 
@@ -65,6 +67,7 @@ const i18n = config.initI18N(localVue);
65
67
  const store = config.initVueXStore(localVue);
66
68
  const router = new Router();
67
69
  localVue.use(Router);
70
+ localVue.use(ToastPlugin);
68
71
  localVue.component('font-awesome-icon', {});
69
72
  localVue.component('b-input-group', {});
70
73
  localVue.component('b-input-group-prepend', {});
@@ -90,6 +93,7 @@ describe('Component Tests', () => {
90
93
  router,
91
94
  provide: {
92
95
  <%= entityInstance %>Service: () => <%= entityInstance %>ServiceStub,
96
+ alertService: () => new AlertService(),
93
97
  <%_
94
98
  const entitiesSeen = [entityAngularName];
95
99
  for (relationship of relationships) { _%>
@@ -100,7 +104,10 @@ describe('Component Tests', () => {
100
104
  <%_ if (relationship.otherEntityUser && authenticationTypeOauth2) { _%>
101
105
  userOAuth2Service: () => new UserOAuth2Service(),
102
106
  <%_ } else { _%>
103
- <%= otherEntityName %>Service: () => new <%= otherEntityAngularName %>Service(),
107
+ <%= otherEntityName %>Service: () =>
108
+ sinon.createStubInstance<<%= otherEntityAngularName %>Service>(<%= otherEntityAngularName %>Service, {
109
+ retrieve: sinon.stub().resolves({}),
110
+ } as any),
104
111
  <%_ } _%>
105
112
  <%_ } _%>
106
113
  <%_ entitiesSeen.push(otherEntityAngularName); _%>
@@ -22,13 +22,16 @@ _%>
22
22
  /* tslint:disable max-line-length */
23
23
  import { shallowMount, createLocalVue, Wrapper } from '@vue/test-utils';
24
24
  import sinon, { SinonStubbedInstance } from 'sinon';
25
+ import { ToastPlugin } from 'bootstrap-vue';
25
26
 
26
27
  import * as config from '@/shared/config/config';
27
28
  import <%= entityAngularName %>Component from '@/entities/<%= entityFolderName %>/<%= entityFileName %>.vue';
28
29
  import <%= entityAngularName %>Class from '@/entities/<%= entityFolderName %>/<%= entityFileName %>.component';
29
30
  import <%= entityAngularName %>Service from '@/entities/<%= entityFolderName %>/<%= entityFileName %>.service';
31
+ import AlertService from '@/shared/alert/alert.service';
30
32
 
31
33
  const localVue = createLocalVue();
34
+ localVue.use(ToastPlugin);
32
35
 
33
36
  config.initVueApp(localVue);
34
37
  <%_ if (enableTranslation) { _%>
@@ -70,7 +73,8 @@ describe('Component Tests', () => {
70
73
  localVue,
71
74
  stubs: {<%_ if (!paginationNo) { _%>jhiItemCount:true, bPagination:true,<%_ } _%> bModal: bModalStub as any},
72
75
  provide: {
73
- <%= entityInstance %>Service: () => <%= entityInstance %>ServiceStub
76
+ <%= entityInstance %>Service: () => <%= entityInstance %>ServiceStub,
77
+ alertService: () => new AlertService(),
74
78
  }
75
79
  });
76
80
  comp = wrapper.vm;
@@ -183,12 +187,14 @@ describe('Component Tests', () => {
183
187
 
184
188
  // WHEN
185
189
  comp.prepareRemove({id: <%- tsKeyId %>});
190
+ expect(<%= entityInstance %>ServiceStub.retrieve.callCount).toEqual(1);
191
+
186
192
  comp.remove<%= entityAngularName %>();
187
193
  await comp.$nextTick();
188
194
 
189
195
  // THEN
190
196
  expect(<%= entityInstance %>ServiceStub.delete.called).toBeTruthy();
191
- expect(<%= entityInstance %>ServiceStub.retrieve.callCount).toEqual(1);
197
+ expect(<%= entityInstance %>ServiceStub.retrieve.callCount).toEqual(2);
192
198
  });
193
199
  <%_ } _%>
194
200
  });
@@ -33,7 +33,7 @@ import { <%_ if (fieldsContainLocalDate) { _%>DATE_FORMAT,<%_ } if (fieldsContai
33
33
  import <%= entityAngularName %>Service from '@/entities/<%= entityFolderName %>/<%= entityFileName %>.service';
34
34
  import { <%= entityAngularName %> } from '@/shared/model/<%= entityModelFileName %>.model';
35
35
  <%_ enumImports.forEach( (importedPath, importedType) => { _%>
36
- import { <%- importedType %> } from '<%- importedPath.replace('app/', '@/') %>';
36
+ import { <%- importedType %> } from '<%- importedPath %>';
37
37
  <%_ }); _%>
38
38
 
39
39
  const error = {
@@ -23,7 +23,6 @@ const { GENERATOR_ENTITY_I_18_N } = require('../generator-list');
23
23
  const BaseBlueprintGenerator = require('../generator-base-blueprint');
24
24
 
25
25
  /* constants used throughout */
26
- let useBlueprints;
27
26
 
28
27
  module.exports = class extends BaseBlueprintGenerator {
29
28
  constructor(args, options, features) {
@@ -31,8 +30,12 @@ module.exports = class extends BaseBlueprintGenerator {
31
30
 
32
31
  this.entity = this.options.context;
33
32
  this.jhipsterContext = this.options.jhipsterContext || this.options.context;
33
+ }
34
34
 
35
- useBlueprints = !this.fromBlueprint && this.instantiateBlueprints(GENERATOR_ENTITY_I_18_N, { context: this.options.context });
35
+ async _postConstruct() {
36
+ if (!this.fromBlueprint) {
37
+ await this.composeWithBlueprints(GENERATOR_ENTITY_I_18_N, { context: this.options.context });
38
+ }
36
39
  }
37
40
 
38
41
  // Public API method used by the getter and also by Blueprints
@@ -47,7 +50,7 @@ module.exports = class extends BaseBlueprintGenerator {
47
50
  }
48
51
 
49
52
  get default() {
50
- if (useBlueprints) return;
53
+ if (this.delegateToBlueprint) return {};
51
54
  return this._default();
52
55
  }
53
56
 
@@ -57,7 +60,7 @@ module.exports = class extends BaseBlueprintGenerator {
57
60
  }
58
61
 
59
62
  get writing() {
60
- if (useBlueprints) return;
63
+ if (this.delegateToBlueprint) return {};
61
64
  return this._writing();
62
65
  }
63
66
  };
@@ -37,7 +37,7 @@ const entityCouchbaseFiles = {
37
37
  templates: [
38
38
  {
39
39
  file: 'package/domain/Entity.java.jhi.spring_data_couchbase',
40
- renameTo: generator => `${generator.packageFolder}/domain/${generator.persistClass}.java.jhi.spring_data_couchbase`,
40
+ renameTo: generator => `${generator.entityAbsoluteFolder}/domain/${generator.persistClass}.java.jhi.spring_data_couchbase`,
41
41
  },
42
42
  ],
43
43
  },
@@ -47,7 +47,7 @@ const entityCouchbaseFiles = {
47
47
  templates: [
48
48
  {
49
49
  file: 'package/repository/EntityRepository.java',
50
- renameTo: generator => `${generator.packageFolder}/repository/${generator.entityClass}Repository.java`,
50
+ renameTo: generator => `${generator.entityAbsoluteFolder}/repository/${generator.entityClass}Repository.java`,
51
51
  },
52
52
  ],
53
53
  },
@@ -60,11 +60,11 @@ const serverFiles = {
60
60
  templates: [
61
61
  {
62
62
  file: 'package/domain/Entity.java.jhi',
63
- renameTo: generator => `${generator.packageFolder}/domain/${generator.persistClass}.java.jhi`,
63
+ renameTo: generator => `${generator.entityAbsoluteFolder}/domain/${generator.persistClass}.java.jhi`,
64
64
  },
65
65
  {
66
66
  file: 'package/domain/Entity.java.jhi.javax_validation',
67
- renameTo: generator => `${generator.packageFolder}/domain/${generator.persistClass}.java.jhi.javax_validation`,
67
+ renameTo: generator => `${generator.entityAbsoluteFolder}/domain/${generator.persistClass}.java.jhi.javax_validation`,
68
68
  },
69
69
  ],
70
70
  },
@@ -74,7 +74,7 @@ const serverFiles = {
74
74
  templates: [
75
75
  {
76
76
  file: 'package/domain/Entity.java.jhi.spring_data_reactive',
77
- renameTo: generator => `${generator.packageFolder}/domain/${generator.persistClass}.java.jhi.spring_data_reactive`,
77
+ renameTo: generator => `${generator.entityAbsoluteFolder}/domain/${generator.persistClass}.java.jhi.spring_data_reactive`,
78
78
  },
79
79
  ],
80
80
  },
@@ -84,7 +84,7 @@ const serverFiles = {
84
84
  templates: [
85
85
  {
86
86
  file: 'package/domain/Entity.java.jhi.spring_data_cassandra',
87
- renameTo: generator => `${generator.packageFolder}/domain/${generator.persistClass}.java.jhi.spring_data_cassandra`,
87
+ renameTo: generator => `${generator.entityAbsoluteFolder}/domain/${generator.persistClass}.java.jhi.spring_data_cassandra`,
88
88
  },
89
89
  ],
90
90
  },
@@ -94,7 +94,7 @@ const serverFiles = {
94
94
  templates: [
95
95
  {
96
96
  file: 'package/domain/Entity.java.jhi.spring_data_neo4j',
97
- renameTo: generator => `${generator.packageFolder}/domain/${generator.persistClass}.java.jhi.spring_data_neo4j`,
97
+ renameTo: generator => `${generator.entityAbsoluteFolder}/domain/${generator.persistClass}.java.jhi.spring_data_neo4j`,
98
98
  },
99
99
  ],
100
100
  },
@@ -104,7 +104,7 @@ const serverFiles = {
104
104
  templates: [
105
105
  {
106
106
  file: 'package/domain/Entity.java.jhi.javax_persistence',
107
- renameTo: generator => `${generator.packageFolder}/domain/${generator.persistClass}.java.jhi.javax_persistence`,
107
+ renameTo: generator => `${generator.entityAbsoluteFolder}/domain/${generator.persistClass}.java.jhi.javax_persistence`,
108
108
  },
109
109
  ],
110
110
  },
@@ -114,7 +114,7 @@ const serverFiles = {
114
114
  templates: [
115
115
  {
116
116
  file: 'package/domain/Entity.java.jhi.spring_data_mongodb',
117
- renameTo: generator => `${generator.packageFolder}/domain/${generator.persistClass}.java.jhi.spring_data_mongodb`,
117
+ renameTo: generator => `${generator.entityAbsoluteFolder}/domain/${generator.persistClass}.java.jhi.spring_data_mongodb`,
118
118
  },
119
119
  ],
120
120
  },
@@ -124,7 +124,7 @@ const serverFiles = {
124
124
  templates: [
125
125
  {
126
126
  file: 'package/domain/Entity.java.jhi.hibernate_cache',
127
- renameTo: generator => `${generator.packageFolder}/domain/${generator.persistClass}.java.jhi.hibernate_cache`,
127
+ renameTo: generator => `${generator.entityAbsoluteFolder}/domain/${generator.persistClass}.java.jhi.hibernate_cache`,
128
128
  },
129
129
  ],
130
130
  },
@@ -134,7 +134,7 @@ const serverFiles = {
134
134
  templates: [
135
135
  {
136
136
  file: 'package/domain/Entity.java.jhi.elastic_search',
137
- renameTo: generator => `${generator.packageFolder}/domain/${generator.persistClass}.java.jhi.elastic_search`,
137
+ renameTo: generator => `${generator.entityAbsoluteFolder}/domain/${generator.persistClass}.java.jhi.elastic_search`,
138
138
  },
139
139
  ],
140
140
  },
@@ -144,7 +144,7 @@ const serverFiles = {
144
144
  templates: [
145
145
  {
146
146
  file: 'package/web/rest/EntityResource.java',
147
- renameTo: generator => `${generator.packageFolder}/web/rest/${generator.entityClass}Resource.java`,
147
+ renameTo: generator => `${generator.entityAbsoluteFolder}/web/rest/${generator.entityClass}Resource.java`,
148
148
  },
149
149
  ],
150
150
  },
@@ -154,11 +154,11 @@ const serverFiles = {
154
154
  templates: [
155
155
  {
156
156
  file: 'package/service/criteria/EntityCriteria.java',
157
- renameTo: generator => `${generator.packageFolder}/service/criteria/${generator.entityClass}Criteria.java`,
157
+ renameTo: generator => `${generator.entityAbsoluteFolder}/service/criteria/${generator.entityClass}Criteria.java`,
158
158
  },
159
159
  {
160
160
  file: 'package/service/EntityQueryService.java',
161
- renameTo: generator => `${generator.packageFolder}/service/${generator.entityClass}QueryService.java`,
161
+ renameTo: generator => `${generator.entityAbsoluteFolder}/service/${generator.entityClass}QueryService.java`,
162
162
  },
163
163
  ],
164
164
  },
@@ -168,7 +168,7 @@ const serverFiles = {
168
168
  templates: [
169
169
  {
170
170
  file: 'package/repository/search/EntitySearchRepository.java',
171
- renameTo: generator => `${generator.packageFolder}/repository/search/${generator.entityClass}SearchRepository.java`,
171
+ renameTo: generator => `${generator.entityAbsoluteFolder}/repository/search/${generator.entityClass}SearchRepository.java`,
172
172
  },
173
173
  ],
174
174
  },
@@ -178,7 +178,7 @@ const serverFiles = {
178
178
  templates: [
179
179
  {
180
180
  file: 'package/repository/EntityRepository.java',
181
- renameTo: generator => `${generator.packageFolder}/repository/${generator.entityClass}Repository.java`,
181
+ renameTo: generator => `${generator.entityAbsoluteFolder}/repository/${generator.entityClass}Repository.java`,
182
182
  },
183
183
  ],
184
184
  },
@@ -188,7 +188,7 @@ const serverFiles = {
188
188
  templates: [
189
189
  {
190
190
  file: 'package/repository/EntityRepository_reactive.java',
191
- renameTo: generator => `${generator.packageFolder}/repository/${generator.entityClass}Repository.java`,
191
+ renameTo: generator => `${generator.entityAbsoluteFolder}/repository/${generator.entityClass}Repository.java`,
192
192
  },
193
193
  ],
194
194
  },
@@ -198,11 +198,15 @@ const serverFiles = {
198
198
  templates: [
199
199
  {
200
200
  file: 'package/repository/EntityRepositoryInternalImpl_reactive.java',
201
- renameTo: generator => `${generator.packageFolder}/repository/${generator.entityClass}RepositoryInternalImpl.java`,
201
+ renameTo: generator => `${generator.entityAbsoluteFolder}/repository/${generator.entityClass}RepositoryInternalImpl.java`,
202
+ },
203
+ {
204
+ file: 'package/repository/EntitySqlHelper_reactive.java',
205
+ renameTo: generator => `${generator.entityAbsoluteFolder}/repository/${generator.entityClass}SqlHelper.java`,
202
206
  },
203
207
  {
204
208
  file: 'package/repository/rowmapper/EntityRowMapper.java',
205
- renameTo: generator => `${generator.packageFolder}/repository/rowmapper/${generator.entityClass}RowMapper.java`,
209
+ renameTo: generator => `${generator.entityAbsoluteFolder}/repository/rowmapper/${generator.entityClass}RowMapper.java`,
206
210
  },
207
211
  ],
208
212
  },
@@ -212,11 +216,11 @@ const serverFiles = {
212
216
  templates: [
213
217
  {
214
218
  file: 'package/service/EntityService.java',
215
- renameTo: generator => `${generator.packageFolder}/service/${generator.entityClass}Service.java`,
219
+ renameTo: generator => `${generator.entityAbsoluteFolder}/service/${generator.entityClass}Service.java`,
216
220
  },
217
221
  {
218
222
  file: 'package/service/impl/EntityServiceImpl.java',
219
- renameTo: generator => `${generator.packageFolder}/service/impl/${generator.entityClass}ServiceImpl.java`,
223
+ renameTo: generator => `${generator.entityAbsoluteFolder}/service/impl/${generator.entityClass}ServiceImpl.java`,
220
224
  },
221
225
  ],
222
226
  },
@@ -226,7 +230,7 @@ const serverFiles = {
226
230
  templates: [
227
231
  {
228
232
  file: 'package/service/impl/EntityServiceImpl.java',
229
- renameTo: generator => `${generator.packageFolder}/service/${generator.entityClass}Service.java`,
233
+ renameTo: generator => `${generator.entityAbsoluteFolder}/service/${generator.entityClass}Service.java`,
230
234
  },
231
235
  ],
232
236
  },
@@ -236,15 +240,15 @@ const serverFiles = {
236
240
  templates: [
237
241
  {
238
242
  file: 'package/service/dto/EntityDTO.java',
239
- renameTo: generator => `${generator.packageFolder}/service/dto/${generator.asDto(generator.entityClass)}.java`,
243
+ renameTo: generator => `${generator.entityAbsoluteFolder}/service/dto/${generator.asDto(generator.entityClass)}.java`,
240
244
  },
241
245
  {
242
246
  file: 'package/service/mapper/BaseEntityMapper.java',
243
- renameTo: generator => `${generator.packageFolder}/service/mapper/EntityMapper.java`,
247
+ renameTo: generator => `${generator.entityAbsoluteFolder}/service/mapper/EntityMapper.java`,
244
248
  },
245
249
  {
246
250
  file: 'package/service/mapper/EntityMapper.java',
247
- renameTo: generator => `${generator.packageFolder}/service/mapper/${generator.entityClass}Mapper.java`,
251
+ renameTo: generator => `${generator.entityAbsoluteFolder}/service/mapper/${generator.entityClass}Mapper.java`,
248
252
  },
249
253
  ],
250
254
  },
@@ -264,7 +268,7 @@ const serverFiles = {
264
268
  SERVER_TEST_SRC_DIR,
265
269
  },
266
270
  },
267
- renameTo: generator => `${generator.packageFolder}/web/rest/${generator.entityClass}ResourceIT.java`,
271
+ renameTo: generator => `${generator.entityAbsoluteFolder}/web/rest/${generator.entityClass}ResourceIT.java`,
268
272
  },
269
273
  ],
270
274
  },
@@ -275,7 +279,7 @@ const serverFiles = {
275
279
  {
276
280
  file: 'package/repository/search/EntitySearchRepositoryMockConfiguration.java',
277
281
  renameTo: generator =>
278
- `${generator.packageFolder}/repository/search/${generator.entityClass}SearchRepositoryMockConfiguration.java`,
282
+ `${generator.entityAbsoluteFolder}/repository/search/${generator.entityClass}SearchRepositoryMockConfiguration.java`,
279
283
  },
280
284
  ],
281
285
  },
@@ -295,7 +299,7 @@ const serverFiles = {
295
299
  templates: [
296
300
  {
297
301
  file: 'package/domain/EntityTest.java',
298
- renameTo: generator => `${generator.packageFolder}/domain/${generator.persistClass}Test.java`,
302
+ renameTo: generator => `${generator.entityAbsoluteFolder}/domain/${generator.persistClass}Test.java`,
299
303
  },
300
304
  ],
301
305
  },
@@ -305,7 +309,7 @@ const serverFiles = {
305
309
  templates: [
306
310
  {
307
311
  file: 'package/service/dto/EntityDTOTest.java',
308
- renameTo: generator => `${generator.packageFolder}/service/dto/${generator.asDto(generator.entityClass)}Test.java`,
312
+ renameTo: generator => `${generator.entityAbsoluteFolder}/service/dto/${generator.asDto(generator.entityClass)}Test.java`,
309
313
  },
310
314
  ],
311
315
  },
@@ -315,7 +319,7 @@ const serverFiles = {
315
319
  templates: [
316
320
  {
317
321
  file: 'package/service/mapper/EntityMapperTest.java',
318
- renameTo: generator => `${generator.packageFolder}/service/mapper/${generator.entityClass}MapperTest.java`,
322
+ renameTo: generator => `${generator.entityAbsoluteFolder}/service/mapper/${generator.entityClass}MapperTest.java`,
319
323
  },
320
324
  ],
321
325
  },
@@ -350,6 +354,7 @@ function writeFiles() {
350
354
  ...utils.getEnumInfo(field, this.clientRootFolder),
351
355
  frontendAppName: this.frontendAppName,
352
356
  packageName: this.packageName,
357
+ entityAbsolutePackage: this.entityAbsolutePackage || this.packageName,
353
358
  };
354
359
  // eslint-disable-next-line no-console
355
360
  if (!this.skipServer) {
@@ -358,7 +363,7 @@ function writeFiles() {
358
363
  )}/${SERVER_MAIN_SRC_DIR}package/domain/enumeration/Enum.java.ejs`;
359
364
  this.template(
360
365
  pathToTemplateFile,
361
- `${SERVER_MAIN_SRC_DIR}${this.packageFolder}/domain/enumeration/${fieldType}.java`,
366
+ `${SERVER_MAIN_SRC_DIR}${this.entityAbsoluteFolder}/domain/enumeration/${fieldType}.java`,
362
367
  this,
363
368
  {},
364
369
  enumInfo
@@ -373,7 +378,7 @@ function writeFiles() {
373
378
  function customizeFiles() {
374
379
  if (this.databaseType === SQL) {
375
380
  if ([EHCACHE, CAFFEINE, INFINISPAN, REDIS].includes(this.cacheProvider) && this.enableHibernateCache) {
376
- this.addEntityToCache(this.asEntity(this.entityClass), this.relationships, this.packageName, this.packageFolder, this.cacheProvider);
381
+ this.addEntityToCache(this.entityAbsoluteClass, this.relationships, this.packageName, this.packageFolder, this.cacheProvider);
377
382
  }
378
383
  }
379
384
  }