@adonisjs/core 7.0.0-next.1 → 7.0.0-next.3

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.
@@ -308,8 +308,16 @@ export class Codemods extends EventEmitter {
308
308
  const transformer = await this.#getCodeTransformer();
309
309
  const appPath = this.#app.makePath();
310
310
  const colors = this.#cliLogger.getColors();
311
- const devDependencies = packages.filter((pkg) => pkg.isDevDependency).map(({ name }) => name);
312
- const dependencies = packages.filter((pkg) => !pkg.isDevDependency).map(({ name }) => name);
311
+ const devDependencies = packages
312
+ .filter((pkg) => pkg.isDevDependency)
313
+ .map(({ name }) => {
314
+ return name.startsWith('@adonisjs/') ? `${name}@next` : name;
315
+ });
316
+ const dependencies = packages
317
+ .filter((pkg) => !pkg.isDevDependency)
318
+ .map(({ name }) => {
319
+ return name.startsWith('@adonisjs/') ? `${name}@next` : name;
320
+ });
313
321
  if (!transformer) {
314
322
  this.#cliLogger.warning('Cannot install packages. Install "@adonisjs/assembler" or manually install following packages');
315
323
  this.#cliLogger.log(`devDependencies: ${devDependencies.join(',')}`);
@@ -71,6 +71,7 @@ export default class EdgeServiceProvider {
71
71
  edge.configure({ cache: app.inProduction });
72
72
  /**
73
73
  * Define Edge global helpers
74
+ * @deprecated
74
75
  */
75
76
  edge.global('route', function (...args) {
76
77
  return router.makeUrl(...args);
@@ -80,6 +81,15 @@ export default class EdgeServiceProvider {
80
81
  });
81
82
  edge.global('app', app);
82
83
  edge.global('config', edgeConfigResolver);
84
+ /**
85
+ * Route helpers
86
+ */
87
+ edge.global('urlFor', function (...args) {
88
+ return router.urlBuilder.urlFor(...args);
89
+ });
90
+ edge.global('signedUrlFor', function (...args) {
91
+ return router.urlBuilder.signedUrlFor(...args);
92
+ });
83
93
  /**
84
94
  * Creating a isolated instance of edge renderer
85
95
  */
@@ -45,12 +45,18 @@ export function indexEntities(entities = {}) {
45
45
  const events = Object.assign({ enabled: true, source: 'app/events', importAlias: '#events' }, entities.events);
46
46
  const listeners = Object.assign({ enabled: true, source: 'app/listeners', importAlias: '#listeners' }, entities.listeners);
47
47
  const controllers = Object.assign({ enabled: true, source: 'app/controllers', importAlias: '#controllers' }, entities.controllers);
48
- const transformers = Object.assign({ enabled: false, source: 'app/transformers', importAlias: '#transformers' }, entities.transformers);
48
+ const transformers = Object.assign({
49
+ enabled: false,
50
+ source: 'app/transformers',
51
+ importAlias: '#transformers',
52
+ withSharedProps: false,
53
+ }, entities.transformers);
49
54
  return {
50
55
  run(_, indexGenerator) {
51
56
  if (events.enabled) {
52
57
  indexGenerator.add('events', {
53
58
  source: events.source,
59
+ disableLazyImports: true,
54
60
  glob: events.glob,
55
61
  as: 'barrelFile',
56
62
  exportName: 'events',
@@ -95,7 +101,7 @@ export function indexEntities(entities = {}) {
95
101
  },
96
102
  transformValue: helpers.toImportPath,
97
103
  });
98
- outputTransformerDataObjects(transformersList, buffer);
104
+ outputTransformerDataObjects(transformersList, buffer, transformers.withSharedProps);
99
105
  },
100
106
  importAlias: transformers.importAlias,
101
107
  output: '.adonisjs/client/data.d.ts',
@@ -374,6 +374,7 @@ export type IndexEntitiesConfig = {
374
374
  };
375
375
  transformers?: {
376
376
  enabled?: boolean;
377
+ withSharedProps?: boolean;
377
378
  source?: string;
378
379
  importAlias?: string;
379
380
  glob?: string[];
@@ -57,4 +57,4 @@ export declare function importTypeScript(app: ApplicationService): Promise<typeo
57
57
  * // }
58
58
  * // }
59
59
  */
60
- export declare function outputTransformerDataObjects(transformersList: RecursiveFileTree, buffer: Assembler.FileBuffer): Promise<void>;
60
+ export declare function outputTransformerDataObjects(transformersList: RecursiveFileTree, buffer: Assembler.FileBuffer, withSharedProps: boolean): Promise<void>;
@@ -71,9 +71,12 @@ export async function importTypeScript(app) {
71
71
  * // }
72
72
  * // }
73
73
  */
74
- export async function outputTransformerDataObjects(transformersList, buffer) {
74
+ export async function outputTransformerDataObjects(transformersList, buffer, withSharedProps) {
75
75
  const importsBuffer = buffer.create();
76
- importsBuffer.write(`import { InferData } from '@adonisjs/core/types/transformers'`);
76
+ importsBuffer.write(`import type { InferData, InferVariants } from '@adonisjs/core/types/transformers'`);
77
+ if (withSharedProps) {
78
+ importsBuffer.write(`import type { InferSharedProps } from '@adonisjs/inertia/types'`);
79
+ }
77
80
  buffer.writeLine(importsBuffer);
78
81
  buffer.write('export namespace Data {').indent();
79
82
  /**
@@ -91,6 +94,9 @@ export async function outputTransformerDataObjects(transformersList, buffer) {
91
94
  const importName = `${parents.join()}${key}Transformer`;
92
95
  importsBuffer.write(`import ${importName} from '${value}'`);
93
96
  buffer.write(`export type ${key} = InferData<${importName}>`);
97
+ buffer.write(`export namespace ${key} {`).indent();
98
+ buffer.write(`export type Variants = InferVariants<${importName}>`);
99
+ buffer.dedent().write('}');
94
100
  }
95
101
  else {
96
102
  buffer.write(`export namespace ${key} {`).indent();
@@ -100,5 +106,9 @@ export async function outputTransformerDataObjects(transformersList, buffer) {
100
106
  });
101
107
  }
102
108
  generateNamespaceTree(transformersList, []);
109
+ if (withSharedProps) {
110
+ importsBuffer.write(`import type InertiaMiddleware from '#middleware/inertia_middleware'`);
111
+ buffer.write('export type SharedProps = InferSharedProps<InertiaMiddleware>');
112
+ }
103
113
  buffer.dedent().write('}');
104
114
  }
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "@adonisjs/core",
3
3
  "description": "Core of AdonisJS",
4
- "version": "7.0.0-next.1",
4
+ "version": "7.0.0-next.3",
5
5
  "engines": {
6
6
  "node": ">=24.0.0"
7
7
  },
@@ -84,7 +84,7 @@
84
84
  "index:commands": "node --import=@poppinss/ts-exec toolkit/main.js index build/commands"
85
85
  },
86
86
  "devDependencies": {
87
- "@adonisjs/assembler": "^8.0.0-next.9",
87
+ "@adonisjs/assembler": "^8.0.0-next.10",
88
88
  "@adonisjs/eslint-config": "^3.0.0-next.1",
89
89
  "@adonisjs/prettier-config": "^1.4.5",
90
90
  "@adonisjs/tsconfig": "^2.0.0-next.0",
@@ -123,7 +123,7 @@
123
123
  },
124
124
  "dependencies": {
125
125
  "@adonisjs/ace": "^14.0.1-next.1",
126
- "@adonisjs/application": "^9.0.0-next.8",
126
+ "@adonisjs/application": "^9.0.0-next.9",
127
127
  "@adonisjs/bodyparser": "^11.0.0-next.1",
128
128
  "@adonisjs/config": "^6.0.0-next.1",
129
129
  "@adonisjs/encryption": "^7.0.0-next.1",
@@ -148,7 +148,7 @@
148
148
  "string-width": "^8.1.0"
149
149
  },
150
150
  "peerDependencies": {
151
- "@adonisjs/assembler": "^8.0.0-next.6",
151
+ "@adonisjs/assembler": "^8.0.0-next.10",
152
152
  "@vinejs/vine": "^3.0.0",
153
153
  "argon2": "^0.43.0",
154
154
  "bcrypt": "^6.0.0",