@sun-asterisk/sungen 1.0.24 → 2.0.0
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.
- package/README.md +198 -74
- package/dist/cli/commands/add.d.ts.map +1 -1
- package/dist/cli/commands/add.js +5 -3
- package/dist/cli/commands/add.js.map +1 -1
- package/dist/cli/commands/generate.d.ts.map +1 -1
- package/dist/cli/commands/generate.js +110 -35
- package/dist/cli/commands/generate.js.map +1 -1
- package/dist/cli/index.d.ts +2 -2
- package/dist/cli/index.js +5 -16
- package/dist/cli/index.js.map +1 -1
- package/dist/generators/test-generator/adapters/playwright/templates/steps/actions/frame-enter-action.hbs +1 -0
- package/dist/generators/test-generator/adapters/playwright/templates/steps/actions/frame-exit-action.hbs +1 -0
- package/dist/generators/test-generator/adapters/playwright/templates/steps/actions/keyboard-global-action.hbs +1 -0
- package/dist/generators/test-generator/adapters/playwright/templates/steps/actions/scroll-action.hbs +1 -0
- package/dist/generators/test-generator/adapters/playwright/templates/steps/actions/table-action-in-row.hbs +2 -0
- package/dist/generators/test-generator/adapters/playwright/templates/steps/assertions/table-cell-by-filter.hbs +3 -0
- package/dist/generators/test-generator/adapters/playwright/templates/steps/assertions/table-cell-by-index.hbs +3 -0
- package/dist/generators/test-generator/adapters/playwright/templates/steps/assertions/table-column-exists.hbs +2 -0
- package/dist/generators/test-generator/adapters/playwright/templates/steps/assertions/table-empty.hbs +2 -0
- package/dist/generators/test-generator/adapters/playwright/templates/steps/assertions/table-row-count.hbs +2 -0
- package/dist/generators/test-generator/adapters/playwright/templates/steps/assertions/table-row-exists.hbs +2 -0
- package/dist/generators/test-generator/adapters/playwright/templates/steps/assertions/table-row-not-exists.hbs +2 -0
- package/dist/generators/test-generator/adapters/playwright/templates/steps/assertions/visible-with-value-assertion.hbs +1 -1
- package/dist/generators/test-generator/adapters/playwright/templates/steps/partials/locator-base.hbs +11 -2
- package/dist/generators/test-generator/adapters/playwright/templates/steps/partials/locator.hbs +11 -2
- package/dist/generators/test-generator/code-generator.d.ts +0 -1
- package/dist/generators/test-generator/code-generator.d.ts.map +1 -1
- package/dist/generators/test-generator/code-generator.js +0 -47
- package/dist/generators/test-generator/code-generator.js.map +1 -1
- package/dist/generators/test-generator/patterns/assertion-patterns.d.ts.map +1 -1
- package/dist/generators/test-generator/patterns/assertion-patterns.js +2 -0
- package/dist/generators/test-generator/patterns/assertion-patterns.js.map +1 -1
- package/dist/generators/test-generator/patterns/index.d.ts +4 -1
- package/dist/generators/test-generator/patterns/index.d.ts.map +1 -1
- package/dist/generators/test-generator/patterns/index.js +17 -5
- package/dist/generators/test-generator/patterns/index.js.map +1 -1
- package/dist/generators/test-generator/patterns/interaction-patterns.js +1 -1
- package/dist/generators/test-generator/patterns/interaction-patterns.js.map +1 -1
- package/dist/generators/test-generator/patterns/keyboard-patterns.d.ts +7 -0
- package/dist/generators/test-generator/patterns/keyboard-patterns.d.ts.map +1 -0
- package/dist/generators/test-generator/patterns/keyboard-patterns.js +47 -0
- package/dist/generators/test-generator/patterns/keyboard-patterns.js.map +1 -0
- package/dist/generators/test-generator/patterns/scope-patterns.d.ts +7 -0
- package/dist/generators/test-generator/patterns/scope-patterns.d.ts.map +1 -0
- package/dist/generators/test-generator/patterns/scope-patterns.js +36 -0
- package/dist/generators/test-generator/patterns/scope-patterns.js.map +1 -0
- package/dist/generators/test-generator/patterns/scroll-patterns.d.ts +7 -0
- package/dist/generators/test-generator/patterns/scroll-patterns.d.ts.map +1 -0
- package/dist/generators/test-generator/patterns/scroll-patterns.js +25 -0
- package/dist/generators/test-generator/patterns/scroll-patterns.js.map +1 -0
- package/dist/generators/test-generator/patterns/table-patterns.d.ts +7 -0
- package/dist/generators/test-generator/patterns/table-patterns.d.ts.map +1 -0
- package/dist/generators/test-generator/patterns/table-patterns.js +192 -0
- package/dist/generators/test-generator/patterns/table-patterns.js.map +1 -0
- package/dist/generators/test-generator/step-mapper.d.ts +1 -3
- package/dist/generators/test-generator/step-mapper.d.ts.map +1 -1
- package/dist/generators/test-generator/step-mapper.js +30 -27
- package/dist/generators/test-generator/step-mapper.js.map +1 -1
- package/dist/generators/test-generator/template-engine.d.ts.map +1 -1
- package/dist/generators/test-generator/template-engine.js +4 -1
- package/dist/generators/test-generator/template-engine.js.map +1 -1
- package/dist/generators/test-generator/types.d.ts +7 -24
- package/dist/generators/test-generator/types.d.ts.map +1 -1
- package/dist/generators/test-generator/types.js +2 -101
- package/dist/generators/test-generator/types.js.map +1 -1
- package/dist/generators/test-generator/utils/selector-resolver.d.ts +14 -0
- package/dist/generators/test-generator/utils/selector-resolver.d.ts.map +1 -1
- package/dist/generators/test-generator/utils/selector-resolver.js +37 -11
- package/dist/generators/test-generator/utils/selector-resolver.js.map +1 -1
- package/dist/orchestrator/project-initializer.d.ts +8 -0
- package/dist/orchestrator/project-initializer.d.ts.map +1 -1
- package/dist/orchestrator/project-initializer.js +343 -32
- package/dist/orchestrator/project-initializer.js.map +1 -1
- package/dist/orchestrator/screen-manager.d.ts +1 -32
- package/dist/orchestrator/screen-manager.d.ts.map +1 -1
- package/dist/orchestrator/screen-manager.js +55 -216
- package/dist/orchestrator/screen-manager.js.map +1 -1
- package/dist/utils/selector-types.d.ts +1 -1
- package/dist/utils/selector-types.d.ts.map +1 -1
- package/dist/utils/selector-types.js +3 -0
- package/dist/utils/selector-types.js.map +1 -1
- package/package.json +2 -2
- package/src/cli/commands/add.ts +5 -3
- package/src/cli/commands/generate.ts +90 -38
- package/src/cli/index.ts +5 -16
- package/src/generators/test-generator/adapters/playwright/templates/steps/actions/frame-enter-action.hbs +1 -0
- package/src/generators/test-generator/adapters/playwright/templates/steps/actions/frame-exit-action.hbs +1 -0
- package/src/generators/test-generator/adapters/playwright/templates/steps/actions/keyboard-global-action.hbs +1 -0
- package/src/generators/test-generator/adapters/playwright/templates/steps/actions/scroll-action.hbs +1 -0
- package/src/generators/test-generator/adapters/playwright/templates/steps/actions/table-action-in-row.hbs +2 -0
- package/src/generators/test-generator/adapters/playwright/templates/steps/assertions/table-cell-by-filter.hbs +3 -0
- package/src/generators/test-generator/adapters/playwright/templates/steps/assertions/table-cell-by-index.hbs +3 -0
- package/src/generators/test-generator/adapters/playwright/templates/steps/assertions/table-column-exists.hbs +2 -0
- package/src/generators/test-generator/adapters/playwright/templates/steps/assertions/table-empty.hbs +2 -0
- package/src/generators/test-generator/adapters/playwright/templates/steps/assertions/table-row-count.hbs +2 -0
- package/src/generators/test-generator/adapters/playwright/templates/steps/assertions/table-row-exists.hbs +2 -0
- package/src/generators/test-generator/adapters/playwright/templates/steps/assertions/table-row-not-exists.hbs +2 -0
- package/src/generators/test-generator/adapters/playwright/templates/steps/assertions/visible-with-value-assertion.hbs +1 -1
- package/src/generators/test-generator/adapters/playwright/templates/steps/partials/locator-base.hbs +11 -2
- package/src/generators/test-generator/adapters/playwright/templates/steps/partials/locator.hbs +11 -2
- package/src/generators/test-generator/code-generator.ts +0 -59
- package/src/generators/test-generator/patterns/assertion-patterns.ts +2 -0
- package/src/generators/test-generator/patterns/index.ts +12 -3
- package/src/generators/test-generator/patterns/interaction-patterns.ts +1 -1
- package/src/generators/test-generator/patterns/keyboard-patterns.ts +51 -0
- package/src/generators/test-generator/patterns/scope-patterns.ts +40 -0
- package/src/generators/test-generator/patterns/scroll-patterns.ts +27 -0
- package/src/generators/test-generator/patterns/table-patterns.ts +232 -0
- package/src/generators/test-generator/step-mapper.ts +33 -27
- package/src/generators/test-generator/template-engine.ts +3 -1
- package/src/generators/test-generator/types.ts +7 -112
- package/src/generators/test-generator/utils/selector-resolver.ts +70 -25
- package/src/orchestrator/project-initializer.ts +345 -32
- package/src/orchestrator/screen-manager.ts +61 -233
- package/src/utils/selector-types.ts +3 -0
- package/dist/cli/commands/cache-clear.d.ts +0 -3
- package/dist/cli/commands/cache-clear.d.ts.map +0 -1
- package/dist/cli/commands/cache-clear.js +0 -24
- package/dist/cli/commands/cache-clear.js.map +0 -1
- package/dist/cli/commands/full.d.ts +0 -3
- package/dist/cli/commands/full.d.ts.map +0 -1
- package/dist/cli/commands/full.js +0 -37
- package/dist/cli/commands/full.js.map +0 -1
- package/dist/cli/commands/live-scan.d.ts +0 -3
- package/dist/cli/commands/live-scan.d.ts.map +0 -1
- package/dist/cli/commands/live-scan.js +0 -78
- package/dist/cli/commands/live-scan.js.map +0 -1
- package/dist/cli/commands/map.d.ts +0 -3
- package/dist/cli/commands/map.d.ts.map +0 -1
- package/dist/cli/commands/map.js +0 -93
- package/dist/cli/commands/map.js.map +0 -1
- package/dist/cli/commands/validate.d.ts +0 -3
- package/dist/cli/commands/validate.d.ts.map +0 -1
- package/dist/cli/commands/validate.js +0 -43
- package/dist/cli/commands/validate.js.map +0 -1
- package/dist/cli/utils.d.ts +0 -6
- package/dist/cli/utils.d.ts.map +0 -1
- package/dist/cli/utils.js +0 -101
- package/dist/cli/utils.js.map +0 -1
- package/dist/config/config-loader.d.ts +0 -51
- package/dist/config/config-loader.d.ts.map +0 -1
- package/dist/config/config-loader.js +0 -216
- package/dist/config/config-loader.js.map +0 -1
- package/dist/config/config-schema.d.ts +0 -121
- package/dist/config/config-schema.d.ts.map +0 -1
- package/dist/config/config-schema.js +0 -7
- package/dist/config/config-schema.js.map +0 -1
- package/dist/core/live-scanner/config-reader.d.ts +0 -10
- package/dist/core/live-scanner/config-reader.d.ts.map +0 -1
- package/dist/core/live-scanner/config-reader.js +0 -87
- package/dist/core/live-scanner/config-reader.js.map +0 -1
- package/dist/core/live-scanner/element-finder.d.ts +0 -20
- package/dist/core/live-scanner/element-finder.d.ts.map +0 -1
- package/dist/core/live-scanner/element-finder.js +0 -481
- package/dist/core/live-scanner/element-finder.js.map +0 -1
- package/dist/core/live-scanner/index.d.ts +0 -8
- package/dist/core/live-scanner/index.d.ts.map +0 -1
- package/dist/core/live-scanner/index.js +0 -33
- package/dist/core/live-scanner/index.js.map +0 -1
- package/dist/core/live-scanner/matrix-reader.d.ts +0 -17
- package/dist/core/live-scanner/matrix-reader.d.ts.map +0 -1
- package/dist/core/live-scanner/matrix-reader.js +0 -60
- package/dist/core/live-scanner/matrix-reader.js.map +0 -1
- package/dist/core/live-scanner/matrix-writer.d.ts +0 -7
- package/dist/core/live-scanner/matrix-writer.d.ts.map +0 -1
- package/dist/core/live-scanner/matrix-writer.js +0 -103
- package/dist/core/live-scanner/matrix-writer.js.map +0 -1
- package/dist/core/live-scanner/role-fallback.d.ts +0 -15
- package/dist/core/live-scanner/role-fallback.d.ts.map +0 -1
- package/dist/core/live-scanner/role-fallback.js +0 -46
- package/dist/core/live-scanner/role-fallback.js.map +0 -1
- package/dist/core/live-scanner/scanner.d.ts +0 -22
- package/dist/core/live-scanner/scanner.d.ts.map +0 -1
- package/dist/core/live-scanner/scanner.js +0 -303
- package/dist/core/live-scanner/scanner.js.map +0 -1
- package/dist/core/live-scanner/step-replayer.d.ts +0 -26
- package/dist/core/live-scanner/step-replayer.d.ts.map +0 -1
- package/dist/core/live-scanner/step-replayer.js +0 -473
- package/dist/core/live-scanner/step-replayer.js.map +0 -1
- package/dist/core/live-scanner/types.d.ts +0 -52
- package/dist/core/live-scanner/types.d.ts.map +0 -1
- package/dist/core/live-scanner/types.js +0 -14
- package/dist/core/live-scanner/types.js.map +0 -1
- package/dist/core/selector-base/annotation-handler.d.ts +0 -45
- package/dist/core/selector-base/annotation-handler.d.ts.map +0 -1
- package/dist/core/selector-base/annotation-handler.js +0 -102
- package/dist/core/selector-base/annotation-handler.js.map +0 -1
- package/dist/core/selector-base/base-generator.d.ts +0 -49
- package/dist/core/selector-base/base-generator.d.ts.map +0 -1
- package/dist/core/selector-base/base-generator.js +0 -214
- package/dist/core/selector-base/base-generator.js.map +0 -1
- package/dist/core/selector-base/gherkin-parser.d.ts +0 -24
- package/dist/core/selector-base/gherkin-parser.d.ts.map +0 -1
- package/dist/core/selector-base/gherkin-parser.js +0 -42
- package/dist/core/selector-base/gherkin-parser.js.map +0 -1
- package/dist/core/selector-mapper/priority-mapper.d.ts +0 -74
- package/dist/core/selector-mapper/priority-mapper.d.ts.map +0 -1
- package/dist/core/selector-mapper/priority-mapper.js +0 -477
- package/dist/core/selector-mapper/priority-mapper.js.map +0 -1
- package/dist/core/ui-scanner/heuristics/base-heuristic.d.ts +0 -91
- package/dist/core/ui-scanner/heuristics/base-heuristic.d.ts.map +0 -1
- package/dist/core/ui-scanner/heuristics/base-heuristic.js +0 -175
- package/dist/core/ui-scanner/heuristics/base-heuristic.js.map +0 -1
- package/dist/core/ui-scanner/react-scanner.d.ts +0 -32
- package/dist/core/ui-scanner/react-scanner.d.ts.map +0 -1
- package/dist/core/ui-scanner/react-scanner.js +0 -163
- package/dist/core/ui-scanner/react-scanner.js.map +0 -1
- package/dist/core/ui-scanner/scanner-interface.d.ts +0 -94
- package/dist/core/ui-scanner/scanner-interface.d.ts.map +0 -1
- package/dist/core/ui-scanner/scanner-interface.js +0 -33
- package/dist/core/ui-scanner/scanner-interface.js.map +0 -1
- package/dist/core/ui-scanner/strict-scanner.d.ts +0 -81
- package/dist/core/ui-scanner/strict-scanner.d.ts.map +0 -1
- package/dist/core/ui-scanner/strict-scanner.js +0 -511
- package/dist/core/ui-scanner/strict-scanner.js.map +0 -1
- package/dist/core/validator/data-validator.d.ts +0 -38
- package/dist/core/validator/data-validator.d.ts.map +0 -1
- package/dist/core/validator/data-validator.js +0 -212
- package/dist/core/validator/data-validator.js.map +0 -1
- package/dist/core/validator/feature-validator.d.ts +0 -27
- package/dist/core/validator/feature-validator.d.ts.map +0 -1
- package/dist/core/validator/feature-validator.js +0 -182
- package/dist/core/validator/feature-validator.js.map +0 -1
- package/dist/core/validator/index.d.ts +0 -46
- package/dist/core/validator/index.d.ts.map +0 -1
- package/dist/core/validator/index.js +0 -17
- package/dist/core/validator/index.js.map +0 -1
- package/dist/core/validator/screen-validator.d.ts +0 -35
- package/dist/core/validator/screen-validator.d.ts.map +0 -1
- package/dist/core/validator/screen-validator.js +0 -195
- package/dist/core/validator/screen-validator.js.map +0 -1
- package/dist/core/validator/selector-validator.d.ts +0 -36
- package/dist/core/validator/selector-validator.d.ts.map +0 -1
- package/dist/core/validator/selector-validator.js +0 -210
- package/dist/core/validator/selector-validator.js.map +0 -1
- package/dist/external/ai-provider.d.ts +0 -60
- package/dist/external/ai-provider.d.ts.map +0 -1
- package/dist/external/ai-provider.js +0 -30
- package/dist/external/ai-provider.js.map +0 -1
- package/dist/external/anthropic-provider.d.ts +0 -29
- package/dist/external/anthropic-provider.d.ts.map +0 -1
- package/dist/external/anthropic-provider.js +0 -85
- package/dist/external/anthropic-provider.js.map +0 -1
- package/dist/generators/cache/cache-manager.d.ts +0 -66
- package/dist/generators/cache/cache-manager.d.ts.map +0 -1
- package/dist/generators/cache/cache-manager.js +0 -286
- package/dist/generators/cache/cache-manager.js.map +0 -1
- package/dist/generators/dsl-writer/index.d.ts +0 -33
- package/dist/generators/dsl-writer/index.d.ts.map +0 -1
- package/dist/generators/dsl-writer/index.js +0 -226
- package/dist/generators/dsl-writer/index.js.map +0 -1
- package/dist/generators/scaffold-generator/index.d.ts +0 -162
- package/dist/generators/scaffold-generator/index.d.ts.map +0 -1
- package/dist/generators/scaffold-generator/index.js +0 -877
- package/dist/generators/scaffold-generator/index.js.map +0 -1
- package/dist/generators/selector-mapper/ai-mapper.d.ts +0 -56
- package/dist/generators/selector-mapper/ai-mapper.d.ts.map +0 -1
- package/dist/generators/selector-mapper/ai-mapper.js +0 -457
- package/dist/generators/selector-mapper/ai-mapper.js.map +0 -1
- package/dist/generators/selector-mapper/hybrid-mapper.d.ts +0 -67
- package/dist/generators/selector-mapper/hybrid-mapper.d.ts.map +0 -1
- package/dist/generators/selector-mapper/hybrid-mapper.js +0 -349
- package/dist/generators/selector-mapper/hybrid-mapper.js.map +0 -1
- package/dist/generators/selector-mapper/index.d.ts +0 -8
- package/dist/generators/selector-mapper/index.d.ts.map +0 -1
- package/dist/generators/selector-mapper/index.js +0 -12
- package/dist/generators/selector-mapper/index.js.map +0 -1
- package/dist/generators/selector-mapper/intelligent-mapper.d.ts +0 -125
- package/dist/generators/selector-mapper/intelligent-mapper.d.ts.map +0 -1
- package/dist/generators/selector-mapper/intelligent-mapper.js +0 -391
- package/dist/generators/selector-mapper/intelligent-mapper.js.map +0 -1
- package/dist/generators/test-generator/ai-step-mapper.d.ts +0 -27
- package/dist/generators/test-generator/ai-step-mapper.d.ts.map +0 -1
- package/dist/generators/test-generator/ai-step-mapper.js +0 -204
- package/dist/generators/test-generator/ai-step-mapper.js.map +0 -1
- package/dist/generators/test-generator/auth-setup-generator.d.ts +0 -18
- package/dist/generators/test-generator/auth-setup-generator.d.ts.map +0 -1
- package/dist/generators/test-generator/auth-setup-generator.js +0 -82
- package/dist/generators/test-generator/auth-setup-generator.js.map +0 -1
- package/dist/generators/test-generator/patterns/legacy-patterns.d.ts +0 -7
- package/dist/generators/test-generator/patterns/legacy-patterns.d.ts.map +0 -1
- package/dist/generators/test-generator/patterns/legacy-patterns.js +0 -98
- package/dist/generators/test-generator/patterns/legacy-patterns.js.map +0 -1
- package/dist/generators/test-generator/templates/auth-setup.ts.hbs +0 -36
- package/dist/generators/ui-model-builder/deep-scanner.d.ts +0 -121
- package/dist/generators/ui-model-builder/deep-scanner.d.ts.map +0 -1
- package/dist/generators/ui-model-builder/deep-scanner.js +0 -1113
- package/dist/generators/ui-model-builder/deep-scanner.js.map +0 -1
- package/dist/generators/ui-model-builder/enhanced-deep-scanner.d.ts +0 -110
- package/dist/generators/ui-model-builder/enhanced-deep-scanner.d.ts.map +0 -1
- package/dist/generators/ui-model-builder/enhanced-deep-scanner.js +0 -608
- package/dist/generators/ui-model-builder/enhanced-deep-scanner.js.map +0 -1
- package/dist/generators/ui-model-builder/react-scanner.d.ts +0 -107
- package/dist/generators/ui-model-builder/react-scanner.d.ts.map +0 -1
- package/dist/generators/ui-model-builder/react-scanner.js +0 -797
- package/dist/generators/ui-model-builder/react-scanner.js.map +0 -1
- package/dist/orchestrator/cache-manager.d.ts +0 -15
- package/dist/orchestrator/cache-manager.d.ts.map +0 -1
- package/dist/orchestrator/cache-manager.js +0 -62
- package/dist/orchestrator/cache-manager.js.map +0 -1
- package/dist/orchestrator/pipeline.d.ts +0 -56
- package/dist/orchestrator/pipeline.d.ts.map +0 -1
- package/dist/orchestrator/pipeline.js +0 -298
- package/dist/orchestrator/pipeline.js.map +0 -1
- package/dist/orchestrator/reporter.d.ts +0 -15
- package/dist/orchestrator/reporter.d.ts.map +0 -1
- package/dist/orchestrator/reporter.js +0 -30
- package/dist/orchestrator/reporter.js.map +0 -1
- package/src/cli/commands/cache-clear.ts +0 -22
- package/src/cli/commands/full.ts +0 -35
- package/src/cli/commands/live-scan.ts +0 -82
- package/src/cli/commands/map.ts +0 -97
- package/src/cli/commands/validate.ts +0 -43
- package/src/cli/utils.ts +0 -106
- package/src/config/ai-providers.yaml +0 -56
- package/src/config/config-loader.ts +0 -248
- package/src/config/config-schema.ts +0 -148
- package/src/config/default.config.yaml +0 -107
- package/src/config/framework.config.yaml +0 -52
- package/src/config/routes.yaml +0 -31
- package/src/core/live-scanner/config-reader.ts +0 -57
- package/src/core/live-scanner/element-finder.ts +0 -534
- package/src/core/live-scanner/index.ts +0 -7
- package/src/core/live-scanner/matrix-reader.ts +0 -65
- package/src/core/live-scanner/matrix-writer.ts +0 -77
- package/src/core/live-scanner/role-fallback.ts +0 -44
- package/src/core/live-scanner/scanner.ts +0 -321
- package/src/core/live-scanner/step-replayer.ts +0 -503
- package/src/core/live-scanner/types.ts +0 -58
- package/src/core/selector-base/annotation-handler.ts +0 -127
- package/src/core/selector-base/base-generator.ts +0 -234
- package/src/core/selector-base/gherkin-parser.ts +0 -57
- package/src/core/selector-mapper/priority-mapper.ts +0 -607
- package/src/core/ui-scanner/heuristics/base-heuristic.ts +0 -216
- package/src/core/ui-scanner/react-scanner.ts +0 -156
- package/src/core/ui-scanner/scanner-interface.ts +0 -133
- package/src/core/ui-scanner/strict-scanner.ts +0 -629
- package/src/core/validator/data-validator.ts +0 -202
- package/src/core/validator/feature-validator.ts +0 -176
- package/src/core/validator/index.ts +0 -57
- package/src/core/validator/screen-validator.ts +0 -209
- package/src/core/validator/selector-validator.ts +0 -209
- package/src/external/ai-provider.ts +0 -90
- package/src/external/anthropic-provider.ts +0 -114
- package/src/generators/README.md +0 -410
- package/src/generators/cache/cache-manager.ts +0 -322
- package/src/generators/dsl-writer/index.ts +0 -253
- package/src/generators/scaffold-generator/index.ts +0 -1029
- package/src/generators/selector-mapper/ai-mapper.ts +0 -528
- package/src/generators/selector-mapper/hybrid-mapper.ts +0 -427
- package/src/generators/selector-mapper/index.ts +0 -10
- package/src/generators/selector-mapper/intelligent-mapper.ts +0 -530
- package/src/generators/test-generator/ai-step-mapper.ts +0 -224
- package/src/generators/test-generator/auth-setup-generator.ts +0 -59
- package/src/generators/test-generator/patterns/legacy-patterns.ts +0 -104
- package/src/generators/test-generator/templates/auth-setup.ts.hbs +0 -36
- package/src/generators/ui-model-builder/deep-scanner.ts +0 -1244
- package/src/generators/ui-model-builder/enhanced-deep-scanner.ts +0 -731
- package/src/generators/ui-model-builder/react-scanner.ts +0 -959
- package/src/orchestrator/cache-manager.ts +0 -32
- package/src/orchestrator/pipeline.ts +0 -354
- package/src/orchestrator/reporter.ts +0 -36
|
@@ -1,18 +0,0 @@
|
|
|
1
|
-
export interface AuthSetupGeneratorOptions {
|
|
2
|
-
roles: string[];
|
|
3
|
-
outputDir: string;
|
|
4
|
-
verbose?: boolean;
|
|
5
|
-
}
|
|
6
|
-
export declare class AuthSetupGenerator {
|
|
7
|
-
/**
|
|
8
|
-
* Generate auth.setup.ts if it doesn't exist
|
|
9
|
-
* Creates:
|
|
10
|
-
* - specs/auth.setup.ts (from template)
|
|
11
|
-
* - specs/.auth/ directory
|
|
12
|
-
* - specs/.auth/.gitignore
|
|
13
|
-
*/
|
|
14
|
-
generateIfNeeded(options: AuthSetupGeneratorOptions): Promise<boolean>;
|
|
15
|
-
private loadTemplate;
|
|
16
|
-
private renderTemplate;
|
|
17
|
-
}
|
|
18
|
-
//# sourceMappingURL=auth-setup-generator.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"auth-setup-generator.d.ts","sourceRoot":"","sources":["../../../src/generators/test-generator/auth-setup-generator.ts"],"names":[],"mappings":"AAIA,MAAM,WAAW,yBAAyB;IACxC,KAAK,EAAE,MAAM,EAAE,CAAC;IAChB,SAAS,EAAE,MAAM,CAAC;IAClB,OAAO,CAAC,EAAE,OAAO,CAAC;CACnB;AAED,qBAAa,kBAAkB;IAC7B;;;;;;OAMG;IACG,gBAAgB,CAAC,OAAO,EAAE,yBAAyB,GAAG,OAAO,CAAC,OAAO,CAAC;IA+B5E,OAAO,CAAC,YAAY;IAKpB,OAAO,CAAC,cAAc;CAIvB"}
|
|
@@ -1,82 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
-
if (k2 === undefined) k2 = k;
|
|
4
|
-
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
-
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
-
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
-
}
|
|
8
|
-
Object.defineProperty(o, k2, desc);
|
|
9
|
-
}) : (function(o, m, k, k2) {
|
|
10
|
-
if (k2 === undefined) k2 = k;
|
|
11
|
-
o[k2] = m[k];
|
|
12
|
-
}));
|
|
13
|
-
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
14
|
-
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
15
|
-
}) : function(o, v) {
|
|
16
|
-
o["default"] = v;
|
|
17
|
-
});
|
|
18
|
-
var __importStar = (this && this.__importStar) || (function () {
|
|
19
|
-
var ownKeys = function(o) {
|
|
20
|
-
ownKeys = Object.getOwnPropertyNames || function (o) {
|
|
21
|
-
var ar = [];
|
|
22
|
-
for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
|
|
23
|
-
return ar;
|
|
24
|
-
};
|
|
25
|
-
return ownKeys(o);
|
|
26
|
-
};
|
|
27
|
-
return function (mod) {
|
|
28
|
-
if (mod && mod.__esModule) return mod;
|
|
29
|
-
var result = {};
|
|
30
|
-
if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
|
|
31
|
-
__setModuleDefault(result, mod);
|
|
32
|
-
return result;
|
|
33
|
-
};
|
|
34
|
-
})();
|
|
35
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
36
|
-
exports.AuthSetupGenerator = void 0;
|
|
37
|
-
const fs = __importStar(require("fs"));
|
|
38
|
-
const path = __importStar(require("path"));
|
|
39
|
-
const Handlebars = __importStar(require("handlebars"));
|
|
40
|
-
class AuthSetupGenerator {
|
|
41
|
-
/**
|
|
42
|
-
* Generate auth.setup.ts if it doesn't exist
|
|
43
|
-
* Creates:
|
|
44
|
-
* - specs/auth.setup.ts (from template)
|
|
45
|
-
* - specs/.auth/ directory
|
|
46
|
-
* - specs/.auth/.gitignore
|
|
47
|
-
*/
|
|
48
|
-
async generateIfNeeded(options) {
|
|
49
|
-
const setupFile = path.join(options.outputDir, 'auth.setup.ts');
|
|
50
|
-
// Don't overwrite existing setup
|
|
51
|
-
if (fs.existsSync(setupFile)) {
|
|
52
|
-
if (options.verbose) {
|
|
53
|
-
console.log('ℹ Auth setup already exists, skipping generation');
|
|
54
|
-
}
|
|
55
|
-
return false;
|
|
56
|
-
}
|
|
57
|
-
// Create .auth directory
|
|
58
|
-
const authDir = path.join(options.outputDir, '.auth');
|
|
59
|
-
fs.mkdirSync(authDir, { recursive: true });
|
|
60
|
-
// Generate .gitignore (storage states are runtime artifacts)
|
|
61
|
-
const gitignore = path.join(authDir, '.gitignore');
|
|
62
|
-
fs.writeFileSync(gitignore, '*.json\n', 'utf-8');
|
|
63
|
-
// Generate setup file from template
|
|
64
|
-
const template = this.loadTemplate();
|
|
65
|
-
const content = this.renderTemplate(template, { roles: options.roles });
|
|
66
|
-
fs.writeFileSync(setupFile, content, 'utf-8');
|
|
67
|
-
console.log('✓ Generated specs/auth.setup.ts - Update TODOs before running tests');
|
|
68
|
-
console.log(`✓ Created specs/.auth/ directory for storage states`);
|
|
69
|
-
console.log(` Detected roles: ${options.roles.join(', ')}`);
|
|
70
|
-
return true;
|
|
71
|
-
}
|
|
72
|
-
loadTemplate() {
|
|
73
|
-
const templatePath = path.join(__dirname, 'templates', 'auth-setup.ts.hbs');
|
|
74
|
-
return fs.readFileSync(templatePath, 'utf-8');
|
|
75
|
-
}
|
|
76
|
-
renderTemplate(template, data) {
|
|
77
|
-
const compiled = Handlebars.compile(template);
|
|
78
|
-
return compiled(data);
|
|
79
|
-
}
|
|
80
|
-
}
|
|
81
|
-
exports.AuthSetupGenerator = AuthSetupGenerator;
|
|
82
|
-
//# sourceMappingURL=auth-setup-generator.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"auth-setup-generator.js","sourceRoot":"","sources":["../../../src/generators/test-generator/auth-setup-generator.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,uCAAyB;AACzB,2CAA6B;AAC7B,uDAAyC;AAQzC,MAAa,kBAAkB;IAC7B;;;;;;OAMG;IACH,KAAK,CAAC,gBAAgB,CAAC,OAAkC;QACvD,MAAM,SAAS,GAAG,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,SAAS,EAAE,eAAe,CAAC,CAAC;QAEhE,iCAAiC;QACjC,IAAI,EAAE,CAAC,UAAU,CAAC,SAAS,CAAC,EAAE,CAAC;YAC7B,IAAI,OAAO,CAAC,OAAO,EAAE,CAAC;gBACpB,OAAO,CAAC,GAAG,CAAC,kDAAkD,CAAC,CAAC;YAClE,CAAC;YACD,OAAO,KAAK,CAAC;QACf,CAAC;QAED,yBAAyB;QACzB,MAAM,OAAO,GAAG,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,SAAS,EAAE,OAAO,CAAC,CAAC;QACtD,EAAE,CAAC,SAAS,CAAC,OAAO,EAAE,EAAE,SAAS,EAAE,IAAI,EAAE,CAAC,CAAC;QAE3C,6DAA6D;QAC7D,MAAM,SAAS,GAAG,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE,YAAY,CAAC,CAAC;QACnD,EAAE,CAAC,aAAa,CAAC,SAAS,EAAE,UAAU,EAAE,OAAO,CAAC,CAAC;QAEjD,oCAAoC;QACpC,MAAM,QAAQ,GAAG,IAAI,CAAC,YAAY,EAAE,CAAC;QACrC,MAAM,OAAO,GAAG,IAAI,CAAC,cAAc,CAAC,QAAQ,EAAE,EAAE,KAAK,EAAE,OAAO,CAAC,KAAK,EAAE,CAAC,CAAC;QACxE,EAAE,CAAC,aAAa,CAAC,SAAS,EAAE,OAAO,EAAE,OAAO,CAAC,CAAC;QAE9C,OAAO,CAAC,GAAG,CAAC,qEAAqE,CAAC,CAAC;QACnF,OAAO,CAAC,GAAG,CAAC,qDAAqD,CAAC,CAAC;QACnE,OAAO,CAAC,GAAG,CAAC,qBAAqB,OAAO,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;QAE7D,OAAO,IAAI,CAAC;IACd,CAAC;IAEO,YAAY;QAClB,MAAM,YAAY,GAAG,IAAI,CAAC,IAAI,CAAC,SAAS,EAAE,WAAW,EAAE,mBAAmB,CAAC,CAAC;QAC5E,OAAO,EAAE,CAAC,YAAY,CAAC,YAAY,EAAE,OAAO,CAAC,CAAC;IAChD,CAAC;IAEO,cAAc,CAAC,QAAgB,EAAE,IAAyB;QAChE,MAAM,QAAQ,GAAG,UAAU,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC;QAC9C,OAAO,QAAQ,CAAC,IAAI,CAAC,CAAC;IACxB,CAAC;CACF;AAhDD,gDAgDC"}
|
|
@@ -1,7 +0,0 @@
|
|
|
1
|
-
import { StepPattern } from './types';
|
|
2
|
-
/**
|
|
3
|
-
* Legacy patterns migrated from step-mapper.ts tryLegacyPatterns().
|
|
4
|
-
* These use templates that already exist (login, error-message-assertion, etc.)
|
|
5
|
-
*/
|
|
6
|
-
export declare const legacyPatterns: StepPattern[];
|
|
7
|
-
//# sourceMappingURL=legacy-patterns.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"legacy-patterns.d.ts","sourceRoot":"","sources":["../../../../src/generators/test-generator/patterns/legacy-patterns.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,WAAW,EAAE,MAAM,SAAS,CAAC;AAUtC;;;GAGG;AACH,eAAO,MAAM,cAAc,EAAE,WAAW,EAwFvC,CAAC"}
|
|
@@ -1,98 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.legacyPatterns = void 0;
|
|
4
|
-
/**
|
|
5
|
-
* Helper to extract screen ID from selector reference.
|
|
6
|
-
*/
|
|
7
|
-
function extractScreenId(selectorRef) {
|
|
8
|
-
const match = selectorRef.match(/\[([\w-]+)\./);
|
|
9
|
-
return match ? match[1] : 'unknown';
|
|
10
|
-
}
|
|
11
|
-
/**
|
|
12
|
-
* Legacy patterns migrated from step-mapper.ts tryLegacyPatterns().
|
|
13
|
-
* These use templates that already exist (login, error-message-assertion, etc.)
|
|
14
|
-
*/
|
|
15
|
-
exports.legacyPatterns = [
|
|
16
|
-
{
|
|
17
|
-
name: 'legacy-login',
|
|
18
|
-
matcher: (step) => step.text.includes('user is logged in as') && !!step.dataRef,
|
|
19
|
-
resolver: (step, context) => {
|
|
20
|
-
const varName = step.dataRef.replace(/[^a-zA-Z0-9]/g, '_') + '_' + context.stepCounter;
|
|
21
|
-
return {
|
|
22
|
-
templateName: 'login',
|
|
23
|
-
data: { varName, dataRef: step.dataRef },
|
|
24
|
-
comment: `Login as ${step.dataRef}`,
|
|
25
|
-
};
|
|
26
|
-
},
|
|
27
|
-
priority: 9,
|
|
28
|
-
},
|
|
29
|
-
{
|
|
30
|
-
name: 'legacy-error-message',
|
|
31
|
-
matcher: (step) => step.text.includes('error message') && step.text.includes('should'),
|
|
32
|
-
resolver: (step, context) => ({
|
|
33
|
-
templateName: 'error-message-assertion',
|
|
34
|
-
data: {},
|
|
35
|
-
comment: 'Assert error message is displayed',
|
|
36
|
-
}),
|
|
37
|
-
priority: 6,
|
|
38
|
-
},
|
|
39
|
-
{
|
|
40
|
-
name: 'legacy-generic-message',
|
|
41
|
-
matcher: (step) => step.text.includes('message') && step.text.includes('should be displayed'),
|
|
42
|
-
resolver: (step, context) => {
|
|
43
|
-
const messageType = step.text.includes('welcome') ? 'welcome' :
|
|
44
|
-
step.text.includes('success') ? 'success' : 'message';
|
|
45
|
-
return {
|
|
46
|
-
templateName: 'generic-message-assertion',
|
|
47
|
-
data: { messageType },
|
|
48
|
-
comment: `Assert ${messageType} message is displayed`,
|
|
49
|
-
};
|
|
50
|
-
},
|
|
51
|
-
priority: 6,
|
|
52
|
-
},
|
|
53
|
-
{
|
|
54
|
-
name: 'legacy-message-with-value',
|
|
55
|
-
matcher: (step) => step.text.includes('should see message') && !!step.value,
|
|
56
|
-
resolver: (step, context) => {
|
|
57
|
-
const varName = (step.selectorRef || 'message').replace(/[^a-zA-Z0-9]/g, '_') + '_' + context.stepCounter;
|
|
58
|
-
return {
|
|
59
|
-
templateName: 'message-assertion-body',
|
|
60
|
-
data: { varName, value: step.value, selectorRef: step.selectorRef },
|
|
61
|
-
comment: `Assert message: ${step.value}`,
|
|
62
|
-
};
|
|
63
|
-
},
|
|
64
|
-
priority: 6,
|
|
65
|
-
},
|
|
66
|
-
{
|
|
67
|
-
name: 'legacy-ai-response',
|
|
68
|
-
matcher: (step) => step.text.includes('user should see') && step.text.includes('AI response') && !!step.selectorRef,
|
|
69
|
-
resolver: (step, context) => {
|
|
70
|
-
const screenId = extractScreenId(step.selectorRef);
|
|
71
|
-
const varName = step.selectorRef.replace(/[^a-zA-Z0-9]/g, '_') + '_' + context.stepCounter;
|
|
72
|
-
return {
|
|
73
|
-
templateName: 'ai-response-assertion-selector',
|
|
74
|
-
data: { varName, selectorRef: step.selectorRef, screenId },
|
|
75
|
-
comment: `Assert AI response in ${step.selectorRef}`,
|
|
76
|
-
};
|
|
77
|
-
},
|
|
78
|
-
priority: 6,
|
|
79
|
-
},
|
|
80
|
-
{
|
|
81
|
-
name: 'legacy-message-count',
|
|
82
|
-
matcher: (step) => (step.text.includes('messages in') || (step.text.includes('should contain') && step.text.includes('messages'))) &&
|
|
83
|
-
!!step.selectorRef,
|
|
84
|
-
resolver: (step, context) => {
|
|
85
|
-
const match = step.text.match(/(\d+)\s+messages?/);
|
|
86
|
-
const expectedCount = match ? parseInt(match[1]) : 1;
|
|
87
|
-
const screenId = extractScreenId(step.selectorRef);
|
|
88
|
-
const varName = step.selectorRef.replace(/[^a-zA-Z0-9]/g, '_') + '_' + context.stepCounter;
|
|
89
|
-
return {
|
|
90
|
-
templateName: 'message-count-assertion',
|
|
91
|
-
data: { varName, selectorRef: step.selectorRef, screenId, expectedCount },
|
|
92
|
-
comment: `Assert ${expectedCount} messages in ${step.selectorRef}`,
|
|
93
|
-
};
|
|
94
|
-
},
|
|
95
|
-
priority: 6,
|
|
96
|
-
},
|
|
97
|
-
];
|
|
98
|
-
//# sourceMappingURL=legacy-patterns.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"legacy-patterns.js","sourceRoot":"","sources":["../../../../src/generators/test-generator/patterns/legacy-patterns.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,36 +0,0 @@
|
|
|
1
|
-
import { test as setup, expect } from '@playwright/test';
|
|
2
|
-
|
|
3
|
-
/**
|
|
4
|
-
* Authentication Setup
|
|
5
|
-
*
|
|
6
|
-
* This file creates authenticated browser contexts for your tests.
|
|
7
|
-
* Update the TODOs with your application's actual login flow.
|
|
8
|
-
*
|
|
9
|
-
* Generated roles: {{#each roles}}{{this}}{{#unless @last}}, {{/unless}}{{/each}}
|
|
10
|
-
*/
|
|
11
|
-
|
|
12
|
-
const authFile = (role: string) => `specs/.auth/${role}.json`;
|
|
13
|
-
|
|
14
|
-
{{#each roles}}
|
|
15
|
-
setup('authenticate as {{this}}', async ({ page }) => {
|
|
16
|
-
// TODO: Navigate to your login page
|
|
17
|
-
await page.goto('/login');
|
|
18
|
-
|
|
19
|
-
// TODO: Fill in credentials for {{this}} role
|
|
20
|
-
// Update these selectors to match your application
|
|
21
|
-
await page.getByLabel('Email').fill('{{this}}@example.com');
|
|
22
|
-
await page.getByLabel('Password').fill('{{this}}123');
|
|
23
|
-
|
|
24
|
-
// TODO: Click login button
|
|
25
|
-
await page.getByRole('button', { name: 'Sign in' }).click();
|
|
26
|
-
|
|
27
|
-
// TODO: Wait for authentication to complete
|
|
28
|
-
// Update this to match your post-login URL or element
|
|
29
|
-
await page.waitForURL('/dashboard');
|
|
30
|
-
|
|
31
|
-
// Save authentication state
|
|
32
|
-
await page.context().storageState({ path: authFile('{{this}}') });
|
|
33
|
-
});
|
|
34
|
-
|
|
35
|
-
{{/each}}
|
|
36
|
-
// TODO: Add more roles as needed by adding @auth:{role} tags to your features
|
|
@@ -1,121 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* PRODUCTION-READY Deep Scanner
|
|
3
|
-
* Implements all 4 iterations:
|
|
4
|
-
* 1. Deep Scanning (4+ levels)
|
|
5
|
-
* 2. UI Library Handling
|
|
6
|
-
* 3. Props Merging
|
|
7
|
-
* 4. Smart Filtering
|
|
8
|
-
*/
|
|
9
|
-
import { UIElement } from '../types';
|
|
10
|
-
interface DeepScanConfig {
|
|
11
|
-
sourceRoot: string;
|
|
12
|
-
projectRoot: string;
|
|
13
|
-
maxDepth: number;
|
|
14
|
-
verbose?: boolean;
|
|
15
|
-
}
|
|
16
|
-
export declare class DeepScanner {
|
|
17
|
-
private config;
|
|
18
|
-
private elements;
|
|
19
|
-
private elementCounter;
|
|
20
|
-
private scannedFiles;
|
|
21
|
-
private componentCache;
|
|
22
|
-
constructor(config: DeepScanConfig);
|
|
23
|
-
/**
|
|
24
|
-
* Main entry point - scan files deeply
|
|
25
|
-
*/
|
|
26
|
-
scanFiles(filePaths: string[]): Promise<UIElement[]>;
|
|
27
|
-
/**
|
|
28
|
-
* Check if component should be scanned
|
|
29
|
-
*/
|
|
30
|
-
private shouldScanComponent;
|
|
31
|
-
/**
|
|
32
|
-
* Check if this is an actual DOM element OR a UI library component
|
|
33
|
-
* We treat UI library components as terminal elements (don't scan deeper)
|
|
34
|
-
*/
|
|
35
|
-
private isActualDOMElement;
|
|
36
|
-
/**
|
|
37
|
-
* Check if this is a UI library component (flowbite, MUI, etc.)
|
|
38
|
-
* These are treated as "actual elements" for our purposes
|
|
39
|
-
*/
|
|
40
|
-
private isUILibraryComponent;
|
|
41
|
-
/**
|
|
42
|
-
* Check if component is a custom wrapper of UI library component
|
|
43
|
-
* E.g., Button wraps ButtonFlowbite, TextInput wraps InputText
|
|
44
|
-
* These should be treated as terminal elements (buttons/inputs)
|
|
45
|
-
*/
|
|
46
|
-
private isCustomUIWrapper;
|
|
47
|
-
/**
|
|
48
|
-
* Check if component is a framework component (Next.js, React Router, etc.)
|
|
49
|
-
* Returns component definition if found, null otherwise
|
|
50
|
-
*/
|
|
51
|
-
private getFrameworkComponent;
|
|
52
|
-
/**
|
|
53
|
-
* Map framework component props to target DOM element props
|
|
54
|
-
*/
|
|
55
|
-
private mapFrameworkProps;
|
|
56
|
-
/**
|
|
57
|
-
* Convert framework component to synthetic DOM element
|
|
58
|
-
*/
|
|
59
|
-
private convertFrameworkComponent;
|
|
60
|
-
/**
|
|
61
|
-
* Try to resolve a path with different file extensions
|
|
62
|
-
*/
|
|
63
|
-
private tryResolveWithExtensions;
|
|
64
|
-
/**
|
|
65
|
-
* Resolve import path to actual file path
|
|
66
|
-
* Enhanced to try multiple locations for @/ alias
|
|
67
|
-
*/
|
|
68
|
-
private resolveComponentPath;
|
|
69
|
-
/**
|
|
70
|
-
* Extract JSX element from conditional expression (ignoring the condition)
|
|
71
|
-
* This allows us to discover elements in modals, conditional blocks, etc.
|
|
72
|
-
*/
|
|
73
|
-
private extractConditionalJSXElement;
|
|
74
|
-
/**
|
|
75
|
-
* Extract attributes from JSX element
|
|
76
|
-
* Now supports resolving expressions from componentProps!
|
|
77
|
-
*/
|
|
78
|
-
private extractAttributes;
|
|
79
|
-
/**
|
|
80
|
-
* Extract text content from JSX element
|
|
81
|
-
*/
|
|
82
|
-
private extractTextContent;
|
|
83
|
-
/**
|
|
84
|
-
* Check if element should be included in UI model
|
|
85
|
-
*/
|
|
86
|
-
private shouldIncludeElement;
|
|
87
|
-
/**
|
|
88
|
-
* Merge props from component chain
|
|
89
|
-
*/
|
|
90
|
-
private mergeProps;
|
|
91
|
-
/**
|
|
92
|
-
* Generate cache key for file+props combination
|
|
93
|
-
* This allows same component to be scanned multiple times with different props
|
|
94
|
-
*/
|
|
95
|
-
private getCacheKey;
|
|
96
|
-
/**
|
|
97
|
-
* Recursively scan a file for UI elements
|
|
98
|
-
*/
|
|
99
|
-
private scanFile;
|
|
100
|
-
/**
|
|
101
|
-
* Infer wrapper type from component name
|
|
102
|
-
* Used for fallback when component is empty
|
|
103
|
-
*/
|
|
104
|
-
private inferWrapperType;
|
|
105
|
-
/**
|
|
106
|
-
* Infer semantic role from tag name
|
|
107
|
-
*/
|
|
108
|
-
private inferRole;
|
|
109
|
-
/**
|
|
110
|
-
* Get scan results with statistics
|
|
111
|
-
*/
|
|
112
|
-
getResults(): {
|
|
113
|
-
totalElements: number;
|
|
114
|
-
filesScanned: number;
|
|
115
|
-
byTag: Record<string, number>;
|
|
116
|
-
formElements: any[];
|
|
117
|
-
elements: UIElement[];
|
|
118
|
-
};
|
|
119
|
-
}
|
|
120
|
-
export {};
|
|
121
|
-
//# sourceMappingURL=deep-scanner.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"deep-scanner.d.ts","sourceRoot":"","sources":["../../../src/generators/ui-model-builder/deep-scanner.ts"],"names":[],"mappings":"AAAA;;;;;;;GAOG;AAOH,OAAO,EAAE,SAAS,EAAE,MAAM,UAAU,CAAC;AAMrC,UAAU,cAAc;IACtB,UAAU,EAAE,MAAM,CAAC;IACnB,WAAW,EAAE,MAAM,CAAC;IACpB,QAAQ,EAAE,MAAM,CAAC;IACjB,OAAO,CAAC,EAAE,OAAO,CAAC;CACnB;AA2ID,qBAAa,WAAW;IACtB,OAAO,CAAC,MAAM,CAAiB;IAC/B,OAAO,CAAC,QAAQ,CAAmB;IACnC,OAAO,CAAC,cAAc,CAAK;IAC3B,OAAO,CAAC,YAAY,CAAqB;IACzC,OAAO,CAAC,cAAc,CAA0B;gBAEpC,MAAM,EAAE,cAAc;IAIlC;;OAEG;IACG,SAAS,CAAC,SAAS,EAAE,MAAM,EAAE,GAAG,OAAO,CAAC,SAAS,EAAE,CAAC;IAY1D;;OAEG;IACH,OAAO,CAAC,mBAAmB;IA4B3B;;;OAGG;IACH,OAAO,CAAC,kBAAkB;IAc1B;;;OAGG;IACH,OAAO,CAAC,oBAAoB;IAkC5B;;;;OAIG;IACH,OAAO,CAAC,iBAAiB;IAwBzB;;;OAGG;IACH,OAAO,CAAC,qBAAqB;IAW7B;;OAEG;IACH,OAAO,CAAC,iBAAiB;IAiCzB;;OAEG;IACH,OAAO,CAAC,yBAAyB;IAwCjC;;OAEG;IACH,OAAO,CAAC,wBAAwB;IAsBhC;;;OAGG;IACH,OAAO,CAAC,oBAAoB;IAyE5B;;;OAGG;IACH,OAAO,CAAC,4BAA4B;IAkHpC;;;OAGG;IACH,OAAO,CAAC,iBAAiB;IAoEzB;;OAEG;IACH,OAAO,CAAC,kBAAkB;IAqB1B;;OAEG;IACH,OAAO,CAAC,oBAAoB;IA0C5B;;OAEG;IACH,OAAO,CAAC,UAAU;IAqBlB;;;OAGG;IACH,OAAO,CAAC,WAAW;IAWnB;;OAEG;YACW,QAAQ;IAuXtB;;;OAGG;IACH,OAAO,CAAC,gBAAgB;IAiBxB;;OAEG;IACH,OAAO,CAAC,SAAS;IAiBjB;;OAEG;IACH,UAAU;;;;;;;CAqBX"}
|