@eui/showcase 18.0.0-rc.10 → 18.0.0-rc.12

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.
@@ -120,24 +120,35 @@ export class AppModule {}
120
120
  `;
121
121
  export const angularJsonFile = `
122
122
  {
123
+ "$schema": "./node_modules/@angular/cli/lib/config/schema.json",
123
124
  "version": 1,
124
125
  "newProjectRoot": "projects",
125
126
  "projects": {
126
127
  "demo": {
127
- "root": "",
128
- "sourceRoot": "",
129
- "projectType": "application",
130
- "prefix": "app",
131
- "schematics": {},
132
128
  "architect": {
133
129
  "build": {
134
- "builder": "@angular-devkit/build-angular:browser",
130
+ "builder": "@angular-devkit/build-angular:application",
131
+ "configurations": {
132
+ "development": {
133
+ "extractLicenses": false,
134
+ "namedChunks": true,
135
+ "optimization": false,
136
+ "sourceMap": true
137
+ },
138
+ "production": {
139
+ "aot": true,
140
+ "extractLicenses": true,
141
+ "namedChunks": false,
142
+ "optimization": true,
143
+ "outputHashing": "all",
144
+ "sourceMap": false
145
+ }
146
+ },
135
147
  "options": {
136
- "outputPath": "dist/demo",
137
148
  "index": "src/index.html",
138
- "main": "src/main.ts",
139
- "polyfills": "src/polyfills.ts",
140
- "tsConfig": "tsconfig.json",
149
+ "browser": "src/main.ts",
150
+ "outputPath": "dist/demo",
151
+ "scripts": [],
141
152
  "assets": [
142
153
  {
143
154
  "glob": "**/*",
@@ -151,47 +162,31 @@ export const angularJsonFile = `
151
162
  }
152
163
  ],
153
164
  "styles": [
154
- "./node_modules/@eui/styles/dist/styles/eui.css"
165
+ "./node_modules/@eui/styles/dist/eui.css"
155
166
  ],
156
- "scripts": [],
157
- "preserveSymlinks": true
158
- },
159
- "configurations": {
160
- "production": {
161
- "optimization": true,
162
- "outputHashing": "all",
163
- "sourceMap": false,
164
- "extractCss": true,
165
- "namedChunks": false,
166
- "aot": true,
167
- "extractLicenses": true,
168
- "vendorChunk": false,
169
- "buildOptimizer": true
170
- }
167
+ "tsConfig": "tsconfig.json"
171
168
  }
172
169
  },
173
170
  "serve": {
174
171
  "builder": "@angular-devkit/build-angular:dev-server",
175
- "options": {
176
- "browserTarget": "demo:build"
177
- },
178
172
  "configurations": {
173
+ "development": {
174
+ "buildTarget": "demo:build:development"
175
+ },
179
176
  "production": {
180
- "browserTarget": "demo:build:production"
177
+ "buildTarget": "demo:build:production"
181
178
  }
182
- }
183
- },
184
- "lint": {
185
- "builder": "@angular-devkit/build-angular:tslint",
186
- "options": {
187
- "tsConfig": ["tsconfig.json"],
188
- "exclude": ["**/node_modules/**"]
189
- }
179
+ },
180
+ "defaultConfiguration": "development"
190
181
  }
191
- }
182
+ },
183
+ "prefix": "app",
184
+ "projectType": "application",
185
+ "root": "",
186
+ "schematics": {},
187
+ "sourceRoot": "src"
192
188
  }
193
189
  },
194
- "defaultProject": "demo",
195
190
  "cli": {
196
191
  "analytics": "0f944abb-e787-4c1f-9092-e34292361c91"
197
192
  }
@@ -206,36 +201,50 @@ export const PACKAGE_JSON = {
206
201
  name: 'demo',
207
202
  version: '0.0.0',
208
203
  private: true,
204
+ scripts: {
205
+ ng: 'ng',
206
+ start: 'ng serve',
207
+ build: 'ng build',
208
+ watch: 'ng build --watch --configuration development',
209
+ test: 'ng test',
210
+ lint: 'ng lint',
211
+ },
209
212
  dependencies: {},
210
213
  };
211
214
  export const tsConfig = `
215
+ /* To learn more about this file see: https://angular.io/config/tsconfig. */
212
216
  {
213
217
  "compileOnSave": false,
214
218
  "compilerOptions": {
215
- "baseUrl": "./",
216
- "outDir": "./dist/out-tsc",
219
+ "outDir": "./out-tsc/app",
220
+ "skipLibCheck": true, // needed for @ngrx compilation
221
+ "target": "ES2022",
222
+ "module": "ES2022",
223
+ "useDefineForClassFields": false,
224
+ "lib": ["ES2022", "dom"],
225
+ "declaration": true,
226
+ "declarationMap": true,
227
+ "inlineSources": true,
228
+ "emitDecoratorMetadata": false,
229
+ "types": [],
230
+ "esModuleInterop": true,
217
231
  "sourceMap": true,
218
- "declaration": false,
219
- "downlevelIteration": true,
220
232
  "experimentalDecorators": true,
221
- "module": "esnext",
222
- "moduleResolution": "node",
223
- "importHelpers": true,
224
- "target": "es2016",
225
- "allowSyntheticDefaultImports": true,
226
- "emitDecoratorMetadata": true,
227
- "typeRoots": [
228
- "node_modules/@types"
229
- ],
230
- "lib": [
231
- "es2020",
232
- "dom"
233
- ]
233
+ "moduleResolution": "bundler",
234
+ "importHelpers": true
234
235
  },
235
236
  "angularCompilerOptions": {
236
- "enableIvy": true,
237
- "fullTemplateTypeCheck": true,
238
- "strictInjectionParameters": true
239
- }
237
+ "compilationMode": "partial",
238
+ "enableI18nLegacyMessageIdFormat": false,
239
+ "strictInputAccessModifiers": true,
240
+ "strictMetadataEmit": true,
241
+ "strictTemplates": true,
242
+ "annotateForClosureCompiler": true,
243
+ "skipTemplateCodegen": true,
244
+ "fullTemplateTypeCheck": true
245
+ },
246
+ "exclude": ["src/test.ts", "**/*.spec.ts"],
247
+ "files": ["src/main.ts"],
248
+ "include": ["src/**/*.d.ts"]
240
249
  }`;
241
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"stackblitz.files.js","sourceRoot":"","sources":["../../../../../src/lib/components/playground/stackblitz.files.ts"],"names":[],"mappings":"AAAA,MAAM,CAAC,MAAM,aAAa,GAAG,qBAAqB,CAAC;AACnD,MAAM,CAAC,MAAM,QAAQ,GAAG,CAAC,UAAkB,EAAE,aAAqB,EAAU,EAAE,CAAC;;;;;;;;;;WAUpE,aAAa,KAAK,UAAU;;;;;;;;;;;;MAYjC,UAAU;;;;;;;;;;;;;;;;;;gBAkBA,aAAa;;;;;;;;;;;;;;CAc5B,CAAC;AACF,MAAM,CAAC,MAAM,UAAU,GAAG,CAAC,aAAqB,EAAE,IAAsC,EAAE,EAAU,EAAE,CAClG;;;;;;;;;;;;;;;;;;;;;WAqBO,aAAa;CACvB;IACG,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,YAAY,CAAC,CAAC,IAAI,YAAY,CAAC,CAAC,IAAI,MAAM,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC;IACjE;;;;;;;;;;;;;;;;;KAiBC;IACD,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,GAAG,CAAC,CAAC,IAAI,GAAG,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC;IACnC;;mBAEe,aAAa;;;;;;;;;;;;;;;gBAehB,aAAa;;;CAG5B,CAAC;AACF,MAAM,CAAC,MAAM,eAAe,GAAG;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CA8E9B,CAAC;AACF,MAAM,CAAC,MAAM,aAAa,GAAG,CAAC,QAAgB,EAAU,EAAE,CAAC;;OAEpD,QAAQ,MAAM,QAAQ;;CAE5B,CAAC;AACF,MAAM,CAAC,MAAM,YAAY,GAAG;IACxB,IAAI,EAAE,MAAM;IACZ,OAAO,EAAE,OAAO;IAChB,OAAO,EAAE,IAAI;IACb,YAAY,EAAE,EAAE;CACnB,CAAC;AACF,MAAM,CAAC,MAAM,QAAQ,GAAG;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EA6BtB,CAAC","sourcesContent":["export const polyfillsFile = 'import \\'zone.js\\';';\nexport const mainFile = (moduleName: string, componentName: string): string => `\nimport './polyfills';\nimport { BrowserModule } from '@angular/platform-browser';\nimport { InjectionToken, NgModule } from '@angular/core';\nimport { HttpClientModule } from '@angular/common/http';\nimport { platformBrowserDynamic } from '@angular/platform-browser-dynamic';\nimport { reducers as coreReducers, CoreModule, EUI_CONFIG_TOKEN } from '@eui/core';\nimport { TranslateModule } from '@ngx-translate/core';\nimport { StoreModule } from '@ngrx/store';\n\nimport { ${componentName}, ${moduleName} } from './component';\n\nexport const REDUCER_TOKEN = new InjectionToken<any>('Registered Reducers');\nconst rootReducer = Object.assign({}, coreReducers, {});\n\n@NgModule({\n  imports: [\n    BrowserModule,\n    HttpClientModule,\n    CoreModule.forRoot(),\n    TranslateModule.forRoot(),\n    StoreModule.forRoot(REDUCER_TOKEN),\n    ${moduleName},\n  ],\n  providers: [\n    {\n      provide: REDUCER_TOKEN,\n      deps: [],\n      useFactory: () => rootReducer ,\n    },\n    {\n      provide: EUI_CONFIG_TOKEN,\n      useValue: {\n        appConfig: {\n          global: {},\n        },\n        environment: {}\n      }\n    }\n  ],\n  bootstrap: [${componentName}],\n})\nexport class RootModule {\n}\n\nplatformBrowserDynamic().bootstrapModule(RootModule).then(ref => {\n  // Ensure Angular destroys itself on hot reloads.\n  if (window['ngRef']) {\n    window['ngRef'].destroy();\n  }\n  window['ngRef'] = ref;\n\n  // Otherwise, log the boot error\n}).catch(err => console.error(err));\n`;\nexport const moduleFile = (componentName: string, m: { name: string; path: string }[] = []): string =>\n    `\nimport { NgModule, InjectionToken } from '@angular/core';\nimport { BrowserModule } from '@angular/platform-browser';\nimport { BrowserAnimationsModule } from '@angular/platform-browser/animations';\nimport { RouterModule } from '@angular/router';\nimport { APP_BASE_HREF } from '@angular/common';\nimport { HttpClientModule } from '@angular/common/http';\nimport { StoreModule } from '@ngrx/store';\nimport { EffectsModule } from '@ngrx/effects';\nimport { TranslateModule } from '@ngx-translate/core';\nimport { FormsModule } from '@angular/forms';\nimport { CommonModule } from '@angular/common';\nimport { EuiAllModule } from '@eui/components';\nimport {\n    reducers as coreReducers,\n    CoreModule as EuiCoreModule,\n    translateConfig,\n    CoreModuleEffects,\n    EUI_CONFIG_TOKEN,\n} from '@eui/core';\n\nimport { ${componentName} } from './component';\n` +\n    m.map((i) => `import { ${i.name} } from '${i.path}';\\n`).join('') +\n    `\n\nexport const REDUCER_TOKEN = new InjectionToken<any>('Registered Reducers');\n\n@NgModule({\n  imports: [\n    BrowserAnimationsModule,\n    CommonModule,\n    BrowserModule,\n    FormsModule,\n    EuiAllModule,\n    HttpClientModule,\n    RouterModule.forRoot([]),\n    EuiCoreModule.forRoot(),\n    EffectsModule.forRoot([...CoreModuleEffects]),\n    TranslateModule.forRoot(translateConfig),\n    StoreModule.forRoot(REDUCER_TOKEN, { })\n    ` +\n    m.map((i) => `${i.name},`).join('') +\n    `\n  ],\n  declarations: [${componentName}],\n  providers: [\n    {\n        provide: REDUCER_TOKEN,\n        deps: [],\n        useFactory: () => Object.assign({}, coreReducers),\n    },\n    {\n        provide: EUI_CONFIG_TOKEN,\n        useValue: { appConfig: {}, environment: {} }\n    },\n    {\n        provide: APP_BASE_HREF, useValue: '/'\n    }\n  ],\n  bootstrap: [${componentName}],\n})\nexport class AppModule {}\n`;\nexport const angularJsonFile = `\n{\n  \"version\": 1,\n  \"newProjectRoot\": \"projects\",\n  \"projects\": {\n    \"demo\": {\n      \"root\": \"\",\n      \"sourceRoot\": \"\",\n      \"projectType\": \"application\",\n      \"prefix\": \"app\",\n      \"schematics\": {},\n      \"architect\": {\n        \"build\": {\n          \"builder\": \"@angular-devkit/build-angular:browser\",\n          \"options\": {\n            \"outputPath\": \"dist/demo\",\n            \"index\": \"src/index.html\",\n            \"main\": \"src/main.ts\",\n            \"polyfills\": \"src/polyfills.ts\",\n            \"tsConfig\": \"tsconfig.json\",\n            \"assets\": [\n              {\n                \"glob\": \"**/*\",\n                \"input\": \"./node_modules/@eui/styles/dist/assets/\",\n                \"output\": \"src/assets\"\n              },\n              {\n                \"glob\": \"**/*\",\n                \"input\": \"./node_modules/@eui/core/assets/\",\n                \"output\": \"src/assets\"\n              }\n            ],\n            \"styles\": [\n              \"./node_modules/@eui/styles/dist/styles/eui.css\"\n            ],\n            \"scripts\": [],\n            \"preserveSymlinks\": true\n          },\n          \"configurations\": {\n            \"production\": {\n              \"optimization\": true,\n              \"outputHashing\": \"all\",\n              \"sourceMap\": false,\n              \"extractCss\": true,\n              \"namedChunks\": false,\n              \"aot\": true,\n              \"extractLicenses\": true,\n              \"vendorChunk\": false,\n              \"buildOptimizer\": true\n            }\n          }\n        },\n        \"serve\": {\n          \"builder\": \"@angular-devkit/build-angular:dev-server\",\n          \"options\": {\n            \"browserTarget\": \"demo:build\"\n          },\n          \"configurations\": {\n            \"production\": {\n              \"browserTarget\": \"demo:build:production\"\n            }\n          }\n        },\n        \"lint\": {\n          \"builder\": \"@angular-devkit/build-angular:tslint\",\n          \"options\": {\n            \"tsConfig\": [\"tsconfig.json\"],\n            \"exclude\": [\"**/node_modules/**\"]\n          }\n        }\n      }\n    }\n  },\n  \"defaultProject\": \"demo\",\n  \"cli\": {\n    \"analytics\": \"0f944abb-e787-4c1f-9092-e34292361c91\"\n  }\n}\n`;\nexport const indexHtmlFile = (selector: string): string => `\n<div style=\"padding: 10px\">\n    <${selector}></${selector}>\n</div>\n`;\nexport const PACKAGE_JSON = {\n    name: 'demo',\n    version: '0.0.0',\n    private: true,\n    dependencies: {},\n};\nexport const tsConfig = `\n{\n  \"compileOnSave\": false,\n  \"compilerOptions\": {\n    \"baseUrl\": \"./\",\n    \"outDir\": \"./dist/out-tsc\",\n    \"sourceMap\": true,\n    \"declaration\": false,\n    \"downlevelIteration\": true,\n    \"experimentalDecorators\": true,\n    \"module\": \"esnext\",\n    \"moduleResolution\": \"node\",\n    \"importHelpers\": true,\n    \"target\": \"es2016\",\n    \"allowSyntheticDefaultImports\": true,\n    \"emitDecoratorMetadata\": true,\n    \"typeRoots\": [\n      \"node_modules/@types\"\n    ],\n    \"lib\": [\n      \"es2020\",\n      \"dom\"\n    ]\n  },\n  \"angularCompilerOptions\": {\n    \"enableIvy\": true,\n    \"fullTemplateTypeCheck\": true,\n    \"strictInjectionParameters\": true\n  }\n}`;\n"]}
250
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"stackblitz.files.js","sourceRoot":"","sources":["../../../../../src/lib/components/playground/stackblitz.files.ts"],"names":[],"mappings":"AAAA,MAAM,CAAC,MAAM,aAAa,GAAG,qBAAqB,CAAC;AACnD,MAAM,CAAC,MAAM,QAAQ,GAAG,CAAC,UAAkB,EAAE,aAAqB,EAAU,EAAE,CAAC;;;;;;;;;;WAUpE,aAAa,KAAK,UAAU;;;;;;;;;;;;MAYjC,UAAU;;;;;;;;;;;;;;;;;;gBAkBA,aAAa;;;;;;;;;;;;;;CAc5B,CAAC;AACF,MAAM,CAAC,MAAM,UAAU,GAAG,CAAC,aAAqB,EAAE,IAAsC,EAAE,EAAU,EAAE,CAClG;;;;;;;;;;;;;;;;;;;;;WAqBO,aAAa;CACvB;IACG,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,YAAY,CAAC,CAAC,IAAI,YAAY,CAAC,CAAC,IAAI,MAAM,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC;IACjE;;;;;;;;;;;;;;;;;KAiBC;IACD,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,GAAG,CAAC,CAAC,IAAI,GAAG,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC;IACnC;;mBAEe,aAAa;;;;;;;;;;;;;;;gBAehB,aAAa;;;CAG5B,CAAC;AACF,MAAM,CAAC,MAAM,eAAe,GAAG;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CAyE9B,CAAC;AACF,MAAM,CAAC,MAAM,aAAa,GAAG,CAAC,QAAgB,EAAU,EAAE,CAAC;;OAEpD,QAAQ,MAAM,QAAQ;;CAE5B,CAAC;AACF,MAAM,CAAC,MAAM,YAAY,GAAG;IACxB,IAAI,EAAE,MAAM;IACZ,OAAO,EAAE,OAAO;IAChB,OAAO,EAAE,IAAI;IACb,OAAO,EAAE;QACL,EAAE,EAAE,IAAI;QACR,KAAK,EAAE,UAAU;QACjB,KAAK,EAAE,UAAU;QACjB,KAAK,EAAE,8CAA8C;QACrD,IAAI,EAAE,SAAS;QACf,IAAI,EAAE,SAAS;KAClB;IACD,YAAY,EAAE,EAAE;CACnB,CAAC;AACF,MAAM,CAAC,MAAM,QAAQ,GAAG;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EAmCtB,CAAC","sourcesContent":["export const polyfillsFile = 'import \\'zone.js\\';';\nexport const mainFile = (moduleName: string, componentName: string): string => `\nimport './polyfills';\nimport { BrowserModule } from '@angular/platform-browser';\nimport { InjectionToken, NgModule } from '@angular/core';\nimport { HttpClientModule } from '@angular/common/http';\nimport { platformBrowserDynamic } from '@angular/platform-browser-dynamic';\nimport { reducers as coreReducers, CoreModule, EUI_CONFIG_TOKEN } from '@eui/core';\nimport { TranslateModule } from '@ngx-translate/core';\nimport { StoreModule } from '@ngrx/store';\n\nimport { ${componentName}, ${moduleName} } from './component';\n\nexport const REDUCER_TOKEN = new InjectionToken<any>('Registered Reducers');\nconst rootReducer = Object.assign({}, coreReducers, {});\n\n@NgModule({\n  imports: [\n    BrowserModule,\n    HttpClientModule,\n    CoreModule.forRoot(),\n    TranslateModule.forRoot(),\n    StoreModule.forRoot(REDUCER_TOKEN),\n    ${moduleName},\n  ],\n  providers: [\n    {\n      provide: REDUCER_TOKEN,\n      deps: [],\n      useFactory: () => rootReducer ,\n    },\n    {\n      provide: EUI_CONFIG_TOKEN,\n      useValue: {\n        appConfig: {\n          global: {},\n        },\n        environment: {}\n      }\n    }\n  ],\n  bootstrap: [${componentName}],\n})\nexport class RootModule {\n}\n\nplatformBrowserDynamic().bootstrapModule(RootModule).then(ref => {\n  // Ensure Angular destroys itself on hot reloads.\n  if (window['ngRef']) {\n    window['ngRef'].destroy();\n  }\n  window['ngRef'] = ref;\n\n  // Otherwise, log the boot error\n}).catch(err => console.error(err));\n`;\nexport const moduleFile = (componentName: string, m: { name: string; path: string }[] = []): string =>\n    `\nimport { NgModule, InjectionToken } from '@angular/core';\nimport { BrowserModule } from '@angular/platform-browser';\nimport { BrowserAnimationsModule } from '@angular/platform-browser/animations';\nimport { RouterModule } from '@angular/router';\nimport { APP_BASE_HREF } from '@angular/common';\nimport { HttpClientModule } from '@angular/common/http';\nimport { StoreModule } from '@ngrx/store';\nimport { EffectsModule } from '@ngrx/effects';\nimport { TranslateModule } from '@ngx-translate/core';\nimport { FormsModule } from '@angular/forms';\nimport { CommonModule } from '@angular/common';\nimport { EuiAllModule } from '@eui/components';\nimport {\n    reducers as coreReducers,\n    CoreModule as EuiCoreModule,\n    translateConfig,\n    CoreModuleEffects,\n    EUI_CONFIG_TOKEN,\n} from '@eui/core';\n\nimport { ${componentName} } from './component';\n` +\n    m.map((i) => `import { ${i.name} } from '${i.path}';\\n`).join('') +\n    `\n\nexport const REDUCER_TOKEN = new InjectionToken<any>('Registered Reducers');\n\n@NgModule({\n  imports: [\n    BrowserAnimationsModule,\n    CommonModule,\n    BrowserModule,\n    FormsModule,\n    EuiAllModule,\n    HttpClientModule,\n    RouterModule.forRoot([]),\n    EuiCoreModule.forRoot(),\n    EffectsModule.forRoot([...CoreModuleEffects]),\n    TranslateModule.forRoot(translateConfig),\n    StoreModule.forRoot(REDUCER_TOKEN, { })\n    ` +\n    m.map((i) => `${i.name},`).join('') +\n    `\n  ],\n  declarations: [${componentName}],\n  providers: [\n    {\n        provide: REDUCER_TOKEN,\n        deps: [],\n        useFactory: () => Object.assign({}, coreReducers),\n    },\n    {\n        provide: EUI_CONFIG_TOKEN,\n        useValue: { appConfig: {}, environment: {} }\n    },\n    {\n        provide: APP_BASE_HREF, useValue: '/'\n    }\n  ],\n  bootstrap: [${componentName}],\n})\nexport class AppModule {}\n`;\nexport const angularJsonFile = `\n{\n  \"$schema\": \"./node_modules/@angular/cli/lib/config/schema.json\",\n  \"version\": 1,\n  \"newProjectRoot\": \"projects\",\n  \"projects\": {\n    \"demo\": {\n      \"architect\": {\n        \"build\": {\n          \"builder\": \"@angular-devkit/build-angular:application\",\n          \"configurations\": {\n            \"development\": {\n              \"extractLicenses\": false,\n              \"namedChunks\": true,\n              \"optimization\": false,\n              \"sourceMap\": true\n            },\n            \"production\": {\n              \"aot\": true,\n              \"extractLicenses\": true,\n              \"namedChunks\": false,\n              \"optimization\": true,\n              \"outputHashing\": \"all\",\n              \"sourceMap\": false\n            }\n          },\n          \"options\": {\n            \"index\": \"src/index.html\",\n            \"browser\": \"src/main.ts\",\n            \"outputPath\": \"dist/demo\",\n            \"scripts\": [],\n            \"assets\": [\n              {\n                \"glob\": \"**/*\",\n                \"input\": \"./node_modules/@eui/styles/dist/assets/\",\n                \"output\": \"src/assets\"\n              },\n              {\n                \"glob\": \"**/*\",\n                \"input\": \"./node_modules/@eui/core/assets/\",\n                \"output\": \"src/assets\"\n              }\n            ],\n            \"styles\": [\n              \"./node_modules/@eui/styles/dist/eui.css\"\n            ],\n            \"tsConfig\": \"tsconfig.json\"\n          }\n        },\n        \"serve\": {\n          \"builder\": \"@angular-devkit/build-angular:dev-server\",\n          \"configurations\": {\n            \"development\": {\n              \"buildTarget\": \"demo:build:development\"\n            },\n            \"production\": {\n              \"buildTarget\": \"demo:build:production\"\n            }\n          },\n          \"defaultConfiguration\": \"development\"\n        }\n      },\n      \"prefix\": \"app\",\n      \"projectType\": \"application\",\n      \"root\": \"\",\n      \"schematics\": {},\n      \"sourceRoot\": \"src\"\n    }\n  },\n  \"cli\": {\n    \"analytics\": \"0f944abb-e787-4c1f-9092-e34292361c91\"\n  }\n}\n`;\nexport const indexHtmlFile = (selector: string): string => `\n<div style=\"padding: 10px\">\n    <${selector}></${selector}>\n</div>\n`;\nexport const PACKAGE_JSON = {\n    name: 'demo',\n    version: '0.0.0',\n    private: true,\n    scripts: {\n        ng: 'ng',\n        start: 'ng serve',\n        build: 'ng build',\n        watch: 'ng build --watch --configuration development',\n        test: 'ng test',\n        lint: 'ng lint',\n    },\n    dependencies: {},\n};\nexport const tsConfig = `\n/* To learn more about this file see: https://angular.io/config/tsconfig. */\n{\n  \"compileOnSave\": false,\n  \"compilerOptions\": {\n    \"outDir\": \"./out-tsc/app\",\n    \"skipLibCheck\": true, // needed for @ngrx compilation\n    \"target\": \"ES2022\",\n    \"module\": \"ES2022\",\n    \"useDefineForClassFields\": false,\n    \"lib\": [\"ES2022\", \"dom\"],\n    \"declaration\": true,\n    \"declarationMap\": true,\n    \"inlineSources\": true,\n    \"emitDecoratorMetadata\": false,\n    \"types\": [],\n    \"esModuleInterop\": true,\n    \"sourceMap\": true,\n    \"experimentalDecorators\": true,\n    \"moduleResolution\": \"bundler\",\n    \"importHelpers\": true\n  },\n  \"angularCompilerOptions\": {\n    \"compilationMode\": \"partial\",\n    \"enableI18nLegacyMessageIdFormat\": false,\n    \"strictInputAccessModifiers\": true,\n    \"strictMetadataEmit\": true,\n    \"strictTemplates\": true,\n    \"annotateForClosureCompiler\": true,\n    \"skipTemplateCodegen\": true,\n    \"fullTemplateTypeCheck\": true\n  },\n  \"exclude\": [\"src/test.ts\", \"**/*.spec.ts\"],\n  \"files\": [\"src/main.ts\"],\n  \"include\": [\"src/**/*.d.ts\"]\n}`;\n"]}
@@ -74,7 +74,7 @@ export class StackblitzService {
74
74
  const project = {
75
75
  title: title,
76
76
  description: `An eUI example for the ${title}.`,
77
- template: 'angular-cli',
77
+ template: 'node',
78
78
  files: {
79
79
  'src/component.html': htmlContent,
80
80
  'src/component.ts': this.appendVitalNgModules(typescriptContent),
@@ -88,6 +88,7 @@ export class StackblitzService {
88
88
  devDependencies,
89
89
  }, null, 2),
90
90
  'tsconfig.json': tsConfig,
91
+ '.stackblitzrc': '{\n\t"installDependencies": false,\n\t"startCommand": "npm install --force && npm start"\n}',
91
92
  },
92
93
  settings: {
93
94
  compile: {
@@ -129,6 +130,7 @@ export class StackblitzService {
129
130
  '@ngrx/effects',
130
131
  '@ngrx/store',
131
132
  '@ngx-translate/core',
133
+ 'ngx-device-detector',
132
134
  'localforage',
133
135
  'lodash-es',
134
136
  'reselect',
@@ -145,7 +147,6 @@ export class StackblitzService {
145
147
  const filteredObj = Object.fromEntries(filteredArr);
146
148
  const extraDependencies = {
147
149
  uuid: '8.3.2',
148
- 'ngx-device-detector': '3.0.0',
149
150
  'ngx-moment': '~6.0.0',
150
151
  'ngx-mask': '^14.0.0',
151
152
  'cleave.js': '^1.6.0',
@@ -166,7 +167,7 @@ export class StackblitzService {
166
167
  * @private
167
168
  */
168
169
  retrievePackageDependencies(version) {
169
- return fetch(`https://unpkg.com/@eui/deps-base@${version}/package.json`)
170
+ return fetch(`https://unpkg.com/@eui/deps-base-light@${version}/package.json`)
170
171
  .then((response) => response.json())
171
172
  .then((pkg) => pkg?.dependencies);
172
173
  }
@@ -184,4 +185,4 @@ export class StackblitzService {
184
185
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0", ngImport: i0, type: StackblitzService, decorators: [{
185
186
  type: Injectable
186
187
  }] });
187
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"stackblitz.service.js","sourceRoot":"","sources":["../../../../../src/lib/components/playground/stackblitz.service.ts"],"names":[],"mappings":"AAAA,OAAO,GAAqC,MAAM,iBAAiB,CAAC;AACpE,OAAO,EAAE,aAAa,EAAE,MAAM,MAAM,CAAC;AACrC,OAAO,EAAE,MAAM,EAAE,UAAU,EAAE,MAAM,eAAe,CAAC;AACnD,OAAO,EAAE,UAAU,EAAE,MAAM,sBAAsB,CAAC;AAClD,OAAO,EAAE,eAAe,EAAE,aAAa,EAAE,QAAQ,EAAE,YAAY,EAAE,aAAa,EAAE,QAAQ,EAAE,MAAM,oBAAoB,CAAC;;AAGrH,MAAM,OAAO,iBAAiB;IAD9B;QAEY,SAAI,GAAe,MAAM,CAAC,UAAU,CAAC,CAAC;KAyMjD;IAvMG;;;;;OAKG;IACH,wBAAwB,CAAC,QAAgB;QAIrC,MAAM,aAAa,GAAG,qFAAqF,CAAC;QAC5G,MAAM,UAAU,GAAG,wBAAwB,CAAC;QAE5C,MAAM,SAAS,GAAG,QAAQ,CAAC,KAAK,CAAC,UAAU,CAAC,CAAC;QAC7C,MAAM,YAAY,GAAG,QAAQ,CAAC,KAAK,CAAC,aAAa,CAAC,CAAC;QACnD,MAAM,KAAK,GAAG,YAAY,EAAE,MAAM,EAAE,oBAAoB,IAAI,YAAY,EAAE,MAAM,EAAE,oBAAoB,CAAC;QACvG,OAAO;YACH,SAAS,EAAE,SAAS,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE;YACxC,QAAQ,EAAE,KAAK,IAAI,EAAE;SACxB,CAAC;IACN,CAAC;IAED;;;;;OAKG;IACH,iBAAiB,CAAC,QAAgB;QAC9B,MAAM,WAAW,GAAG,QAAQ,CAAC,KAAK,CAAC,0BAA0B,CAAC,CAAC;QAC/D,OAAO,WAAW,CAAC,CAAC,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC;IAC7C,CAAC;IAED;;;;;OAKG;IACH,oBAAoB,CAAC,QAAgB;QACjC,MAAM,aAAa,GAAG,QAAQ,CAAC,KAAK,CAAC,0BAA0B,CAAC,CAAC;QACjE,OAAO,aAAa,CAAC,CAAC,CAAC,aAAa,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC;IACjD,CAAC;IAED,oBAAoB,CAAC,QAAgB;QACjC,6DAA6D;QAC7D,mCAAmC;QACnC,QAAQ,GAAG,QAAQ,CAAC,OAAO,CAAC,yBAAyB,EAAE,oCAAoC,CAAC,CAAC;QAC7F,kCAAkC;QAClC,QAAQ,GAAG,+DAA+D,QAAQ,EAAE,CAAC;QACrF,6CAA6C;QAC7C,QAAQ,GAAG,QAAQ,CAAC,OAAO,CAAC,yBAAyB,EAAE,8CAA8C,CAAC,CAAC;QACvG,4CAA4C;QAC5C,QAAQ,GAAG,oFAAoF,QAAQ,EAAE,CAAC;QAE1G,OAAO,QAAQ,CAAC;IACpB,CAAC;IAED;;;;;;OAMG;IACI,cAAc,CAAC,WAAmB,EAAE,iBAAyB,EAAE,KAAa,EAAE,QAAgB;QACjG,IAAI,CAAC,yBAAyB,EAAE;aAC3B,IAAI,CAAC,CAAC,IAAI,EAAE,EAAE;YACX,MAAM,EAAE,YAAY,EAAE,eAAe,EAAE,GAAG,IAAI,CAAC;YAC/C,MAAM,EAAE,QAAQ,EAAE,GAAG,IAAI,CAAC,wBAAwB,CAAC,iBAAiB,CAAC,CAAC;YACtE,MAAM,UAAU,GAAG,IAAI,CAAC,iBAAiB,CAAC,iBAAiB,CAAC,CAAC;YAC7D,MAAM,aAAa,GAAG,IAAI,CAAC,oBAAoB,CAAC,iBAAiB,CAAC,CAAC;YACnE,MAAM,OAAO,GAAY;gBACrB,KAAK,EAAE,KAAK;gBACZ,WAAW,EAAE,0BAA0B,KAAK,GAAG;gBAC/C,QAAQ,EAAE,aAAa;gBACvB,KAAK,EAAE;oBACH,oBAAoB,EAAE,WAAW;oBACjC,kBAAkB,EAAE,IAAI,CAAC,oBAAoB,CAAC,iBAAiB,CAAC;oBAChE,aAAa,EAAE,QAAQ,CAAC,UAAU,EAAE,aAAa,CAAC;oBAClD,kBAAkB,EAAE,aAAa;oBACjC,gBAAgB,EAAE,aAAa,CAAC,QAAQ,CAAC;oBACzC,cAAc,EAAE,eAAe;oBAC/B,cAAc,EAAE,IAAI,CAAC,SAAS,CAC1B;wBACI,GAAG,YAAY;wBACf,YAAY;wBACZ,eAAe;qBAClB,EACD,IAAI,EACJ,CAAC,CACJ;oBACD,eAAe,EAAE,QAAQ;iBAC5B;gBACD,QAAQ,EAAE;oBACN,OAAO,EAAE;wBACL,OAAO,EAAE,MAAM;wBACf,YAAY,EAAE,IAAI;qBACrB;iBACJ;gBACD,YAAY;aACf,CAAC;YAEF,OAAO,GAAG,CAAC,WAAW,CAClB,OAAO,EACP;gBACI,QAAQ,EAAE,CAAC,kBAAkB,EAAE,oBAAoB,CAAC;gBACpD,OAAO,EAAE,IAAI;aAChB,CACJ,CAAC;QACN,CAAC,CAAC,CAAC;IACX,CAAC;IAED;;;;OAIG;IACI,yBAAyB;QAI5B,+CAA+C;QAC/C,MAAM,sBAAsB,GAAG;YAC3B,qBAAqB;YACrB,cAAc;YACd,iBAAiB;YACjB,mBAAmB;YACnB,eAAe;YACf,gBAAgB;YAChB,mBAAmB;YACnB,kCAAkC;YAClC,2BAA2B;YAC3B,mCAAmC;YACnC,iBAAiB;YACjB,WAAW;YACX,iBAAiB;YACjB,WAAW;YACX,aAAa;YACb,eAAe;YACf,aAAa;YACb,qBAAqB;YACrB,aAAa;YACb,WAAW;YACX,UAAU;YACV,MAAM;YACN,OAAO;YACP,SAAS;SACZ,CAAC;QAEF,MAAM,yBAAyB,GAAG,CAAC,+BAA+B,EAAE,cAAc,EAAE,uBAAuB,EAAE,YAAY,CAAC,CAAC;QAE3H,OAAO,IAAI,CAAC,4BAA4B,EAAE;aACrC,IAAI,CAAC,CAAC,OAAO,EAAE,EAAE,CAAC,IAAI,CAAC,2BAA2B,CAAC,OAAO,CAAC,CAAC;aAC5D,IAAI,CAAC,CAAC,YAAY,EAAE,EAAE;YACnB,oDAAoD;YACpD,IAAI,WAAW,GAAG,MAAM,CAAC,OAAO,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,sBAAsB,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;YAC7G,MAAM,WAAW,GAAG,MAAM,CAAC,WAAW,CAAC,WAAW,CAAC,CAAC;YACpD,MAAM,iBAAiB,GAAG;gBACtB,IAAI,EAAE,OAAO;gBACb,qBAAqB,EAAE,OAAO;gBAC9B,YAAY,EAAE,QAAQ;gBACtB,UAAU,EAAE,SAAS;gBACrB,WAAW,EAAE,QAAQ;gBACrB,MAAM,EAAE,SAAS;gBACjB,MAAM,EAAE,QAAQ;aACnB,CAAC;YACF,uDAAuD;YACvD,WAAW,GAAG,MAAM,CAAC,OAAO,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,yBAAyB,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;YAC5G,YAAY,GAAG,EAAE,GAAG,iBAAiB,EAAE,GAAG,WAAW,EAAE,CAAC;YACxD,MAAM,eAAe,GAAG,MAAM,CAAC,WAAW,CAAC,WAAW,CAAC,CAAC;YAExD,OAAO,EAAE,YAAY,EAAE,eAAe,EAAE,CAAC;QAC7C,CAAC,CAAC,CAAC;IACX,CAAC;IAED;;;;;OAKG;IACK,2BAA2B,CAAC,OAAO;QACvC,OAAO,KAAK,CAAC,oCAAoC,OAAO,eAAe,CAAC;aACnE,IAAI,CAAC,CAAC,QAAQ,EAAE,EAAE,CAAC,QAAQ,CAAC,IAAI,EAAE,CAAC;aACnC,IAAI,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,GAAG,EAAE,YAAY,CAAC,CAAC;IAC1C,CAAC;IAED;;;;OAIG;IACK,4BAA4B;QAChC,OAAO,aAAa,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,CAAyB,0BAA0B,EAAE,EAAE,YAAY,EAAE,MAAM,EAAE,CAAC,CAAC,CAAC,IAAI,CAClH,CAAC,GAAG,EAAE,EAAE,CAAC,GAAG,EAAE,UAAU,IAAI,QAAQ,CACvC,CAAC;IACN,CAAC;8GAxMQ,iBAAiB;kHAAjB,iBAAiB;;2FAAjB,iBAAiB;kBAD7B,UAAU","sourcesContent":["import sdk, { Project, ProjectDependencies } from '@stackblitz/sdk';\nimport { lastValueFrom } from 'rxjs';\nimport { inject, Injectable } from '@angular/core';\nimport { HttpClient } from '@angular/common/http';\nimport { angularJsonFile, indexHtmlFile, mainFile, PACKAGE_JSON, polyfillsFile, tsConfig } from './stackblitz.files';\n\n@Injectable()\nexport class StackblitzService {\n    private http: HttpClient = inject(HttpClient);\n\n    /**\n     * extract the name of the component class name and selector name from the typescript content\n     *\n     * @param contents\n     * @private\n     */\n    extractComponentMetadata(contents: string): {\n        selector: string;\n        className: string;\n    } {\n        const selectorRegex = /selector: ('(?<singleQuotedSelector>[\\w\\d-]+)'|\"(?<doubleQuotedSelector>[\\w\\d-]+)\")/;\n        const classRegex = /export class ([\\w\\d]+)/;\n\n        const className = contents.match(classRegex);\n        const selectorName = contents.match(selectorRegex);\n        const found = selectorName?.groups?.singleQuotedSelector || selectorName?.groups?.doubleQuotedSelector;\n        return {\n            className: className ? className[1] : '',\n            selector: found || '',\n        };\n    }\n\n    /**\n     * extract module class name from the typescript content\n     *\n     * @param contents\n     * @private\n     */\n    extractModuleName(contents: string): string {\n        const moduleClass = contents.match(/export class (\\w+Module)/);\n        return moduleClass ? moduleClass[1] : '';\n    }\n\n    /**\n     * extract the name of the component class name and selector name from the typescript content\n     *\n     * @param contents\n     * @private\n     */\n    extractComponentName(contents: string): string {\n        const componentName = contents.match(/bootstrap: \\[([\\s\\S]*?)]/);\n        return componentName ? componentName[1] : '';\n    }\n\n    appendVitalNgModules(contents: string): string {\n        // const imports = contents.match(/imports: \\[([\\s\\S]*?)\\]/);\n        // appends BrowserModule to imports\n        contents = contents.replace(/imports: \\[([\\s\\S]*?)\\]/, 'imports: [\\n\\t\\tBrowserModule, $1]');\n        // appends import of BrowserModule\n        contents = `import { BrowserModule } from '@angular/platform-browser';\\n${contents}`;\n        // appends BrowserAnimationsModule to imports\n        contents = contents.replace(/imports: \\[([\\s\\S]*?)\\]/, 'imports: [\\n\\t\\tBrowserAnimationsModule, $1]');\n        // appends import of BrowserAnimationsModule\n        contents = `import { BrowserAnimationsModule } from '@angular/platform-browser/animations';\\n${contents}`;\n\n        return contents;\n    }\n\n    /**\n     * Open a stackblitz project in a new browser TAB with the given html and typescript content\n     * @param htmlContent\n     * @param typescriptContent\n     * @param title\n     * @param sampleId\n     */\n    public openStackBlitz(htmlContent: string, typescriptContent: string, title: string, sampleId: string): void {\n        this.getStackblitzDependencies()\n            .then((deps) => {\n                const { dependencies, devDependencies } = deps;\n                const { selector } = this.extractComponentMetadata(typescriptContent);\n                const moduleName = this.extractModuleName(typescriptContent);\n                const componentName = this.extractComponentName(typescriptContent);\n                const project: Project = {\n                    title: title,\n                    description: `An eUI example for the ${title}.`,\n                    template: 'angular-cli',\n                    files: {\n                        'src/component.html': htmlContent,\n                        'src/component.ts': this.appendVitalNgModules(typescriptContent),\n                        'src/main.ts': mainFile(moduleName, componentName),\n                        'src/polyfills.ts': polyfillsFile,\n                        'src/index.html': indexHtmlFile(selector),\n                        'angular.json': angularJsonFile,\n                        'package.json': JSON.stringify(\n                            {\n                                ...PACKAGE_JSON,\n                                dependencies,\n                                devDependencies,\n                            },\n                            null,\n                            2,\n                        ),\n                        'tsconfig.json': tsConfig,\n                    },\n                    settings: {\n                        compile: {\n                            trigger: 'auto',\n                            clearConsole: true,\n                        },\n                    },\n                    dependencies,\n                };\n\n                return sdk.openProject(\n                    project,\n                    {\n                        openFile: ['src/component.ts', 'src/component.html'],\n                        zenMode: true,\n                    },\n                );\n            });\n    }\n\n    /**\n     * Retrieve only the dependencies that stackblitz will need filtered from @eui/deps-base\n     *\n     * @private\n     */\n    public getStackblitzDependencies(): Promise<{\n        dependencies: ProjectDependencies;\n        devDependencies: ProjectDependencies;\n    }> {\n        // a list of dependencies only stackblitz needs\n        const stackblitzDependencies = [\n            '@angular/animations',\n            '@angular/cdk',\n            '@angular/common',\n            '@angular/compiler',\n            '@angular/core',\n            '@angular/forms',\n            '@angular/material',\n            '@angular/material-moment-adapter',\n            '@angular/platform-browser',\n            '@angular/platform-browser-dynamic',\n            '@angular/router',\n            '@eui/base',\n            '@eui/components',\n            '@eui/core',\n            '@eui/styles',\n            '@ngrx/effects',\n            '@ngrx/store',\n            '@ngx-translate/core',\n            'localforage',\n            'lodash-es',\n            'reselect',\n            'rxjs',\n            'tslib',\n            'zone.js',\n        ];\n\n        const stackblitzDevDependencies = ['@angular-devkit/build-angular', '@angular/cli', '@angular/compiler-cli', 'typescript'];\n\n        return this.getCurrentShowcaseEuiVersion()\n            .then((version) => this.retrievePackageDependencies(version))\n            .then((dependencies) => {\n                // filter dependencies to only what stackblitz needs\n                let filteredArr = Object.entries(dependencies).filter((v) => stackblitzDependencies.find((s) => s === v[0]));\n                const filteredObj = Object.fromEntries(filteredArr);\n                const extraDependencies = {\n                    uuid: '8.3.2',\n                    'ngx-device-detector': '3.0.0',\n                    'ngx-moment': '~6.0.0',\n                    'ngx-mask': '^14.0.0',\n                    'cleave.js': '^1.6.0',\n                    moment: '^2.19.3',\n                    extend: '^3.0.2',\n                };\n                // filter devDependencies to only what stackblitz needs\n                filteredArr = Object.entries(dependencies).filter((v) => stackblitzDevDependencies.find((s) => s === v[0]));\n                dependencies = { ...extraDependencies, ...filteredObj };\n                const devDependencies = Object.fromEntries(filteredArr);\n\n                return { dependencies, devDependencies };\n            });\n    }\n\n    /**\n     * Retrieve the dependencies from the package.json file of @eui/deps-base for the given version.\n     *\n     * @param version\n     * @private\n     */\n    private retrievePackageDependencies(version): Promise<ProjectDependencies> {\n        return fetch(`https://unpkg.com/@eui/deps-base@${version}/package.json`)\n            .then((response) => response.json())\n            .then((pkg) => pkg?.dependencies);\n    }\n\n    /**\n     * Retrieve the eUI version used to build the showcase from application app-metadata.json\n     *\n     * @private\n     */\n    private getCurrentShowcaseEuiVersion(): Promise<string> {\n        return lastValueFrom(this.http.get<{ appVersion: string }>('assets/app-metadata.json', { responseType: 'json' })).then(\n            (res) => res?.appVersion || 'latest',\n        );\n    }\n\n}\n"]}
188
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"stackblitz.service.js","sourceRoot":"","sources":["../../../../../src/lib/components/playground/stackblitz.service.ts"],"names":[],"mappings":"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","sourcesContent":["import sdk, { Project, ProjectDependencies } from '@stackblitz/sdk';\nimport { lastValueFrom } from 'rxjs';\nimport { inject, Injectable } from '@angular/core';\nimport { HttpClient } from '@angular/common/http';\nimport { angularJsonFile, indexHtmlFile, mainFile, PACKAGE_JSON, polyfillsFile, tsConfig } from './stackblitz.files';\n\n@Injectable()\nexport class StackblitzService {\n    private http: HttpClient = inject(HttpClient);\n\n    /**\n     * extract the name of the component class name and selector name from the typescript content\n     *\n     * @param contents\n     * @private\n     */\n    extractComponentMetadata(contents: string): {\n        selector: string;\n        className: string;\n    } {\n        const selectorRegex = /selector: ('(?<singleQuotedSelector>[\\w\\d-]+)'|\"(?<doubleQuotedSelector>[\\w\\d-]+)\")/;\n        const classRegex = /export class ([\\w\\d]+)/;\n\n        const className = contents.match(classRegex);\n        const selectorName = contents.match(selectorRegex);\n        const found = selectorName?.groups?.singleQuotedSelector || selectorName?.groups?.doubleQuotedSelector;\n        return {\n            className: className ? className[1] : '',\n            selector: found || '',\n        };\n    }\n\n    /**\n     * extract module class name from the typescript content\n     *\n     * @param contents\n     * @private\n     */\n    extractModuleName(contents: string): string {\n        const moduleClass = contents.match(/export class (\\w+Module)/);\n        return moduleClass ? moduleClass[1] : '';\n    }\n\n    /**\n     * extract the name of the component class name and selector name from the typescript content\n     *\n     * @param contents\n     * @private\n     */\n    extractComponentName(contents: string): string {\n        const componentName = contents.match(/bootstrap: \\[([\\s\\S]*?)]/);\n        return componentName ? componentName[1] : '';\n    }\n\n    appendVitalNgModules(contents: string): string {\n        // const imports = contents.match(/imports: \\[([\\s\\S]*?)\\]/);\n        // appends BrowserModule to imports\n        contents = contents.replace(/imports: \\[([\\s\\S]*?)\\]/, 'imports: [\\n\\t\\tBrowserModule, $1]');\n        // appends import of BrowserModule\n        contents = `import { BrowserModule } from '@angular/platform-browser';\\n${contents}`;\n        // appends BrowserAnimationsModule to imports\n        contents = contents.replace(/imports: \\[([\\s\\S]*?)\\]/, 'imports: [\\n\\t\\tBrowserAnimationsModule, $1]');\n        // appends import of BrowserAnimationsModule\n        contents = `import { BrowserAnimationsModule } from '@angular/platform-browser/animations';\\n${contents}`;\n\n        return contents;\n    }\n\n    /**\n     * Open a stackblitz project in a new browser TAB with the given html and typescript content\n     * @param htmlContent\n     * @param typescriptContent\n     * @param title\n     * @param sampleId\n     */\n    public openStackBlitz(htmlContent: string, typescriptContent: string, title: string, sampleId: string): void {\n        this.getStackblitzDependencies()\n            .then((deps) => {\n                const { dependencies, devDependencies } = deps;\n                const { selector } = this.extractComponentMetadata(typescriptContent);\n                const moduleName = this.extractModuleName(typescriptContent);\n                const componentName = this.extractComponentName(typescriptContent);\n                const project: Project = {\n                    title: title,\n                    description: `An eUI example for the ${title}.`,\n                    template: 'node',\n                    files: {\n                        'src/component.html': htmlContent,\n                        'src/component.ts': this.appendVitalNgModules(typescriptContent),\n                        'src/main.ts': mainFile(moduleName, componentName),\n                        'src/polyfills.ts': polyfillsFile,\n                        'src/index.html': indexHtmlFile(selector),\n                        'angular.json': angularJsonFile,\n                        'package.json': JSON.stringify(\n                            {\n                                ...PACKAGE_JSON,\n                                dependencies,\n                                devDependencies,\n                            },\n                            null,\n                            2,\n                        ),\n                        'tsconfig.json': tsConfig,\n                        '.stackblitzrc': '{\\n\\t\"installDependencies\": false,\\n\\t\"startCommand\": \"npm install --force && npm start\"\\n}',\n                    },\n                    settings: {\n                        compile: {\n                            trigger: 'auto',\n                            clearConsole: true,\n                        },\n                    },\n                    dependencies,\n                };\n\n                return sdk.openProject(\n                    project,\n                    {\n                        openFile: ['src/component.ts', 'src/component.html'],\n                        zenMode: true,\n                    },\n                );\n            });\n    }\n\n    /**\n     * Retrieve only the dependencies that stackblitz will need filtered from @eui/deps-base\n     *\n     * @private\n     */\n    public getStackblitzDependencies(): Promise<{\n        dependencies: ProjectDependencies;\n        devDependencies: ProjectDependencies;\n    }> {\n        // a list of dependencies only stackblitz needs\n        const stackblitzDependencies = [\n            '@angular/animations',\n            '@angular/cdk',\n            '@angular/common',\n            '@angular/compiler',\n            '@angular/core',\n            '@angular/forms',\n            '@angular/material',\n            '@angular/material-moment-adapter',\n            '@angular/platform-browser',\n            '@angular/platform-browser-dynamic',\n            '@angular/router',\n            '@eui/base',\n            '@eui/components',\n            '@eui/core',\n            '@eui/styles',\n            '@ngrx/effects',\n            '@ngrx/store',\n            '@ngx-translate/core',\n            'ngx-device-detector',\n            'localforage',\n            'lodash-es',\n            'reselect',\n            'rxjs',\n            'tslib',\n            'zone.js',\n        ];\n\n        const stackblitzDevDependencies = ['@angular-devkit/build-angular', '@angular/cli', '@angular/compiler-cli', 'typescript'];\n\n        return this.getCurrentShowcaseEuiVersion()\n            .then((version) => this.retrievePackageDependencies(version))\n            .then((dependencies) => {\n                // filter dependencies to only what stackblitz needs\n                let filteredArr = Object.entries(dependencies).filter((v) => stackblitzDependencies.find((s) => s === v[0]));\n                const filteredObj = Object.fromEntries(filteredArr);\n                const extraDependencies = {\n                    uuid: '8.3.2',\n                    'ngx-moment': '~6.0.0',\n                    'ngx-mask': '^14.0.0',\n                    'cleave.js': '^1.6.0',\n                    moment: '^2.19.3',\n                    extend: '^3.0.2',\n                };\n                // filter devDependencies to only what stackblitz needs\n                filteredArr = Object.entries(dependencies).filter((v) => stackblitzDevDependencies.find((s) => s === v[0]));\n                dependencies = { ...extraDependencies, ...filteredObj };\n                const devDependencies = Object.fromEntries(filteredArr);\n\n                return { dependencies, devDependencies };\n            });\n    }\n\n    /**\n     * Retrieve the dependencies from the package.json file of @eui/deps-base for the given version.\n     *\n     * @param version\n     * @private\n     */\n    private retrievePackageDependencies(version): Promise<ProjectDependencies> {\n        return fetch(`https://unpkg.com/@eui/deps-base-light@${version}/package.json`)\n            .then((response) => response.json())\n            .then((pkg) => pkg?.dependencies);\n    }\n\n    /**\n     * Retrieve the eUI version used to build the showcase from application app-metadata.json\n     *\n     * @private\n     */\n    private getCurrentShowcaseEuiVersion(): Promise<string> {\n        return lastValueFrom(this.http.get<{ appVersion: string }>('assets/app-metadata.json', { responseType: 'json' })).then(\n            (res) => res?.appVersion || 'latest',\n        );\n    }\n\n}\n"]}
@@ -157,24 +157,35 @@ export class AppModule {}
157
157
  `;
158
158
  const angularJsonFile = `
159
159
  {
160
+ "$schema": "./node_modules/@angular/cli/lib/config/schema.json",
160
161
  "version": 1,
161
162
  "newProjectRoot": "projects",
162
163
  "projects": {
163
164
  "demo": {
164
- "root": "",
165
- "sourceRoot": "",
166
- "projectType": "application",
167
- "prefix": "app",
168
- "schematics": {},
169
165
  "architect": {
170
166
  "build": {
171
- "builder": "@angular-devkit/build-angular:browser",
167
+ "builder": "@angular-devkit/build-angular:application",
168
+ "configurations": {
169
+ "development": {
170
+ "extractLicenses": false,
171
+ "namedChunks": true,
172
+ "optimization": false,
173
+ "sourceMap": true
174
+ },
175
+ "production": {
176
+ "aot": true,
177
+ "extractLicenses": true,
178
+ "namedChunks": false,
179
+ "optimization": true,
180
+ "outputHashing": "all",
181
+ "sourceMap": false
182
+ }
183
+ },
172
184
  "options": {
173
- "outputPath": "dist/demo",
174
185
  "index": "src/index.html",
175
- "main": "src/main.ts",
176
- "polyfills": "src/polyfills.ts",
177
- "tsConfig": "tsconfig.json",
186
+ "browser": "src/main.ts",
187
+ "outputPath": "dist/demo",
188
+ "scripts": [],
178
189
  "assets": [
179
190
  {
180
191
  "glob": "**/*",
@@ -188,47 +199,31 @@ const angularJsonFile = `
188
199
  }
189
200
  ],
190
201
  "styles": [
191
- "./node_modules/@eui/styles/dist/styles/eui.css"
202
+ "./node_modules/@eui/styles/dist/eui.css"
192
203
  ],
193
- "scripts": [],
194
- "preserveSymlinks": true
195
- },
196
- "configurations": {
197
- "production": {
198
- "optimization": true,
199
- "outputHashing": "all",
200
- "sourceMap": false,
201
- "extractCss": true,
202
- "namedChunks": false,
203
- "aot": true,
204
- "extractLicenses": true,
205
- "vendorChunk": false,
206
- "buildOptimizer": true
207
- }
204
+ "tsConfig": "tsconfig.json"
208
205
  }
209
206
  },
210
207
  "serve": {
211
208
  "builder": "@angular-devkit/build-angular:dev-server",
212
- "options": {
213
- "browserTarget": "demo:build"
214
- },
215
209
  "configurations": {
210
+ "development": {
211
+ "buildTarget": "demo:build:development"
212
+ },
216
213
  "production": {
217
- "browserTarget": "demo:build:production"
214
+ "buildTarget": "demo:build:production"
218
215
  }
219
- }
220
- },
221
- "lint": {
222
- "builder": "@angular-devkit/build-angular:tslint",
223
- "options": {
224
- "tsConfig": ["tsconfig.json"],
225
- "exclude": ["**/node_modules/**"]
226
- }
216
+ },
217
+ "defaultConfiguration": "development"
227
218
  }
228
- }
219
+ },
220
+ "prefix": "app",
221
+ "projectType": "application",
222
+ "root": "",
223
+ "schematics": {},
224
+ "sourceRoot": "src"
229
225
  }
230
226
  },
231
- "defaultProject": "demo",
232
227
  "cli": {
233
228
  "analytics": "0f944abb-e787-4c1f-9092-e34292361c91"
234
229
  }
@@ -243,37 +238,51 @@ const PACKAGE_JSON = {
243
238
  name: 'demo',
244
239
  version: '0.0.0',
245
240
  private: true,
241
+ scripts: {
242
+ ng: 'ng',
243
+ start: 'ng serve',
244
+ build: 'ng build',
245
+ watch: 'ng build --watch --configuration development',
246
+ test: 'ng test',
247
+ lint: 'ng lint',
248
+ },
246
249
  dependencies: {},
247
250
  };
248
251
  const tsConfig = `
252
+ /* To learn more about this file see: https://angular.io/config/tsconfig. */
249
253
  {
250
254
  "compileOnSave": false,
251
255
  "compilerOptions": {
252
- "baseUrl": "./",
253
- "outDir": "./dist/out-tsc",
256
+ "outDir": "./out-tsc/app",
257
+ "skipLibCheck": true, // needed for @ngrx compilation
258
+ "target": "ES2022",
259
+ "module": "ES2022",
260
+ "useDefineForClassFields": false,
261
+ "lib": ["ES2022", "dom"],
262
+ "declaration": true,
263
+ "declarationMap": true,
264
+ "inlineSources": true,
265
+ "emitDecoratorMetadata": false,
266
+ "types": [],
267
+ "esModuleInterop": true,
254
268
  "sourceMap": true,
255
- "declaration": false,
256
- "downlevelIteration": true,
257
269
  "experimentalDecorators": true,
258
- "module": "esnext",
259
- "moduleResolution": "node",
260
- "importHelpers": true,
261
- "target": "es2016",
262
- "allowSyntheticDefaultImports": true,
263
- "emitDecoratorMetadata": true,
264
- "typeRoots": [
265
- "node_modules/@types"
266
- ],
267
- "lib": [
268
- "es2020",
269
- "dom"
270
- ]
270
+ "moduleResolution": "bundler",
271
+ "importHelpers": true
271
272
  },
272
273
  "angularCompilerOptions": {
273
- "enableIvy": true,
274
- "fullTemplateTypeCheck": true,
275
- "strictInjectionParameters": true
276
- }
274
+ "compilationMode": "partial",
275
+ "enableI18nLegacyMessageIdFormat": false,
276
+ "strictInputAccessModifiers": true,
277
+ "strictMetadataEmit": true,
278
+ "strictTemplates": true,
279
+ "annotateForClosureCompiler": true,
280
+ "skipTemplateCodegen": true,
281
+ "fullTemplateTypeCheck": true
282
+ },
283
+ "exclude": ["src/test.ts", "**/*.spec.ts"],
284
+ "files": ["src/main.ts"],
285
+ "include": ["src/**/*.d.ts"]
277
286
  }`;
278
287
 
279
288
  class StackblitzService {
@@ -346,7 +355,7 @@ class StackblitzService {
346
355
  const project = {
347
356
  title: title,
348
357
  description: `An eUI example for the ${title}.`,
349
- template: 'angular-cli',
358
+ template: 'node',
350
359
  files: {
351
360
  'src/component.html': htmlContent,
352
361
  'src/component.ts': this.appendVitalNgModules(typescriptContent),
@@ -360,6 +369,7 @@ class StackblitzService {
360
369
  devDependencies,
361
370
  }, null, 2),
362
371
  'tsconfig.json': tsConfig,
372
+ '.stackblitzrc': '{\n\t"installDependencies": false,\n\t"startCommand": "npm install --force && npm start"\n}',
363
373
  },
364
374
  settings: {
365
375
  compile: {
@@ -401,6 +411,7 @@ class StackblitzService {
401
411
  '@ngrx/effects',
402
412
  '@ngrx/store',
403
413
  '@ngx-translate/core',
414
+ 'ngx-device-detector',
404
415
  'localforage',
405
416
  'lodash-es',
406
417
  'reselect',
@@ -417,7 +428,6 @@ class StackblitzService {
417
428
  const filteredObj = Object.fromEntries(filteredArr);
418
429
  const extraDependencies = {
419
430
  uuid: '8.3.2',
420
- 'ngx-device-detector': '3.0.0',
421
431
  'ngx-moment': '~6.0.0',
422
432
  'ngx-mask': '^14.0.0',
423
433
  'cleave.js': '^1.6.0',
@@ -438,7 +448,7 @@ class StackblitzService {
438
448
  * @private
439
449
  */
440
450
  retrievePackageDependencies(version) {
441
- return fetch(`https://unpkg.com/@eui/deps-base@${version}/package.json`)
451
+ return fetch(`https://unpkg.com/@eui/deps-base-light@${version}/package.json`)
442
452
  .then((response) => response.json())
443
453
  .then((pkg) => pkg?.dependencies);
444
454
  }